Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
P
project-online-fi
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
EzijingWeb
project-online-fi
Commits
0dd307f2
提交
0dd307f2
authored
1月 13, 2023
作者:
matian
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
代码优化
上级
2efea777
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
49 行增加
和
77 行删除
+49
-77
ContactDialog.vue
src/modules/shop/components/ContactDialog.vue
+0
-1
CourseFooter.vue
src/modules/shop/components/CourseFooter.vue
+7
-11
CourseListItem.vue
src/modules/shop/components/CourseListItem.vue
+9
-11
DetailBanner.vue
src/modules/shop/components/DetailBanner.vue
+11
-18
Index.vue
src/modules/shop/views/Index.vue
+2
-2
View.vue
src/modules/shop/views/View.vue
+16
-21
shop.ts
src/stores/shop.ts
+4
-13
没有找到文件。
src/modules/shop/components/ContactDialog.vue
浏览文件 @
0dd307f2
...
@@ -28,7 +28,6 @@ const handleCancel = () => {
...
@@ -28,7 +28,6 @@ const handleCancel = () => {
title=
"上课方式"
title=
"上课方式"
>
>
<div
class=
"buy_alert"
>
<div
class=
"buy_alert"
>
<!--
<img
src=
"https://webapp-pub.ezijing.com/project_online/fi/icon_contact.png"
alt=
""
/>
-->
<div
class=
"alert_con"
>
<div
class=
"alert_con"
>
<img
src=
"https://webapp-pub.ezijing.com/project_online/fi/contact_wx.png"
class=
"con_img"
/>
<img
src=
"https://webapp-pub.ezijing.com/project_online/fi/contact_wx.png"
class=
"con_img"
/>
<div
class=
"con_desc"
>
请联系小秘书:13263110169(同微信)
</div>
<div
class=
"con_desc"
>
请联系小秘书:13263110169(同微信)
</div>
...
...
src/modules/shop/components/CourseFooter.vue
浏览文件 @
0dd307f2
<
script
lang=
"ts"
setup
>
<
script
lang=
"ts"
setup
>
import
ContactDialog
from
'../components/ContactDialog.vue'
import
ContactDialog
from
'../components/ContactDialog.vue'
import
{
useDevice
}
from
'@/composables/useDevice'
import
{
useDevice
}
from
'@/composables/useDevice'
import
{
useUserStore
}
from
'@/stores/user'
const
user
=
useUserStore
()
const
{
mobile
}
=
useDevice
()
const
{
mobile
}
=
useDevice
()
const
router
=
useRouter
()
const
router
=
useRouter
()
const
props
=
defineProps
({
const
props
=
defineProps
({
payStatus
:
{
type
:
String
},
shopItem
:
{
shopItem
:
{
type
:
Object
type
:
Object
}
}
...
@@ -16,7 +12,7 @@ const props = defineProps({
...
@@ -16,7 +12,7 @@ const props = defineProps({
const
buyDialogVisible
=
ref
(
false
)
const
buyDialogVisible
=
ref
(
false
)
const
handleBuyCourse
=
()
=>
{
const
handleBuyCourse
=
()
=>
{
if
(
props
.
payStatus
===
'4'
||
props
.
shopItem
?.
isBuy
===
true
)
{
if
(
props
.
shopItem
?.
isBuy
===
true
)
{
if
(
props
.
shopItem
?.
category
===
'system_course'
)
{
if
(
props
.
shopItem
?.
category
===
'system_course'
)
{
buyDialogVisible
.
value
=
true
buyDialogVisible
.
value
=
true
}
else
{
}
else
{
...
@@ -29,7 +25,7 @@ const handleBuyCourse = () => {
...
@@ -29,7 +25,7 @@ const handleBuyCourse = () => {
</
script
>
</
script
>
<
template
>
<
template
>
<div
class=
"detail_footer"
v-if=
"!mobile"
>
<div
class=
"detail_footer"
v-if=
"!mobile"
>
<div
class=
"left_status"
v-if=
"
payStatus === '4' ||
shopItem?.isBuy === true"
>
已购买
</div>
<div
class=
"left_status"
v-if=
"shopItem?.isBuy === true"
>
已购买
</div>
<template
v-else
>
<template
v-else
>
<div
class=
"footer_left"
>
<div
class=
"footer_left"
>
<div
class=
"left_tit"
>
总学费
</div>
<div
class=
"left_tit"
>
总学费
</div>
...
@@ -41,11 +37,11 @@ const handleBuyCourse = () => {
...
@@ -41,11 +37,11 @@ const handleBuyCourse = () => {
</div>
</div>
</
template
>
</
template
>
<div
class=
"footer_btn"
@
click=
"handleBuyCourse"
>
<div
class=
"footer_btn"
@
click=
"handleBuyCourse"
>
{{
payStatus === '4' || shopItem?.isBuy === true || shopItem?.is_free === tru
e ? '立即学习' : '立即购买' }}
{{
shopItem?.isBuy === true || shopItem?.is_fre
e ? '立即学习' : '立即购买' }}
</div>
</div>
</div>
</div>
<div
class=
"detail_footer"
v-else
>
<div
class=
"detail_footer"
v-else
>
<div
class=
"left_status"
v-if=
"
payStatus === '4' ||
shopItem?.isBuy === true"
>
已购买
</div>
<div
class=
"left_status"
v-if=
"shopItem?.isBuy === true"
>
已购买
</div>
<
template
v-else
>
<
template
v-else
>
<div
class=
"footer_left"
v-if=
"shopItem?.type === '课程包'"
>
<div
class=
"footer_left"
v-if=
"shopItem?.type === '课程包'"
>
<div
class=
"left_tit"
>
<div
class=
"left_tit"
>
...
@@ -54,7 +50,7 @@ const handleBuyCourse = () => {
...
@@ -54,7 +50,7 @@ const handleBuyCourse = () => {
<div
class=
"left_desc"
>
{{
shopItem
?.
total_price_desc
}}
</div>
<div
class=
"left_desc"
>
{{
shopItem
?.
total_price_desc
}}
</div>
</div>
</div>
<div
class=
"footer_left"
v-else
>
<div
class=
"footer_left"
v-else
>
<div
class=
"left_tit1"
v-if=
"shopItem?.is_free
=== true
"
>
免费
</div>
<div
class=
"left_tit1"
v-if=
"shopItem?.is_free"
>
免费
</div>
<div
class=
"left_tit"
v-else
>
<div
class=
"left_tit"
v-else
>
课程价格
课程价格
<span
class=
"tit_price"
>
¥
{{
shopItem
?.
price
}}
</span>
<span
class=
"tit_price"
>
¥
{{
shopItem
?.
price
}}
</span>
...
@@ -64,7 +60,7 @@ const handleBuyCourse = () => {
...
@@ -64,7 +60,7 @@ const handleBuyCourse = () => {
<div
class=
"footer_btn"
@
click=
"handleBuyCourse"
>
<div
class=
"footer_btn"
@
click=
"handleBuyCourse"
>
<div
class=
"btn_buy"
>
<div
class=
"btn_buy"
>
{{
payStatus === '4' || shopItem?.isBuy === true || shopItem?.is_free === tru
e ? '立即学习' : '立即购买' }}
{{
shopItem?.isBuy === true || shopItem?.is_fre
e ? '立即学习' : '立即购买' }}
</div>
</div>
</div>
</div>
</div>
</div>
...
...
src/modules/shop/components/CourseListItem.vue
浏览文件 @
0dd307f2
<
script
setup
lang=
"ts"
>
<
script
setup
lang=
"ts"
>
import
ContactDialog
from
'../components/ContactDialog.vue'
import
ContactDialog
from
'../components/ContactDialog.vue'
import
{
useDevice
}
from
'@/composables/useDevice'
import
{
useDevice
}
from
'@/composables/useDevice'
import
{
useUserStore
}
from
'@/stores/user'
const
{
mobile
}
=
useDevice
()
const
{
mobile
}
=
useDevice
()
const
user
=
useUserStore
()
const
router
=
useRouter
()
const
router
=
useRouter
()
const
buyDialogVisible
=
ref
(
false
)
const
buyDialogVisible
=
ref
(
false
)
...
@@ -14,20 +12,20 @@ defineProps({
...
@@ -14,20 +12,20 @@ defineProps({
}
}
})
})
// 查看详情
// 查看详情
const
handleD
a
tail
=
(
item
:
any
)
=>
{
const
handleD
e
tail
=
(
item
:
any
)
=>
{
router
.
push
({
router
.
push
({
path
:
`/shop/detail/
${
item
}
`
path
:
`/shop/detail/
${
item
}
`
})
})
}
}
const
handleBuy
=
(
courseItem
:
any
)
=>
{
const
handleBuy
=
(
courseItem
:
any
)
=>
{
if
(
courseItem
?.
isBuy
===
true
)
{
if
(
courseItem
?.
isBuy
===
true
)
{
if
(
courseItem
?.
is_new
===
true
)
{
if
(
courseItem
?.
is_new
)
{
buyDialogVisible
.
value
=
true
buyDialogVisible
.
value
=
true
}
else
{
}
else
{
window
.
open
(
'https://fi-learning.ezijing.com'
)
window
.
open
(
'https://fi-learning.ezijing.com'
)
}
}
}
else
{
}
else
{
if
(
courseItem
?.
is_free
===
true
)
{
if
(
courseItem
?.
is_free
)
{
buyDialogVisible
.
value
=
true
buyDialogVisible
.
value
=
true
}
else
{
}
else
{
router
.
push
(
`/shop/pay/
${
courseItem
.
id
}
`
)
router
.
push
(
`/shop/pay/
${
courseItem
.
id
}
`
)
...
@@ -39,14 +37,14 @@ const handleBuy = (courseItem: any) => {
...
@@ -39,14 +37,14 @@ const handleBuy = (courseItem: any) => {
<
template
>
<
template
>
<div
class=
"main_tab"
>
<div
class=
"main_tab"
>
<div
class=
"tab_con"
>
<div
class=
"tab_con"
>
<div
class=
"con_left"
@
click=
"handleD
a
tail(courseItem?.id)"
>
<div
class=
"con_left"
@
click=
"handleD
e
tail(courseItem?.id)"
>
<div
class=
"left_img"
>
<div
class=
"left_img"
>
<img
:src=
"courseItem?.image_url"
class=
"left_img"
/>
<img
:src=
"courseItem?.image_url"
class=
"left_img"
/>
</div>
</div>
<div
class=
"left_type"
>
{{
courseItem
?.
type
}}
</div>
<div
class=
"left_type"
>
{{
courseItem
?.
type
}}
</div>
</div>
</div>
<div
class=
"con_right"
>
<div
class=
"con_right"
>
<div
class=
"right_top"
@
click=
"handleD
a
tail(courseItem?.id)"
>
<div
class=
"right_top"
@
click=
"handleD
e
tail(courseItem?.id)"
>
<div
class=
"top_use"
>
<div
class=
"top_use"
>
<div
class=
"use_icon"
>
适用人群
</div>
<div
class=
"use_icon"
>
适用人群
</div>
<div
class=
"use_tips"
>
{{
courseItem
?.
for_people
}}
</div>
<div
class=
"use_tips"
>
{{
courseItem
?.
for_people
}}
</div>
...
@@ -57,17 +55,17 @@ const handleBuy = (courseItem: any) => {
...
@@ -57,17 +55,17 @@ const handleBuy = (courseItem: any) => {
</div>
</div>
</div>
</div>
<div
class=
"right_bottom"
>
<div
class=
"right_bottom"
>
<div
class=
"bottom_price"
v-if=
"!mobile && courseItem?.
price !== 0
"
>
<div
class=
"bottom_price"
v-if=
"!mobile && courseItem?.
is_free
"
>
<div
class=
"price_icon"
>
¥
</div>
<div
class=
"price_icon"
>
¥
</div>
<div
class=
"price_num"
>
{{
courseItem
?.
price
}}
</div>
<div
class=
"price_num"
>
{{
courseItem
?.
price
}}
</div>
</div>
</div>
<div
class=
"bottom_price"
v-if=
"!mobile && courseItem?.
price === 0
"
>
<div
class=
"bottom_price"
v-if=
"!mobile && courseItem?.
is_free
"
>
<div
class=
"price_icon"
>
免费
</div>
<div
class=
"price_icon"
>
免费
</div>
</div>
</div>
<div
class=
"bottom_btn"
>
<div
class=
"bottom_btn"
>
<div
class=
"btn_detail"
v-if=
"!mobile"
@
click=
"handleD
a
tail(courseItem?.id)"
>
查看详情
</div>
<div
class=
"btn_detail"
v-if=
"!mobile"
@
click=
"handleD
e
tail(courseItem?.id)"
>
查看详情
</div>
<div
class=
"btn_buy"
@
click=
"handleBuy(courseItem)"
>
<div
class=
"btn_buy"
@
click=
"handleBuy(courseItem)"
>
{{
courseItem
?.
isBuy
===
true
?
'立即学习'
:
'立即购买'
}}
{{
courseItem
?.
isBuy
===
true
||
courseItem
?.
is_free
?
'立即学习'
:
'立即购买'
}}
</div>
</div>
</div>
</div>
</div>
</div>
...
...
src/modules/shop/components/DetailBanner.vue
浏览文件 @
0dd307f2
...
@@ -9,9 +9,6 @@ const { mobile } = useDevice()
...
@@ -9,9 +9,6 @@ const { mobile } = useDevice()
const
props
=
defineProps
({
const
props
=
defineProps
({
shopItem
:
{
shopItem
:
{
type
:
Object
type
:
Object
},
payStatus
:
{
type
:
String
}
}
})
})
const
router
=
useRouter
()
const
router
=
useRouter
()
...
@@ -31,22 +28,18 @@ const shareTit = computed(() => {
...
@@ -31,22 +28,18 @@ const shareTit = computed(() => {
})
})
// 购买课程
// 购买课程
const
handleBuyCourse
=
()
=>
{
const
handleBuyCourse
=
()
=>
{
if
(
user
.
isLogin
)
{
if
(
props
.
shopItem
?.
isBuy
===
true
)
{
if
(
props
.
payStatus
===
'4'
||
props
.
shopItem
?.
isBuy
===
true
)
{
if
(
props
.
shopItem
?.
is_new
)
{
if
(
props
.
shopItem
?.
is_new
===
true
)
{
buyDialogVisible
.
value
=
true
buyDialogVisible
.
value
=
true
}
else
{
window
.
open
(
'https://fi-learning.ezijing.com'
)
}
}
else
{
}
else
{
if
(
props
.
shopItem
?.
is_free
===
true
)
{
window
.
open
(
'https://fi-learning.ezijing.com'
)
buyDialogVisible
.
value
=
true
}
else
{
router
.
push
(
`/shop/pay/
${
props
.
shopItem
?.
id
}
`)
}
}
}
}
else
{
}
else
{
window.location.href = `
$
{
import
.
meta
.
env
.
VITE_LOGIN_URL
}?
rd
=
$
{
encodeURIComponent
(
location
.
href
)}
`
if
(
props
.
shopItem
?.
is_free
)
{
buyDialogVisible
.
value
=
true
}
else
{
router
.
push
(
`/shop/pay/
${
props
.
shopItem
?.
id
}
`)
}
}
}
}
}
// 控制复制弹窗显示
// 控制复制弹窗显示
...
@@ -124,7 +117,7 @@ const handleCopyLink = () => {
...
@@ -124,7 +117,7 @@ const handleCopyLink = () => {
</div>
</div>
<div
class=
"detail_buy"
>
<div
class=
"detail_buy"
>
<div
class=
"buy_left"
>
<div
class=
"buy_left"
>
<div
class=
"left_status"
v-if=
"
payStatus === '4' ||
shopItem?.isBuy === true"
>
已购买
</div>
<div
class=
"left_status"
v-if=
"shopItem?.isBuy === true"
>
已购买
</div>
<
template
v-else
>
<
template
v-else
>
<div
class=
"left_price"
v-if=
"shopItem?.price !== 0"
>
<div
class=
"left_price"
v-if=
"shopItem?.price !== 0"
>
<div
class=
"price_icon"
>
¥
</div>
<div
class=
"price_icon"
>
¥
</div>
...
@@ -140,7 +133,7 @@ const handleCopyLink = () => {
...
@@ -140,7 +133,7 @@ const handleCopyLink = () => {
</div>
</div>
</div>
</div>
<div
class=
"buy_right"
@
click=
"handleBuyCourse"
v-if=
"!mobile"
>
<div
class=
"buy_right"
@
click=
"handleBuyCourse"
v-if=
"!mobile"
>
{{
payStatus === '4' || shopItem?.isBuy === true || shopItem?.is_free === tru
e ? '立即学习' : '立即购买' }}
{{
shopItem?.isBuy === true || shopItem?.is_fre
e ? '立即学习' : '立即购买' }}
</div>
</div>
</div>
</div>
<div
class=
"detail_info"
v-if=
"mobile"
>
<div
class=
"detail_info"
v-if=
"mobile"
>
...
...
src/modules/shop/views/Index.vue
浏览文件 @
0dd307f2
...
@@ -14,7 +14,8 @@ const handleTabClick = (tab: any) => {
...
@@ -14,7 +14,8 @@ const handleTabClick = (tab: any) => {
}
}
}
}
watchEffect
(()
=>
{
watchEffect
(()
=>
{
if
(
route
.
query
.
id
)
!
mobile
?
(
activeName
=
route
.
query
.
id
.
toString
())
:
(
activeNameH5
=
Number
(
route
.
query
.
id
))
console
.
log
(
typeof
route
.
query
.
id
)
if
(
route
.
query
.
id
)
!
mobile
?
(
activeName
=
route
.
query
.
id
as
string
)
:
(
activeNameH5
=
Number
(
route
.
query
.
id
))
})
})
</
script
>
</
script
>
...
@@ -36,7 +37,6 @@ watchEffect(() => {
...
@@ -36,7 +37,6 @@ watchEffect(() => {
</div>
</div>
<div
class=
"main_shop"
v-else
>
<div
class=
"main_shop"
v-else
>
<img
src=
"https://webapp-pub.ezijing.com/project_online/paa/shop_banner.jpg"
class=
"shop_banner"
/>
<img
src=
"https://webapp-pub.ezijing.com/project_online/paa/shop_banner.jpg"
class=
"shop_banner"
/>
<van-tabs
v-model:active=
"activeNameH5"
>
<van-tabs
v-model:active=
"activeNameH5"
>
<van-tab
:title=
"item.label"
v-for=
"(item, index) in shopStore.filters"
:key=
"index"
lazy
>
<van-tab
:title=
"item.label"
v-for=
"(item, index) in shopStore.filters"
:key=
"index"
lazy
>
<CourseList
:type=
"item.value"
:courseList=
"shopStore.shopList"
:key=
"index"
/>
<CourseList
:type=
"item.value"
:courseList=
"shopStore.shopList"
:key=
"index"
/>
...
...
src/modules/shop/views/View.vue
浏览文件 @
0dd307f2
...
@@ -10,27 +10,22 @@ import RecommendCourse from '../components/RecommendCourse.vue'
...
@@ -10,27 +10,22 @@ import RecommendCourse from '../components/RecommendCourse.vue'
import
CourseFooter
from
'../components/CourseFooter.vue'
import
CourseFooter
from
'../components/CourseFooter.vue'
import
{
useShopStore
}
from
'@/stores/shop'
import
{
useShopStore
}
from
'@/stores/shop'
import
{
useDevice
}
from
'@/composables/useDevice'
import
{
useDevice
}
from
'@/composables/useDevice'
import
{
storeToRefs
}
from
'pinia'
const
{
mobile
}
=
useDevice
()
const
shopStore
=
useShopStore
()
const
shopStore
=
useShopStore
()
const
route
=
useRoute
()
const
{
shopItem
}
=
storeToRefs
(
shopStore
)
const
payStatus
:
any
=
ref
(
route
.
query
.
payStatus
)
const
{
mobile
}
=
useDevice
()
const
courseItem
:
any
=
ref
([])
// 课程所属课程包
courseItem
.
value
=
shopStore
.
shopList
.
filter
(
(
item
:
any
)
=>
item
.
type
===
'课程包'
&&
item
.
child_ids
.
includes
(
shopStore
.
shopItem
?.
id
)
)
</
script
>
</
script
>
<
template
>
<
template
>
<div
class=
"course_detail"
v-if=
"!mobile"
>
<div
class=
"course_detail"
v-if=
"!mobile"
>
<DetailBanner
:shopItem=
"shop
Store.shopItem"
:payStatus=
"payStatus
"
/>
<DetailBanner
:shopItem=
"shop
Item
"
/>
<div
class=
"detail_con"
>
<div
class=
"detail_con"
>
<div
class=
"con_left"
>
<div
class=
"con_left"
>
<IncludeCourseCard
v-if=
"shop
Store.shopItem?.type === '课程'"
:courseItem=
"courseItem
"
/>
<IncludeCourseCard
v-if=
"shop
Item?.type === '课程'"
:courseItem=
"shopItem?.course_list
"
/>
<div
class=
"left_course"
v-if=
"shop
Store.shop
Item?.type === '课程包'"
>
<div
class=
"left_course"
v-if=
"shopItem?.type === '课程包'"
>
<CourseIntrouduce
:shopItem=
"shop
Store.shop
Item"
/>
<CourseIntrouduce
:shopItem=
"shopItem"
/>
<CourseFor
:shopItem=
"shop
Store.shop
Item"
/>
<CourseFor
:shopItem=
"shopItem"
/>
<CourseCatalogPC
v-if=
"shop
Store.shopItem?.type === '课程包'"
:shopItem=
"shopStore.
shopItem"
/>
<CourseCatalogPC
v-if=
"shop
Item?.type === '课程包'"
:shopItem=
"
shopItem"
/>
</div>
</div>
</div>
</div>
<div
class=
"con_right"
>
<div
class=
"con_right"
>
...
@@ -38,18 +33,18 @@ courseItem.value = shopStore.shopList.filter(
...
@@ -38,18 +33,18 @@ courseItem.value = shopStore.shopList.filter(
<RecommendCourse
:shopRelatedList=
"shopStore.shopRelatedList"
/>
<RecommendCourse
:shopRelatedList=
"shopStore.shopRelatedList"
/>
</div>
</div>
</div>
</div>
<CourseFooter
:
payStatus=
"payStatus"
:shopItem=
"shopStore.shopItem"
v-if=
"shopStore.
shopItem?.type == '课程包'"
/>
<CourseFooter
:
shopItem=
"shopItem"
v-if=
"
shopItem?.type == '课程包'"
/>
</div>
</div>
<div
class=
"course_detail"
v-else
>
<div
class=
"course_detail"
v-else
>
<DetailBanner
:shopItem=
"shop
Store.shopItem"
:payStatus=
"payStatus
"
/>
<DetailBanner
:shopItem=
"shop
Item
"
/>
<IncludeCourseCard
v-if=
"shop
Store.shopItem?.type === '课程'"
:courseItem=
"courseItem
"
/>
<IncludeCourseCard
v-if=
"shop
Item?.type === '课程'"
:courseItem=
"shopItem?.course_list
"
/>
<div
class=
"detail_con"
v-if=
"shop
Store.shop
Item?.type === '课程包'"
>
<div
class=
"detail_con"
v-if=
"shopItem?.type === '课程包'"
>
<CourseIntrouduce
:shopItem=
"shop
Store.shop
Item"
/>
<CourseIntrouduce
:shopItem=
"shopItem"
/>
<!--
<TeacherCard
:lecturerList=
"shopStore.shopItem?.lecturer_list"
/>
-->
<!--
<TeacherCard
:lecturerList=
"shopStore.shopItem?.lecturer_list"
/>
-->
<CourseCatalogH5
:shopItem=
"shop
Store.shop
Item"
/>
<CourseCatalogH5
:shopItem=
"shopItem"
/>
</div>
</div>
<RecommendCourse
:shopRelatedList=
"shopStore.shopRelatedList"
/>
<RecommendCourse
:shopRelatedList=
"shopStore.shopRelatedList"
/>
<CourseFooter
:
payStatus=
"payStatus"
:shopItem=
"shopStore.
shopItem"
/>
<CourseFooter
:
shopItem=
"
shopItem"
/>
</div>
</div>
</
template
>
</
template
>
<
style
lang=
"scss"
scoped
>
<
style
lang=
"scss"
scoped
>
...
...
src/stores/shop.ts
浏览文件 @
0dd307f2
...
@@ -41,19 +41,10 @@ export const useShopStore = defineStore('shop', () => {
...
@@ -41,19 +41,10 @@ export const useShopStore = defineStore('shop', () => {
// 相关推荐商品列表
// 相关推荐商品列表
const
shopRelatedList
=
computed
(()
=>
{
const
shopRelatedList
=
computed
(()
=>
{
if
(
shopItem
.
value
?.
type
===
'课程包'
)
{
const
list
=
shopList
.
value
.
filter
(
return
shopList
.
value
.
filter
(
item
=>
item
.
type
===
shopItem
.
value
?.
type
&&
!
item
.
is_test
&&
item
.
id
!==
shopItem
.
value
?.
id
item
=>
item
.
type
===
shopItem
.
value
?.
type
&&
!
item
.
is_test
&&
item
.
id
!==
shopItem
.
value
?.
id
)
)
return
shopItem
.
value
?.
type
===
'课程包'
?
list
:
list
.
filter
(
item
=>
item
.
category
===
shopItem
.
value
?.
category
)
}
else
{
return
shopList
.
value
.
filter
(
item
=>
item
.
type
===
shopItem
.
value
?.
type
&&
!
item
.
is_test
&&
item
.
id
!==
shopItem
.
value
?.
id
&&
item
.
category
===
shopItem
.
value
?.
category
)
}
})
})
return
{
filters
,
list
,
shopList
,
shopItem
,
shopRelatedList
}
return
{
filters
,
list
,
shopList
,
shopItem
,
shopRelatedList
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论