Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
5
51business
Project
Project
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
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
方斌
51business
Commits
e179ad94
Commit
e179ad94
authored
Aug 26, 2020
by
任国军
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix act bug
parent
5c4d5a80
Pipeline
#27667
passed with stage
in 15 seconds
Changes
3
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
50 additions
and
26 deletions
+50
-26
courseActImage.js
app/model/class/courseActImage.js
+1
-0
option.js
app/service/course/v5/option.js
+1
-1
user.js
app/service/course/v5/user.js
+48
-25
No files found.
app/model/class/courseActImage.js
View file @
e179ad94
...
...
@@ -17,6 +17,7 @@ module.exports = app => {
institution_id
:
INTEGER
,
h5_promote_success_url
:
STRING
,
h5_promote_middle_url
:
STRING
,
type
:
INTEGER
,
title
:
STRING
,
content
:
STRING
,
selected_image
:
STRING
,
...
...
app/service/course/v5/option.js
View file @
e179ad94
...
...
@@ -380,7 +380,7 @@ class OptionService extends Service {
async
getActImageList
()
{
const
{
ctx
}
=
this
;
const
giftList
=
await
ctx
.
classModel
.
CourseActImage
.
findAll
({
where
:
{
status
:
1
,
is_deleted
:
0
},
attributes
:
[
'id'
,
'selected_image'
,
'unselected_image'
],
order
:
[[
'sort'
,
'asc'
]]
});
const
giftList
=
await
ctx
.
classModel
.
CourseActImage
.
findAll
({
where
:
{
status
:
1
,
is_deleted
:
0
},
attributes
:
[
'id'
,
'selected_image'
,
'unselected_image'
,
'type'
],
order
:
[[
'sort'
,
'asc'
]]
});
const
ret
=
{
list
:
giftList
,
};
...
...
app/service/course/v5/user.js
View file @
e179ad94
...
...
@@ -622,12 +622,28 @@ class UserService extends Service {
// 获取用户的礼品列表
async
getUserActImageList
()
{
const
{
ctx
}
=
this
;
const
userImageList
=
await
ctx
.
classModel
.
CourseUserActImage
.
findAll
({
where
:
{
user_uuid
:
ctx
.
userUuid
,
status
:
1
,
is_deleted
:
0
}
});
const
userUuid
=
ctx
.
userUuid
;
// const userImageList = await ctx.classModel.CourseUserActImage.findAll({ where: { user_uuid: ctx.userUuid, status: 1, is_deleted: 0 } });
const
imageList
=
await
ctx
.
classModel
.
CourseActImage
.
findAll
({
where
:
{
id
:
{
$in
:
R
.
pluck
(
'image_id'
,
userImageList
)
}
},
attributes
:
[
'id'
,
'selected_image'
,
'unselected_image'
,
'title'
,
'content'
,
'h5_promote_success_url'
]
});
const
ret
=
{
list
:
imageList
,
};
// const imageList = await ctx.classModel.CourseActImage.findAll({ where: { id: { $in: R.pluck('image_id', userImageList) } }, attributes: [ 'id', 'selected_image', 'unselected_image', 'title', 'content', 'h5_promote_success_url' ] });
// const ret = {
// list: imageList,
// };
const
userActImage
=
await
ctx
.
classModel
.
CourseUserActImage
.
findOne
({
where
:
{
user_uuid
:
userUuid
,
status
:
1
,
is_deleted
:
0
}
});
if
(
ctx
.
isEmpty
(
userActImage
))
{
return
{};
}
const
actInfo
=
await
ctx
.
classModel
.
CourseActImage
.
findOne
({
where
:
{
id
:
userActImage
.
image_id
},
attributes
:
[
'id'
,
'selected_image'
,
'unselected_image'
,
'title'
,
'content'
,
'h5_promote_success_url'
,
'class_id'
,
'type'
],
raw
:
true
});
if
(
ctx
.
isEmpty
(
actInfo
))
{
return
{};
}
const
order
=
await
ctx
.
classModel
.
V5
.
CourseUserOrder
.
findOne
({
where
:
{
user_uuid
:
userUuid
,
type
:
3
,
status
:
1
,
class_id
:
actInfo
.
class_id
,
is_deleted
:
0
}
});
const
ret
=
actInfo
;
ret
.
order_no
=
ctx
.
isEmpty
(
order
)
?
''
:
order
.
order_no
;
ret
.
redeem
=
ctx
.
isEmpty
(
order
)
?
''
:
order
.
redeem
;
return
ret
;
}
...
...
@@ -659,23 +675,6 @@ class UserService extends Service {
ctx
.
failed
(
'课程已下线'
);
}
// 判断是否有兑换码
let
redeem
=
''
;
if
(
actInfo
.
type
===
2
)
{
const
redeemCode
=
await
ctx
.
classModel
.
V5
.
CourseRedeemCode
.
findOne
({
where
:
{
class_id
:
actInfo
.
class_id
,
status
:
1
,
is_used
:
0
,
is_deleted
:
0
}
});
if
(
ctx
.
isEmpty
(
redeemCode
))
{
ctx
.
failed
(
'兑换码不足'
);
}
await
ctx
.
classModel
.
V5
.
CourseRedeemCode
.
update
({
is_used
:
1
,
user_uuid
:
userUuid
,
used_time
:
moment
().
format
(
'YYYY-MM-DD HH:mm:ss'
)
},
{
id
:
redeemCode
.
id
});
redeem
=
redeemCode
.
code
;
}
else
if
(
actInfo
.
type
===
3
)
{
const
redeemCode
=
await
ctx
.
classModel
.
V5
.
CourseV5InstitutionRedeemCode
.
findOne
({
where
:
{
class_id
:
actInfo
.
class_id
,
status
:
1
,
is_used
:
0
,
is_deleted
:
0
}
});
if
(
ctx
.
isEmpty
(
redeemCode
))
{
ctx
.
failed
(
'兑换码不足'
);
}
await
ctx
.
classModel
.
V5
.
CourseV5InstitutionRedeemCode
.
update
({
is_used
:
1
,
user_uuid
:
userUuid
,
used_time
:
moment
().
format
(
'YYYY-MM-DD HH:mm:ss'
)
},
{
id
:
redeemCode
.
id
});
redeem
=
redeemCode
.
code
;
}
// 生成订单
const
orderNo
=
'11'
+
moment
().
format
(
'YYYYMMDDHHmmSS'
)
+
await
this
.
getRandomNumber
(
6
);
const
order
=
{
...
...
@@ -685,7 +684,7 @@ class UserService extends Service {
class_id
:
actInfo
.
class_id
,
pay
:
0
,
pay_time
:
moment
().
format
(
'YYYY-MM-DD HH:mm:ss'
),
redeem
,
columns
:
'{}'
,
status
:
ctx
.
isEmpty
(
institutionInfo
.
pay_column
)
&&
classInfo
.
has_address
===
0
?
1
:
0
,
};
await
ctx
.
classModel
.
V5
.
CourseUserOrder
.
create
(
order
);
...
...
@@ -728,14 +727,20 @@ class UserService extends Service {
async
updateUserOrder
(
input
)
{
const
{
ctx
}
=
this
;
const
orderNo
=
input
.
order_no
||
''
;
const
columns
=
input
.
columns
||
''
;
const
columns
=
input
.
columns
||
'
{}
'
;
const
id
=
input
.
id
||
0
;
const
userUuid
=
ctx
.
userUuid
;
const
order
=
await
ctx
.
classModel
.
V5
.
CourseUserOrder
.
findOne
({
where
:
{
order_no
:
orderNo
,
is_deleted
:
0
}
});
if
(
ctx
.
isEmpty
(
order
))
{
ctx
.
failed
(
'订单不存在'
);
}
const
actInfo
=
await
ctx
.
classModel
.
CourseActImage
.
findOne
({
where
:
{
id
,
status
:
1
,
is_deleted
:
0
}
});
if
(
ctx
.
isEmpty
(
actInfo
))
{
ctx
.
failed
(
'该礼包已失效'
);
}
const
classInfo
=
await
ctx
.
classModel
.
V5
.
CourseV5Class
.
findOne
({
where
:
{
id
:
order
.
class_id
,
status
:
1
,
is_deleted
:
0
},
attributes
:
[
'has_address'
]
});
// 获取用户地址
...
...
@@ -748,7 +753,25 @@ class UserService extends Service {
address
=
JSON
.
stringify
(
address
);
}
await
ctx
.
classModel
.
V5
.
CourseUserOrder
.
update
({
address
,
columns
,
status
:
1
},
{
where
:
{
id
:
order
.
id
}
});
// 判断是否有兑换码
let
redeem
=
''
;
if
(
actInfo
.
type
===
2
)
{
const
redeemCode
=
await
ctx
.
classModel
.
V5
.
CourseRedeemCode
.
findOne
({
where
:
{
class_id
:
actInfo
.
class_id
,
status
:
1
,
is_used
:
0
,
is_deleted
:
0
},
raw
:
true
});
if
(
ctx
.
isEmpty
(
redeemCode
))
{
ctx
.
failed
(
'兑换码不足'
);
}
await
ctx
.
classModel
.
V5
.
CourseRedeemCode
.
update
({
is_used
:
1
,
user_uuid
:
userUuid
,
used_time
:
moment
().
format
(
'YYYY-MM-DD HH:mm:ss'
)
},
{
where
:
{
id
:
redeemCode
.
id
}
});
redeem
=
redeemCode
.
code
;
}
else
if
(
actInfo
.
type
===
3
)
{
const
redeemCode
=
await
ctx
.
classModel
.
V5
.
CourseV5InstitutionRedeemCode
.
findOne
({
where
:
{
class_id
:
actInfo
.
class_id
,
status
:
1
,
is_used
:
0
,
is_deleted
:
0
},
raw
:
true
});
if
(
ctx
.
isEmpty
(
redeemCode
))
{
ctx
.
failed
(
'兑换码不足'
);
}
await
ctx
.
classModel
.
V5
.
CourseV5InstitutionRedeemCode
.
update
({
is_used
:
1
,
user_uuid
:
userUuid
,
used_time
:
moment
().
format
(
'YYYY-MM-DD HH:mm:ss'
)
},
{
where
:
{
id
:
redeemCode
.
id
}
});
redeem
=
redeemCode
.
code
;
}
await
ctx
.
classModel
.
V5
.
CourseUserOrder
.
update
({
address
,
columns
,
redeem
,
status
:
1
},
{
where
:
{
id
:
order
.
id
}
});
await
ctx
.
classModel
.
CourseUserActImage
.
findOrCreate
({
where
:
{
user_uuid
:
ctx
.
userUuid
,
image_id
:
id
,
status
:
1
,
is_deleted
:
0
},
defaults
:
{
user_uuid
:
ctx
.
userUuid
,
image_id
:
id
}
});
const
ret
=
{
...
...
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