Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
F
final-exam
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Nawasan Wisitsingkhon
final-exam
Commits
5d635a06
Commit
5d635a06
authored
Oct 03, 2023
by
Nawasan Wisitsingkhon
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add order from cart
parent
d3d5cc44
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
199 additions
and
1 deletion
+199
-1
OrderController.js
app/controllers/OrderController.js
+72
-0
UserController.js
app/controllers/UserController.js
+2
-0
user.js
app/routes/user.js
+3
-0
ConfirmOrder.js
src/components/order/ConfirmOrder.js
+115
-0
cart.js
src/pages/cart.js
+7
-1
No files found.
app/controllers/OrderController.js
0 → 100644
View file @
5d635a06
import
{
Request
,
Response
}
from
"express"
;
import
db
from
"../models/prismaClient"
;
const
OrderController
=
{
/**
*
* @param {Request} req
* @param {Response} res
*/
async
create
(
req
,
res
)
{
try
{
const
{
address
,
sending
}
=
req
.
body
;
let
cart
=
await
db
.
cart
.
findMany
({
where
:
{
user_id
:
Number
(
req
.
user
.
id
)
},
});
if
(
!
cart
.
length
||
!
address
||
!
sending
)
throw
200
;
let
total_price
=
0
;
const
cartProduct
=
[];
for
(
let
i
=
0
;
i
<
cart
.
length
;
i
++
)
{
let
getpd
=
await
db
.
product
.
findFirst
({
where
:
{
id
:
Number
(
cart
[
i
].
product_id
)
},
});
getpd
.
real_price
=
getpd
.
price
-
getpd
.
price
*
(
getpd
.
discount
/
100
);
total_price
+=
getpd
.
real_price
;
cartProduct
.
push
(
getpd
);
}
// return res.json({ cartProduct, total_price });
const
order
=
await
db
.
order
.
create
({
data
:
{
user_id
:
Number
(
req
.
user
.
id
),
total_price
:
Number
(
total_price
),
product_count
:
cart
.
length
,
// ****
address
:
address
,
// ****
shipping_price
:
sending
,
pay_status
:
0
,
send_status
:
0
,
},
});
const
orderDetail
=
[];
for
(
let
i
=
0
;
i
<
cartProduct
.
length
;
i
++
)
{
orderDetail
.
push
({
count
:
1
,
order_id
:
order
.
id
,
product_discount
:
cartProduct
[
i
].
discount
,
product_id
:
cartProduct
[
i
].
id
,
product_price
:
cartProduct
[
i
].
price
,
user_id
:
Number
(
req
.
user
.
id
),
});
}
await
db
.
order_detail
.
createMany
({
data
:
orderDetail
,
});
await
db
.
cart
.
deleteMany
({
where
:
{
user_id
:
Number
(
req
.
user
.
id
)
}
});
await
db
.
user
.
update
({
data
:
{
address
},
where
:
{
id
:
Number
(
req
.
user
.
id
)
},
});
await
db
.
$disconnect
();
res
.
json
({
status
:
201
,
message
:
"create order success"
});
}
catch
(
err
)
{
console
.
log
(
err
);
res
.
json
({
status
:
200
,
message
:
"server error with some error"
});
}
},
};
export
default
OrderController
;
app/controllers/UserController.js
View file @
5d635a06
...
@@ -16,6 +16,7 @@ const UserController = {
...
@@ -16,6 +16,7 @@ const UserController = {
delete
userAll
[
i
].
google_token
;
delete
userAll
[
i
].
google_token
;
delete
userAll
[
i
].
rank
;
delete
userAll
[
i
].
rank
;
delete
userAll
[
i
].
password
;
delete
userAll
[
i
].
password
;
delete
userAll
[
i
].
address
;
}
}
res
.
json
(
userAll
);
res
.
json
(
userAll
);
},
},
...
@@ -99,6 +100,7 @@ const UserController = {
...
@@ -99,6 +100,7 @@ const UserController = {
name
:
user
.
name
,
name
:
user
.
name
,
email
:
user
.
email
,
email
:
user
.
email
,
phone
:
user
.
phone
,
phone
:
user
.
phone
,
address
:
user
.
address
??
""
,
photo
:
user
.
photo
,
photo
:
user
.
photo
,
username
:
user
.
username
,
username
:
user
.
username
,
rank
:
user
.
rank
,
rank
:
user
.
rank
,
...
...
app/routes/user.js
View file @
5d635a06
import
express
from
"express"
;
import
express
from
"express"
;
import
WishlistController
from
"../controllers/WishlistController"
;
import
WishlistController
from
"../controllers/WishlistController"
;
import
CartController
from
"../controllers/CartController"
;
import
CartController
from
"../controllers/CartController"
;
import
OrderController
from
"../controllers/OrderController"
;
const
UserRouter
=
express
.
Router
();
const
UserRouter
=
express
.
Router
();
UserRouter
.
get
(
"/wishlist"
,
WishlistController
.
index
);
UserRouter
.
get
(
"/wishlist"
,
WishlistController
.
index
);
...
@@ -11,4 +12,6 @@ UserRouter.get("/cart", CartController.index);
...
@@ -11,4 +12,6 @@ UserRouter.get("/cart", CartController.index);
UserRouter
.
post
(
"/cart"
,
CartController
.
create
);
UserRouter
.
post
(
"/cart"
,
CartController
.
create
);
UserRouter
.
delete
(
"/cart"
,
CartController
.
delete
);
UserRouter
.
delete
(
"/cart"
,
CartController
.
delete
);
UserRouter
.
post
(
"/order"
,
OrderController
.
create
);
export
default
UserRouter
;
export
default
UserRouter
;
src/components/order/ConfirmOrder.js
0 → 100644
View file @
5d635a06
import
{
useState
,
useEffect
,
useContext
}
from
"react"
;
import
Button
from
"@mui/material/Button"
;
import
TextField
from
"@mui/material/TextField"
;
import
Dialog
from
"@mui/material/Dialog"
;
import
DialogActions
from
"@mui/material/DialogActions"
;
import
DialogContent
from
"@mui/material/DialogContent"
;
import
DialogTitle
from
"@mui/material/DialogTitle"
;
import
{
Alert
,
FormControl
,
InputLabel
,
MenuItem
,
Select
,
Snackbar
,
}
from
"@mui/material"
;
import
axios
from
"axios"
;
import
{
CartContext
,
UserContext
}
from
"@/pages/_app"
;
export
default
function
ConfirmOrder
({
open
,
handleClose
})
{
const
user
=
useContext
(
UserContext
);
const
cart
=
useContext
(
CartContext
);
const
[
message
,
setMessage
]
=
useState
({
message
:
""
,
error
:
false
});
const
[
address
,
setAddress
]
=
useState
(
user
.
value
?.
address
??
""
);
const
[
sending
,
setSending
]
=
useState
(
40
);
/**
*
* @param {FormDataEvent} e
*/
async
function
onOrder
(
e
)
{
e
.
preventDefault
();
try
{
let
response
=
await
axios
.
post
(
"/api/u/order"
,
{
address
,
sending
},
{
headers
:
{
token
:
user
.
value
.
token
}
}
);
console
.
log
(
response
.
data
);
setMessage
({
message
:
"สั่งซื้อสำเร็จ"
,
error
:
false
});
setTimeout
(()
=>
{
setMessage
({
message
:
""
,
error
:
false
});
},
2000
);
cart
.
fetch
();
handleClose
();
}
catch
(
err
)
{
setMessage
({
message
:
"พบข้อผิดพลาด กรุณาลองใหม่อีกครั้ง"
,
error
:
true
});
setTimeout
(()
=>
{
setMessage
({
message
:
""
,
error
:
true
});
},
2000
);
}
}
return
(
<>
<
Snackbar
anchorOrigin
=
{{
horizontal
:
"center"
,
vertical
:
"top"
}}
open
=
{
!!
message
.
message
.
length
}
>
<
Alert
severity
=
{
message
.
error
?
"error"
:
"success"
}
>
{
message
.
message
}
<
/Alert
>
<
/Snackbar
>
<
Dialog
open
=
{
open
}
onClose
=
{
handleClose
}
>
<
form
onSubmit
=
{
onOrder
}
>
<
DialogTitle
>
ยืนยันการสั่งซื้อ
<
/DialogTitle
>
<
DialogContent
className
=
"text-center"
>
<
div
className
=
"text-left"
>
<
TextField
fullWidth
className
=
"m-1"
label
=
"ที่อยู่"
variant
=
"standard"
multiline
rows
=
{
3
}
value
=
{
address
}
onChange
=
{(
e
)
=>
setAddress
(
e
.
target
.
value
)}
required
/>
<
/div
>
<
FormControl
className
=
"m-1"
variant
=
"standard"
sx
=
{{
minWidth
:
100
}}
>
<
InputLabel
>
จัดส่ง
<
/InputLabel
>
<
Select
value
=
{
sending
}
onChange
=
{(
e
)
=>
setSending
(
Number
(
e
.
target
.
value
))}
required
>
{[
[
"เร็ว"
,
100
],
[
"ธรรมดา"
,
40
],
[
"ช้า"
,
20
],
].
map
((
ls
,
idx
)
=>
(
<
MenuItem
key
=
{
idx
}
selected
=
{
ls
[
1
]
===
40
}
value
=
{
ls
[
1
]}
>
{
ls
[
0
]}
<
/MenuItem
>
))}
<
/Select
>
<
/FormControl
>
<
/DialogContent
>
<
DialogActions
>
<
Button
color
=
"error"
onClick
=
{
handleClose
}
>
ยกเลิก
<
/Button
>
<
Button
type
=
"submit"
>
ยืนยัน
<
/Button
>
<
/DialogActions
>
<
/form
>
<
/Dialog
>
<
/
>
);
}
src/pages/cart.js
View file @
5d635a06
...
@@ -17,6 +17,7 @@ import { ShoppingCart } from "@mui/icons-material";
...
@@ -17,6 +17,7 @@ import { ShoppingCart } from "@mui/icons-material";
import
PopupAlert
from
"@/components/PopupAlert"
;
import
PopupAlert
from
"@/components/PopupAlert"
;
import
Head
from
"next/head"
;
import
Head
from
"next/head"
;
import
{
ShoppingBag
}
from
"@mui/icons-material"
;
import
{
ShoppingBag
}
from
"@mui/icons-material"
;
import
ConfirmOrder
from
"@/components/order/ConfirmOrder"
;
export
default
function
Cart
()
{
export
default
function
Cart
()
{
const
user
=
useContext
(
UserContext
);
const
user
=
useContext
(
UserContext
);
...
@@ -24,6 +25,7 @@ export default function Cart() {
...
@@ -24,6 +25,7 @@ export default function Cart() {
const
cart
=
useContext
(
CartContext
);
const
cart
=
useContext
(
CartContext
);
const
[
products
,
setProducts
]
=
useState
([]);
const
[
products
,
setProducts
]
=
useState
([]);
const
[
message
,
setMessage
]
=
useState
({
error
:
false
,
message
:
""
});
const
[
message
,
setMessage
]
=
useState
({
error
:
false
,
message
:
""
});
const
[
orderState
,
setOrderState
]
=
useState
(
false
);
const
router
=
useRouter
();
const
router
=
useRouter
();
const
[
CartProduct
,
setCartProduct
]
=
useState
([]);
const
[
CartProduct
,
setCartProduct
]
=
useState
([]);
...
@@ -135,7 +137,7 @@ export default function Cart() {
...
@@ -135,7 +137,7 @@ export default function Cart() {
<
/TableBody
>
<
/TableBody
>
<
/Table
>
<
/Table
>
<
Box
sx
=
{{
textAlign
:
"right"
,
p
:
1
}}
>
<
Box
sx
=
{{
textAlign
:
"right"
,
p
:
1
}}
>
<
Button
size
=
"large"
>
<
Button
size
=
"large"
onClick
=
{()
=>
setOrderState
(
true
)}
>
<
ShoppingBag
/>
สั่งซื้อ
<
ShoppingBag
/>
สั่งซื้อ
<
/Button
>
<
/Button
>
<
/Box
>
<
/Box
>
...
@@ -148,6 +150,10 @@ export default function Cart() {
...
@@ -148,6 +150,10 @@ export default function Cart() {
<
/div
>
<
/div
>
)}
)}
<
/Paper
>
<
/Paper
>
<
ConfirmOrder
open
=
{
orderState
}
handleClose
=
{()
=>
setOrderState
(
false
)}
/
>
<
/Box
>
<
/Box
>
<
/
>
<
/
>
);
);
...
...
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