Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
mayi-mp-shop
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
程默
mayi-mp-shop
Commits
286740db
Commit
286740db
authored
Feb 03, 2021
by
程默
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
显示条件
parent
370a1389
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
107 additions
and
613 deletions
+107
-613
custom-tab-bar/index.wxml
+3
-3
custom-tab-bar/index.wxss
+4
-0
ext.json
+3
-1
src/App.vue
+33
-2
src/api/shop.js
+4
-1
src/pages/home/index.vue
+16
-16
src/pages/index/index.vue
+2
-2
src/pages/rediect/index.vue
+0
-571
src/pages/rediect/main.js
+0
-12
src/pages/rediect/main.json
+0
-4
src/utils/mayi.js
+42
-1
No files found.
custom-tab-bar/index.wxml
View file @
286740db
<!--miniprogram/custom-tab-bar/index.wxml-->
<cover-view
class="tab-bar" wx:if="{{show
}}">
<
cover-view class="antt ant-daipinglun"></cover-view
>
<
cover-view class="iconfont icon-fenzhi">3</cover-view
>
<cover-view
class="tab-bar {{show?'':'hide'
}}">
<
!-- <cover-view class="antt ant-daipinglun"></cover-view> --
>
<
!-- <cover-view class="iconfont icon-fenzhi">3</cover-view> --
>
<cover-view class="tab-bar-border"></cover-view>
<cover-view
...
...
custom-tab-bar/index.wxss
View file @
286740db
...
...
@@ -1417,3 +1417,7 @@
width: 100%;
height: 100%;
}
.hide{
display: none;
}
ext.json
View file @
286740db
...
...
@@ -3,6 +3,7 @@
"extEnable"
:
true
,
"extAppid"
:
"wxae95a07ffdf11548"
,
"ext"
:{
"mixid"
:
"antgood"
"mixid"
:
"antgood"
,
"shopid"
:
67
}
}
\ No newline at end of file
src/App.vue
View file @
286740db
<
script
>
import
shop
from
"@/api/shop"
;
import
{
themeColor
}
from
"@/utils/mayi"
import
{
themeColor
,
checkShowConditionIds
}
from
"@/utils/mayi"
export
default
{
created
()
{
// NODE_ENV
...
...
@@ -43,6 +44,31 @@ export default {
this
.
getThemePage
(
extConfig
);
},
methods
:
{
async
setVisible
(
pageList
){
// 首页显示条件
this
.
pageInfo
=
pageList
.
filter
((
item
)
=>
item
.
pageCode
==
1
)[
0
];
this
.
pageData
=
JSON
.
parse
(
this
.
pageInfo
.
pageData
);
// 显示条件列表
let
showConditionIds
=
checkShowConditionIds
(
this
.
pageData
)
let
ll
=
await
this
.
checkCondition
(
showConditionIds
)
console
.
log
(
showConditionIds
,
'--------------5454'
,
ll
)
},
checkCondition
({
allCondition
})
{
return
new
Promise
((
resolve
,
reject
)
=>
{
// 获取
let
params
=
{
allCondition
,
region
:
''
}
shop
.
checkShowCondition
(
params
).
then
(
res
=>
{
if
(
res
.
code
==
200
)
{
console
.
log
(
params
,
'check显示条件'
,
res
.
data
)
// commit('setShowConditionIds', res.data)
// commit('updateCondition')
resolve
(
res
.
data
)
}
}).
catch
(
err
=>
{
console
.
log
(
'check显示条件失败'
,
err
)
})
})
},
//商城配置
getShopInfo
({
mixid
})
{
shop
.
getShopInfo
({
shopMixId
:
mixid
}).
then
((
res
)
=>
{
...
...
@@ -91,21 +117,26 @@ export default {
console
.
log
(
"90"
,
data
);
this
.
mpApp
.
globalData
.
pageList
=
data
;
this
.
setVisible
(
data
)
// app中异步数据回调 底部栏数据
if
(
this
.
mpApp
.
pageCallBack
)
{
this
.
mpApp
.
pageCallBack
(
data
);
}
}
}
})
.
catch
((
err
)
=>
{});
},
// ---
},
onError
(
data
)
{
console
.
log
(
data
,
"js异常捕获"
);
this
.
$mpAnalytics
.
recordError
({
data
,
keyword
:
data
,
'keyword'
:
data
,
extendsInfo
:
{
mixid
:
this
.
$store
.
state
.
mixid
||
null
,
},
...
...
src/api/shop.js
View file @
286740db
...
...
@@ -13,5 +13,8 @@ export default {
// 页面数据
themePagesInfo
(
params
)
{
return
requestPOST
(
`
${
process
.
env
.
OLSHOP_URL
}
/cms/get_shop_install_pages`
,
{
params
})
}
},
checkShowCondition
(
params
)
{
return
requestPOST
(
`
${
process
.
env
.
OLSHOP_URL
}
/cms/check_show_condition`
,
{
params
})
},
};
src/pages/home/index.vue
View file @
286740db
...
...
@@ -6,52 +6,52 @@
<div
style=
"position:relative;"
>
<ThemeDataPlant></ThemeDataPlant>
<div
v-for=
"(item,index) in pageData"
:key=
"index"
>
<div
v-if=
"item.componentCode=='banner'"
>
<div
v-if=
"item.componentCode=='banner'
&& item.componentInfo.visible == 1
"
>
<banner
:datas=
"item"
></banner>
</div>
<div
v-else-if=
"item.componentCode=='goods-list'"
style=
"height:100%;"
>
<div
v-else-if=
"item.componentCode=='goods-list'
&& item.componentInfo.visible == 1
"
style=
"height:100%;"
>
<goods-list
class=
"goodsListItem"
:datas=
"item"
></goods-list>
</div>
<div
v-else-if=
"item.componentCode == 'area-navigation'"
>
<div
v-else-if=
"item.componentCode == 'area-navigation'
&& item.componentInfo.visible == 1
"
>
<area-navigation
:datas=
"item"
></area-navigation>
</div>
<div
v-else-if=
"item.componentCode == 'cube-nav'"
>
<div
v-else-if=
"item.componentCode == 'cube-nav'
&& item.componentInfo.visible == 1
"
>
<cube-nav
:datas=
"item"
></cube-nav>
</div>
<div
v-else-if=
"item.componentCode == 'time-limited-discount'"
>
<div
v-else-if=
"item.componentCode == 'time-limited-discount'
&& item.componentInfo.visible == 1
"
>
<time-limited-discount
:datas=
"item"
></time-limited-discount>
</div>
<div
v-if=
"item.componentCode == 'links'"
>
<div
v-if=
"item.componentCode == 'links'
&& item.componentInfo.visible == 1
"
>
<links
:datas=
"item"
></links>
</div>
<div
v-if=
"item.componentCode == 'interval'"
>
<div
v-if=
"item.componentCode == 'interval'
&& item.componentInfo.visible == 1
"
>
<interval
:datas=
"item"
></interval>
</div>
<div
v-if=
"item.componentCode == 'partition'"
>
<div
v-if=
"item.componentCode == 'partition'
&& item.componentInfo.visible == 1
"
>
<partition
:datas=
"item"
></partition>
</div>
<div
v-if=
"item.componentCode == 'shop-popup'"
>
<div
v-if=
"item.componentCode == 'shop-popup'
&& item.componentInfo.visible == 1
"
>
<shop-popup
:datas=
"item"
></shop-popup>
</div>
<div
v-if=
"item.componentCode == 'float-button'"
>
<div
v-if=
"item.componentCode == 'float-button'
&& item.componentInfo.visible == 1
"
>
<float-button
:datas=
"item"
></float-button>
</div>
<div
v-if=
"item.componentCode == 'text-text'"
>
<div
v-if=
"item.componentCode == 'text-text'
&& item.componentInfo.visible == 1
"
>
<text-text
:datas=
"item"
></text-text>
</div>
<div
v-if=
"item.componentCode == 'img-text'"
>
<div
v-if=
"item.componentCode == 'img-text'
&& item.componentInfo.visible == 1
"
>
<img-text
:datas=
"item"
></img-text>
</div>
<div
v-if=
"item.componentCode == 'video-player'"
>
<div
v-if=
"item.componentCode == 'video-player'
&& item.componentInfo.visible == 1
"
>
<videoPlayer
:datas=
"item"
></videoPlayer>
</div>
<div
v-if=
"item.componentCode == 'goods-search'"
>
<div
v-if=
"item.componentCode == 'goods-search'
&& item.componentInfo.visible == 1
"
>
<goods-search
:datas=
"item"
></goods-search>
</div>
<div
v-if=
"item.componentCode == 'notice'"
>
<div
v-if=
"item.componentCode == 'notice'
&& item.componentInfo.visible == 1
"
>
<notice
:datas=
"item"
></notice>
</div>
<div
v-if=
"item.componentCode == 'pop-up'"
>
<div
v-if=
"item.componentCode == 'pop-up'
&& item.componentInfo.visible == 1
"
>
<pop-up
:datas=
"item"
></pop-up>
</div>
...
...
src/pages/index/index.vue
View file @
286740db
<
template
>
<div>
{{
withoutScene
}}
<div>
{{
withoutScene
?
"初始化完成"
:
"初始化中"
}}
</div>
<web-view
v-if=
"withoutScene"
:src=
"pageUrl"
@
message=
"getMessage"
@
error=
"handleError"
@
load=
"handleLoad"
></web-view>
</div>
</
template
>
...
...
@@ -76,6 +76,7 @@ export default {
}
},
onLoad
(
options
)
{
this
.
withoutScene
=
true
;
this
.
options
=
options
;
Object
.
assign
(
this
.
$data
,
this
.
$options
.
data
());
...
...
@@ -84,7 +85,6 @@ export default {
success
:
res
=>
{
this
.
code
=
res
.
code
;
login
.
miniLogin
({
code
:
this
.
code
}).
then
(
res1
=>
{
this
.
withoutScene
=
true
;
console
.
log
(
res1
,
555555
)
if
(
res1
.
data
.
code
==
200
)
{
wx
.
setStorage
({
...
...
src/pages/rediect/index.vue
deleted
100644 → 0
View file @
370a1389
<
template
>
<div>
<web-view
v-if=
"withoutScene"
:src=
"pageUrl"
@
message=
"getMessage"
@
error=
"handleError"
@
load=
"handleLoad"
></web-view>
</div>
</
template
>
<
script
>
import
spokesman
from
"@/api/spokesman.js"
;
import
shop
from
"@/api/shop.js"
;
import
indexApi
from
"@/api/index.js"
;
import
{
serialize
,
getQueryVariable
,
DFSImg
}
from
"@/utils/index"
;
import
login
from
"@/api/login"
;
export
default
{
data
()
{
return
{
code
:
''
,
shopId
:
this
.
$store
.
state
.
mixid
,
options
:
{},
session_key
:
""
,
baseUrl
:
process
.
env
.
BASE_URL
,
link
:
this
.
baseUrl
,
page
:
"/"
,
params
:
"?mixid="
+
this
.
shopId
,
userInfo
:
{
nickName
:
"mpvue"
,
avatarUrl
:
"http://mpvue.com/assets/logo.png"
},
shareUrl
:
""
,
//分享
shopConfig
:
null
,
spokesmanGroupId
:
""
,
// 代言人的集团id
spokesmanShopId
:
""
,
// 代言人的门店id
spokesmanRelId
:
""
,
//代言人的id
userId
:
''
,
hasInvitationStatus
:
0
,
// 邀请资格:0-不能够邀请下级,1-能够邀请下级
newHref
:
""
,
shareShopName
:
""
,
shareLogoUrl
:
""
,
shareOrderSn
:
""
,
shareTid
:
""
,
newWindowHref
:
''
,
withoutScene
:
true
,
sharePageList
:
[
"goods/"
,
"receivingGift"
,
"article/"
,
"/personalCenter/spokesmanCenter"
]
//分享白名单
};
},
computed
:
{
pageUrl
()
{
return
this
.
link
+
this
.
page
+
this
.
params
;
}
},
watch
:
{
pageUrl
()
{
//埋点未登录时进入文章
// this.params+='&articleId=111'
console
.
log
(
wx
.
getStorageSync
(
"sessionid"
),
3333333
,
this
.
pageUrl
)
if
(
!
wx
.
getStorageSync
(
"sessionid"
)
&&
this
.
pageUrl
.
indexOf
(
'articleId'
)
!=-
1
)
{
// wx.setStorageSync('articleId',true)
var
vars
=
this
.
pageUrl
.
split
(
"&"
);
console
.
log
(
vars
,
2222
)
for
(
var
i
=
0
;
i
<
vars
.
length
;
i
++
)
{
var
pair
=
vars
[
i
].
split
(
"="
);
console
.
log
(
pair
,
1111
)
if
(
pair
[
0
]
==
'articleId'
)
{
wx
.
setStorageSync
(
this
.
$store
.
state
.
mixid
+
'articleId'
,
pair
[
1
])
}
}
}
}
},
onLoad
(
options
)
{
this
.
options
=
options
;
Object
.
assign
(
this
.
$data
,
this
.
$options
.
data
());
console
.
log
(
wx
.
getStorageSync
(
"sessionid"
),
options
,
"index------"
,
this
.
shopId
,
"-----"
,
wx
.
getStorageSync
(
"openid"
),
this
.
shopId
);
//获取openId
wx
.
login
({
success
:
res
=>
{
this
.
code
=
res
.
code
;
login
.
miniLogin
({
code
:
this
.
code
}).
then
(
res1
=>
{
console
.
log
(
res1
,
555555
)
if
(
res1
.
data
.
code
==
200
)
{
wx
.
setStorage
({
key
:
"openid"
,
data
:
res1
.
data
.
data
.
openid
});
}
this
.
params
+=
'&open_id='
+
wx
.
getStorageSync
(
"openid"
);
console
.
log
(
this
.
code
,
77777
,
this
.
params
)
})
},
})
//检测登录态
this
.
checkLogin
();
console
.
log
(
this
.
params
,
6666666
)
this
.
options
=
options
;
console
.
log
(
'-------1'
,
options
.
scene
)
console
.
log
(
this
.
options
)
console
.
log
(
'-------'
)
if
(
options
.
share
)
{
//来自分享
this
.
link
=
decodeURIComponent
(
options
.
share
);
this
.
spokesmanGroupId
=
getQueryVariable
(
this
.
link
,
"spokesmanGroupId"
)
||
""
;
this
.
spokesmanShopId
=
getQueryVariable
(
this
.
link
,
"spokesmanShopId"
)
||
""
;
this
.
spokesmanRelId
=
getQueryVariable
(
this
.
link
,
"spokesmanRelId"
)
||
""
;
this
.
userId
=
getQueryVariable
(
this
.
link
,
"userId"
)
||
""
;
if
(
this
.
spokesmanGroupId
!=
""
)
{
//上级分销员信息
this
.
$store
.
commit
(
"setSpokesman"
,
{
spokesmanGroupId
:
this
.
spokesmanGroupId
,
spokesmanShopId
:
this
.
spokesmanShopId
,
spokesmanRelId
:
this
.
spokesmanRelId
});
}
this
.
page
=
""
;
this
.
params
=
""
;
}
else
if
(
options
.
from
&&
options
.
from
==
"h5login"
)
{
//来自h5登录
let
params
=
JSON
.
parse
(
options
.
params
);
wx
.
setStorage
({
key
:
"sessionid"
,
data
:
params
.
sessionid
});
}
else
if
(
options
.
from
&&
options
.
from
==
"livedToIndex"
)
{
//来自直播详情
this
.
page
=
decodeURIComponent
(
options
.
backpath
);
this
.
params
+=
"&"
+
serialize
(
options
.
params
);
}
else
if
(
options
.
from
&&
options
.
from
==
"livedBackShop"
)
{
//直播页back到商城
this
.
page
=
decodeURIComponent
(
options
.
backpath
);
this
.
params
+=
"&"
+
serialize
(
options
.
params
);
}
else
if
(
options
.
from
&&
options
.
from
==
"liveList"
){
//从主播端跳到商品
this
.
page
=
decodeURIComponent
(
options
.
backpath
);
this
.
params
+=
"&"
+
serialize
(
options
.
params
);
}
else
if
(
options
.
from
&&
options
.
from
==
"livedToGoodsInfo"
)
{
//从直播详情商品列表到商城商品详情
this
.
page
=
decodeURIComponent
(
options
.
backpath
);
this
.
params
+=
"&"
+
serialize
(
options
.
params
);
}
else
if
(
options
.
from
&&
options
.
from
==
"livedToOrderConfirm"
)
{
//从直播详情商品列表到商城确认订单
this
.
page
=
decodeURIComponent
(
options
.
backpath
);
this
.
params
+=
"&"
+
serialize
(
options
.
params
);
}
else
if
(
options
.
from
&&
options
.
from
==
"login"
)
{
//来自小程序登录页面
this
.
page
=
decodeURIComponent
(
options
.
backpath
);
this
.
params
+=
"&"
+
decodeURIComponent
(
options
.
params
);
}
else
if
(
options
.
from
&&
options
.
from
==
"logout"
)
{
//来自用户登出
wx
.
removeStorage
({
key
:
"sessionid"
});
wx
.
removeStorage
({
key
:
"openid"
});
}
else
if
(
options
.
from
&&
options
.
from
==
"address"
)
{
// 来自小程序地址页面
this
.
link
=
decodeURIComponent
(
options
.
backpath
);
console
.
log
(
"adress"
,
options
.
backpath
,
this
.
link
);
this
.
page
=
""
;
this
.
params
=
""
;
}
else
if
(
options
.
from
==
"wxPay"
)
{
//来自支付页面
this
.
page
=
options
.
backpath
;
this
.
params
+=
"&"
+
serialize
(
options
.
params
);
}
else
if
(
options
.
scene
)
{
console
.
log
(
options
)
console
.
log
(
222222
)
if
(
options
.
scene
.
indexOf
(
'_'
)
==
-
1
){
this
.
withoutScene
=
false
;
//新二维码扫码进入
wx
.
nextTick
(()
=>
{
indexApi
.
getShareSceneRecord
(
options
.
scene
).
then
(
res
=>
{
this
.
withoutScene
=
true
;
if
(
res
.
data
.
code
==
'200'
){
this
.
page
=
res
.
data
.
data
.
pageUri
;
let
paramsObj
=
JSON
.
parse
(
res
.
data
.
data
.
scene
);
wx
.
setStorageSync
(
'attractingCustomerChannelId'
,
paramsObj
.
attractingCustomerChannelId
)
console
.
log
(
res
.
data
.
data
)
console
.
log
(
wx
.
getStorageSync
(
"openid"
))
console
.
log
(
333333
)
if
(
wx
.
getStorageSync
(
"openid"
))
{
indexApi
.
addRecord
(
{
attractingCustomersChannelId
:
paramsObj
.
attractingCustomerChannelId
,
miniOpenId
:
wx
.
getStorageSync
(
"openid"
),
registerFlag
:
1
,
newRegisterFlag
:
0
,
}
).
then
(
ele
=>
{
//清空引客渠道id
wx
.
setStorageSync
(
'attractingCustomerChannelId'
,
''
)
})
}
let
params
=
''
;
for
(
let
i
in
paramsObj
){
params
+=
"&"
+
i
+
'='
+
paramsObj
[
i
]
}
this
.
params
+=
params
}
}).
catch
((
err
)
=>
{
this
.
withoutScene
=
true
;
})
});
}
else
{
//来自扫码
// options 中的scene需要使用decodeURIComponent才能获取到生成二维码时传入的scene
var
scene
=
decodeURIComponent
(
options
.
scene
);
//参数二维码传递过来的参数
let
querys
=
scene
.
split
(
"_"
);
if
(
querys
)
{
if
(
querys
[
0
]
==
"pid"
)
{
//商品详情 pid_123
this
.
page
=
`/goods/
${
querys
[
1
]}
`
;
this
.
params
+=
this
.
paramsHander
(
querys
,
3
)
+
`&discountMargin=
${
querys
[
querys
.
length
-
1
]}
`
// if(querys.length > 3){
// if(querys[5]){
// this.params += `&spokesmanGroupId=${querys[2]}&spokesmanShopId=${querys[3]}&spokesmanRelId=${querys[4]}&userId=${querys[5]}`
// }else{
// this.params += `&spokesmanGroupId=${querys[2]}&spokesmanShopId=${querys[3]}&spokesmanRelId=${querys[4]}`
// }
// }else if(querys.length == 3){
// this.params += `&userId=${querys[2]}`
// }
}
else
if
(
querys
[
0
]
==
"activty"
)
{
//活动页面activty_turntable_123
this
.
params
+=
`&pageInfo=
${
scene
}
`
;
}
else
if
(
querys
[
0
]
==
"spokesman"
)
{
//分销员 小程序码
this
.
page
=
`/personalCenter/spokesmanCenter`
;
this
.
params
+=
this
.
paramsHander
(
querys
,
2
)
// if(querys.length > 2){
// if(querys[4]){
// this.params += `&spokesmanGroupId=${querys[1]}&spokesmanShopId=${querys[2]}&spokesmanRelId=${querys[3]}&userId=${querys[4]}`
// }else{
// this.params += `&spokesmanGroupId=${querys[1]}&spokesmanShopId=${querys[2]}&spokesmanRelId=${querys[3]}`
// }
// }else if(querys.length == 2){
// this.params += `&userId=${querys[1]}`
// }
}
else
if
(
querys
[
0
]
==
"home"
){
this
.
page
=
`/`
;
this
.
params
+=
this
.
paramsHander
(
querys
,
2
)
// if(querys.length > 2){
// if(querys[4]){
// this.params += `&spokesmanGroupId=${querys[1]}&spokesmanShopId=${querys[2]}&spokesmanRelId=${querys[3]}&userId=${querys[4]}`
// }else{
// this.params += `&spokesmanGroupId=${querys[1]}&spokesmanShopId=${querys[2]}&spokesmanRelId=${querys[3]}`
// }
// }else if(querys.length == 2){
// this.params += `&userId=${querys[1]}`
// }
}
else
if
(
querys
[
0
]
==
"coupon"
){
this
.
page
=
`/personalCenter/coupon/getCoupon`
;
this
.
params
+=
`&couponId=
${
querys
[
1
]}
`
}
else
if
(
querys
[
0
]
==
"a"
){
this
.
page
=
"/activty/receivingGift"
this
.
params
+=
`&orderId=
${
querys
[
1
]}
`
this
.
params
+=
this
.
paramsHander
(
querys
,
3
)
// if(querys.length > 3){
// if(querys[5]){
// this.params += `&orderSn=${querys[1]}&spokesmanGroupId=${querys[2]}&spokesmanShopId=${querys[3]}&spokesmanRelId=${querys[4]}&userId=${querys[5]}`
// }else{
// this.params += `&orderSn=${querys[1]}&spokesmanGroupId=${querys[2]}&spokesmanShopId=${querys[3]}&spokesmanRelId=${querys[4]}`
// }
// }else if(querys.length == 3){
// this.params += `&orderSn=${querys[1]}&userId=${querys[2]}`
// }
}
else
if
(
querys
[
0
]
==
'redeemCode'
)
{
//兑换码
this
.
page
=
`/personalCenter/CDkey/exchange`
;
}
else
if
(
querys
[
0
]
==
'card'
){
this
.
page
=
`/giftCards/linkReceive`
;
this
.
params
+=
`&id=
${
querys
[
1
]}
`
this
.
params
+=
this
.
paramsHander
(
querys
,
3
)
}
else
if
(
querys
[
0
]
==
'giftView'
){
this
.
page
=
`/giftCoupon/preview`
;
this
.
params
+=
`&id=
${
querys
[
1
]}
`
}
else
if
(
querys
[
0
]
==
'form'
){
//问卷调查
this
.
page
=
`/smartForm`
;
this
.
params
+=
`&formId=
${
querys
[
1
]}
`
;
this
.
params
+=
this
.
paramsHander
(
querys
,
3
)
}
}
console
.
log
(
querys
,
"scene"
);
console
.
log
(
this
.
page
)
console
.
log
(
this
.
params
)
}
// var query = options.query.dentistId; // 参数二维码传递过来的场景参数
}
this
.
init
();
},
onShow
()
{
// console.log('显示了',options.webViewUrl);
},
methods
:
{
init
()
{
// 获取小程序开启的订阅消息配置
shop
.
getWxMiniSubscribeMessageConfig
().
then
(
res
=>
{
if
(
res
.
data
.
code
==
200
)
{
const
data
=
res
.
data
.
data
;
console
.
log
(
"wx mini subscribe message data: "
,
data
);
if
(
data
!=
null
)
{
const
subscribeMessageObj
=
{};
for
(
var
key
in
data
)
{
if
(
data
[
key
]
&&
data
[
key
].
template_id
)
{
subscribeMessageObj
[
key
]
=
data
[
key
].
template_id
;
}
}
this
.
$store
.
commit
(
"setSubscribeMessageObj"
,
subscribeMessageObj
);
}
}
});
},
checkLogin
()
{
let
getOpenid
=
wx
.
getStorageSync
(
"openid"
);
let
getSessionid
=
wx
.
getStorageSync
(
"sessionid"
);
console
.
log
(
'244'
,
getOpenid
,
getSessionid
);
if
(
getOpenid
==
""
||
getSessionid
==
""
)
{
this
.
params
+=
"&logOut=true"
;
}
},
getLocationHandle
()
{
wx
.
getLocation
({
type
:
"wgs84"
,
success
:
res
=>
{
var
latitude
=
res
.
latitude
;
var
longitude
=
res
.
longitude
;
var
speed
=
res
.
speed
;
var
accuracy
=
res
.
accuracy
;
console
.
log
(
"~~~~~~~~~1~~~~~~~"
,
res
);
},
fail
:
res
=>
{
console
.
log
(
"++++++++++2++++++"
,
res
);
}
});
},
async
getSpokesman
()
{
await
spokesman
.
getSpokesmanidByShare
().
then
(
res
=>
{
if
(
res
.
data
.
code
==
200
)
{
if
(
res
.
data
.
data
.
hasInvitationStatus
==
1
)
{
this
.
hasInvitationStatus
=
1
;
this
.
spokesmanGroupId
=
res
.
data
.
data
.
groupId
;
this
.
spokesmanShopId
=
res
.
data
.
data
.
shopId
;
this
.
spokesmanRelId
=
res
.
data
.
data
.
spokesmanId
;
this
.
newHref
=
`&spokesmanGroupId=
${
this
.
spokesmanGroupId
}
&spokesmanShopId=
${
this
.
spokesmanShopId
}
&spokesmanRelId=
${
this
.
spokesmanRelId
}
`
;
}
else
{
this
.
newHref
=
""
;
}
console
.
log
(
this
.
newHref
,
"this.newHrefthis.newHrefthis.newHref"
);
}
});
},
bindViewTap
()
{
const
url
=
"../logs/main"
;
if
(
mpvuePlatform
===
"wx"
)
{
mpvue
.
switchTab
({
url
});
}
else
{
mpvue
.
navigateTo
({
url
});
}
},
//右上角分享时触发
getMessage
(
res
)
{
let
len
=
res
.
target
.
data
.
length
-
1
;
console
.
log
(
res
,
"h5消息"
,
res
.
target
.
data
[
len
]);
this
.
shareShopName
=
res
.
target
.
data
[
len
].
shareShopName
||
""
;
this
.
shareLogoUrl
=
DFSImg
(
res
.
target
.
data
[
len
].
shareLogoUrl
,
500
,
400
);
//分享内容中有订单信息为送礼活动
this
.
shareOrderSn
=
res
.
target
.
data
[
len
].
orderSn
;
this
.
shareTid
=
res
.
target
.
data
[
len
].
shareTid
;
this
.
newWindowHref
=
res
.
target
.
data
[
len
].
shareImgUrl
;
// + '&fromVisitorOpenId=' + wx.getStorageSync("openid")
console
.
log
(
"分享信息:"
,
this
.
shareLogoUrl
,
this
.
shareShopName
,
1111111
,
this
.
newWindowHref
);
//文章详情分享埋点
if
(
this
.
newWindowHref
.
indexOf
(
'articleId'
)
!=-
1
)
{
var
articleId
=
''
var
vars
=
this
.
newWindowHref
.
split
(
"&"
);
for
(
var
i
=
0
;
i
<
vars
.
length
;
i
++
)
{
var
pair
=
vars
[
i
].
split
(
"="
);
console
.
log
(
pair
,
2222
)
if
(
pair
[
0
]
==
'articleId'
)
{
articleId
=
pair
[
1
];
}
}
indexApi
.
forward
({
articleId
:
articleId
,}).
then
(
res
=>
{
})
}
},
//加载成功
handleLoad
(){
console
.
log
(
'网页加载成功'
);
},
handleError
(
data
){
wx
.
showLoading
({
title
:
"网页加载失败 请右上角刷新"
});
this
.
$mpAnalytics
.
recordError
({
data
,
extendsInfo
:
{
mixid
:
this
.
$store
.
state
.
mixid
||
null
}
});
},
checkPageUrl
(
val
)
{
for
(
let
i
=
0
;
i
<
this
.
sharePageList
.
length
;
i
++
)
{
if
(
val
.
indexOf
(
this
.
sharePageList
[
i
])
!=
-
1
)
{
return
true
;
}
}
return
false
;
},
//增加params参数
paramsHander
(
querys
,
midNum
){
let
params
=
''
if
(
querys
.
length
>
midNum
){
if
(
querys
[
midNum
+
2
]){
params
+=
`&spokesmanGroupId=
${
querys
[
midNum
-
1
]}
&spokesmanShopId=
${
querys
[
midNum
]}
&spokesmanRelId=
${
querys
[
midNum
+
1
]}
&userId=
${
querys
[
midNum
+
2
]}
`
}
else
{
params
+=
`&spokesmanGroupId=
${
querys
[
midNum
-
1
]}
&spokesmanShopId=
${
querys
[
midNum
]}
&spokesmanRelId=
${
querys
[
midNum
+
1
]}
`
}
}
else
if
(
querys
.
length
==
midNum
){
params
+=
`&userId=
${
querys
[
midNum
-
1
]}
`
}
return
params
;
}
},
onUnload
()
{
console
.
log
(
"卸载----------------"
,
this
.
options
);
},
async
onShareAppMessage
(
res
)
{
await
this
.
getSpokesman
();
let
url
=
''
console
.
log
(
this
.
newWindowHref
+
'this.newWindowHref'
)
//分享路径
if
(
this
.
newWindowHref
){
url
=
this
.
newWindowHref
;
}
else
{
url
=
res
.
webViewUrl
;
}
//分享页面去掉登录态
if
(
url
.
indexOf
(
"sessionid"
)
>
-
1
)
{
url
=
url
.
split
(
"?"
)[
0
]
+
"?mixid="
+
this
.
shopId
;
}
//分销员推广页面 默认分享分销员中心页面
if
(
url
.
indexOf
(
"/personalCenter/spokesmanCenter/mine/popularize"
)
>
-
1
)
{
url
=
`
${
this
.
baseUrl
}
/personalCenter/spokesmanCenter?mixid=
${
this
.
shopId
}
`
;
}
console
.
log
(
'shareUrl---------------'
+
url
)
//增加分销员信息
if
(
this
.
hasInvitationStatus
==
1
&&
url
.
indexOf
(
'spokesmanGroupId'
)
==-
1
){
this
.
shareUrl
=
url
+
this
.
newHref
}
else
{
this
.
shareUrl
=
url
;
}
console
.
log
(
this
.
shareUrl
,
"index12"
);
console
.
log
(
`/pages/index/main?share=
${
encodeURIComponent
(
this
.
shareUrl
)}
`
,
'测试直播分享相关'
)
return
{
title
:
this
.
shareShopName
,
// 默认是小程序的名称
path
:
`/pages/index/main?share=
${
encodeURIComponent
(
this
.
shareUrl
)}
`
,
// 默认是当前页面
imageUrl
:
this
.
shareLogoUrl
,
success
:
function
(
res
)
{
// 转发成功之后的回调
if
(
res
.
errMsg
==
"shareAppMessage:ok"
)
{
console
.
log
(
res
,
"分享成功"
);
}
},
fail
:
function
()
{
// 转发失败之后的回调
if
(
res
.
errMsg
==
"shareAppMessage:fail cancel"
)
{
// 用户取消转发
console
.
log
(
res
,
"分享失败"
);
}
else
if
(
res
.
errMsg
==
"shareAppMessage:fail"
)
{
// 转发失败,其中 detail message 为详细失败信息
}
},
complete
:
function
()
{
// 转发结束之后的回调(转发成不成功都会执行)
}
};
}
};
</
script
>
<
style
scoped
>
.userinfo
{
display
:
flex
;
flex-direction
:
column
;
align-items
:
center
;
}
.userinfo-avatar
{
width
:
128
rpx
;
height
:
128
rpx
;
margin
:
20
rpx
;
border-radius
:
50%
;
}
.userinfo-nickname
{
color
:
#aaa
;
}
.form-control
{
display
:
block
;
padding
:
0
12px
;
margin-bottom
:
5px
;
border
:
1px
solid
#ccc
;
}
.all
{
width
:
7.5rem
;
height
:
1rem
;
background-color
:
blue
;
}
.all
:after
{
display
:
block
;
content
:
""
;
clear
:
both
;
}
.left
{
float
:
left
;
width
:
3rem
;
height
:
1rem
;
background-color
:
red
;
}
.right
{
float
:
left
;
width
:
4.5rem
;
height
:
1rem
;
background-color
:
green
;
}
</
style
>
src/pages/rediect/main.js
deleted
100644 → 0
View file @
370a1389
import
Vue
from
'vue'
import
App
from
'./index'
// add this to handle exception
Vue
.
config
.
errorHandler
=
function
(
err
)
{
if
(
console
&&
console
.
error
)
{
console
.
error
(
err
)
}
}
const
app
=
new
Vue
(
App
)
app
.
$mount
()
src/pages/rediect/main.json
deleted
100644 → 0
View file @
370a1389
{
}
\ No newline at end of file
src/utils/mayi.js
View file @
286740db
// 主题色
export
let
themeColor
=
{
export
let
themeColor
=
{
"--main-color"
:
"#ffffff"
,
"--minor-color"
:
"#ffffff"
}
...
...
@@ -125,3 +125,43 @@ export function setTabBarActive(data) {
})
}
}
// 遍历所有组件有显示条件的id 是否包含地区导航组件
export
function
checkShowConditionIds
(
list
)
{
let
allCondition
=
[];
let
isAreaNavigation
=
false
;
list
.
forEach
(
element
=>
{
pollCondition
(
element
)
});
function
pollCondition
(
object
)
{
if
(
Object
.
prototype
.
toString
.
call
(
object
)
===
'[object Object]'
)
{
if
(
object
.
condition
!=
''
&&
object
.
condition
!=
undefined
)
{
allCondition
.
push
(
object
.
condition
);
}
for
(
const
key
in
object
)
{
if
(
object
.
hasOwnProperty
(
key
))
{
const
element
=
object
[
key
];
if
(
Object
.
prototype
.
toString
.
call
(
element
)
===
'[object Object]'
)
{
if
(
element
.
condition
!=
''
&&
element
.
condition
!=
undefined
)
{
allCondition
.
push
(
element
.
condition
);
}
pollCondition
(
element
)
}
else
if
(
Object
.
prototype
.
toString
.
call
(
element
)
===
'[object Array]'
&&
element
.
length
>
0
)
{
element
.
forEach
((
item
)
=>
{
pollCondition
(
item
)
})
}
}
}
// 有地区导航组件
if
(
object
.
componentCode
==
'area-navigation'
)
{
isAreaNavigation
=
true
}
}
}
return
{
allCondition
:[...
new
Set
(
allCondition
)],
isAreaNavigation
}
}
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment