Compare commits
16 Commits
xie_fangji
...
appJump
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
72190b811d | ||
|
|
ecdc8a85ec | ||
|
|
f625109e2d | ||
|
|
d30d3553a1 | ||
|
|
4440d4facb | ||
|
|
493d74d025 | ||
|
|
31b73967a3 | ||
|
|
79fb0c430f | ||
|
|
1d04dffd4e | ||
|
|
5277ab3f5b | ||
|
|
1172043635 | ||
|
|
3b57f0aeb0 | ||
|
|
890a3c45ad | ||
|
|
c50dfc0bd5 | ||
|
|
52f7ad40c8 | ||
|
|
7db05c39fa |
32
App.vue
@@ -17,11 +17,11 @@
|
|||||||
import updata from '@/uni_modules/uni-upgrade-center-app/utils/check-update'
|
import updata from '@/uni_modules/uni-upgrade-center-app/utils/check-update'
|
||||||
// #endif
|
// #endif
|
||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
data(){
|
data() {
|
||||||
return{
|
return {
|
||||||
platform:null, // 系统
|
platform: null, // 系统
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onLaunch: function(e) {
|
onLaunch: function(e) {
|
||||||
@@ -144,10 +144,10 @@
|
|||||||
}
|
}
|
||||||
// APPUpdate();
|
// APPUpdate();
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
},
|
},
|
||||||
onShow: function(e) {
|
onShow: function(e) {
|
||||||
|
|
||||||
// #ifdef MP-WEIXIN
|
// #ifdef MP-WEIXIN
|
||||||
//获取二维码携带的参数
|
//获取二维码携带的参数
|
||||||
let scene = decodeURIComponent(e.query.scene);
|
let scene = decodeURIComponent(e.query.scene);
|
||||||
@@ -192,16 +192,28 @@
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
// #endif
|
// #endif
|
||||||
|
// #ifdef APP-PLUS
|
||||||
|
setTimeout(function(){
|
||||||
|
var args = plus.runtime.arguments;
|
||||||
|
if (args) {
|
||||||
|
// 处理args参数,如直达到某新页面等
|
||||||
|
console.log(args)
|
||||||
|
}
|
||||||
|
},300)
|
||||||
|
|
||||||
|
// #endif
|
||||||
|
},
|
||||||
|
onHide: function(){
|
||||||
|
plus.runtime.arguments = ''
|
||||||
|
console.log('清空')
|
||||||
},
|
},
|
||||||
onHide: function() {},
|
|
||||||
destroyed() {
|
destroyed() {
|
||||||
store.commit('setUserInfo', {
|
store.commit('setUserInfo', {
|
||||||
'playFlag': true
|
'playFlag': true
|
||||||
})
|
})
|
||||||
console.log('页面销毁')
|
console.log('页面销毁')
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|||||||
@@ -7,9 +7,9 @@ if (process.env.NODE_ENV === 'development') {
|
|||||||
// baseUrl = "https://twin-ui.com/demo/";
|
// baseUrl = "https://twin-ui.com/demo/";
|
||||||
// baseUrl = "http://59.110.212.44:9200/pb/";
|
// baseUrl = "http://59.110.212.44:9200/pb/";
|
||||||
// baseUrl = "https://testapi.nuttyreading.com/"; // 线上测试环境
|
// baseUrl = "https://testapi.nuttyreading.com/"; // 线上测试环境
|
||||||
baseUrl = "https://api.nuttyreading.com/"; // 线上正式
|
// baseUrl = "https://api.nuttyreading.com/"; // 线上正式
|
||||||
// baseUrl = "http://192.168.110.100:9100/pb/"; // 开发用电脑
|
// baseUrl = "http://192.168.110.100:9100/pb/"; // 开发用电脑
|
||||||
// baseUrl = "http://192.168.110.110:9200/pb/";
|
baseUrl = "http://192.168.110.110:9200/pb/";
|
||||||
// baseUrl = "http://192.168.110.38:9200/pb/"; // 吴春磊笔记本1
|
// baseUrl = "http://192.168.110.38:9200/pb/"; // 吴春磊笔记本1
|
||||||
// socketUrl = "ws://8.129.186.35:6001/";
|
// socketUrl = "ws://8.129.186.35:6001/";
|
||||||
} else if (process.env.NODE_ENV === 'production') {
|
} else if (process.env.NODE_ENV === 'production') {
|
||||||
@@ -45,9 +45,10 @@ const courtConfig = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
//手机号验证正则表达式
|
//手机号验证正则表达式
|
||||||
// const phoneRegular = /^1\d{10}$/;
|
// (中国大陆)
|
||||||
|
const phoneRegular = /^1\d{10}$/;
|
||||||
// 手机号码验证 支持港澳台 大陆
|
// 手机号码验证 支持港澳台 大陆
|
||||||
const phoneRegular = /^[1][3-8]\d{9}$|^([6|9])\d{7}$|^[0][9]\d{8}$|^[6]([8|6])\d{5}$|^(00){0,1}(65){1}[13689]\d{6,7}$/;
|
// const phoneRegular = /^[1][3-8]\d{9}$|^([6|9])\d{7}$|^[0][9]\d{8}$|^[6]([8|6])\d{5}$|^(00){0,1}(65){1}[13689]\d{6,7}$/;
|
||||||
//邮箱验证正则表达式
|
//邮箱验证正则表达式
|
||||||
const mailRegular = /^\w+@\w+(\.[a-zA-Z]{2,3}){1,2}$/;
|
const mailRegular = /^\w+@\w+(\.[a-zA-Z]{2,3}){1,2}$/;
|
||||||
//密码验证正则表达式
|
//密码验证正则表达式
|
||||||
|
|||||||
@@ -167,6 +167,7 @@ $http.dataFactory = async function(res) {
|
|||||||
title: '登录失效,请重新登录',
|
title: '登录失效,请重新登录',
|
||||||
icon: 'none'
|
icon: 'none'
|
||||||
});
|
});
|
||||||
|
console.log('到这里了')
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: "/pages/user/login"
|
url: "/pages/user/login"
|
||||||
|
|||||||
@@ -12,8 +12,8 @@
|
|||||||
"src" : "图片路径"
|
"src" : "图片路径"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"versionName" : "1.2.13",
|
"versionName" : "1.2.16",
|
||||||
"versionCode" : 1213,
|
"versionCode" : 1216,
|
||||||
"app-plus" : {
|
"app-plus" : {
|
||||||
"compatible" : {
|
"compatible" : {
|
||||||
"ignoreVersion" : true
|
"ignoreVersion" : true
|
||||||
@@ -22,7 +22,7 @@
|
|||||||
"prompt" : "template",
|
"prompt" : "template",
|
||||||
"template" : {
|
"template" : {
|
||||||
"title" : "用户协议和隐私政策",
|
"title" : "用户协议和隐私政策",
|
||||||
"message" : "请你务必审慎阅读、充分理解“隐私政策”各条款,包括但不限于:为了更好的向你提供服务,我们需要收集你的设备标识、操作日志等信息用于分析、优化应用性能。<br/> 你可阅读<a href='https://main.nuttyreading.com/agreement.html'>《用户协议》</a>和<a href='https://main.nuttyreading.com/privacy.html'>《隐私协议》</a>了解详细信息。如果你同意,请点击下面按钮开始接受我们的服务。",
|
"message" : "请你务必审慎阅读、充分理解“隐私政策”各条款,包括但不限于:为了更好的向你提供服务,我们需要收集你的设备标识、操作日志等信息用于分析、优化应用性能。<br/> 你可阅读<a href='https://www.nuttyreading.com/agreement.html'>《用户协议》</a>和<a href='https://www.nuttyreading.com/privacy.html'>《隐私协议》</a>了解详细信息。如果你同意,请点击下面按钮开始接受我们的服务。",
|
||||||
"buttonAccept" : "同意",
|
"buttonAccept" : "同意",
|
||||||
"buttonRefuse" : "暂不同意"
|
"buttonRefuse" : "暂不同意"
|
||||||
}
|
}
|
||||||
@@ -78,7 +78,8 @@
|
|||||||
],
|
],
|
||||||
"abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ],
|
"abiFilters" : [ "armeabi-v7a", "arm64-v8a", "x86" ],
|
||||||
"minSdkVersion" : 21,
|
"minSdkVersion" : 21,
|
||||||
"targetSdkVersion" : 30
|
"targetSdkVersion" : 30,
|
||||||
|
"schemes" : "nuttyreading"
|
||||||
},
|
},
|
||||||
"sdkConfigs" : {
|
"sdkConfigs" : {
|
||||||
"ad" : {},
|
"ad" : {},
|
||||||
@@ -114,7 +115,9 @@
|
|||||||
"com.apple.developer.associated-domains" : [ "applinks:verification.nuttyreading.com" ]
|
"com.apple.developer.associated-domains" : [ "applinks:verification.nuttyreading.com" ]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"idfa" : false
|
"idfa" : false,
|
||||||
|
"urltypes" : "nuttyreading",
|
||||||
|
"urlschemewhitelist" : "everhealth"
|
||||||
},
|
},
|
||||||
"icons" : {
|
"icons" : {
|
||||||
"android" : {
|
"android" : {
|
||||||
@@ -154,7 +157,10 @@
|
|||||||
"splashscreen" : {
|
"splashscreen" : {
|
||||||
"alwaysShowBeforeRender" : false
|
"alwaysShowBeforeRender" : false
|
||||||
},
|
},
|
||||||
"nativePlugins" : {}
|
"nativePlugins" : {},
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
},
|
},
|
||||||
// 5+App特有相关
|
// 5+App特有相关
|
||||||
"quickapp" : {},
|
"quickapp" : {},
|
||||||
@@ -172,6 +178,9 @@
|
|||||||
"scope.userLocation" : {
|
"scope.userLocation" : {
|
||||||
"desc" : "你的位置信息将用于小程序位置接口的效果展示"
|
"desc" : "你的位置信息将用于小程序位置接口的效果展示"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"h5" : {
|
"h5" : {
|
||||||
@@ -184,9 +193,61 @@
|
|||||||
"treeShaking" : {
|
"treeShaking" : {
|
||||||
"enable" : true
|
"enable" : true
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"_spaceID" : "mp-3614b80b-2d75-4462-a481-4998f8187274"
|
"_spaceID" : "mp-3614b80b-2d75-4462-a481-4998f8187274",
|
||||||
|
"uniStatistics" : {
|
||||||
|
"version" : "2",
|
||||||
|
"enable" : true
|
||||||
|
},
|
||||||
|
"mp-alipay" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mp-baidu" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mp-jd" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mp-kuaishou" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mp-lark" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mp-qq" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"mp-toutiao" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"quickapp-webview-huawei" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"quickapp-webview-union" : {
|
||||||
|
"uniStatistics" : {
|
||||||
|
"enable" : true
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// 小程序特有相关
|
// 小程序特有相关
|
||||||
|
|
||||||
|
|||||||
32
pages.json
@@ -508,22 +508,6 @@
|
|||||||
"navigationBarTitleText" : "脉穴详情",
|
"navigationBarTitleText" : "脉穴详情",
|
||||||
"enablePullDownRefresh" : false
|
"enablePullDownRefresh" : false
|
||||||
}
|
}
|
||||||
},
|
|
||||||
{
|
|
||||||
"path" : "pages/prescription/prescription",
|
|
||||||
"style" :
|
|
||||||
{
|
|
||||||
"navigationBarTitleText" : "方药检索",
|
|
||||||
"enablePullDownRefresh" : false
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path" : "pages/prescription/prescriptionDetail",
|
|
||||||
"style" :
|
|
||||||
{
|
|
||||||
"navigationBarTitleText" : "方药详情",
|
|
||||||
"enablePullDownRefresh" : false
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"globalStyle": {
|
"globalStyle": {
|
||||||
@@ -577,13 +561,13 @@
|
|||||||
"text": "我"
|
"text": "我"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
|
||||||
"condition": { //模式配置,仅开发期间生效
|
|
||||||
"current": 0, //当前激活的模式(list 的索引项)
|
|
||||||
"list": [{
|
|
||||||
"name": "", //模式名称
|
|
||||||
"path": "", //启动页面,必选
|
|
||||||
"query": "" //启动参数,在页面的onLoad函数里面得到
|
|
||||||
}]
|
|
||||||
}
|
}
|
||||||
|
// "condition": { //模式配置,仅开发期间生效
|
||||||
|
// "current": 0, //当前激活的模式(list 的索引项)
|
||||||
|
// "list": [{
|
||||||
|
// "name": "", //模式名称
|
||||||
|
// "path": "", //启动页面,必选
|
||||||
|
// "query": "" //启动参数,在页面的onLoad函数里面得到
|
||||||
|
// }]
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
|
|||||||
801
pages/bookShop/orderList copy.vue
Normal file
@@ -0,0 +1,801 @@
|
|||||||
|
<template>
|
||||||
|
<view>
|
||||||
|
<!-- 公共组件-每个页面必须引入 -->
|
||||||
|
<public-module></public-module>
|
||||||
|
<!-- <z-nav-bar title="我的订单"></z-nav-bar> -->
|
||||||
|
<z-nav-bar backState="2000" title="我的订单"></z-nav-bar>
|
||||||
|
|
||||||
|
<view class="orderTabs flexbox">
|
||||||
|
<view v-for="(item,index) in orderTabs" @click="orderTabCLi(item.value)"
|
||||||
|
:class="orderListTab==item.value?'ordStyle':''">{{item.name}}</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<view class="orderList" v-if="orderList.length > 0">
|
||||||
|
<view class="orderItem" v-for="(ifex,inten) in orderList" @click="goOrdiCont(ifex)" :key="inten">
|
||||||
|
<text class="orderState orderState0" v-if="ifex.orderStatus==0">待支付</text>
|
||||||
|
<text class="orderState orderState1" v-if="ifex.orderStatus==1">待发货</text>
|
||||||
|
<text class="orderState orderState2" v-if="ifex.orderStatus==2">待收货</text>
|
||||||
|
<text class="orderState orderState3" v-if="ifex.orderStatus==3">已完成</text>
|
||||||
|
<text class="orderState orderState5" v-if="ifex.orderStatus==5">已超时</text>
|
||||||
|
<view class="guoqi flexbox" v-if="ifex.orderStatus==0 && ifex.overTime > 0">
|
||||||
|
<text>剩余支付时间:</text>
|
||||||
|
<uni-countdown background-color="#ff5500" color="#ffffff" :font-size="14" :show-day="false"
|
||||||
|
:hour="0" :minute="0" :second="ifex.overTime" @timeup="countDown"></uni-countdown>
|
||||||
|
</view>
|
||||||
|
<view class="flexbox orderSn">
|
||||||
|
<text class="">订单编号: {{ifex.orderSn}}</text>
|
||||||
|
</view>
|
||||||
|
<view class="orderContent" :key="index" v-if="ifex.orderType=='order'"
|
||||||
|
v-for="(item,index) in ifex.productList">
|
||||||
|
<image :src="item.product.productImages" mode=""></image>
|
||||||
|
<view class="itemJian">
|
||||||
|
<view class="orderTitle">
|
||||||
|
<text>{{item.product.productName}}</text>
|
||||||
|
</view>
|
||||||
|
<view class="orderPrice">
|
||||||
|
<text style="color: #f56c6c;">¥</text><text
|
||||||
|
style="font-weight: bold; color: #f56c6c;">{{item.product.price}}</text><br>
|
||||||
|
<text style="color: #bbbbbb;font-size: 20rpx;margin-right: 10rpx;">X</text>
|
||||||
|
<text style="color: #bbbbbb;">{{item.quantity}}</text>
|
||||||
|
</view>
|
||||||
|
<br clear="both">
|
||||||
|
</view>
|
||||||
|
<br clear="both">
|
||||||
|
</view>
|
||||||
|
<view class="orderContent" v-if="ifex.orderType=='point'" @click.stop="goOrdiCont(ifex)">
|
||||||
|
<image src="../../static/icon/oder_chong.png" mode="" style="height: 150rpx;"></image>
|
||||||
|
<view class="itemJian">
|
||||||
|
<view class="orderTitle">
|
||||||
|
<text>天医币充值</text>
|
||||||
|
</view>
|
||||||
|
<view class="orderPrice">
|
||||||
|
<text style="color: #f56c6c;">¥</text><text
|
||||||
|
style="font-weight: bold; color: #f56c6c;">{{ifex.realMoney}}</text>
|
||||||
|
</view>
|
||||||
|
<br clear="both">
|
||||||
|
</view>
|
||||||
|
<br clear="both">
|
||||||
|
</view>
|
||||||
|
<view class="orderContent" v-if="ifex.orderType=='vip'" @click.stop="goOrdiCont(ifex)">
|
||||||
|
<image src="../../static/icon/oder_vip.png" mode="" style="height: 150rpx;"></image>
|
||||||
|
<view class="itemJian">
|
||||||
|
<view class="orderTitle">
|
||||||
|
<text>会员充值</text>
|
||||||
|
</view>
|
||||||
|
<view class="orderPrice">
|
||||||
|
<text style="color: #f56c6c;">¥</text><text
|
||||||
|
style="font-weight: bold; color: #f56c6c;">{{ifex.realMoney}}</text>
|
||||||
|
</view>
|
||||||
|
<br clear="both">
|
||||||
|
</view>
|
||||||
|
<br clear="both">
|
||||||
|
</view>
|
||||||
|
<view class="orderReal">
|
||||||
|
<span style="color: #999; float: left; font-size: 12px;">下单时间:{{ifex.createTime}}</span>
|
||||||
|
<span style="color: #999;margin-right: 10rpx;">实付款 : </span>
|
||||||
|
<span style=" color: #f56c6c;">¥</span><text
|
||||||
|
style="font-weight: bold; color: #f56c6c;">{{ifex.realMoney}}</text>
|
||||||
|
</view>
|
||||||
|
<view class="orderOper" v-if="ifex.orderStatus==0">
|
||||||
|
<view class="opFix" @click.stop = "canceOrder(ifex)">取消订单</view>
|
||||||
|
<view class="opCan" @click.stop = "getNewIap" v-if="ifex.orderType == 'point' && ifex.paymentMethod == '3'">重新下单</view>
|
||||||
|
<view class="opCan" v-else @click.stop = "goPay(ifex)">去支付</view>
|
||||||
|
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view v-if="status==0" style="text-align: center;">
|
||||||
|
<u-loading-icon style="display: inline-block;"></u-loading-icon>
|
||||||
|
<font style='vertical-align: super;margin-left: 10px;font-size: 26rpx;color: #909399;'>努力加载中</font>
|
||||||
|
</view>
|
||||||
|
<view v-if="status==1" style="padding-bottom: 20rpx;">
|
||||||
|
<u-divider text="全部加载完成"></u-divider>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="" v-else style=" margin-top: 250rpx;">
|
||||||
|
<u-divider text="暂无订单数据"></u-divider>
|
||||||
|
</view>
|
||||||
|
<z-navigation></z-navigation>
|
||||||
|
<music-play :playData="playData"></music-play>
|
||||||
|
</view>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import musicPlay from '@/components/music.vue'
|
||||||
|
import $http from '@/config/requestConfig.js';
|
||||||
|
import {
|
||||||
|
setPay,
|
||||||
|
setPayAssign,
|
||||||
|
setWXPay
|
||||||
|
} from '@/config/utils';
|
||||||
|
import {
|
||||||
|
mapState,
|
||||||
|
mapMutations
|
||||||
|
} from 'vuex';
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
playData: {},
|
||||||
|
orderTabs: [{
|
||||||
|
name: '全部',
|
||||||
|
value: null
|
||||||
|
}, {
|
||||||
|
name: '待支付',
|
||||||
|
value: 0
|
||||||
|
}, {
|
||||||
|
name: '待发货',
|
||||||
|
value: 1
|
||||||
|
}, {
|
||||||
|
name: '待收货',
|
||||||
|
value: 2
|
||||||
|
}, {
|
||||||
|
name: '已完成',
|
||||||
|
value: 3
|
||||||
|
}, {
|
||||||
|
name: '已超时',
|
||||||
|
value: 5
|
||||||
|
}, ],
|
||||||
|
orderListTab: null,
|
||||||
|
orderList: [],
|
||||||
|
iapChannel: {},
|
||||||
|
checking: false, // 正在检测
|
||||||
|
ComplateRequestArr: null,
|
||||||
|
isAndorid: true,
|
||||||
|
status: 3, // 加载状态
|
||||||
|
totalPage: 0,
|
||||||
|
page: 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onHide() {
|
||||||
|
this.orderList = [],
|
||||||
|
this.page = 1
|
||||||
|
this.totalPage = 0
|
||||||
|
this.orderListTab = null
|
||||||
|
},
|
||||||
|
onShow() {
|
||||||
|
this.getOrderList()
|
||||||
|
// this.checkIapOrders() //检查未完成的苹果支付订单
|
||||||
|
this.getOS()
|
||||||
|
// this.countDown()
|
||||||
|
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
...mapState(['userInfo']),
|
||||||
|
},
|
||||||
|
// 下拉刷新
|
||||||
|
onPullDownRefresh() {
|
||||||
|
this.orderList = [],
|
||||||
|
this.page = 1
|
||||||
|
this.totalPage = 0
|
||||||
|
this.getOrderList()
|
||||||
|
uni.stopPullDownRefresh()
|
||||||
|
},
|
||||||
|
onReachBottom() {
|
||||||
|
console.log('到底了')
|
||||||
|
if (this.page < this.totalPage) {
|
||||||
|
this.page++
|
||||||
|
// console.log('加载',this.page)
|
||||||
|
this.status = 0
|
||||||
|
this.getOrderList()
|
||||||
|
} else {
|
||||||
|
this.status = 1
|
||||||
|
console.log('加载完成了', this.page)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
},
|
||||||
|
components: {
|
||||||
|
musicPlay
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
...mapMutations(['setUserInfo']),
|
||||||
|
// 苹果用户重新下单
|
||||||
|
getNewIap(){
|
||||||
|
uni.navigateTo({
|
||||||
|
url:'/pages/peanut/reCharge'
|
||||||
|
})
|
||||||
|
},
|
||||||
|
// 倒计时回调
|
||||||
|
countDown() {
|
||||||
|
console.log('重新刷新订单')
|
||||||
|
this.totalPage = 0
|
||||||
|
this.page = 1
|
||||||
|
this.orderList = []
|
||||||
|
this.getOrderList()
|
||||||
|
},
|
||||||
|
// 获得操作系统
|
||||||
|
getOS() {
|
||||||
|
let oprateOs = ''
|
||||||
|
oprateOs = uni.getSystemInfoSync().platform
|
||||||
|
console.log(oprateOs)
|
||||||
|
if (oprateOs == 'android') {
|
||||||
|
this.isAndorid = true
|
||||||
|
} else {
|
||||||
|
this.isAndorid = false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
checkIapOrders() {
|
||||||
|
const that = this
|
||||||
|
// 如果ios已经绑定支付信息,就直接支付,如果没有绑定,就需要先绑定
|
||||||
|
console.log('检测支付环境...')
|
||||||
|
plus.payment.getChannels((channels) => {
|
||||||
|
console.log(channels, 'channels')
|
||||||
|
for (var i in channels) {
|
||||||
|
// 判断是否苹果支付1
|
||||||
|
if (channels[i].id === 'appleiap') {
|
||||||
|
that.iapChannel = channels[i]
|
||||||
|
that.restoreComplateRequest() // 检查未关闭订单
|
||||||
|
// that.requestOrder(productId)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
},
|
||||||
|
// 切换订单状态
|
||||||
|
orderTabCLi(e) {
|
||||||
|
this.orderListTab = e
|
||||||
|
this.totalPage = 0
|
||||||
|
this.page = 1
|
||||||
|
this.orderList = []
|
||||||
|
this.getOrderList()
|
||||||
|
},
|
||||||
|
|
||||||
|
// 获取订单列表
|
||||||
|
getOrderList() {
|
||||||
|
let data = {
|
||||||
|
"userId": "",
|
||||||
|
"orderStatus": this.orderListTab,
|
||||||
|
"page": this.page,
|
||||||
|
"limit": 10,
|
||||||
|
'userId': this.userInfo.id
|
||||||
|
}
|
||||||
|
|
||||||
|
$http.request({
|
||||||
|
// url: "book/buyOrder/orderList",
|
||||||
|
url: "book/buyOrder/getUserOrderList",
|
||||||
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
|
data,
|
||||||
|
header: { //默认 无 说明:请求头
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
},
|
||||||
|
}).then(res => {
|
||||||
|
if (res.code == 0) {
|
||||||
|
res.page.records.forEach((item, index) => {
|
||||||
|
var seconds = item.timestamp + 30 * 60 + 2 // 过期时间 30分钟+2
|
||||||
|
// var seconds = item.timestamp + 30 + 2 // 过期时间 30秒
|
||||||
|
var nowSeconds = Math.floor(new Date().getTime() / 1000); // 单位秒
|
||||||
|
item.overTime = seconds - nowSeconds
|
||||||
|
// console.log(item.overTime,'item.overTime')
|
||||||
|
})
|
||||||
|
this.orderList = this.orderList.concat(res.page.records)
|
||||||
|
this.totalPage = res.page.pages
|
||||||
|
if (res.page.pages == this.page) {
|
||||||
|
this.status = 1
|
||||||
|
} else {
|
||||||
|
this.status = 3
|
||||||
|
}
|
||||||
|
console.log(this.orderList, '订单列表')
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
// 订单详情
|
||||||
|
goOrdiCont(e) {
|
||||||
|
console.log(e, 'e')
|
||||||
|
//let orderId = e.orderId ? e.orderId : e.id
|
||||||
|
if(e.orderType == 'point'){ // 充值订单
|
||||||
|
console.log('跳转到充值页面')
|
||||||
|
uni.navigateTo({
|
||||||
|
url: '/pages/peanut/chargeDetaill?orderId=' + e.orderId + '&orderSn=' + e.orderSn
|
||||||
|
});
|
||||||
|
}else if(e.orderType == 'order'){ // 实体订单
|
||||||
|
uni.navigateTo({
|
||||||
|
url: './orderLCont?orderId=' + e.orderId + '&orderType=' + e.orderStatus + '&orderSn=' + e.orderSn
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// 跳转到支付页面
|
||||||
|
goPay1(e) {
|
||||||
|
console.log(e, 'goPay1')
|
||||||
|
uni.navigateTo({
|
||||||
|
url: '../peanut/reCharge?orderSn=' + e.orderSn
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
// 取消订单
|
||||||
|
canceOrder(e) {
|
||||||
|
uni.showModal({
|
||||||
|
title: '提示',
|
||||||
|
content: '确定要取消订单吗?',
|
||||||
|
confirmText: "取消订单",
|
||||||
|
cancelText: "考虑一下",
|
||||||
|
confirmColor: '#c96713',
|
||||||
|
cancelColor: '#555',
|
||||||
|
success: res => {
|
||||||
|
if (res.confirm) {
|
||||||
|
this.$http
|
||||||
|
.post(`book/buyOrder/appDelete?orderId=${e.orderId}`)
|
||||||
|
.then(res => {
|
||||||
|
uni.showToast({
|
||||||
|
icon: 'none',
|
||||||
|
title: '取消订单成功'
|
||||||
|
})
|
||||||
|
this.page = 1
|
||||||
|
this.totalPage = 0
|
||||||
|
this.orderList = []
|
||||||
|
this.getOrderList()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
// 支付
|
||||||
|
goPay(payItem) {
|
||||||
|
console.log(payItem, 'payItem')
|
||||||
|
if (payItem.paymentMethod == 2) {
|
||||||
|
console.log('阿里支付')
|
||||||
|
setPay({
|
||||||
|
typePay: 'alipay',
|
||||||
|
subject: 'order',
|
||||||
|
totalAmount: payItem.realMoney,
|
||||||
|
type: 2,
|
||||||
|
relevanceoid: payItem.orderSn,
|
||||||
|
customerId: this.userInfo.id,
|
||||||
|
}, res => {
|
||||||
|
if (res.success) {
|
||||||
|
uni.showToast({
|
||||||
|
title: "支付成功"
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
uni.showToast({
|
||||||
|
title: "支付失败",
|
||||||
|
icon: "none",
|
||||||
|
image: '../../static/icon/ic_close.png'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
this.orderList = [],
|
||||||
|
this.page = 1
|
||||||
|
this.totalPage = 0
|
||||||
|
this.getOrderList()
|
||||||
|
})
|
||||||
|
} else if (payItem.paymentMethod == 1) {
|
||||||
|
console.log('微信支付')
|
||||||
|
// console.log(this.isAndorid)
|
||||||
|
if (this.isAndorid == false) {
|
||||||
|
uni.showModal({
|
||||||
|
title: '提示',
|
||||||
|
content: '很抱歉,苹果系统暂不支持微信支付',
|
||||||
|
showCancel: false
|
||||||
|
})
|
||||||
|
return false
|
||||||
|
} else {
|
||||||
|
let data1 = {
|
||||||
|
orderSn: payItem.orderSn,
|
||||||
|
buyOrderId: null,
|
||||||
|
totalAmount: payItem.realMoney
|
||||||
|
}
|
||||||
|
console.log(data1, 'data1')
|
||||||
|
setWXPay(data1, res => {
|
||||||
|
if (res.success) {
|
||||||
|
uni.showToast({
|
||||||
|
title: "支付成功"
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.log(res)
|
||||||
|
if (res.data.errMsg.indexOf('User canceled') != -1) {
|
||||||
|
uni.showToast({
|
||||||
|
title: "用户取消支付",
|
||||||
|
icon: "none",
|
||||||
|
image: '../../static/icon/ic_close.png'
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
uni.showToast({
|
||||||
|
title: "支付失败",
|
||||||
|
icon: "none",
|
||||||
|
image: '../../static/icon/ic_close.png'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
} else if (payItem.paymentMethod == 3) {
|
||||||
|
// 苹果充值
|
||||||
|
console.log('苹果二次支付')
|
||||||
|
if (this.isAndorid) {
|
||||||
|
uni.showModal({
|
||||||
|
title: '提示',
|
||||||
|
showCancel: false,
|
||||||
|
content: '很抱歉,当前订单属于苹果系统内购订单,安卓系统无法完成支付操作,您可切换到苹果系统进行支付,也可以取消该订单,并重新下单'
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.iphonepay(payItem)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
iphonepay(payItem) {
|
||||||
|
console.log(this.userInfo.restoreFlag, 'this.userInfo.restoreFlag')
|
||||||
|
if (this.ComplateRequestArr == null || this.ComplateRequestArr == []) {
|
||||||
|
this.requestOrder(payItem)
|
||||||
|
} else {
|
||||||
|
uni.showModal({
|
||||||
|
title: '提示',
|
||||||
|
showCancel: false,
|
||||||
|
content: '您的账户存在未完成的支付订单,请稍后重启app留意账户变动。',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
requestOrder(payItem) {
|
||||||
|
uni.showLoading({
|
||||||
|
title: '获取商品信息',
|
||||||
|
mask: true
|
||||||
|
})
|
||||||
|
const that = this
|
||||||
|
// console.log(productId, 88888888)
|
||||||
|
// ['xxxxx'] 是平台申请拿到的内购商品的id
|
||||||
|
let IAPOrders = []
|
||||||
|
IAPOrders.push(payItem.productId + '')
|
||||||
|
console.log(IAPOrders, 'IAPOrders')
|
||||||
|
// 新建订单
|
||||||
|
that.iapChannel.requestOrder(IAPOrders, function(event) {
|
||||||
|
// uni.hideLoading()
|
||||||
|
console.log(event, 'event')
|
||||||
|
for (var index in event) {
|
||||||
|
var OrderItem = event[index]
|
||||||
|
// console.log(OrderItem, 'OrderItem')
|
||||||
|
console.log(OrderItem.productid, 'OrderItem.productid')
|
||||||
|
that.topay(payItem)
|
||||||
|
}
|
||||||
|
}, function(erroemsg) {
|
||||||
|
uni.showToast({
|
||||||
|
title: "商品获取失败",
|
||||||
|
icon: 'none'
|
||||||
|
})
|
||||||
|
})
|
||||||
|
},
|
||||||
|
topay(payItem) {
|
||||||
|
const that = this
|
||||||
|
uni.hideLoading()
|
||||||
|
// var restoreFlag = true; // 调用支付接口时标记 restoreFlag = true , 实际应用请将标记存储在 storage 中
|
||||||
|
this.setUserInfo({
|
||||||
|
restoreFlag: true
|
||||||
|
});
|
||||||
|
console.log(this.userInfo, '更新后的用户信息')
|
||||||
|
plus.payment.request(that.iapChannel, {
|
||||||
|
productid: payItem.productId,
|
||||||
|
username: payItem.orderSn, // 用户标识/订单标识
|
||||||
|
manualFinishTransaction: true // 3.5.1+ 支持,设置此参数后需要开发者主动关闭订单,参见下面的关闭订单方法 finishTransaction()
|
||||||
|
|
||||||
|
}, function(result) {
|
||||||
|
// restoreFlag = false; // 支付成功清除标记 restoreFlag = false
|
||||||
|
that.transaction = result
|
||||||
|
// 支付成功,result 为 IAP商品交易信息对象 IAPTransaction 需将返回的支付凭证传给后端进行二次认证
|
||||||
|
that.iapCheck(result)
|
||||||
|
}, function(e) {
|
||||||
|
if (e.errCode == 2) {
|
||||||
|
// 用户未绑定支付方式,app内支付流程结束,系统弹出框引导用户绑定支付方式,此过程将跳转到系统应用 AppStore 进行绑定支付方式,绑定成功同步支付成功,用户成功付款
|
||||||
|
// plus.runtime.openURL("https://apps.apple.com/account/billing");
|
||||||
|
} else {
|
||||||
|
// restoreFlag = false; // 支付失败清楚标记
|
||||||
|
that.finishTransaction(result);
|
||||||
|
//console.log('订单关闭后的用户信息', that.userInfo);
|
||||||
|
// console.log(e)
|
||||||
|
//console.log(e.message)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// 查询未关闭订单
|
||||||
|
restoreComplateRequest() {
|
||||||
|
let that = this
|
||||||
|
console.log('检测未完成订单')
|
||||||
|
// console.log(that.iapChannel,'this.iapChannel')
|
||||||
|
that.iapChannel.restoreComplateRequest({
|
||||||
|
manualFinishTransaction: true
|
||||||
|
}, function(results) {
|
||||||
|
console.log('进入restoreComplateRequest')
|
||||||
|
// if(!that.checking){
|
||||||
|
// that.checking = true
|
||||||
|
// console.log(that.checking)
|
||||||
|
// results 格式为数组存放恢复的IAP商品交易信息对象 IAPTransaction,通用需将返回的支付凭证传给后端进行二次认证
|
||||||
|
that.ComplateRequestArr = results
|
||||||
|
console.log(that.ComplateRequestArr, '未完成订单数组')
|
||||||
|
if (results && results.length > 0) {
|
||||||
|
results.map((item, index) => {
|
||||||
|
// "0"为正在支付;"1"为支付成功;"2"为支付失败;"3"为支付已恢复。
|
||||||
|
if (item.transactionState == '1') {
|
||||||
|
// 已经支付,但是没有走逻辑的内购订单
|
||||||
|
that.iapCheck(item, index)
|
||||||
|
} else {
|
||||||
|
// 其他状态的内购订单
|
||||||
|
that.finishTransaction(item)
|
||||||
|
|
||||||
|
}
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.setUserInfo({
|
||||||
|
restoreFlag: false
|
||||||
|
});
|
||||||
|
console.log('无未处理订单,可以拉起新的支付')
|
||||||
|
}
|
||||||
|
// }
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
// 关闭交易订单
|
||||||
|
finishTransaction(trans, index) {
|
||||||
|
this.iapChannel.finishTransaction(trans, (success) => {
|
||||||
|
console.log('关闭订单成功', index);
|
||||||
|
|
||||||
|
if (index == this.ComplateRequestArr.length - 1) { // 最后一个支付订单
|
||||||
|
this.setUserInfo({
|
||||||
|
restoreFlag: false
|
||||||
|
});
|
||||||
|
console.log(this.userInfo.restoreFlag, 'this.userInfo.restoreFlag')
|
||||||
|
}
|
||||||
|
|
||||||
|
}, (fail) => {
|
||||||
|
console.log('关闭订单失败');
|
||||||
|
});
|
||||||
|
},
|
||||||
|
iapCheck(result, index) {
|
||||||
|
const that = this
|
||||||
|
console.log('进入后台验证')
|
||||||
|
let data = {
|
||||||
|
transactionId: result.transactionIdentifier, // 支付交易id
|
||||||
|
customerOid: that.userInfo.id,
|
||||||
|
productId: result.payment.productid, // 产品id
|
||||||
|
orderId: result.payment.username, // 系统订单号
|
||||||
|
receiptData: result.transactionReceipt, // 苹果返回收据
|
||||||
|
loadAnimate: 'none', // 请求加载动画
|
||||||
|
}
|
||||||
|
console.log(data, 'data')
|
||||||
|
$http.request({
|
||||||
|
url: "/Ipa/veri",
|
||||||
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
|
data,
|
||||||
|
header: { //默认 无 说明:请求头
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
},
|
||||||
|
}).then(res => {
|
||||||
|
console.log(JSON.stringify(res))
|
||||||
|
console.log(res.code)
|
||||||
|
if (res.code == 0) {
|
||||||
|
// uni.hideLoading()
|
||||||
|
console.log('充值订单已处理,请留意账户金额变动....')
|
||||||
|
// 服务器验证票据有效后在客户端关闭订单
|
||||||
|
that.finishTransaction(result, index)
|
||||||
|
} else if (res.code == 200) { // 重复验证订单
|
||||||
|
console.log('重复验证....')
|
||||||
|
that.finishTransaction(result, index)
|
||||||
|
}
|
||||||
|
}).catch(e => {
|
||||||
|
console.log('支付验证失败,进入轮询程序...')
|
||||||
|
that.getIapPayResult(result, index)
|
||||||
|
})
|
||||||
|
console.log('--------------')
|
||||||
|
},
|
||||||
|
|
||||||
|
// 轮询验证支付结果
|
||||||
|
getIapPayResult(result, index) {
|
||||||
|
// let interval = null
|
||||||
|
this.ComplateRequestInterval = setTimeout(() => {
|
||||||
|
if (this.maxTimes <= 3) {
|
||||||
|
this.iapCheck(result, index)
|
||||||
|
console.log('执行1', this.maxTimes, this.ComplateRequestInterval)
|
||||||
|
this.maxTimes += 1
|
||||||
|
} else {
|
||||||
|
this.maxTimes = 0
|
||||||
|
console.log('停止轮询', this.maxTimes, this.ComplateRequestInterval, this.maxTimes)
|
||||||
|
this.checking = false
|
||||||
|
this.saveErrorIapOrder(result, index)
|
||||||
|
clearTimeout(this.ComplateRequestInterval)
|
||||||
|
|
||||||
|
}
|
||||||
|
}, 10000)
|
||||||
|
|
||||||
|
},
|
||||||
|
// 轮询失败接口
|
||||||
|
saveErrorIapOrder(result, index) {
|
||||||
|
console.log('提交到充值问题单里面...')
|
||||||
|
let data = {
|
||||||
|
transactionId: result.transactionIdentifier,
|
||||||
|
failureflag: 1,
|
||||||
|
orderId: result.payment.username,
|
||||||
|
receiptData: result.transactionReceipt,
|
||||||
|
productId: result.payment.productid,
|
||||||
|
customerOid: this.userInfo.id
|
||||||
|
}
|
||||||
|
$http.request({
|
||||||
|
url: "Ipa/failure",
|
||||||
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
|
data,
|
||||||
|
header: { //默认 无 说明:请求头
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
},
|
||||||
|
}).then(res => {
|
||||||
|
console.log(JSON.stringify(res))
|
||||||
|
if (res.code == 200) {
|
||||||
|
console.log('提交成功,关闭订单')
|
||||||
|
this.finishTransaction(result, index)
|
||||||
|
}
|
||||||
|
}).catch(e => {
|
||||||
|
console.log(e)
|
||||||
|
if (e.statusCode == 0) { // 重复提交,直接关闭订单
|
||||||
|
this.finishTransaction(result, index)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
@import '@/style/mixin.scss';
|
||||||
|
|
||||||
|
.guoqi {
|
||||||
|
font-size: 28rpx;
|
||||||
|
align-items: center;
|
||||||
|
color: red;
|
||||||
|
float: right;
|
||||||
|
line-height: 40rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flexbox {
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderTabs {
|
||||||
|
margin: 60rpx 0 0 0;
|
||||||
|
width: 100%;
|
||||||
|
padding: 30rpx 3% 3% 3%;
|
||||||
|
// padding-top: 100rpx;
|
||||||
|
position: fixed;
|
||||||
|
top: 80rpx;
|
||||||
|
background-color: #fff;
|
||||||
|
z-index: 100;
|
||||||
|
|
||||||
|
view {
|
||||||
|
border-radius: 20rpx;
|
||||||
|
border: 1px solid #d0d0d0;
|
||||||
|
display: inline-block;
|
||||||
|
padding: 20rpx 0;
|
||||||
|
margin: 0 6rpx;
|
||||||
|
// margin: 40rpx 0 15rpx 0;
|
||||||
|
width: 20%;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 30rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ordStyle {
|
||||||
|
background: #f0f9eb;
|
||||||
|
border: 2rpx solid #54a966;
|
||||||
|
color: #54a966;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderList {
|
||||||
|
padding: 20rpx;
|
||||||
|
margin-top: 130rpx;
|
||||||
|
|
||||||
|
.orderItem {
|
||||||
|
position: relative;
|
||||||
|
padding: 30rpx 10rpx 30rpx 30rpx;
|
||||||
|
background-color: #fff;
|
||||||
|
border-radius: 30rpx;
|
||||||
|
margin-bottom: 30rpx;
|
||||||
|
|
||||||
|
.orderSn {
|
||||||
|
font-size: 26rpx;
|
||||||
|
color: #999;
|
||||||
|
padding-bottom: 20rpx;
|
||||||
|
border-bottom: 1px solid #eee;
|
||||||
|
margin-top: 60rpx;
|
||||||
|
margin-bottom: 30rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderState {
|
||||||
|
color: #fff;
|
||||||
|
|
||||||
|
position: absolute;
|
||||||
|
left: 0;
|
||||||
|
top: 20rpx;
|
||||||
|
padding: 10rpx;
|
||||||
|
border-radius: 0 24rpx 24rpx 0;
|
||||||
|
font-size: 26rpx;
|
||||||
|
// font-weight: bold;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderState0 {
|
||||||
|
background-color: #e6a23c;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderState1 {
|
||||||
|
background-color: #409eff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderState2 {
|
||||||
|
background-color: #f56c6c;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderState3 {
|
||||||
|
background-color: #67c23a;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderState5 {
|
||||||
|
background-color: #787878;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderContent {
|
||||||
|
margin-bottom: 20rpx;
|
||||||
|
|
||||||
|
image {
|
||||||
|
width: 130rpx;
|
||||||
|
height: 140rpx;
|
||||||
|
margin-right: 20rpx;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.itemJian {
|
||||||
|
float: left;
|
||||||
|
width: 470rpx;
|
||||||
|
|
||||||
|
.orderTitle {
|
||||||
|
// font-weight: bold;
|
||||||
|
font-size: 28rpx;
|
||||||
|
margin: 0 0 20rpx 0;
|
||||||
|
float: left;
|
||||||
|
width: 410rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderPrice {
|
||||||
|
font-size: 28rpx;
|
||||||
|
float: right;
|
||||||
|
width: 60rpx;
|
||||||
|
text-align: right;
|
||||||
|
line-height: 40rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderReal {
|
||||||
|
border-top: 1px solid #eee;
|
||||||
|
text-align: right;
|
||||||
|
font-size: 30rpx;
|
||||||
|
margin: 30rpx 20rpx 0 0;
|
||||||
|
padding: 30rpx 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orderOper {
|
||||||
|
text-align: right;
|
||||||
|
margin: 30rpx 20rpx 0 0;
|
||||||
|
|
||||||
|
view {
|
||||||
|
margin-left: 20rpx;
|
||||||
|
padding: 10rpx 0;
|
||||||
|
display: inline-block;
|
||||||
|
width: 150rpx;
|
||||||
|
font-size: 25rpx;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.opFix {
|
||||||
|
color: #555;
|
||||||
|
border: 1px solid #ddd;
|
||||||
|
border-radius: 30rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.opCan {
|
||||||
|
color: #c96713;
|
||||||
|
border: 1px solid #eba00b;
|
||||||
|
border-radius: 30rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
624
pages/bookShop/orderList1.vue
Normal file
@@ -0,0 +1,624 @@
|
|||||||
|
<template>
|
||||||
|
<view class="container">
|
||||||
|
<!-- 公共组件-每个页面必须引入 -->
|
||||||
|
<public-module></public-module>
|
||||||
|
<view class="header">
|
||||||
|
<!-- 顶部导航栏 -->
|
||||||
|
<z-nav-bar backState="2000" title="我的订单"></z-nav-bar>
|
||||||
|
<view class="ordersTabs">
|
||||||
|
<view v-for="(item,index) in ordersTabs" @click="ordersTabCLi(item.value)" :key="index"
|
||||||
|
:class="ordersListTab==item.value?'ordersdefine ordStyle':'ordersdefine'">
|
||||||
|
{{item.name}}
|
||||||
|
<view class="ordersnum">22</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<!-- 站位 -->
|
||||||
|
<view class="ordersTabs" style="z-index:0;position:unset;">
|
||||||
|
<view class="ordersdefine">1</view>
|
||||||
|
</view>
|
||||||
|
<view v-if="ordersListTab == 1">
|
||||||
|
<view v-if="newList.length > 0">
|
||||||
|
<view class="orderInfo" v-for="(item,index) in newList" :key="index">
|
||||||
|
<view class="mainContent">
|
||||||
|
<view class="item" @click.stop="toDetail(item)">
|
||||||
|
<view class="orderstatus">已完成</view>
|
||||||
|
<view>
|
||||||
|
<image class="feng" v-if="item.bookimage" :src="item.bookimage" mode="aspectFill"></image>
|
||||||
|
<!-- <view class="description" v-html="item.content">
|
||||||
|
</view> -->
|
||||||
|
<view class="btns flexbox">
|
||||||
|
<span class="booknameleft">{{item.bookname}}</span>
|
||||||
|
<span class="right flexbox opbtns">
|
||||||
|
¥76
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
<view class="btns flexbox" style="margin-top:10rpx;padding-bottom: 72rpx;">
|
||||||
|
<span class="left" style="color: #C0C4CC;"></span>
|
||||||
|
<span class="right flexbox opbtns" style="color: #C0C4CC;">
|
||||||
|
×1
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="btns flexbox" style="margin-top:10rpx;">
|
||||||
|
<span class="left" style="color: #C0C4CC;"></span>
|
||||||
|
<span class="right flexbox opbtns">
|
||||||
|
<view style="color: #000;font-size:30rpx;font-weight:700;">实付款</view>
|
||||||
|
<view style="color: #000;font-size:30rpx;font-weight:700;">{{' ¥' + item.commentNum}}</view>
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
<view class="btns flexbox" style="margin-top:10rpx;">
|
||||||
|
<span class="left" style="color: #C0C4CC;">订单详情</span>
|
||||||
|
<span class="right flexbox opbtns">
|
||||||
|
<view style="color: #000;border:1px solid #999;border-radius: 10rpx;padding: 0 10rpx;">查看物流</view>
|
||||||
|
<view style="color: #000;border:1px solid #999;border-radius: 10rpx;padding: 0 10rpx;margin-left:20rpx;width:140rpx;text-align: center;">评价</view>
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
<view style="border-bottom:2rpx solid #e9e9e9;height:50rpx;" v-if="index<item.length-1"></view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="quesheng" v-else>
|
||||||
|
暂无书评内容~
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view v-if="ordersListTab == 2">
|
||||||
|
<view v-if="hotList.length > 0">
|
||||||
|
<view class="orderInfo" v-for="(item,index) in hotList" :key="index">
|
||||||
|
<view class="mainContent">
|
||||||
|
<view class="item" @click.stop="toDetail(item)">
|
||||||
|
|
||||||
|
<view class="orderstatus">{{item.title}}</view>
|
||||||
|
<image class="feng" v-if="item.bookimage" :src="item.bookimage" mode="aspectFill"></image>
|
||||||
|
<view class="description" v-html="item.content">
|
||||||
|
</view>
|
||||||
|
<view class="btns flexbox">
|
||||||
|
<span class="left">{{item.bookname}}</span>
|
||||||
|
<span class="right flexbox opbtns" style="color:#3c9cff;">
|
||||||
|
全文
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
<view class="btns flexbox" style="margin-top:10rpx;">
|
||||||
|
<span class="left" style="color: #C0C4CC;">{{item.createTime}}</span>
|
||||||
|
<span class="right flexbox opbtns">
|
||||||
|
<image class="gzicon" v-if="item.ilike" src="../../static/icon/gz2.png" mode="aspectFill" @click.stop="clickLike(item)"></image>
|
||||||
|
<image class="gzicon" v-else src="../../static/icon/gz.png" mode="aspectFill"></image>
|
||||||
|
<view style="color: #C0C4CC;">{{item.contlike}}</view>
|
||||||
|
<image class="gzicon" v-if="1" src="../../static/icon/pinglun.png" mode="aspectFill"></image>
|
||||||
|
<view style="color: #C0C4CC;">{{item.commentNum}}</view>
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
<view style="border-bottom:2rpx solid #e9e9e9;height:50rpx;" v-if="index<item.length-1"></view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="quesheng" v-else>
|
||||||
|
暂无书评内容~
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<!-- <view v-if="ordersListTab == 3">
|
||||||
|
<view class="" style="padding:40rpx 20rpx;">
|
||||||
|
<view class="mytabs flexbox">
|
||||||
|
<view :class="['item','item1', contentShow == 1 ? 'active' :'']" @click="setData(1)">
|
||||||
|
已购图书
|
||||||
|
</view>
|
||||||
|
<view :class="['item','item2', contentShow == 2 ? 'active' :'']" @click="setData(2)">
|
||||||
|
推荐图书
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view v-if="bookList.length > 0">
|
||||||
|
<view class="orderInfo3" v-for="(item,index) in bookList" :key="index">
|
||||||
|
<view class="mainContent3">
|
||||||
|
<view class="item">
|
||||||
|
<view class="btns flexbox" @click.stop="toMore(item)">
|
||||||
|
<view class="title">{{item.name}}</view>
|
||||||
|
<view class="pianshuping">{{item.forumNum}}篇书评</view>
|
||||||
|
</view>
|
||||||
|
<image class="feng" v-if="item.images" :src="item.images" mode="aspectFill" @click.stop="toMore(item)"></image>
|
||||||
|
<view class="shupingList">
|
||||||
|
<view class="description" v-for="(item1,index1) in item.forums" :key="index1" @click.stop="toDetail(item1)">{{item1.title}}</view>
|
||||||
|
</view>
|
||||||
|
<view class="btns flexbox" @click.stop="toMore(item)">
|
||||||
|
<span class="left"></span>
|
||||||
|
<span class="right flexbox opbtns" style="color:#3c9cff;">
|
||||||
|
全部
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="quesheng" v-else>
|
||||||
|
暂无书评内容~
|
||||||
|
</view>
|
||||||
|
</view> -->
|
||||||
|
|
||||||
|
<view v-if="status==0" style="text-align: center;">
|
||||||
|
<u-loading-icon style="display: inline-block;"></u-loading-icon>
|
||||||
|
<font style='vertical-align: super;margin-left: 10px;font-size: 26rpx;color: #909399;'>努力加载中</font>
|
||||||
|
</view>
|
||||||
|
<view v-if="status==1" style="padding-bottom: 20rpx;">
|
||||||
|
<u-divider text="全部加载完成"></u-divider>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<music-play :playData="playData"></music-play>
|
||||||
|
</view>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import $http from '@/config/requestConfig.js';
|
||||||
|
import emotion from '@/bkhumor-emojiplus/components/bkhumor-emojiplus/bkhumor-emojiplus.vue';
|
||||||
|
import musicPlay from '@/components/music.vue'
|
||||||
|
import { data } from 'jquery';
|
||||||
|
import {
|
||||||
|
mapState, mapMutations
|
||||||
|
} from 'vuex';
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
// loadingNow : false,
|
||||||
|
playData:{},
|
||||||
|
emojiIcon:'cuIcon-emoji',
|
||||||
|
windowWidth:0,
|
||||||
|
bookid:null,
|
||||||
|
booklistpage: 1,
|
||||||
|
productList:[],
|
||||||
|
productInfo:{},
|
||||||
|
pingjiaShow:false, //添加评价
|
||||||
|
Pform:{ // 评价表单
|
||||||
|
star:0,
|
||||||
|
comment:'',
|
||||||
|
img:[],
|
||||||
|
html:''
|
||||||
|
},
|
||||||
|
emoji:[],
|
||||||
|
Files:[],
|
||||||
|
page:1,
|
||||||
|
pageSize:10,
|
||||||
|
total:0,
|
||||||
|
status:3,
|
||||||
|
shupingList:[],
|
||||||
|
bfaid:null,
|
||||||
|
ordersTabs: [{
|
||||||
|
name: '全部',
|
||||||
|
value: 1
|
||||||
|
}, {
|
||||||
|
name: '待付款',
|
||||||
|
value: 2
|
||||||
|
}, {
|
||||||
|
name: '待发货',
|
||||||
|
value: 3
|
||||||
|
}, {
|
||||||
|
name: '待收货',
|
||||||
|
value: 4
|
||||||
|
}, {
|
||||||
|
name: '已完成',
|
||||||
|
value: 5
|
||||||
|
}],
|
||||||
|
ordersListTab: 1,
|
||||||
|
newestpage: 1,
|
||||||
|
hotestpage: 1,
|
||||||
|
booksetpage: 1,
|
||||||
|
newList:[],
|
||||||
|
hotList:[],
|
||||||
|
bookList:[],
|
||||||
|
contentShow: 1,
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onPullDownRefresh() {
|
||||||
|
console.log('下拉刷新了')
|
||||||
|
uni.stopPullDownRefresh();
|
||||||
|
|
||||||
|
this.newestpage = 1
|
||||||
|
this.hotestpage = 1
|
||||||
|
this.booksetpage = 1
|
||||||
|
this.newList = []
|
||||||
|
this.hotList = []
|
||||||
|
this.bookList = []
|
||||||
|
this.getBookList(this.ordersListTab, false)
|
||||||
|
|
||||||
|
},
|
||||||
|
onReachBottom() {
|
||||||
|
this.newestpage++
|
||||||
|
this.hotestpage++
|
||||||
|
this.booksetpage++
|
||||||
|
this.getBookList(this.ordersListTab, false)
|
||||||
|
},
|
||||||
|
onLoad(e) {
|
||||||
|
this.windowWidth = uni.getSystemInfoSync().windowWidth;
|
||||||
|
console.log(e,'onload')
|
||||||
|
// this.bookid = e.bookid
|
||||||
|
this.getBookList(1, false)
|
||||||
|
},
|
||||||
|
computed:{
|
||||||
|
...mapState(['userInfo']),
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
...mapMutations(['setLoadingShow']),
|
||||||
|
setData(e) {
|
||||||
|
this.contentShow = e
|
||||||
|
this.getBookList(this.ordersListTab, true)
|
||||||
|
},
|
||||||
|
// 切换tab状态
|
||||||
|
ordersTabCLi(e) {
|
||||||
|
this.ordersListTab = e
|
||||||
|
this.newestpage = 1
|
||||||
|
this.hotestpage = 1
|
||||||
|
this.booksetpage = 1
|
||||||
|
this.newList = []
|
||||||
|
this.hotList = []
|
||||||
|
this.bookList = []
|
||||||
|
this.getBookList(this.ordersListTab, false)
|
||||||
|
},
|
||||||
|
// 查看本书更多书评
|
||||||
|
toMore(val){
|
||||||
|
console.log(val,'val')
|
||||||
|
uni.navigateTo({
|
||||||
|
url: '../comments/comments?bookid='+val.id,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
// 书评详情
|
||||||
|
toDetail(val){
|
||||||
|
console.log(val,'val')
|
||||||
|
// uni.navigateTo({
|
||||||
|
// url:'../bookShop/commentsDetail?bookid='+val.bookid+'&bfa_id='+val.id
|
||||||
|
// })
|
||||||
|
uni.navigateTo({
|
||||||
|
url: './orderLCont?orderId=' + e.orderId + '&orderType=' + e.orderStatus + '&orderSn=' + e.orderSn
|
||||||
|
});
|
||||||
|
},
|
||||||
|
getBookList(flag, tushuflag){
|
||||||
|
// 根据tab不同,获取最新书评、最热书评、书集列表
|
||||||
|
// uni.showLoading({
|
||||||
|
// title: '加载中'
|
||||||
|
// });
|
||||||
|
|
||||||
|
var httpurl = ""
|
||||||
|
if(flag == 1){
|
||||||
|
httpurl = "forum/articles/getForumsNew?page=" + this.newestpage + '&limit=10'
|
||||||
|
}else if(flag == 2){
|
||||||
|
httpurl = "forum/articles/getForumsHot?page=" + this.hotestpage + '&limit=10'
|
||||||
|
}else{
|
||||||
|
if(tushuflag){ // 点击切换已购和推荐
|
||||||
|
this.booksetpage = 1
|
||||||
|
this.bookList = []
|
||||||
|
}
|
||||||
|
if(this.contentShow == 1){
|
||||||
|
httpurl = "forum/articles/getHasForumsAndBook?page=" + this.booksetpage + '&limit=10&userId=' + this.userInfo.id
|
||||||
|
} else {
|
||||||
|
httpurl = "forum/articles/getBestForumsAndBook?page=" + this.booksetpage + '&limit=10&userId=' + this.userInfo.id
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.$http
|
||||||
|
.post(httpurl)
|
||||||
|
.then(res => {
|
||||||
|
|
||||||
|
if(flag == 1){
|
||||||
|
this.newList = this.newList.concat(res.page.records)
|
||||||
|
}else if(flag == 2){
|
||||||
|
this.hotList = this.hotList.concat(res.page.records)
|
||||||
|
}else{
|
||||||
|
this.bookList = this.bookList.concat(res.page.records)
|
||||||
|
}
|
||||||
|
console.log(this.newList,'this.newList')
|
||||||
|
// let list = res.page.records
|
||||||
|
// console.log(list,'list')
|
||||||
|
// for(let i=0; i < list.length; i++){
|
||||||
|
// let data = {
|
||||||
|
// 'page': 1,
|
||||||
|
// 'limit': 3,
|
||||||
|
// 'bookid' : list[i].bookid
|
||||||
|
// }
|
||||||
|
// this.$http
|
||||||
|
// .post('forum/articles/descupdatelist', data)
|
||||||
|
// .then(res => {
|
||||||
|
// // this.total = res.page.totalPage
|
||||||
|
// // this.shupingList = this.shupingList.concat(res.page.list)
|
||||||
|
// list[i].shupingList = res.page.list
|
||||||
|
// console.log(res.page.list,'评论获取成功')
|
||||||
|
|
||||||
|
// console.log(list,'list')
|
||||||
|
// this.productList.push(list[i])
|
||||||
|
// console.log(this.productList,'productList')
|
||||||
|
// // this.status = 3
|
||||||
|
// }).catch((e)=>{
|
||||||
|
// console.log(e,'e')
|
||||||
|
// })
|
||||||
|
// }
|
||||||
|
if(res.page.records.length != 10){
|
||||||
|
this.status = 1
|
||||||
|
} else {
|
||||||
|
this.status = 0
|
||||||
|
}
|
||||||
|
// uni.hideLoading();
|
||||||
|
}).catch((e)=>{
|
||||||
|
console.log(e,'e')
|
||||||
|
})
|
||||||
|
},
|
||||||
|
},
|
||||||
|
components:{
|
||||||
|
musicPlay,
|
||||||
|
emotion
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
// @import '@/style/mixin.scss';
|
||||||
|
.ordersTabs {
|
||||||
|
// margin: 70rpx 0 0 0;
|
||||||
|
width: 730rpx;
|
||||||
|
// padding: 0 3% 3% 3%;
|
||||||
|
position: fixed;
|
||||||
|
// top: 80rpx;
|
||||||
|
background-color: #f7faf9;
|
||||||
|
z-index: 100;
|
||||||
|
|
||||||
|
.ordersdefine {
|
||||||
|
display: inline-block;
|
||||||
|
padding: 20rpx 0 20rpx 0;
|
||||||
|
// margin: 40rpx 0 15rpx 0;
|
||||||
|
width:140rpx;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 30rpx;
|
||||||
|
position: relative;
|
||||||
|
.ordersnum{
|
||||||
|
position: absolute;
|
||||||
|
top: 8rpx;
|
||||||
|
right: 0rpx;
|
||||||
|
background-color: red;
|
||||||
|
// border:1rpx solid #a3a3a3;
|
||||||
|
border-radius: 40rpx;
|
||||||
|
width: 28rpx;
|
||||||
|
height: 28rpx;
|
||||||
|
font-size: 20rpx;
|
||||||
|
font-weight: 500;
|
||||||
|
color: rgb(255, 255, 255);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.ordStyle {
|
||||||
|
// border-bottom: 4rpx solid #54a966;
|
||||||
|
// color: #54a966;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.flexbox{display: flex;}
|
||||||
|
.container{padding: 0 10px;}
|
||||||
|
.star{display: inline-block; width: 20px; height: 20px; margin-right: 10rpx;}
|
||||||
|
.starGray{ background : url(../../static/icon/star_greey.png) no-repeat; background-size: contain; }
|
||||||
|
.starLight{ background : url(../../static/icon/star_light.png) no-repeat; background-size: contain;}
|
||||||
|
.cuIcon-emoji {
|
||||||
|
background : url(../../static/biaoqing.png) no-repeat; background-size: contain; display: block; margin-right: 20rpx;
|
||||||
|
width: 30px; }
|
||||||
|
.cuIcon-keyboard{background : url(../../static/biaoqing.png) no-repeat; background-size: contain; display: block;
|
||||||
|
width: 30px; }
|
||||||
|
.tanchu {
|
||||||
|
padding: 40rpx 30rpx 40rpx 30rpx;
|
||||||
|
position: relative;
|
||||||
|
|
||||||
|
|
||||||
|
.dp_title {
|
||||||
|
font-size: 32rpx;
|
||||||
|
margin-bottom: 50rpx;
|
||||||
|
color: #555;
|
||||||
|
text-align: center;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.dp_add {
|
||||||
|
position: absolute;
|
||||||
|
top: 40rpx;
|
||||||
|
right: 30rpx;
|
||||||
|
font-size: 22rpx;
|
||||||
|
background-color: #fd6004;
|
||||||
|
color: #fff;
|
||||||
|
border-radius: 10rpx;
|
||||||
|
padding: 5rpx 10rpx;
|
||||||
|
|
||||||
|
.u-icon {
|
||||||
|
display: inline-block;
|
||||||
|
margin-right: 5rpx;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
.quesheng{text-align: center; margin-top: 100rpx; color: #8b8a91; padding-bottom: 20rpx; padding-top: 20rpx;}
|
||||||
|
.gengduoshuping{text-align: right; color: #0044ff; padding-bottom: 20rpx; padding-top: 20rpx;}
|
||||||
|
.orderInfo{
|
||||||
|
justify-content: space-between;
|
||||||
|
// margin-bottom: 15px;
|
||||||
|
background-color: #fff;
|
||||||
|
padding:20rpx;
|
||||||
|
border: 1px splid #999;
|
||||||
|
box-sizing: border-box;
|
||||||
|
// padding-bottom: 20rpx;
|
||||||
|
border-radius: 20rpx;
|
||||||
|
margin-bottom: 20rpx;
|
||||||
|
|
||||||
|
}
|
||||||
|
.mainContent{
|
||||||
|
background-color: #fff;
|
||||||
|
.item{
|
||||||
|
// padding: 10px;
|
||||||
|
// margin-bottom: 30rpx;
|
||||||
|
// border: 1px solid #999;
|
||||||
|
box-sizing: border-box;
|
||||||
|
// padding-bottom: 20rpx;
|
||||||
|
border-radius: 20rpx;
|
||||||
|
// margin-bottom: 20rpx;
|
||||||
|
}
|
||||||
|
.feng{
|
||||||
|
margin:0rpx 20rpx 0 0;
|
||||||
|
height: 160rpx;
|
||||||
|
width: 140rpx;
|
||||||
|
float:left;
|
||||||
|
border-radius: 20rpx;
|
||||||
|
border:1rpx solid #e9e9e9;
|
||||||
|
}
|
||||||
|
.orderstatus{font-size: 30rpx; color: red; text-align: right;padding-bottom: 10rpx;}
|
||||||
|
/deep/.description{
|
||||||
|
overflow: hidden;
|
||||||
|
color: #666;
|
||||||
|
text-overflow: -o-ellipsis-lastline;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
display: -webkit-box;
|
||||||
|
-webkit-line-clamp: 5;
|
||||||
|
line-clamp: 5;
|
||||||
|
-webkit-box-orient: vertical;
|
||||||
|
font-size: 26rpx;
|
||||||
|
margin-bottom: 20rpx;
|
||||||
|
margin-top:10rpx;
|
||||||
|
height: 172rpx;
|
||||||
|
img{
|
||||||
|
width: 100% !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.btns{
|
||||||
|
font-size: 28rpx;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
.booknameleft{
|
||||||
|
width: 372rpx;
|
||||||
|
color: #000000;
|
||||||
|
}
|
||||||
|
.left{
|
||||||
|
width: 300rpx;
|
||||||
|
color: #a1a1a1;
|
||||||
|
}
|
||||||
|
.right{
|
||||||
|
width: 350rpx;
|
||||||
|
display: flex;
|
||||||
|
justify-content: flex-end;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.gzicon{
|
||||||
|
margin:0 0 0 20rpx;
|
||||||
|
height: 40rpx;
|
||||||
|
width: 40rpx;
|
||||||
|
// float:left;
|
||||||
|
// border-radius: 20rpx;
|
||||||
|
// border:1rpx solid #e9e9e9;
|
||||||
|
}
|
||||||
|
.opbtns{
|
||||||
|
.pingjia{margin-left: 10px;}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.mb30{margin-bottom: 30rpx; overflow: hidden;}
|
||||||
|
|
||||||
|
// .orderInfo3{
|
||||||
|
// justify-content: space-between;
|
||||||
|
// // margin-bottom: 15px;
|
||||||
|
// background-color: #fff;
|
||||||
|
// padding:20rpx;
|
||||||
|
// border: 1px splid #999;
|
||||||
|
// box-sizing: border-box;
|
||||||
|
// // padding-bottom: 20rpx;
|
||||||
|
// border-radius: 20rpx;
|
||||||
|
// margin-bottom: 20rpx;
|
||||||
|
// .mainContent3{
|
||||||
|
// background-color: #fff;
|
||||||
|
// .item{
|
||||||
|
// // padding: 10px;
|
||||||
|
// // margin-bottom: 30rpx;
|
||||||
|
// // border: 1px solid #999;
|
||||||
|
// box-sizing: border-box;
|
||||||
|
// // padding-bottom: 20rpx;
|
||||||
|
// border-radius: 20rpx;
|
||||||
|
// // margin-bottom: 20rpx;
|
||||||
|
// }
|
||||||
|
// .feng{
|
||||||
|
// margin:10rpx 20rpx 0 0;
|
||||||
|
// height: 240rpx;
|
||||||
|
// width: 164rpx;
|
||||||
|
// float:left;
|
||||||
|
// border-radius: 20rpx;
|
||||||
|
// border:1rpx solid #e9e9e9;
|
||||||
|
// }
|
||||||
|
// .title{font-size: 30rpx; font-weight: 700; color: #000; overflow: hidden;}
|
||||||
|
// .pianshuping{
|
||||||
|
// font-size: 24rpx;
|
||||||
|
// color: red;
|
||||||
|
// }
|
||||||
|
// .shupingList{
|
||||||
|
// min-height: 212rpx;
|
||||||
|
// }
|
||||||
|
// /deep/.description{
|
||||||
|
// overflow: hidden;
|
||||||
|
// color: #666;
|
||||||
|
// text-overflow: -o-ellipsis-lastline;
|
||||||
|
// overflow: hidden;
|
||||||
|
// text-overflow: ellipsis;
|
||||||
|
// display: -webkit-box;
|
||||||
|
// -webkit-line-clamp: 1;
|
||||||
|
// line-clamp: 1;
|
||||||
|
// -webkit-box-orient: vertical;
|
||||||
|
// font-size: 26rpx;
|
||||||
|
// margin-bottom: 20rpx;
|
||||||
|
// margin-top:10rpx;
|
||||||
|
// img{
|
||||||
|
// width: 100% !important;
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// .btns{
|
||||||
|
// font-size: 22rpx;
|
||||||
|
// justify-content: space-between;
|
||||||
|
// align-items: center;
|
||||||
|
// .left{
|
||||||
|
// width: 300rpx;
|
||||||
|
// color: #a1a1a1;
|
||||||
|
// }
|
||||||
|
// .right{
|
||||||
|
// width: 300rpx;
|
||||||
|
// display: flex;
|
||||||
|
// justify-content: flex-end;
|
||||||
|
// align-items: center;
|
||||||
|
// }
|
||||||
|
// .gzicon{
|
||||||
|
// margin:0 0 0 20rpx;
|
||||||
|
// height: 40rpx;
|
||||||
|
// width: 40rpx;
|
||||||
|
// // float:left;
|
||||||
|
// // border-radius: 20rpx;
|
||||||
|
// // border:1rpx solid #e9e9e9;
|
||||||
|
// }
|
||||||
|
// .opbtns{
|
||||||
|
// .pingjia{margin-left: 10px;}
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
.mytabs {
|
||||||
|
// background: url('@/static/icon/bgtushu.png') no-repeat left top;
|
||||||
|
height: 80rpx;
|
||||||
|
// margin-bottom: 30rpx;
|
||||||
|
|
||||||
|
.item {
|
||||||
|
border-radius: 10rpx;
|
||||||
|
background-color: #c6ead0;
|
||||||
|
width: 48%;
|
||||||
|
// margin: 0 10rpx;
|
||||||
|
text-align: center;
|
||||||
|
color: #3c7f56;
|
||||||
|
font-size: 36rpx;
|
||||||
|
line-height: 80rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.item.active {
|
||||||
|
background-color: #3c7f56;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.item1 {
|
||||||
|
margin-right: 20rpx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@@ -224,7 +224,7 @@
|
|||||||
// 去讲书
|
// 去讲书
|
||||||
goJiangShu(){
|
goJiangShu(){
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: '../talkBook/talkBookDetail?bookId='+ this.bookId
|
url: '../talkBook/talkBookML?bookid='+ this.bookId
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
// 去听书
|
// 去听书
|
||||||
|
|||||||
@@ -3,34 +3,36 @@
|
|||||||
<!-- <z-nav-bar backState="2000" title="首页"></z-nav-bar> -->
|
<!-- <z-nav-bar backState="2000" title="首页"></z-nav-bar> -->
|
||||||
<view class="home_bg">
|
<view class="home_bg">
|
||||||
<view class="" style=" ">
|
<view class="" style=" ">
|
||||||
<view class="icon_hua">
|
|
||||||
<image src="../../static/icon/home_icon_3.png" mode="aspectFit" class="icon_hua_1"></image>
|
<view class="icon_hua">
|
||||||
</view>
|
<image src="../../static/icon/home_icon_1.png" mode="aspectFit" class="icon_hua_1"></image>
|
||||||
<view class="hehan">
|
</view>
|
||||||
<image src="../../static/icon/hehan.png" mode="aspectFit" class="icon_hua_1"></image>
|
<view class="hehan">
|
||||||
</view>
|
<image src="../../static/icon/hehan.png" mode="aspectFit" class="icon_hua_1"></image>
|
||||||
<view class="fiveIcon flexbox" >
|
</view>
|
||||||
|
|
||||||
|
<view class="fiveIcon flexbox" style="justify-content: space-around;">
|
||||||
<div class="item item1" @click="onPageJump('../acupoint/acupoint')">
|
<div class="item item1" @click="onPageJump('../acupoint/acupoint')">
|
||||||
<image src="../../static/icon/five1.png" mode="aspectFit" ></image>
|
<image src="../../static/icon/five1.png" mode="aspectFit" ></image>
|
||||||
<text>经穴检索</text>
|
<text>经穴检索</text>
|
||||||
</div>
|
</div>
|
||||||
<div class="item item1" @click="onPageJump('../prescription/prescription')">
|
<!-- <div class="item item1">
|
||||||
<image src="../../static/icon/five2.png" mode="aspectFit"></image>
|
<image src="../../static/icon/five2.png" mode="aspectFit"></image>
|
||||||
<text>方药检索</text>
|
<text>方药检索</text>
|
||||||
</div>
|
</div> -->
|
||||||
<div class="item item1">
|
<!-- <div class="item item1">
|
||||||
<image src="../../static/icon/five4.png" mode="aspectFit"></image>
|
<image src="../../static/icon/five4.png" mode="aspectFit"></image>
|
||||||
<text>五运六气</text>
|
<text>五运六气</text>
|
||||||
</div>
|
</div> -->
|
||||||
<div class="item item1" @click="onPageJump('../peanut/searchFor')">
|
<div class="item item1" @click="onPageJump('../peanut/searchFor')">
|
||||||
<image src="../../static/icon/five3.png" mode="aspectFit"></image>
|
<image src="../../static/icon/five3.png" mode="aspectFit"></image>
|
||||||
<text>书名检索</text>
|
<text>书名检索</text>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="item item1">
|
<!-- <div class="item item1">
|
||||||
<image src="../../static/icon/five5.png" mode="aspectFit"></image>
|
<image src="../../static/icon/five5.png" mode="aspectFit"></image>
|
||||||
<text>吴门医述</text>
|
<text>吴门医述</text>
|
||||||
</div>
|
</div> -->
|
||||||
</view>
|
</view>
|
||||||
<!-- <view class="search_box flexbox" @click="onPageJump('../peanut/searchFor')">
|
<!-- <view class="search_box flexbox" @click="onPageJump('../peanut/searchFor')">
|
||||||
<view class="search">
|
<view class="search">
|
||||||
@@ -50,23 +52,23 @@
|
|||||||
<!-- <view class="home_nar" v-if="showEbook"> -->
|
<!-- <view class="home_nar" v-if="showEbook"> -->
|
||||||
<view class="home_nar">
|
<view class="home_nar">
|
||||||
<view class="hn_cl_tit shuguan" @click="onPageJump('../clock/index')">
|
<view class="hn_cl_tit shuguan" @click="onPageJump('../clock/index')">
|
||||||
<image src="../../static/icon/home1.png" mode="aspectFit"></image>
|
<image src="../../static/icon/home1-1.png" mode="aspectFit"></image>
|
||||||
<!-- <text>打 卡</text> -->
|
<!-- <text>打 卡</text> -->
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<view class="hn_cl_tit dianzishu" @click="onPageJump('../listen/home')">
|
<view class="hn_cl_tit dianzishu" @click="onPageJump('../listen/home')">
|
||||||
<image src="../../static/icon/home2.png" mode="aspectFit"></image>
|
<image src="../../static/icon/home2-1.png" mode="aspectFit"></image>
|
||||||
<!-- <text>听 书</text> -->
|
<!-- <text>听 书</text> -->
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- <view class="hn_cl_tit" @click="onPageJump('../bookShop/bookShopIndex')"> -->
|
<!-- <view class="hn_cl_tit" @click="onPageJump('../bookShop/bookShopIndex')"> -->
|
||||||
<view class="hn_cl_tit shuping" @click="onPageJump('../comments/commentsList')">
|
<view class="hn_cl_tit shuping" @click="onPageJump('../comments/commentsList')">
|
||||||
<image src="../../static/icon/home3.png" mode="aspectFit"></image>
|
<image src="../../static/icon/home3-1.png" mode="aspectFit"></image>
|
||||||
<!-- <text>书 评</text> -->
|
<!-- <text>书 评</text> -->
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<view class="hn_cl_tit chaoshi" @click="onPageJump('../talkBook/talkBook')">
|
<view class="hn_cl_tit chaoshi" @click="onPageJump('../talkBook/talkBook')">
|
||||||
<image src="../../static/icon/home4.png" mode="aspectFit"></image>
|
<image src="../../static/icon/home4-1.png" mode="aspectFit"></image>
|
||||||
<!-- <text>讲 书</text> -->
|
<!-- <text>讲 书</text> -->
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
@@ -125,14 +127,14 @@
|
|||||||
</view>
|
</view>
|
||||||
</view> -->
|
</view> -->
|
||||||
|
|
||||||
<view class="head_line" style="margin-top: -20rpx;">
|
<view class="head_line" style="background-color: #fff;">
|
||||||
<b></b>
|
<b></b>
|
||||||
<text>新书上市</text>
|
<text>新书上市</text>
|
||||||
<!-- <i @click="onBookMore('New')">查看更多 ></i> -->
|
<!-- <i @click="onBookMore('New')">查看更多 ></i> -->
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<view class="newBook">
|
<view class="newBook">
|
||||||
<scroll-view class="scroll-view_H " scroll-x="true" scroll-left="10">
|
<scroll-view class="scroll-view_H " scroll-x="true" scroll-left="10" style="margin-top: 0 !important;">
|
||||||
<view :class="['item']" v-for="(item,index) in newBookList" :key="index">
|
<view :class="['item']" v-for="(item,index) in newBookList" :key="index">
|
||||||
<view class="videoBox" @click="goDetail(item.productId)">
|
<view class="videoBox" @click="goDetail(item.productId)">
|
||||||
<image v-if="item.productImages != ''" :src="item.productImages" mode="scaleToFill"></image>
|
<image v-if="item.productImages != ''" :src="item.productImages" mode="scaleToFill"></image>
|
||||||
@@ -727,23 +729,23 @@
|
|||||||
.ProTabs{
|
.ProTabs{
|
||||||
// margin: 20rpx 0;
|
// margin: 20rpx 0;
|
||||||
padding:0 20rpx;
|
padding:0 20rpx;
|
||||||
text{padding: 12rpx 14rpx; font-size: 32rpx; border-radius: 10rpx; overflow: hidden;
|
text{padding: 8rpx 14rpx; font-size: 32rpx; display: inline-block; border-radius: 10rpx; overflow: hidden;
|
||||||
// background-color: #eee;
|
// background-color: #eee;
|
||||||
color: #55aa7f; margin-right: 10rpx;}
|
color: #55aa7f; margin-right: 10rpx;}
|
||||||
text.cur{background-color:#55aa7f ; color: #fff;}
|
text.cur{background-color:#55aa7f ; color: #fff;}
|
||||||
}
|
}
|
||||||
.newBook{margin-top: 20rpx;}
|
// .newBook{margin-top: 10rpx;}
|
||||||
.scroll-view_H{background-color: #fff;white-space: nowrap;
|
.scroll-view_H{background-color: #fff;white-space: nowrap;
|
||||||
padding:10rpx ; }
|
padding:10rpx ; margin-top: 12rpx;}
|
||||||
.scroll-view_H{
|
.scroll-view_H{
|
||||||
.item { padding: 10rpx; overflow: hidden; display: inline-block;
|
.item { padding: 10rpx; overflow: hidden; display: inline-block; padding-bottom: 0;
|
||||||
width: 180rpx !important; margin-right: 20rpx; border-radius: 10rpx;
|
width: 180rpx !important; margin-right: 20rpx; border-radius: 10rpx;
|
||||||
.videoBox{
|
.videoBox{
|
||||||
image{display: block; width:150rpx;
|
image{display: block; width:150rpx;
|
||||||
height: 170rpx;
|
height: 170rpx;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.bookName{display: block; margin-top: 20rpx; color: #666; font-size: 24rpx; white-space: nowrap;
|
.bookName{display: block; margin-top: 6rpx; color: #666; font-size: 24rpx; white-space: nowrap;
|
||||||
overflow-x: hidden; overflow: hidden;
|
overflow-x: hidden; overflow: hidden;
|
||||||
text-overflow: ellipsis;}
|
text-overflow: ellipsis;}
|
||||||
}
|
}
|
||||||
@@ -751,7 +753,8 @@
|
|||||||
}
|
}
|
||||||
.flexbox{display: flex;}
|
.flexbox{display: flex;}
|
||||||
.head_line {
|
.head_line {
|
||||||
margin: 20rpx 0 0 0;
|
padding-top: 8rpx;
|
||||||
|
margin: 12rpx 0 0 0;
|
||||||
|
|
||||||
|
|
||||||
b {
|
b {
|
||||||
@@ -793,8 +796,8 @@
|
|||||||
image{width: 150rpx; height: 80rpx;}
|
image{width: 150rpx; height: 80rpx;}
|
||||||
}
|
}
|
||||||
.icon_hua{width: 100%; text-align: center; display: block;
|
.icon_hua{width: 100%; text-align: center; display: block;
|
||||||
image{width: 150rpx; height: 150rpx; margin: 0 auto;}
|
image{width: 150rpx; height: 150rpx; margin: 0 auto;}
|
||||||
}
|
}
|
||||||
.search_box { margin: 0 auto; margin-top: 20rpx; align-items: center;
|
.search_box { margin: 0 auto; margin-top: 20rpx; align-items: center;
|
||||||
width: calc(100% - 30rpx); margin-top: 0;
|
width: calc(100% - 30rpx); margin-top: 0;
|
||||||
margin-bottom: 20rpx;
|
margin-bottom: 20rpx;
|
||||||
@@ -828,8 +831,10 @@
|
|||||||
font-size: 30rpx; color: #fff;
|
font-size: 30rpx; color: #fff;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.home_nar {
|
.home_nar {
|
||||||
margin: 10rpx 20rpx; justify-content: space-between;
|
background-color: #fff;
|
||||||
|
padding: 20rpx 30rpx;
|
||||||
|
justify-content: space-between;
|
||||||
display: flex;
|
display: flex;
|
||||||
color: #333;
|
color: #333;
|
||||||
margin-bottom: 0;
|
margin-bottom: 0;
|
||||||
@@ -839,18 +844,18 @@
|
|||||||
// .chaoshi{background-color:#fff2d8 ; border: 2px solid #ede6d3; }
|
// .chaoshi{background-color:#fff2d8 ; border: 2px solid #ede6d3; }
|
||||||
// .shuping{ background-color: #d6ffda; border: 2px solid #bae9bf;}
|
// .shuping{ background-color: #d6ffda; border: 2px solid #bae9bf;}
|
||||||
// .shuguan{ background-color:#e3f9f9 ; border: 2px solid #d7eced; }
|
// .shuguan{ background-color:#e3f9f9 ; border: 2px solid #d7eced; }
|
||||||
.hn_cl_tit { padding-bottom: 10rpx;
|
.hn_cl_tit {
|
||||||
// width: 23%;
|
// width: 23%;
|
||||||
width: 31%;
|
width: 31%;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
border-radius: 20rpx ; padding-top: 10rpx;
|
border-radius: 20rpx ;
|
||||||
// line-height: 110upx;
|
// line-height: 110upx;
|
||||||
//display: flex;
|
//display: flex;
|
||||||
align-content: center;
|
align-content: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
image {
|
image {
|
||||||
width:90%;
|
width:120rpx;
|
||||||
height:156rpx;
|
height:120rpx;
|
||||||
display: block;
|
display: block;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
// margin: 0 20rpx;
|
// margin: 0 20rpx;
|
||||||
@@ -1119,13 +1124,13 @@
|
|||||||
|
|
||||||
.goods {
|
.goods {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
margin:18rpx 0 50rpx 0;
|
margin:0 0 50rpx 0; background-color: #fff;
|
||||||
|
|
||||||
.goodsItem {
|
.goodsItem {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
width: 46%;
|
width: 46%;
|
||||||
border-radius: 20rpx;
|
border-radius: 20rpx;
|
||||||
padding: 25rpx 25rpx 20rpx 25rpx;
|
padding: 25rpx; padding-bottom: 5rpx;
|
||||||
margin: 0 20rpx 20rpx 20rpx;
|
margin: 0 20rpx 20rpx 20rpx;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
border: 1px solid #eee;
|
border: 1px solid #eee;
|
||||||
@@ -1140,12 +1145,12 @@
|
|||||||
|
|
||||||
.goodsName {
|
.goodsName {
|
||||||
margin-top: 10rpx;
|
margin-top: 10rpx;
|
||||||
font-size: 30rpx;
|
font-size: 28rpx;
|
||||||
// font-weight: bold;
|
// font-weight: bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
.goodsPrice {
|
.goodsPrice {
|
||||||
font-size: 30rpx;
|
font-size: 28rpx;
|
||||||
margin: 5rpx 0 0 3rpx;
|
margin: 5rpx 0 0 3rpx;
|
||||||
display: flex; justify-content: space-between;
|
display: flex; justify-content: space-between;
|
||||||
.price{
|
.price{
|
||||||
|
|||||||
@@ -57,7 +57,12 @@
|
|||||||
<view class="xiugai">
|
<view class="xiugai">
|
||||||
<view class="nav_list" @click="switchTab('../bookShop/orderList')">
|
<view class="nav_list" @click="switchTab('../bookShop/orderList')">
|
||||||
<text>我的订单</text>
|
<text>我的订单</text>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
|
<view class="nav_list" @click="appJump()" v-if="this.osName != ''">
|
||||||
|
<text>打开一路健康</text>
|
||||||
|
</view>
|
||||||
|
|
||||||
<!-- <view class="nav_list" @click="onPageJump('../clock/clockList')">
|
<!-- <view class="nav_list" @click="onPageJump('../clock/clockList')">
|
||||||
<text>我的打卡</text>
|
<text>我的打卡</text>
|
||||||
</view> -->
|
</view> -->
|
||||||
@@ -85,11 +90,12 @@
|
|||||||
<view class="nav_list" @click="onPageJump('../user/address')">
|
<view class="nav_list" @click="onPageJump('../user/address')">
|
||||||
<text>地址管理</text>
|
<text>地址管理</text>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<!-- <view class="nav_list" @click="onGoing()">
|
<!-- <view class="nav_list" @click="onGoing()">
|
||||||
<text>帮助与反馈11111</text>
|
<text>帮助与反馈11111</text>
|
||||||
</view> -->
|
</view> -->
|
||||||
<view class="nav_list" @click="newOnShare" v-if="isAndorid">
|
<!-- <view class="nav_list" @click="newOnShare" v-if="isAndorid"> -->
|
||||||
|
<view class="nav_list" @click="newOnShare">
|
||||||
<text>分享App</text>
|
<text>分享App</text>
|
||||||
</view>
|
</view>
|
||||||
<view class="nav_list" @click="onPageJump('../peanut/aboutUs')">
|
<view class="nav_list" @click="onPageJump('../peanut/aboutUs')">
|
||||||
@@ -101,7 +107,7 @@
|
|||||||
<view class="nav_list" @click="logout">
|
<view class="nav_list" @click="logout">
|
||||||
<text>注销帐号</text>
|
<text>注销帐号</text>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
<u-modal :show="signShow" :content="signContent" :showCancelButton="true" @cancel="signShow=false"
|
<u-modal :show="signShow" :content="signContent" :showCancelButton="true" @cancel="signShow=false"
|
||||||
@@ -111,7 +117,7 @@
|
|||||||
<uni-popup ref="share" type="share" safeArea backgroundColor="#fff">
|
<uni-popup ref="share" type="share" safeArea backgroundColor="#fff">
|
||||||
<uni-popup-share @select="haveSelected"></uni-popup-share>
|
<uni-popup-share @select="haveSelected"></uni-popup-share>
|
||||||
</uni-popup>
|
</uni-popup>
|
||||||
|
|
||||||
<music-play :playData="playData"></music-play>
|
<music-play :playData="playData"></music-play>
|
||||||
<z-navigation></z-navigation>
|
<z-navigation></z-navigation>
|
||||||
</view>
|
</view>
|
||||||
@@ -122,27 +128,30 @@
|
|||||||
import $http from '@/config/requestConfig.js';
|
import $http from '@/config/requestConfig.js';
|
||||||
// import appShare, { closeShare } from '@/uni_modules/zhouWei-APPshare/js_sdk/appShare';
|
// import appShare, { closeShare } from '@/uni_modules/zhouWei-APPshare/js_sdk/appShare';
|
||||||
import {
|
import {
|
||||||
mapState
|
mapState,
|
||||||
|
mapMutations
|
||||||
} from 'vuex';
|
} from 'vuex';
|
||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
showEbook:false, // 显示电子书相关
|
showEbook: false, // 显示电子书相关
|
||||||
userMes: {},
|
userMes: {},
|
||||||
signShow: false,
|
signShow: false,
|
||||||
signContent: '是否要退出登录?',
|
signContent: '是否要退出登录?',
|
||||||
playData:{},
|
playData: {},
|
||||||
isAndorid:true,
|
isAndorid: true,
|
||||||
platform : null, // 设备系统
|
platform: null, // 设备系统
|
||||||
|
osName: '', // 系统名称
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
//第一次加载
|
//第一次加载
|
||||||
onLoad(e) {
|
onLoad(e) {
|
||||||
// 隐藏原生的tabbar
|
// 隐藏原生的tabbar
|
||||||
uni.hideTabBar();
|
uni.hideTabBar();
|
||||||
// #ifdef APP-PLUS
|
// #ifdef APP-PLUS
|
||||||
this.getOS()
|
this.getOS()
|
||||||
this.platform = uni.getSystemInfoSync().platform
|
this.platform = uni.getSystemInfoSync().platform
|
||||||
|
this.osName = plus.os.name
|
||||||
// console.log('操纵系统',this.platform)
|
// console.log('操纵系统',this.platform)
|
||||||
// #endif
|
// #endif
|
||||||
},
|
},
|
||||||
@@ -154,26 +163,70 @@
|
|||||||
// 隐藏原生的tabbar
|
// 隐藏原生的tabbar
|
||||||
uni.hideTabBar();
|
uni.hideTabBar();
|
||||||
this.getData();
|
this.getData();
|
||||||
|
|
||||||
},
|
},
|
||||||
components: {
|
components: {
|
||||||
musicPlay
|
musicPlay
|
||||||
},
|
},
|
||||||
//方法
|
//方法
|
||||||
methods: {
|
methods: {
|
||||||
|
...mapMutations(['setUserInfo']),
|
||||||
|
|
||||||
|
// app 跳转
|
||||||
|
appJump() {
|
||||||
|
// console.log(plus.os.name,'系统名称')
|
||||||
|
if (this.osName == "Android") { //安卓
|
||||||
|
if (plus.runtime.isApplicationExist({ //查看安卓系统手机有没有下载这款app
|
||||||
|
pname: 'cn.com.everhealth', //B款app云打包的包名
|
||||||
|
})) { //安装了app
|
||||||
|
plus.runtime.launchApplication({ //打开app
|
||||||
|
pname: "cn.com.everhealth", //B款app云打包的包名
|
||||||
|
extra: {
|
||||||
|
key1: "我是三方app携带的参数激活99" //B款app配置的schemes+云打包的包名
|
||||||
|
},
|
||||||
|
function(e) {
|
||||||
|
console.log("Open system default browser failed: " + e.message);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
} else { //未安装app
|
||||||
|
plus.runtime.openURL('https://a.app.qq.com/o/simple.jsp?pkgname=cn.com.everhealth', function(res) {
|
||||||
|
//进入后台小哥哥给我的应用宝下载链接,让你们后台给你
|
||||||
|
//这链接会判断你手机是ios还是Android,Android进入应用宝下载app
|
||||||
|
//跟下面的是一个链接
|
||||||
|
console.log(res);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else if (this.osName == "iOS") { //苹果
|
||||||
|
//因为ios查不到B款app在ios系统手机里面,其实下载了,也是检测不到,所以就不检测了
|
||||||
|
//直接打开B款app,B款app没有的话,会进入回调报错,我们在回调去打开下载链接
|
||||||
|
plus.runtime.launchApplication({
|
||||||
|
action: "everhealth://"
|
||||||
|
}, function(e) {
|
||||||
|
plus.runtime.openURL('https://a.app.qq.com/o/simple.jsp?pkgname=cn.com.everhealth',
|
||||||
|
function(res) {
|
||||||
|
//进入后台小哥哥给我的appStore下载app链接,,让你们后台给你
|
||||||
|
//这链接会判断你手机是ios还是Android,ios进入应用宝下载app
|
||||||
|
//跟上面的是一个链接
|
||||||
|
console.log(res);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
},
|
||||||
// 获得操作系统
|
// 获得操作系统
|
||||||
getOS(){
|
getOS() {
|
||||||
let oprateOs = ''
|
let oprateOs = ''
|
||||||
oprateOs = uni.getSystemInfoSync().platform
|
oprateOs = uni.getSystemInfoSync().platform
|
||||||
// console.log(oprateOs)
|
// console.log(oprateOs)
|
||||||
if(oprateOs == 'android'){
|
if (oprateOs == 'android') {
|
||||||
this.isAndorid = true
|
this.isAndorid = true
|
||||||
}else{
|
} else {
|
||||||
this.isAndorid = false
|
this.isAndorid = false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
haveSelected(data){
|
haveSelected(data) {
|
||||||
console.log(data,' 选择的是')
|
console.log(data, ' 选择的是')
|
||||||
if(data.index == 0){
|
if (data.index == 0) {
|
||||||
// 分享到好友
|
// 分享到好友
|
||||||
uni.share({
|
uni.share({
|
||||||
provider: "weixin",
|
provider: "weixin",
|
||||||
@@ -183,14 +236,14 @@
|
|||||||
title: "疯子读书",
|
title: "疯子读书",
|
||||||
summary: "我正在使用疯子读书提升自己,赶紧跟我一起来体验吧!",
|
summary: "我正在使用疯子读书提升自己,赶紧跟我一起来体验吧!",
|
||||||
imageUrl: "static/fengziIcon.jpg",
|
imageUrl: "static/fengziIcon.jpg",
|
||||||
success: function (res) {
|
success: function(res) {
|
||||||
console.log("success:" + JSON.stringify(res));
|
console.log("success:" + JSON.stringify(res));
|
||||||
},
|
},
|
||||||
fail: function (err) {
|
fail: function(err) {
|
||||||
console.log("fail:" + JSON.stringify(err));
|
console.log("fail:" + JSON.stringify(err));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}else if(data.index == 1){
|
} else if (data.index == 1) {
|
||||||
// 分享到朋友圈
|
// 分享到朋友圈
|
||||||
uni.share({
|
uni.share({
|
||||||
provider: "weixin",
|
provider: "weixin",
|
||||||
@@ -200,16 +253,16 @@
|
|||||||
title: "疯子读书",
|
title: "疯子读书",
|
||||||
summary: "我正在使用疯子读书提升自己,赶紧跟我一起来体验吧!",
|
summary: "我正在使用疯子读书提升自己,赶紧跟我一起来体验吧!",
|
||||||
imageUrl: "static/fengziIcon.jpg",
|
imageUrl: "static/fengziIcon.jpg",
|
||||||
success: function (res) {
|
success: function(res) {
|
||||||
console.log("success:" + JSON.stringify(res));
|
console.log("success:" + JSON.stringify(res));
|
||||||
},
|
},
|
||||||
fail: function (err) {
|
fail: function(err) {
|
||||||
console.log("fail:" + JSON.stringify(err));
|
console.log("fail:" + JSON.stringify(err));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
switchTab(url){
|
switchTab(url) {
|
||||||
uni.switchTab({
|
uni.switchTab({
|
||||||
url: url
|
url: url
|
||||||
});
|
});
|
||||||
@@ -230,25 +283,25 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// 新写分享
|
// 新写分享
|
||||||
newOnShare(){
|
newOnShare() {
|
||||||
this.$refs.share.open()
|
this.$refs.share.open()
|
||||||
},
|
},
|
||||||
|
|
||||||
// 注销账户
|
// 注销账户
|
||||||
logout(){
|
logout() {
|
||||||
let that = this
|
let that = this
|
||||||
uni.showModal({
|
uni.showModal({
|
||||||
title: '提示',
|
title: '提示',
|
||||||
content: '确定要注销当前账户吗?',
|
content: '确定要注销当前账户吗?',
|
||||||
success: function (res) {
|
success: function(res) {
|
||||||
if (res.confirm) {
|
if (res.confirm) {
|
||||||
uni.showModal({
|
uni.showModal({
|
||||||
title: '提示',
|
title: '提示',
|
||||||
showCancel:false,
|
showCancel: false,
|
||||||
content: `注销申请已提交成功,请联系客服进行后续操作:022-24142321`,
|
content: `注销申请已提交成功,请联系客服进行后续操作:022-24142321`,
|
||||||
success: function (res1) {
|
success: function(res1) {
|
||||||
if (res1.confirm) {
|
if (res1.confirm) {
|
||||||
that.signOut()
|
that.signOut()
|
||||||
}
|
}
|
||||||
@@ -268,7 +321,7 @@
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
onPageJump(url) {
|
onPageJump(url) {
|
||||||
console.log(url,'url')
|
console.log(url, 'url')
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: url
|
url: url
|
||||||
});
|
});
|
||||||
@@ -278,6 +331,9 @@
|
|||||||
// 退出登录
|
// 退出登录
|
||||||
signOut() {
|
signOut() {
|
||||||
this.signShow = false
|
this.signShow = false
|
||||||
|
this.setUserInfo({
|
||||||
|
'token': null
|
||||||
|
})
|
||||||
uni.reLaunch({
|
uni.reLaunch({
|
||||||
url: '../user/login'
|
url: '../user/login'
|
||||||
});
|
});
|
||||||
@@ -444,4 +500,4 @@
|
|||||||
border-bottom: 0;
|
border-bottom: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
@@ -1,630 +0,0 @@
|
|||||||
<template>
|
|
||||||
<view class="container">
|
|
||||||
<!-- 公共组件-每个页面必须引入1 -->
|
|
||||||
<public-module></public-module> -->
|
|
||||||
<z-nav-bar title="方药检索"></z-nav-bar>
|
|
||||||
<!-- <uni-search-bar @confirm="search" :focus="true" v-model="searchValue" @blur="blur" @focus="focus" @input="input"
|
|
||||||
@cancel="cancel" @clear="clear">
|
|
||||||
</uni-search-bar> -->
|
|
||||||
<view class="oneCateList flexbox">
|
|
||||||
<text :class="[curOneCateIndex == index ? 'cur' : '']" @click="setOneCateIndex(item,index)"
|
|
||||||
v-for="(item, index) in oneCateList" :key="item.id">{{item.title}}</text>
|
|
||||||
</view>
|
|
||||||
<view class="search_box">
|
|
||||||
<u-search placeholder="请输入方药名" @focus="focus" @clear="clear" v-model="searchValue" @input="input"
|
|
||||||
@blur="blur" @search="search"></u-search>
|
|
||||||
</view>
|
|
||||||
<view class="searchList" v-show="showSearchList">
|
|
||||||
<view class="itemBox" v-if="searchList.length > 0">
|
|
||||||
<view class="item" v-for="(item, index) in searchList" :key="index" @click="gotoDetail(item)">
|
|
||||||
{{item.title}}
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
<view v-else class="">
|
|
||||||
<u-divider text="未找到相关方药哦~"></u-divider>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
<view v-show="!showSearchList" class="contentBox">
|
|
||||||
<view class="" v-if="false">
|
|
||||||
<!-- 常规格式 -->
|
|
||||||
<view class="grid twoCateList" v-if="twoCateList.length > 0">
|
|
||||||
<u-grid :col="3" border class="u-grid-list">
|
|
||||||
<u-grid-item v-for="(item, index) in twoCateList" :key="item.id"
|
|
||||||
@click="setTwoCateIndex(item, index)">
|
|
||||||
<view :class="['grid-text',curTwoCateIndex == index ? 'cur' : '']">{{item.title}}</view>
|
|
||||||
</u-grid-item>
|
|
||||||
</u-grid>
|
|
||||||
</view>
|
|
||||||
<view class="titleList">
|
|
||||||
<u-grid :col="3" v-if="titleList.length > 0">
|
|
||||||
<u-grid-item v-for="(item, index) in titleList" :key="item.id" @click="gotoDetail(item)">
|
|
||||||
<view :class="['titleItem']">{{item.title}}</view>
|
|
||||||
</u-grid-item>
|
|
||||||
</u-grid>
|
|
||||||
<u-divider v-else text="暂无方药数据哦~"></u-divider>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
<view class="mode2" v-else>
|
|
||||||
<!-- 经方样式 -->
|
|
||||||
<scroll-view class="scroll-container" scroll-y="true" :scroll-into-view="toView"
|
|
||||||
scroll-with-animation="true">
|
|
||||||
<view class="address-book" v-for="(item, index) in jingfangList" :key="index" :id="item.id">
|
|
||||||
<view class="address-book-index">{{ item.id }}</view>
|
|
||||||
<view class="contact-container" v-for="(item, index) in item.data" :key="index">
|
|
||||||
<view class="contact-detail-container">
|
|
||||||
<view class="contact-name">{{ item.title }}</view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
</scroll-view>
|
|
||||||
<view class="letter-nav">
|
|
||||||
<view class="item" v-for="(item, index) in indexList" :key="index" @click="toSelectIndex(item)">
|
|
||||||
{{ item }}
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
|
|
||||||
</view>
|
|
||||||
</view>
|
|
||||||
<music-play :playData="playData"></music-play>
|
|
||||||
<z-navigation></z-navigation>
|
|
||||||
</view>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
import musicPlay from '@/components/music.vue'
|
|
||||||
import $http from '@/config/requestConfig.js';
|
|
||||||
export default {
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
indexList: ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
|
|
||||||
'T', 'U', 'V', 'W', 'X', 'Y', 'Z'
|
|
||||||
],
|
|
||||||
playData: {},
|
|
||||||
searchValue: '',
|
|
||||||
oneCateList: [], // 一级分类标题1
|
|
||||||
twoCateList: [], // 二级分类标题
|
|
||||||
titleList: [], // 方药标题
|
|
||||||
curOneCateIndex: 0, // 当前选中的一级分类
|
|
||||||
curTwoCateIndex: 0, // 当前选中的二级分类
|
|
||||||
searchList: [], // 搜索结果数组
|
|
||||||
showSearchList: false,
|
|
||||||
toView: '',
|
|
||||||
jingfangList: [{
|
|
||||||
id: 'A',
|
|
||||||
data: [{
|
|
||||||
title: '阿联酋迪拉姆',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '阿尔巴尼亚列克',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'B',
|
|
||||||
data: [{
|
|
||||||
title: '孟加拉国塔卡',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '保加利亚列瓦',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
id: 'C',
|
|
||||||
data: [{
|
|
||||||
title: '加拿大元',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '瑞士法郎',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'D',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'E',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'F',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'G',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'H',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'I',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'J',
|
|
||||||
data: [{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '丹麦克朗',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '多米尼加比索',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 'Z',
|
|
||||||
data: [{
|
|
||||||
title: 'z',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: 'zzz',
|
|
||||||
},
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
||||||
], // 经方数组
|
|
||||||
}
|
|
||||||
},
|
|
||||||
onLoad() {
|
|
||||||
this.getCateList()
|
|
||||||
},
|
|
||||||
onHide() {
|
|
||||||
this.showSearchList = false
|
|
||||||
this.searchList = []
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
toSelectIndex(item) {
|
|
||||||
this.toView = item
|
|
||||||
},
|
|
||||||
// 方药详情
|
|
||||||
gotoDetail(item) {
|
|
||||||
uni.navigateTo({
|
|
||||||
url: "./acupointDetail?id=" + item.id
|
|
||||||
})
|
|
||||||
},
|
|
||||||
// 获取方药名称
|
|
||||||
getTitles(id) {
|
|
||||||
$http.request({
|
|
||||||
url: "book/point/getPointsByCategoryId",
|
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
|
||||||
data: {
|
|
||||||
// loadAnimate: 'none', // 请求加载动画
|
|
||||||
'pointCategoryId': id
|
|
||||||
},
|
|
||||||
header: { //默认 无 说明:请求头
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
},
|
|
||||||
}).then(res => {
|
|
||||||
console.log(res, '内容获取成功')
|
|
||||||
if (res.code == 0 && res.points.length > 0) {
|
|
||||||
this.titleList = res.points
|
|
||||||
} else {
|
|
||||||
this.titleList = []
|
|
||||||
}
|
|
||||||
}).catch(e => {
|
|
||||||
this.titleList = []
|
|
||||||
console.log(e)
|
|
||||||
})
|
|
||||||
},
|
|
||||||
setTwoCateIndex(item, index) {
|
|
||||||
let id = item.id
|
|
||||||
this.curTwoCateIndex = index
|
|
||||||
this.getTitles(id)
|
|
||||||
},
|
|
||||||
setOneCateIndex(item, index) {
|
|
||||||
let id = item.id
|
|
||||||
this.curOneCateIndex = index
|
|
||||||
this.curTwoCateIndex = 0
|
|
||||||
this.getTowCateList(id)
|
|
||||||
},
|
|
||||||
getTowCateList(id) {
|
|
||||||
$http.request({
|
|
||||||
url: "book/point/getPointCategoryByPid",
|
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
|
||||||
data: {
|
|
||||||
loadAnimate: 'none', // 请求加载动画
|
|
||||||
'id': id
|
|
||||||
},
|
|
||||||
header: { //默认 无 说明:请求头
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
},
|
|
||||||
}).then(res => {
|
|
||||||
console.log(res, '二级分类获取成功')
|
|
||||||
if (res.code == 0 && res.category.length > 0) {
|
|
||||||
this.twoCateList = res.category
|
|
||||||
this.getTitles(this.twoCateList[0].id)
|
|
||||||
} else {
|
|
||||||
this.twoCateList = []
|
|
||||||
this.titleList = []
|
|
||||||
}
|
|
||||||
}).catch(e => {
|
|
||||||
this.twoCateList = []
|
|
||||||
this.titleList = []
|
|
||||||
console.log(e)
|
|
||||||
})
|
|
||||||
},
|
|
||||||
getCateList(id) {
|
|
||||||
id ? '' : id = 0
|
|
||||||
this.twoCateList = []
|
|
||||||
this.curTwoCateIndex = 0
|
|
||||||
// 0为获取顶级分类,其他为搜索下级分类,目前的逻辑,顶级是写死的,所以可能只会涉及到搜索第二级
|
|
||||||
$http.request({
|
|
||||||
url: "book/point/getPointCategoryByPid",
|
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
|
||||||
data: {
|
|
||||||
loadAnimate: 'none', // 请求加载动画
|
|
||||||
'id': id
|
|
||||||
},
|
|
||||||
header: { //默认 无 说明:请求头
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
},
|
|
||||||
}).then(res => {
|
|
||||||
console.log(res, '脉穴分类获取成功')
|
|
||||||
if (res.code == 0 && res.category.length > 0) {
|
|
||||||
this.oneCateList = res.category
|
|
||||||
this.getTowCateList(this.oneCateList[0].id)
|
|
||||||
} else {
|
|
||||||
this.oneCateList = []
|
|
||||||
}
|
|
||||||
}).catch(e => {
|
|
||||||
this.oneCateList = []
|
|
||||||
console.log(e)
|
|
||||||
})
|
|
||||||
},
|
|
||||||
getSearch() {
|
|
||||||
$http.request({
|
|
||||||
url: "book/point/searchPointList",
|
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
|
||||||
data: {
|
|
||||||
loadAnimate: 'none', // 请求加载动画
|
|
||||||
'keywords': this.searchValue
|
|
||||||
},
|
|
||||||
header: { //默认 无 说明:请求头
|
|
||||||
'Content-Type': 'application/json'
|
|
||||||
},
|
|
||||||
}).then(res => {
|
|
||||||
console.log(res, '搜索结果')
|
|
||||||
if (res.code == 0 && res.points.length > 0) {
|
|
||||||
this.searchList = res.points
|
|
||||||
}
|
|
||||||
}).catch(e => {
|
|
||||||
// this.titleList = []
|
|
||||||
this.searchList = []
|
|
||||||
console.log(e)
|
|
||||||
})
|
|
||||||
},
|
|
||||||
search(res) {
|
|
||||||
console.log(res, 'res')
|
|
||||||
// uni.showToast({
|
|
||||||
// title: '搜索:' + res,
|
|
||||||
// icon: 'none'
|
|
||||||
// })
|
|
||||||
|
|
||||||
},
|
|
||||||
input(res) {
|
|
||||||
console.log('----input:', res)
|
|
||||||
if (res == '') {
|
|
||||||
this.searchList = []
|
|
||||||
} else {
|
|
||||||
this.getSearch()
|
|
||||||
}
|
|
||||||
},
|
|
||||||
clear(res) {
|
|
||||||
// uni.showToast({
|
|
||||||
// title: 'clear事件,清除值为:',
|
|
||||||
// icon: 'none'
|
|
||||||
// })
|
|
||||||
this.showSearchList = false
|
|
||||||
},
|
|
||||||
blur(res) {
|
|
||||||
if (res == '') {
|
|
||||||
this.showSearchList = false
|
|
||||||
this.searchList = []
|
|
||||||
} else {
|
|
||||||
this.getSearch()
|
|
||||||
}
|
|
||||||
},
|
|
||||||
focus(e) {
|
|
||||||
// uni.showToast({
|
|
||||||
// title: 'focus事件,输出值为:' + e.value,
|
|
||||||
// icon: 'none'
|
|
||||||
// })
|
|
||||||
this.showSearchList = true
|
|
||||||
},
|
|
||||||
// cancel(res) {
|
|
||||||
// uni.showToast({
|
|
||||||
// title: '点击取消,输入值为:' + res.value,
|
|
||||||
// icon: 'none'
|
|
||||||
// })
|
|
||||||
// }
|
|
||||||
},
|
|
||||||
onBackPress() {
|
|
||||||
// #ifdef APP-PLUS
|
|
||||||
plus.key.hideSoftKeybord();
|
|
||||||
// #endif
|
|
||||||
},
|
|
||||||
components: {
|
|
||||||
musicPlay
|
|
||||||
},
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.mode2 {
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
.address-book-index {
|
|
||||||
background-color: #f8f9fa; padding: 10rpx 0; text-indent: 2%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.contact-img {
|
|
||||||
width: 20px;
|
|
||||||
height: 20px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.scroll-container {
|
|
||||||
height: calc(100vh - 70rpx);
|
|
||||||
}
|
|
||||||
|
|
||||||
.letter-nav {
|
|
||||||
position: absolute;
|
|
||||||
right: 25rpx;
|
|
||||||
top: 40rpx;
|
|
||||||
|
|
||||||
.item {
|
|
||||||
font-size: 28rpx; margin-bottom: 10rpx;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.contact-container {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
margin: 2%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.contact-detail-container {
|
|
||||||
margin-left: 2%;
|
|
||||||
.contact-name{
|
|
||||||
padding: 10rpx;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.searchList {
|
|
||||||
.item {
|
|
||||||
font-size: 28rpx;
|
|
||||||
padding: 20rpx;
|
|
||||||
border-bottom: 1px solid #dadbde;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.scroll-view_H {
|
|
||||||
background-color: #fff;
|
|
||||||
white-space: nowrap;
|
|
||||||
padding: 10rpx;
|
|
||||||
}
|
|
||||||
|
|
||||||
.oneCateList {
|
|
||||||
margin-bottom: 20rpx;
|
|
||||||
justify-content: space-between;
|
|
||||||
|
|
||||||
text {
|
|
||||||
text-align: center;
|
|
||||||
display: inline-block;
|
|
||||||
width: 32%;
|
|
||||||
padding: 20rpx 0;
|
|
||||||
font-size: 34rpx;
|
|
||||||
border-radius: 10rpx;
|
|
||||||
}
|
|
||||||
|
|
||||||
.cur {
|
|
||||||
background-color: #55aa7f;
|
|
||||||
color: #fff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.contentBox {
|
|
||||||
|
|
||||||
.twoCateList {
|
|
||||||
font-size: 28rpx;
|
|
||||||
margin-top: 20rpx;
|
|
||||||
|
|
||||||
.grid-text {
|
|
||||||
padding: 30rpx 20rpx;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.cur {
|
|
||||||
color: #55aa7f;
|
|
||||||
}
|
|
||||||
|
|
||||||
// .u-grid-list{border: 0.5px solid #dadbde;}
|
|
||||||
}
|
|
||||||
|
|
||||||
.titleList {
|
|
||||||
font-size: 26rpx;
|
|
||||||
margin-top: 20rpx;
|
|
||||||
padding: 10rpx;
|
|
||||||
border-radius: 10rpx;
|
|
||||||
background-color: #f8f9fa;
|
|
||||||
|
|
||||||
.titleItem {
|
|
||||||
padding: 20rpx 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.container {
|
|
||||||
padding: 10rpx;
|
|
||||||
min-height: 100vh;
|
|
||||||
overflow: hidden;
|
|
||||||
background-color: #fff;
|
|
||||||
}
|
|
||||||
|
|
||||||
.search_box {
|
|
||||||
margin: 0 auto;
|
|
||||||
overflow: hidden;
|
|
||||||
margin-top: 20rpx;
|
|
||||||
align-items: center;
|
|
||||||
width: calc(100% - 10px);
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 40rpx;
|
|
||||||
|
|
||||||
.search {
|
|
||||||
height: 56upx;
|
|
||||||
display: flex;
|
|
||||||
width: 86%;
|
|
||||||
margin: 0 auto;
|
|
||||||
align-items: center;
|
|
||||||
padding: 0upx 40upx;
|
|
||||||
background-color: #fff;
|
|
||||||
border-radius: 20upx;
|
|
||||||
box-shadow: 0 0px 10px 1px #54a96633;
|
|
||||||
}
|
|
||||||
|
|
||||||
.prompt {
|
|
||||||
color: #838383;
|
|
||||||
font-size: 24rpx;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.icon_search {
|
|
||||||
background-image: url('@/static/icon/map_ic_search.png');
|
|
||||||
background-position: center center;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-size: cover;
|
|
||||||
width: 36upx;
|
|
||||||
height: 36upx;
|
|
||||||
margin-right: 20upx;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.flexbox {
|
|
||||||
display: flex;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
<template>
|
|
||||||
<view>
|
|
||||||
|
|
||||||
</view>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script>
|
|
||||||
export default {
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
|
|
||||||
}
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style>
|
|
||||||
|
|
||||||
</style>
|
|
||||||
@@ -19,17 +19,17 @@
|
|||||||
</view> -->
|
</view> -->
|
||||||
<view class="mainContainer">
|
<view class="mainContainer">
|
||||||
<view class="item" v-if="bookList.length > 0">
|
<view class="item" v-if="bookList.length > 0">
|
||||||
<u-row gutter="16" justify="flex-start" >
|
<u-row gutter="16" justify="flex-start">
|
||||||
<u-col span="4" v-for="(item,index) in bookList" :key="index">
|
<u-col span="4" v-for="(item,index) in bookList" :key="index">
|
||||||
<view>
|
<view>
|
||||||
<view class="videoBox demo-layout bg-purple" @click="toDetail(item)">
|
<view class="videoBox demo-layout bg-purple" @click="toDetail(item)">
|
||||||
<image v-if="item.images != ''" :src="item.images" mode="scaleToFill"></image>
|
<image v-if="item.images != ''" :src="item.images" mode="scaleToFill"></image>
|
||||||
<image v-else src="../../static/icon/wufeng.jpg" mode="scaleToFill"></image>
|
<image v-else src="../../static/icon/wufeng.jpg" mode="scaleToFill"></image>
|
||||||
</view>
|
</view>
|
||||||
<text class="bookName">{{item.name}}</text>
|
<text class="bookName">{{item.name}}</text>
|
||||||
</view>
|
</view>
|
||||||
</u-col>
|
</u-col>
|
||||||
</u-row>
|
</u-row>
|
||||||
</view>
|
</view>
|
||||||
<u-divider v-else text="暂无数据"></u-divider>
|
<u-divider v-else text="暂无数据"></u-divider>
|
||||||
<view style="width: 100%;">
|
<view style="width: 100%;">
|
||||||
@@ -41,10 +41,10 @@
|
|||||||
<u-divider text="全部加载完成"></u-divider>
|
<u-divider text="全部加载完成"></u-divider>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
</view>
|
</view>
|
||||||
<!-- 公共组件-每个页面必须引入 -->
|
<!-- 公共组件-每个页面必须引入 -->
|
||||||
<public-module></public-module>
|
<public-module></public-module>
|
||||||
<music-play :playData="playData"></music-play>
|
<music-play :playData="playData"></music-play>
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
@@ -52,42 +52,44 @@
|
|||||||
<script>
|
<script>
|
||||||
import $http from '@/config/requestConfig.js';
|
import $http from '@/config/requestConfig.js';
|
||||||
// import emotion from '@/bkhumor-emojiplus/components/bkhumor-emojiplus/bkhumor-emojiplus.vue';
|
// import emotion from '@/bkhumor-emojiplus/components/bkhumor-emojiplus/bkhumor-emojiplus.vue';
|
||||||
import musicPlay from '@/components/music.vue'
|
import musicPlay from '@/components/music.vue'
|
||||||
import { data } from 'jquery';
|
import {
|
||||||
import {
|
data
|
||||||
mapState
|
} from 'jquery';
|
||||||
} from 'vuex';
|
import {
|
||||||
|
mapState
|
||||||
|
} from 'vuex';
|
||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
loadingNow : false,
|
loadingNow: false,
|
||||||
playData:{},
|
playData: {},
|
||||||
windowWidth:0,
|
windowWidth: 0,
|
||||||
bookid:null,
|
bookid: null,
|
||||||
productInfo:{},
|
productInfo: {},
|
||||||
page:1,
|
page: 1,
|
||||||
bookList:[],
|
bookList: [],
|
||||||
pageSize:9,
|
pageSize: 9,
|
||||||
total:0,
|
total: 0,
|
||||||
totalPage:0,
|
totalPage: 0,
|
||||||
status:3,
|
status: 3,
|
||||||
shupingList:[],
|
shupingList: [],
|
||||||
bfaid:null,
|
bfaid: null,
|
||||||
contentShow: 1,
|
contentShow: 1,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onPullDownRefresh() {
|
onPullDownRefresh() {
|
||||||
console.log('下拉刷新了')
|
console.log('下拉刷新了')
|
||||||
uni.stopPullDownRefresh();
|
uni.stopPullDownRefresh();
|
||||||
},
|
},
|
||||||
onReachBottom() {
|
onReachBottom() {
|
||||||
this.loadingNow = true
|
this.loadingNow = true
|
||||||
// if(this.page < this.total){
|
// if(this.page < this.total){
|
||||||
// this.page++
|
// this.page++
|
||||||
// console.log('加载',this.page)
|
// console.log('加载',this.page)
|
||||||
// this.status = 0
|
// this.status = 0
|
||||||
// this.getBookCom()
|
// this.getBookCom()
|
||||||
|
|
||||||
// }else{
|
// }else{
|
||||||
// this.status = 1
|
// this.status = 1
|
||||||
// console.log('加载完成了',this.page)
|
// console.log('加载完成了',this.page)
|
||||||
@@ -96,104 +98,112 @@ import { data } from 'jquery';
|
|||||||
},
|
},
|
||||||
onLoad(e) {
|
onLoad(e) {
|
||||||
this.windowWidth = uni.getSystemInfoSync().windowWidth;
|
this.windowWidth = uni.getSystemInfoSync().windowWidth;
|
||||||
console.log(e,'onload')
|
console.log(e, 'onload')
|
||||||
this.bookid = e.bookid
|
this.bookid = e.bookid
|
||||||
// this.getProDetail(e)
|
// this.getProDetail(e)
|
||||||
this.getBooks()
|
this.getBooks()
|
||||||
},
|
},
|
||||||
computed:{
|
computed: {
|
||||||
...mapState(['userInfo']),
|
...mapState(['userInfo']),
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
setData(e) {
|
setData(e) {
|
||||||
this.contentShow = e
|
this.contentShow = e
|
||||||
this.getBooks()
|
this.getBooks()
|
||||||
},
|
},
|
||||||
getBooks(){
|
getBooks() {
|
||||||
if(this.contentShow == 1){
|
if (this.contentShow == 1) {
|
||||||
|
|
||||||
$http.request({
|
$http.request({
|
||||||
url: "book/teach/getUserTeachBooks",
|
url: "book/teach/getUserTeachBooks",
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
data: {
|
data: {
|
||||||
id: this.userInfo.id,
|
id: this.userInfo.id,
|
||||||
'limit': 100,
|
'limit': 100,
|
||||||
'page': this.page
|
'page': this.page
|
||||||
},
|
},
|
||||||
header: { //默认 无 说明:请求头
|
header: { //默认 无 说明:请求头
|
||||||
'Content-Type': 'application/json'
|
'Content-Type': 'application/json'
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
.then(res => {
|
.then(res => {
|
||||||
console.log(res,'讲书列表')
|
console.log(res, '讲书列表')
|
||||||
if(res.code == 0 && res.page.records.length > 0){
|
if (res.code == 0 && res.page.records.length > 0) {
|
||||||
this.bookList = res.page.records
|
this.bookList = res.page.records
|
||||||
this.totalPage = res.page.pages
|
this.totalPage = res.page.pages
|
||||||
this.status = 3
|
this.status = 3
|
||||||
console.log(this.bookList,'this.bookList')
|
console.log(this.bookList, 'this.bookList')
|
||||||
}else{
|
} else {
|
||||||
this.bookList = []
|
this.bookList = []
|
||||||
this.totalPage = 0
|
this.totalPage = 0
|
||||||
}
|
}
|
||||||
|
|
||||||
}).catch(e => {
|
}).catch(e => {
|
||||||
console.log(e,'e')
|
console.log(e, 'e')
|
||||||
});
|
});
|
||||||
}else{
|
} else {
|
||||||
$http.request({
|
$http.request({
|
||||||
url: "book/teach/getUserBestTeachBooks",
|
url: "book/teach/getUserBestTeachBooks",
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
data: {
|
data: {
|
||||||
id: this.userInfo.id,
|
id: this.userInfo.id,
|
||||||
'limit': 100,
|
'limit': 100,
|
||||||
'page': this.page
|
'page': this.page
|
||||||
},
|
},
|
||||||
header: { //默认 无 说明:请求头
|
header: { //默认 无 说明:请求头
|
||||||
'Content-Type': 'application/json'
|
'Content-Type': 'application/json'
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
// this.$http
|
// this.$http
|
||||||
// .post('book/teach/getUserBestTeachBooks',{
|
// .post('book/teach/getUserBestTeachBooks',{
|
||||||
// id: this.userInfo.id,
|
// id: this.userInfo.id,
|
||||||
// 'limit': 100,
|
// 'limit': 100,
|
||||||
// 'page': this.page
|
// 'page': this.page
|
||||||
// })
|
// })
|
||||||
.then(res => {
|
.then(res => {
|
||||||
console.log(res,'讲书列表')
|
console.log(res, '讲书列表')
|
||||||
if(res.code == 0 && res.page.records.length > 0){
|
if (res.code == 0 && res.page.records.length > 0) {
|
||||||
this.bookList = res.page.records
|
this.bookList = res.page.records
|
||||||
this.totalPage = res.page.pages
|
this.totalPage = res.page.pages
|
||||||
this.status = 3
|
this.status = 3
|
||||||
console.log(this.bookList,'this.bookList')
|
console.log(this.bookList, 'this.bookList')
|
||||||
}else{
|
} else {
|
||||||
this.bookList = []
|
this.bookList = []
|
||||||
this.totalPage = 0
|
this.totalPage = 0
|
||||||
}
|
}
|
||||||
|
|
||||||
}).catch(e => {
|
}).catch(e => {
|
||||||
console.log(e,'e')
|
console.log(e, 'e')
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
// 书评详情
|
// 书评详情
|
||||||
toDetail(val){
|
toDetail(val) {
|
||||||
console.log(val,'val')
|
// console.log(val,'val')
|
||||||
uni.navigateTo({
|
if (this.contentShow == 1) {
|
||||||
url:'./talkBookML?bookid='+val.id
|
uni.navigateTo({
|
||||||
})
|
url: './talkBookML?bookid=' + val.id
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if (this.contentShow == 2) {
|
||||||
|
uni.navigateTo({
|
||||||
|
url: '../eBook/bookContent?Id=' + val.id
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
},
|
},
|
||||||
components:{
|
components: {
|
||||||
musicPlay
|
musicPlay
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.mytabs {
|
.mytabs {
|
||||||
// background: url('@/static/icon/bgtushu.png') no-repeat left top;
|
// background: url('@/static/icon/bgtushu.png') no-repeat left top;
|
||||||
height: 80rpx;
|
height: 80rpx;
|
||||||
@@ -219,35 +229,55 @@ import { data } from 'jquery';
|
|||||||
margin-right: 20rpx;
|
margin-right: 20rpx;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.tip{
|
|
||||||
padding: 20rpx; background-color: #fff;
|
.tip {
|
||||||
text{ font-size: 36rpx;}
|
padding: 20rpx;
|
||||||
|
background-color: #fff;
|
||||||
|
|
||||||
|
text {
|
||||||
|
font-size: 36rpx;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.flexbox{display: flex;}
|
|
||||||
.container{padding: 10px;}
|
.flexbox {
|
||||||
.bookName {
|
display: flex;
|
||||||
white-space: nowrap;
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bookName {
|
||||||
|
white-space: nowrap;
|
||||||
overflow-x: hidden;
|
overflow-x: hidden;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
font-size: 30rpx;
|
font-size: 30rpx;
|
||||||
color: #333;
|
color: #333;
|
||||||
padding: 10rpx 0;
|
padding: 10rpx 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
uni-image {
|
uni-image {
|
||||||
width: auto !important;
|
width: auto !important;
|
||||||
height: 350rpx;
|
height: 350rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.listenList {
|
.listenList {
|
||||||
padding: 10rpx;
|
padding: 10rpx;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
width: calc(100% - 10rpx);
|
width: calc(100% - 10rpx);
|
||||||
}
|
}
|
||||||
|
|
||||||
.u-row {
|
.u-row {
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
.u-col {
|
.u-col {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
margin-bottom: 20rpx;
|
margin-bottom: 20rpx;
|
||||||
}
|
}
|
||||||
.mb30{margin-bottom: 30rpx; overflow: hidden;}
|
|
||||||
</style>
|
.mb30 {
|
||||||
|
margin-bottom: 30rpx;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@@ -209,7 +209,7 @@
|
|||||||
this.$http
|
this.$http
|
||||||
.post('book/teach/getBookTeachItems', {
|
.post('book/teach/getBookTeachItems', {
|
||||||
'bookId': this.bookid,
|
'bookId': this.bookid,
|
||||||
'limit': 10,
|
'limit': 20,
|
||||||
'page': this.page
|
'page': this.page
|
||||||
// 'userid': this.userInfo.id,
|
// 'userid': this.userInfo.id,
|
||||||
// 'bookid':
|
// 'bookid':
|
||||||
@@ -222,7 +222,9 @@
|
|||||||
this.libLIst = this.libLIst.concat(res.page.records)
|
this.libLIst = this.libLIst.concat(res.page.records)
|
||||||
this.status = 3
|
this.status = 3
|
||||||
this.totalPage = res.page.pages
|
this.totalPage = res.page.pages
|
||||||
|
if(this.totalPage = res.page.current){
|
||||||
|
this.status = 1
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
this.libLIst = []
|
this.libLIst = []
|
||||||
this.totalPage = 0
|
this.totalPage = 0
|
||||||
|
|||||||
@@ -19,9 +19,9 @@
|
|||||||
|
|
||||||
<u-form-item label="所在地区 :" prop="">
|
<u-form-item label="所在地区 :" prop="">
|
||||||
<view class="add_arrow" @click="addreShow=true">{{addressForm.areaidpathtext}}</view>
|
<view class="add_arrow" @click="addreShow=true">{{addressForm.areaidpathtext}}</view>
|
||||||
<u-picker @cancel="addcancel" :show="addreShow" ref="uPicker" :columns="columns" keyName="UName" -->
|
<u-picker @cancel="addcancel" :show="addreShow" ref="uPicker" :columns="columns" keyName="UName"
|
||||||
@confirm="addconfirm" @change="changeHandler" ></u-picker>
|
@confirm="addconfirm" @change="changeHandler" ></u-picker>
|
||||||
</u-form-item>
|
</u-form-item>
|
||||||
<u-form-item label="详细地址 :" prop="useraddress">
|
<u-form-item label="详细地址 :" prop="useraddress">
|
||||||
<u-input type="string" v-model="addressForm.useraddress" placeholder="小区楼栋/乡村名称" clearable
|
<u-input type="string" v-model="addressForm.useraddress" placeholder="小区楼栋/乡村名称" clearable
|
||||||
border="surround" />
|
border="surround" />
|
||||||
@@ -50,6 +50,7 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
|
||||||
import musicPlay from '@/components/music.vue'
|
import musicPlay from '@/components/music.vue'
|
||||||
import $http from '@/config/requestConfig.js';
|
import $http from '@/config/requestConfig.js';
|
||||||
import addressList1 from "@/static/json/address.json"
|
import addressList1 from "@/static/json/address.json"
|
||||||
@@ -63,14 +64,14 @@
|
|||||||
// indexp:0,
|
// indexp:0,
|
||||||
// indexq:0,
|
// indexq:0,
|
||||||
// indexc:0,
|
// indexc:0,
|
||||||
playData: {},
|
playData:{},
|
||||||
addreShow: false, //是否显示
|
addreShow: false, //是否显示
|
||||||
columns: [], //省份数据显示,三级联动需要三维数组,展示初始数据
|
columns: [], //省份数据显示,三级联动需要三维数组,展示初始数据
|
||||||
columnData: [], //市数据
|
columnData: [], //市数据
|
||||||
columnDatas: [], //区地址
|
columnDatas: [], //区地址
|
||||||
switchTrue: true,
|
switchTrue: true,
|
||||||
switchFalse: false,
|
switchFalse: false,
|
||||||
addressChanged: false, // 地址修改标记
|
addressChanged:false, // 地址修改标记
|
||||||
navName: '', // 顶部导航栏标题
|
navName: '', // 顶部导航栏标题
|
||||||
provId: '', // 存储省id
|
provId: '', // 存储省id
|
||||||
cityId: '', // 存储市id
|
cityId: '', // 存储市id
|
||||||
@@ -90,51 +91,6 @@
|
|||||||
isShowDel: false,
|
isShowDel: false,
|
||||||
editIndex: 0,
|
editIndex: 0,
|
||||||
deleteShow: false,
|
deleteShow: false,
|
||||||
list: [{
|
|
||||||
value: 1,
|
|
||||||
label: '中国',
|
|
||||||
children: [{
|
|
||||||
value: 2,
|
|
||||||
label: '广东',
|
|
||||||
children: [{
|
|
||||||
value: 3,
|
|
||||||
label: '深圳'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: 4,
|
|
||||||
label: '广州'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: 5,
|
|
||||||
label: '广西',
|
|
||||||
children: [{
|
|
||||||
value: 6,
|
|
||||||
label: '南宁'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: 7,
|
|
||||||
label: '桂林'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: 8,
|
|
||||||
label: '美国',
|
|
||||||
children: [{
|
|
||||||
value: 9,
|
|
||||||
label: '纽约',
|
|
||||||
children: [{
|
|
||||||
value: 10,
|
|
||||||
label: '皇后街区'
|
|
||||||
}]
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
|
|
||||||
],
|
|
||||||
rules: {
|
rules: {
|
||||||
username: [{
|
username: [{
|
||||||
required: true,
|
required: true,
|
||||||
@@ -181,10 +137,10 @@
|
|||||||
this.getAddress()
|
this.getAddress()
|
||||||
}
|
}
|
||||||
this.initDataPicker() //初始化省份列表
|
this.initDataPicker() //初始化省份列表
|
||||||
|
|
||||||
},
|
},
|
||||||
onShow() {
|
onShow() {
|
||||||
|
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapState(['userInfo']),
|
...mapState(['userInfo']),
|
||||||
@@ -192,113 +148,113 @@
|
|||||||
onReady() {
|
onReady() {
|
||||||
this.$refs.addForm.setRules(this.rules)
|
this.$refs.addForm.setRules(this.rules)
|
||||||
},
|
},
|
||||||
components: {
|
components:{
|
||||||
musicPlay
|
musicPlay
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
// 三级联动
|
// 三级联动
|
||||||
initDataPicker() {
|
initDataPicker() {
|
||||||
// console.log(this.addressList,'addressList')
|
// console.log(this.addressList,'addressList')
|
||||||
// this.$http
|
// this.$http
|
||||||
// .post('api/province/getProvince')
|
// .post('api/province/getProvince')
|
||||||
// .then(res => {
|
// .then(res => {
|
||||||
// if (res.code == 0) {
|
// if (res.code == 0) {
|
||||||
// this.addressList = res.provinceEntity
|
// this.addressList = res.provinceEntity
|
||||||
//此处的province主要用作数据的初始化,即刚打开就需要进行展示的数据,这个跟第一条省份数据相关,我的第一条是北京市,所以需要columns中的三维数组,第一维度是省份数据数组,第二维度是市数据数组,第三维度是区数据数组
|
//此处的province主要用作数据的初始化,即刚打开就需要进行展示的数据,这个跟第一条省份数据相关,我的第一条是北京市,所以需要columns中的三维数组,第一维度是省份数据数组,第二维度是市数据数组,第三维度是区数据数组
|
||||||
let province = []; //初始数据需要展示的省份
|
let province = []; //初始数据需要展示的省份
|
||||||
let province1 = [{
|
let province1 = [{
|
||||||
"cityId": this.addressList[0].cityList[0].cityId,
|
"cityId": this.addressList[0].cityList[0].cityId,
|
||||||
"provId": this.addressList[0].cityList[0].provId,
|
"provId": this.addressList[0].cityList[0].provId,
|
||||||
"cityName": this.addressList[0].cityList[0].cityName,
|
"cityName": this.addressList[0].cityList[0].cityName,
|
||||||
"UName": this.addressList[0].cityList[0].cityName,
|
"UName": this.addressList[0].cityList[0].cityName,
|
||||||
"createDate": this.addressList[0].cityList[0].createDate,
|
"createDate": this.addressList[0].cityList[0].createDate,
|
||||||
"regionCode": this.addressList[0].cityList[0].regionCode,
|
"regionCode": this.addressList[0].cityList[0].regionCode,
|
||||||
"countyList": this.addressList[0].cityList[0].countyList
|
"countyList": this.addressList[0].cityList[0].countyList
|
||||||
}]; //因为第一个市北京市,所以就直接添加北京市下辖的直辖市了 也即初始数据需要展示的市,北京市只有一个市辖区
|
}]; //因为第一个市北京市,所以就直接添加北京市下辖的直辖市了 也即初始数据需要展示的市,北京市只有一个市辖区
|
||||||
let province2 = []; //初始数据需要展示的区域数据,也即是 北京市市辖区内的区
|
let province2 = []; //初始数据需要展示的区域数据,也即是 北京市市辖区内的区
|
||||||
|
|
||||||
|
|
||||||
for (let i = 0; i < this.addressList.length; i++) {
|
for (let i = 0; i < this.addressList.length; i++) {
|
||||||
this.addressList[i].UName = this.addressList[i].provName
|
this.addressList[i].UName = this.addressList[i].provName
|
||||||
if (this.addressList[i].cityList == null) {
|
if (this.addressList[i].cityList == null) {
|
||||||
this.addressList[i].cityList = [{
|
this.addressList[i].cityList = [{
|
||||||
"cityId": this.addressList[i].provId,
|
"cityId": this.addressList[i].provId,
|
||||||
"provId": this.addressList[i].provId,
|
"provId": this.addressList[i].provId,
|
||||||
"cityName": this.addressList[i].provName,
|
"cityName": this.addressList[i].provName,
|
||||||
"UName": this.addressList[i].provName,
|
"UName": this.addressList[i].provName,
|
||||||
"createDate": this.addressList[i].createDate,
|
"createDate": this.addressList[i].createDate,
|
||||||
"regionCode": this.addressList[i].regionCode,
|
"regionCode": this.addressList[i].regionCode,
|
||||||
"countyList": [{
|
"countyList": [{
|
||||||
"countyId": this.addressList[i].provId,
|
"countyId": this.addressList[i].provId,
|
||||||
"cityId": this.addressList[i].provId,
|
"cityId": this.addressList[i].provId,
|
||||||
"countyName": this.addressList[i].provName,
|
"countyName": this.addressList[i].provName,
|
||||||
"UName": this.addressList[i].provName,
|
"UName": this.addressList[i].provName,
|
||||||
"createDate": this.addressList[i].createDate,
|
"createDate": this.addressList[i].createDate,
|
||||||
"regionCode": this.addressList[i].regionCode
|
"regionCode": this.addressList[i].regionCode
|
||||||
}]
|
}]
|
||||||
}]
|
}]
|
||||||
} else {
|
} else {
|
||||||
for (let j = 0; j < this.addressList[i].cityList.length; j++) {
|
for (let j = 0; j < this.addressList[i].cityList.length; j++) {
|
||||||
this.addressList[i].cityList[j].UName = this.addressList[i].cityList[j]
|
this.addressList[i].cityList[j].UName = this.addressList[i].cityList[j]
|
||||||
.cityName
|
.cityName
|
||||||
for (let k = 0; k < this.addressList[i].cityList[j].countyList.length; k++) {
|
for (let k = 0; k < this.addressList[i].cityList[j].countyList.length; k++) {
|
||||||
this.addressList[i].cityList[j].countyList[k].UName = this.addressList[i]
|
this.addressList[i].cityList[j].countyList[k].UName = this.addressList[i]
|
||||||
.cityList[j].countyList[k].countyName
|
.cityList[j].countyList[k].countyName
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
province.push(this.addressList[i]);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
province.push(this.addressList[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
this.addressList[0].cityList[0].countyList.map(item => {
|
this.addressList[0].cityList[0].countyList.map(item => {
|
||||||
province2.push(item);
|
province2.push(item);
|
||||||
});
|
});
|
||||||
|
|
||||||
//省数据 因为要做数据初始化,所以是三维数组
|
//省数据 因为要做数据初始化,所以是三维数组
|
||||||
// 数据格式 [ [所有的省份数据:{},{}] , [第一个省份下的所有的市:{},{},{}] , [第一个市下面所有的区:{},{},{}] ]
|
// 数据格式 [ [所有的省份数据:{},{}] , [第一个省份下的所有的市:{},{},{}] , [第一个市下面所有的区:{},{},{}] ]
|
||||||
this.columns.push(province);
|
this.columns.push(province);
|
||||||
this.columns.push(province1);
|
this.columns.push(province1);
|
||||||
this.columns.push(province2);
|
this.columns.push(province2);
|
||||||
|
|
||||||
// console.log(6666666,this.columns)
|
// console.log(6666666,this.columns)
|
||||||
|
|
||||||
// 市数据数组,筛选address.json文件,将全国所有省下面的市数据放入数组
|
// 市数据数组,筛选address.json文件,将全国所有省下面的市数据放入数组
|
||||||
// 格式[ [第一个省下面所有市,{},{},{}] , [第二个省下面所有市{},{},{}] , [第三个省下面所有市{},{},{}] ] 注意,以上的第一第二对应着 columns[0] 的数据
|
// 格式[ [第一个省下面所有市,{},{},{}] , [第二个省下面所有市{},{},{}] , [第三个省下面所有市{},{},{}] ] 注意,以上的第一第二对应着 columns[0] 的数据
|
||||||
|
|
||||||
this.addressList.map(item => {
|
this.addressList.map(item => {
|
||||||
let city = [];
|
let city = [];
|
||||||
item.cityList.map(item1 => {
|
item.cityList.map(item1 => {
|
||||||
city.push(item1);
|
city.push(item1);
|
||||||
});
|
});
|
||||||
this.columnData.push(city);
|
this.columnData.push(city);
|
||||||
});
|
});
|
||||||
|
|
||||||
//区数据数组
|
//区数据数组
|
||||||
//数据格式: [ 所有省下面所有市的所有区 [ 第一个省下面所有市的区:[ [第一个省下面第一个市的所有区] , [第一个省下面第二个市的所有区] ,] , [ 第二个省下面所有市的区:[ [第二个省下面第一个市的所有区] , [第二个省下面第二个市的所有区] ,] ]
|
//数据格式: [ 所有省下面所有市的所有区 [ 第一个省下面所有市的区:[ [第一个省下面第一个市的所有区] , [第一个省下面第二个市的所有区] ,] , [ 第二个省下面所有市的区:[ [第二个省下面第一个市的所有区] , [第二个省下面第二个市的所有区] ,] ]
|
||||||
|
|
||||||
let area = [];
|
let area = [];
|
||||||
this.addressList.map((item, index) => {
|
this.addressList.map((item, index) => {
|
||||||
let area1 = []; //省下面所有市的初始化
|
let area1 = []; //省下面所有市的初始化
|
||||||
item.cityList.map(item1 => {
|
item.cityList.map(item1 => {
|
||||||
area = []; //市下面的区初始化
|
area = []; //市下面的区初始化
|
||||||
item1.countyList.map(item2 => {
|
item1.countyList.map(item2 => {
|
||||||
area.push(item2);
|
area.push(item2);
|
||||||
});
|
});
|
||||||
area1.push(area); // 每循环一个市,添加该市下面的所有区
|
area1.push(area); // 每循环一个市,添加该市下面的所有区
|
||||||
});
|
});
|
||||||
this.columnDatas.push(area1); // 每循环一个省,添加该省下面的所有市
|
this.columnDatas.push(area1); // 每循环一个省,添加该省下面的所有市
|
||||||
});
|
});
|
||||||
|
|
||||||
// };
|
// };
|
||||||
// }).catch(e => {
|
// }).catch(e => {
|
||||||
// console.log(e,'e')
|
// console.log(e,'e')
|
||||||
// })
|
// })
|
||||||
|
|
||||||
},
|
},
|
||||||
changeHandler(e) { //城市选择时触发
|
changeHandler(e) { //城市选择时触发
|
||||||
console.log(e, '变化了', this.columnData, this.columnDatas)
|
// console.log(e,'变化了',this.columnData, this.columnDatas)
|
||||||
this.addressChanged = true
|
this.addressChanged = true
|
||||||
const {
|
const {
|
||||||
columnIndex, //当前选择的列,省 / 市 / 区
|
columnIndex, //当前选择的列,省 / 市 / 区
|
||||||
value, // 当前选择的数组内容
|
value, // 当前选择的数组内容
|
||||||
@@ -310,7 +266,7 @@
|
|||||||
// 当第一列值发生变化时,变化第二列和第三列的值(省份变更,市和区跟着变更)
|
// 当第一列值发生变化时,变化第二列和第三列的值(省份变更,市和区跟着变更)
|
||||||
if (columnIndex === 0) { // 判断当前变更的是省还是市还是区
|
if (columnIndex === 0) { // 判断当前变更的是省还是市还是区
|
||||||
// picker为选择器this实例,变化第二列对应的选项
|
// picker为选择器this实例,变化第二列对应的选项
|
||||||
|
|
||||||
picker.setColumnValues(1, this.columnData[
|
picker.setColumnValues(1, this.columnData[
|
||||||
index]); //设置市为该省下面的所有市,index是当前省在省份数组的下标,对应市数组中的下表就是 该省下面的所有市 的数据
|
index]); //设置市为该省下面的所有市,index是当前省在省份数组的下标,对应市数组中的下表就是 该省下面的所有市 的数据
|
||||||
picker.setColumnValues(2, this.columnDatas[index][0]); // 设置区域为该省下面第一个市下面的所有区域
|
picker.setColumnValues(2, this.columnDatas[index][0]); // 设置区域为该省下面第一个市下面的所有区域
|
||||||
@@ -322,7 +278,7 @@
|
|||||||
},
|
},
|
||||||
|
|
||||||
addconfirm(e) { //点击确定按钮
|
addconfirm(e) { //点击确定按钮
|
||||||
console.log(e, '选中的值')
|
// console.log(e,'选中的值')
|
||||||
this.addressChanged = true
|
this.addressChanged = true
|
||||||
this.addreShow = false;
|
this.addreShow = false;
|
||||||
this.addressForm.areaidpathtext = e.value[0].UName + '-' + e.value[1].UName + '-' + e.value[2].UName
|
this.addressForm.areaidpathtext = e.value[0].UName + '-' + e.value[1].UName + '-' + e.value[2].UName
|
||||||
@@ -330,7 +286,7 @@
|
|||||||
this.cityId = e.value[1].cityId
|
this.cityId = e.value[1].cityId
|
||||||
this.countyId = e.value[2].regionCode
|
this.countyId = e.value[2].regionCode
|
||||||
},
|
},
|
||||||
|
|
||||||
addcancel() { //点击取消按钮
|
addcancel() { //点击取消按钮
|
||||||
this.addreShow = false;
|
this.addreShow = false;
|
||||||
},
|
},
|
||||||
@@ -358,7 +314,7 @@
|
|||||||
// this.addressForm.consigneePhone = this.addressForm.userphone
|
// this.addressForm.consigneePhone = this.addressForm.userphone
|
||||||
// this.addressForm.consigneeName = this.addressForm.username
|
// this.addressForm.consigneeName = this.addressForm.username
|
||||||
// this.addressForm.regionCode = ''
|
// this.addressForm.regionCode = ''
|
||||||
|
|
||||||
// // this.addressForm.userid = this.userInfo.id
|
// // this.addressForm.userid = this.userInfo.id
|
||||||
// if(this.addressChanged){ // 如果修改过地址区域,就重新赋值,否则保持不变
|
// if(this.addressChanged){ // 如果修改过地址区域,就重新赋值,否则保持不变
|
||||||
// this.addressForm.areaidpath = `${this.provId}_${this.cityId}_${this.countyId}`
|
// this.addressForm.areaidpath = `${this.provId}_${this.cityId}_${this.countyId}`
|
||||||
@@ -369,15 +325,15 @@
|
|||||||
|
|
||||||
// let data = this.addressForm
|
// let data = this.addressForm
|
||||||
let data = {
|
let data = {
|
||||||
'id': this.addressForm.addressid,
|
'id':this.addressForm.addressid,
|
||||||
'detailAddress': this.addressForm.useraddress,
|
'detailAddress' : this.addressForm.useraddress,
|
||||||
'regionCode': this.countyId,
|
'regionCode':this.countyId,
|
||||||
'userId': this.userInfo.id,
|
'userId':this.userInfo.id,
|
||||||
'consigneePhone': this.addressForm.userphone,
|
'consigneePhone':this.addressForm.userphone,
|
||||||
'consigneeName': this.addressForm.username,
|
'consigneeName': this.addressForm.username,
|
||||||
'isDefault': this.addressForm.isDafault ? 1 : 0
|
'isDefault':this.addressForm.isDafault ? 1 : 0
|
||||||
}
|
}
|
||||||
console.log(data, '保存参数')
|
console.log(data,'保存参数')
|
||||||
$http.request({
|
$http.request({
|
||||||
url: link_add,
|
url: link_add,
|
||||||
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
@@ -419,17 +375,16 @@
|
|||||||
.then(res => {
|
.then(res => {
|
||||||
if (res.code == 0) {
|
if (res.code == 0) {
|
||||||
this.addressForm = {
|
this.addressForm = {
|
||||||
'useraddress': res.list[this.editIndex].detailAddress,
|
'useraddress':res.list[this.editIndex].detailAddress,
|
||||||
'userphone': res.list[this.editIndex].consigneePhone,
|
'userphone':res.list[this.editIndex].consigneePhone,
|
||||||
'username': res.list[this.editIndex].consigneeName,
|
'username':res.list[this.editIndex].consigneeName,
|
||||||
'isdefault': res.list[this.editIndex].isDefault,
|
'isdefault':res.list[this.editIndex].isDefault,
|
||||||
'isDafault': res.list[this.editIndex].isDefault == 1 ? true : false,
|
'isDafault':res.list[this.editIndex].isDefault == 1 ? true : false,
|
||||||
'areaidpathtext': res.list[this.editIndex].province + '-' + res.list[this
|
'areaidpathtext':res.list[this.editIndex].province +'-'+ res.list[this.editIndex].city +'-'+ res.list[this.editIndex].county
|
||||||
.editIndex].city + '-' + res.list[this.editIndex].county,
|
,'addressid':res.list[this.editIndex].id
|
||||||
'addressid': res.list[this.editIndex].id
|
|
||||||
}
|
}
|
||||||
this.countyId = res.list[this.editIndex].regionCode
|
this.countyId = res.list[this.editIndex].regionCode
|
||||||
// this.addressForm = res.list[this.editIndex]
|
// this.addressForm = res.list[this.editIndex]
|
||||||
if (this.addressForm.isdefault == 1) {
|
if (this.addressForm.isdefault == 1) {
|
||||||
this.addressForm.isDafault = true
|
this.addressForm.isDafault = true
|
||||||
}
|
}
|
||||||
@@ -444,15 +399,15 @@
|
|||||||
this.deleteShow = false
|
this.deleteShow = false
|
||||||
this.$http
|
this.$http
|
||||||
.get(`book/userAddress/delete?id=${this.addressForm.addressid}`)
|
.get(`book/userAddress/delete?id=${this.addressForm.addressid}`)
|
||||||
.then(res => {
|
.then(res => {
|
||||||
if (res.code == 0) {
|
if (res.code == 0) {
|
||||||
uni.showToast({
|
uni.showToast({
|
||||||
title: '地址删除成功',
|
title: '地址删除成功',
|
||||||
duration: 1000,
|
duration: 1000,
|
||||||
});
|
});
|
||||||
uni.navigateBack()
|
uni.navigateBack()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
},
|
},
|
||||||
@@ -461,19 +416,10 @@
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.flexbox {
|
.flexbox{display: flex;}
|
||||||
display: flex;
|
.selectAdd{ justify-content: space-between;
|
||||||
|
.addItem{ display: block;width: 30%}
|
||||||
}
|
}
|
||||||
|
|
||||||
.selectAdd {
|
|
||||||
justify-content: space-between;
|
|
||||||
|
|
||||||
.addItem {
|
|
||||||
display: block;
|
|
||||||
width: 30%
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.add_arrow {
|
.add_arrow {
|
||||||
height: 28px;
|
height: 28px;
|
||||||
line-height: 28px;
|
line-height: 28px;
|
||||||
@@ -549,4 +495,4 @@
|
|||||||
background-image: linear-gradient(90deg, #bf0c0c 0%, #95110c 100%)
|
background-image: linear-gradient(90deg, #bf0c0c 0%, #95110c 100%)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -15,26 +15,31 @@
|
|||||||
<!-- <view class="title" :class="{ active: type == 2000 }" @click="type = 2000">验证码登录/注册</view>
|
<!-- <view class="title" :class="{ active: type == 2000 }" @click="type = 2000">验证码登录/注册</view>
|
||||||
<view class="title" :class="{ active: type == 1000 }" @click="type = 1000">密码登录</view> -->
|
<view class="title" :class="{ active: type == 1000 }" @click="type = 1000">密码登录</view> -->
|
||||||
</view>
|
</view>
|
||||||
<view class="input_tit">手机号</view>
|
<view class="flexbox" style=" margin-top: 20rpx;">
|
||||||
|
<view class="input_tit" style="margin-top: 0; margin-right: 20rpx;">手机号</view>
|
||||||
|
<view class="quhao">
|
||||||
|
<uni-data-select class="myselect" placeholder="选择区号" v-model="quCode" :localdata="quCodeList" style="height: 30rpx !important;"
|
||||||
|
@change="quChange"></uni-data-select>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
<!-- 带区号 -->
|
<!-- 带区号 -->
|
||||||
<!-- <view class="flexbox " style="margin:36rpx 0; justify-content: space-between;">
|
<view class="flexbox " style="margin:36rpx 0; justify-content: space-between;">
|
||||||
<view class="quhao">
|
<view class="triangle borderBottom phoneNumberInput" style="width: 150rpx;">
|
||||||
<uni-data-select
|
<input type="number" v-model="quCode" placeholder="区号" placeholder-class="grey" />
|
||||||
placeholder="区号" model="quCode"
|
|
||||||
:localdata="quCodeList"
|
|
||||||
@change="quChange"
|
|
||||||
></uni-data-select>
|
|
||||||
</view>
|
</view>
|
||||||
<view class="triangle borderBottom phoneNumberInput" :clasfs="[type == 1000 ? 'left_triangle': 'right_triangle']">
|
<view class="triangle borderBottom phoneNumberInput"
|
||||||
<input type="number" v-model="phone" @input="onInput" placeholder="请输入您的手机号" placeholder-class="grey" />
|
:clasfs="[type == 1000 ? 'left_triangle': 'right_triangle']">
|
||||||
|
<input type="number" v-model="phone" @input="onInput" placeholder="请输入您的手机号"
|
||||||
|
placeholder-class="grey" />
|
||||||
</view>
|
</view>
|
||||||
</view> -->
|
</view>
|
||||||
|
|
||||||
<!-- 不带区号 -->
|
<!-- 不带区号 -->
|
||||||
<view class="triangle borderBottom phoneNumberInput input_box"
|
<!-- <view class="triangle borderBottom phoneNumberInput input_box"
|
||||||
:clasfs="[type == 1000 ? 'left_triangle': 'right_triangle']">
|
:clasfs="[type == 1000 ? 'left_triangle': 'right_triangle']">
|
||||||
<input type="number" v-model="phone" @input="onInput" placeholder="请输入您的手机号" placeholder-class="grey" />
|
<input type="number" v-model="phone" @input="onInput" placeholder="请输入您的手机号" placeholder-class="grey" />
|
||||||
</view>
|
</view> -->
|
||||||
|
|
||||||
<view class="input_tit" v-if="type == 1000">密码</view>
|
<view class="input_tit" v-if="type == 1000">密码</view>
|
||||||
<view class="input_box" v-if="type == 1000">
|
<view class="input_box" v-if="type == 1000">
|
||||||
@@ -190,16 +195,8 @@
|
|||||||
Content: ''
|
Content: ''
|
||||||
},
|
},
|
||||||
quShow: false,
|
quShow: false,
|
||||||
quCodeList: [{
|
quCodeList: [], // 国家区域码
|
||||||
value: '1',
|
quCode: 86,
|
||||||
text: '江'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: '2',
|
|
||||||
text: '湖'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
quCode: null,
|
|
||||||
|
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
@@ -216,11 +213,43 @@
|
|||||||
// #endif
|
// #endif
|
||||||
},
|
},
|
||||||
//页面显示
|
//页面显示
|
||||||
onShow() {},
|
onShow() {
|
||||||
|
this.getCountyCode()
|
||||||
|
},
|
||||||
//方法
|
//方法
|
||||||
methods: {
|
methods: {
|
||||||
...mapMutations(['setUserInfo']),
|
...mapMutations(['setUserInfo']),
|
||||||
...mapMutations(['setHealthMes']),
|
...mapMutations(['setHealthMes']),
|
||||||
|
// 获取国家区域编码
|
||||||
|
getCountyCode() {
|
||||||
|
$http.request({
|
||||||
|
url: "book/baseArea/getAllBaseArea",
|
||||||
|
method: "POST", // POST、GET、PUT、DELETE,具体说明查看官方文档
|
||||||
|
data: {},
|
||||||
|
header: { //默认 无 说明:请求头
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
},
|
||||||
|
})
|
||||||
|
.then(res => {
|
||||||
|
// console.log(res,'区域码')
|
||||||
|
if (res.code == 0 && res.baseAreas.length > 0) {
|
||||||
|
// this.quCodeList = res.baseAreas
|
||||||
|
this.quCodeList = res.baseAreas.map(item => {
|
||||||
|
let obj = {
|
||||||
|
'text': item.title,
|
||||||
|
'value': item.code,
|
||||||
|
}
|
||||||
|
return obj
|
||||||
|
})
|
||||||
|
// console.log('改变格式后',this.quCodeList)
|
||||||
|
} else {
|
||||||
|
this.quCodeList = []
|
||||||
|
// this.totalPage = 0
|
||||||
|
}
|
||||||
|
}).catch(e => {
|
||||||
|
console.log(e, 'e')
|
||||||
|
});
|
||||||
|
},
|
||||||
quChange(e) {
|
quChange(e) {
|
||||||
console.log(e, 'e')
|
console.log(e, 'e')
|
||||||
},
|
},
|
||||||
@@ -294,12 +323,15 @@
|
|||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!this.$base.phoneRegular.test(this.phone)) {
|
if (this.quCode == null || this.quCode == 86) { // 如果没选择国家code,默认是中国大陆
|
||||||
uni.showToast({
|
if (!this.$base.phoneRegular.test(this.phone)) {
|
||||||
title: '手机格式不正确',
|
uni.showToast({
|
||||||
icon: 'none'
|
title: '手机格式不正确',
|
||||||
});
|
icon: 'none'
|
||||||
return;
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
console.log(this.quCode, '选择的区段')
|
||||||
}
|
}
|
||||||
if (!this.agree) {
|
if (!this.agree) {
|
||||||
uni.showToast({
|
uni.showToast({
|
||||||
@@ -312,6 +344,7 @@
|
|||||||
this.$http
|
this.$http
|
||||||
.get('book/user/sms/sendcode', {
|
.get('book/user/sms/sendcode', {
|
||||||
phone: this.phone,
|
phone: this.phone,
|
||||||
|
areaCode: this.quCode,
|
||||||
type: 2000
|
type: 2000
|
||||||
})
|
})
|
||||||
.then(res => {
|
.then(res => {
|
||||||
@@ -339,12 +372,14 @@
|
|||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!this.$base.phoneRegular.test(this.phone)) {
|
if (this.quCode == null || this.quCode == 86) {
|
||||||
uni.showToast({
|
if (!this.$base.phoneRegular.test(this.phone)) {
|
||||||
title: '手机格式不正确',
|
uni.showToast({
|
||||||
icon: 'none'
|
title: '手机格式不正确',
|
||||||
});
|
icon: 'none'
|
||||||
return;
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
let httpData = {};
|
let httpData = {};
|
||||||
if (this.type == 2000) {
|
if (this.type == 2000) {
|
||||||
@@ -635,10 +670,10 @@
|
|||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@import '@/style/mixin.scss';
|
@import '@/style/mixin.scss';
|
||||||
|
.myselect{height: 50rpx !important;}
|
||||||
.phoneNumberInput {
|
.phoneNumberInput {
|
||||||
width: calc(100% - 130rpx);
|
width: calc(100% - 160rpx);
|
||||||
width: 100%;
|
// width: 100%;
|
||||||
height: 67rpx;
|
height: 67rpx;
|
||||||
|
|
||||||
input {
|
input {
|
||||||
@@ -656,7 +691,8 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.quhao {
|
.quhao {
|
||||||
width: 120rpx;
|
height: 50rpx;
|
||||||
|
width: 180rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.highlight {
|
.highlight {
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 3.0 KiB After Width: | Height: | Size: 4.8 KiB |
BIN
static/icon/hehanandLogo.png
Normal file
|
After Width: | Height: | Size: 15 KiB |
BIN
static/icon/home1-1.png
Normal file
|
After Width: | Height: | Size: 5.9 KiB |
|
Before Width: | Height: | Size: 7.5 KiB After Width: | Height: | Size: 6.9 KiB |
BIN
static/icon/home2-1.png
Normal file
|
After Width: | Height: | Size: 5.0 KiB |
|
Before Width: | Height: | Size: 6.6 KiB After Width: | Height: | Size: 6.1 KiB |
BIN
static/icon/home3-1.png
Normal file
|
After Width: | Height: | Size: 6.0 KiB |
|
Before Width: | Height: | Size: 7.6 KiB After Width: | Height: | Size: 6.9 KiB |
BIN
static/icon/home4-1.png
Normal file
|
After Width: | Height: | Size: 4.8 KiB |
|
Before Width: | Height: | Size: 6.4 KiB After Width: | Height: | Size: 5.9 KiB |