product.controller.js 4.29 KB
Newer Older
Jiwon Yoon's avatar
Jiwon Yoon committed
1
import Product from "../schemas/Product.js";
kusang96's avatar
dd    
kusang96 committed
2
3
4
5
6
7
import multer from 'multer';

const upload = multer({ dest: 'uploads/' })

const imageUpload = upload.fields([
    { name: 'main_image' },
Jiwon Yoon's avatar
Jiwon Yoon committed
8
    { name: 'detail_image'}
kusang96's avatar
kusang96 committed
9
])
Jiwon Yoon's avatar
Jiwon Yoon committed
10
11

const regist = async (req, res) => {
kusang96's avatar
kusang96 committed
12
    console.log("req.body=", req.body)
Jiwon Yoon's avatar
Jiwon Yoon committed
13
    try {
kusang96's avatar
kusang96 committed
14
        const { pro_name, price, stock, main_category, sub_category, description, colors, sizes } = req.body
kusang96's avatar
dd    
kusang96 committed
15
16
17
18
19
20
21
22
        const main_img = req.files['main_image'][0]
        const detail_img = req.files['detail_image']
        const main_imgUrl = main_img.filename
        const detail_imgUrls = []
        detail_img.forEach(file => {
            detail_imgUrls.push(file.filename)
        })
        const newProduct = await new Product({
kusang96's avatar
kusang96 committed
23
            pro_name, price, stock, main_category, sub_category, description, main_imgUrl, detail_imgUrls, colors, sizes
Jiwon Yoon's avatar
Jiwon Yoon committed
24
25
26
27
        }).save()
        res.json(newProduct)
    } catch (error) {
        console.log(error)
kusang96's avatar
dd    
kusang96 committed
28
        res.status(500).send('제품 정보 등록에 실패하였습니다. 다시 진행해 주십시오.')
Jiwon Yoon's avatar
Jiwon Yoon committed
29
30
31
    }
}

kusang96's avatar
kusang96 committed
32
const getToHome = async (req, res) => {
kusang96's avatar
0115    
kusang96 committed
33
    try {
kusang96's avatar
kusang96 committed
34
        const bestProduct = await Product.find({}).sort({ purchase: -1 }).limit(6)
kusang96's avatar
0115    
kusang96 committed
35
        const newProduct = await Product.find({}).sort({ createdAt: -1 }).limit(6)
36
37
        // console.log("best=", bestProduct)
        // console.log("new=", newProduct)
kusang96's avatar
kusang96 committed
38
        res.json({ bestProduct, newProduct })
kusang96's avatar
0115    
kusang96 committed
39
40
41
42
43
    } catch {
        res.status(500).send('상품을 불러오지 못했습니다.')
    }
}

kusang96's avatar
kusang96 committed
44
const getAll = async (req, res) => {
이재연's avatar
0113    
이재연 committed
45
    try {
kusang96's avatar
kusang96 committed
46
47
48
49
50
51
52
53
54
55
56
        if (req.query.product) {
            const productslist = await Product.find({ pro_name: { $regex: new RegExp(req.query.product) } }).sort({ createdAt: -1 })
            if (productslist.length == 0) {
                res.status(404).send('상품을 찾을 수 없습니다.')
            } else {
                res.json(productslist)
            }
        } else {
            const productslist = await Product.find({}).sort({ createdAt: -1 })
            res.json(productslist)
        }
이재연's avatar
0113    
이재연 committed
57
58
59
60
61
    } catch (error) {
        res.status(500).send('상품을 불러오지 못했습니다.')
    }
}

kusang96's avatar
kusang96 committed
62
63
64
65
66
67
68
const getlist = (req, res) => {
    try {
        res.json(req.productslist)
    } catch (error) {
        res.status(500).send('상품을 불러오지 못했습니다.')
    }
}
이재연's avatar
dd    
이재연 committed
69

박상호's avatar
박상호 committed
70

이재연's avatar
0113    
이재연 committed
71
const categoryId = async (req, res, next, category) => {
kusang96's avatar
kusang96 committed
72
    console.log("req=", req.query.product)
이재연's avatar
0113    
이재연 committed
73
    try {
kusang96's avatar
kusang96 committed
74
75
76
77
78
79
80
81
82
83
84
        if (req.query.product) {
            const productslist = await Product.find({ main_category: category, pro_name: { $regex: new RegExp(req.query.product) } })
            if (productslist.length == 0) {
                res.status(404).send('상품을 찾을 수 없습니다.')
            } else {
                req.productslist = productslist
            }
        } else {
            const productslist = await Product.find({ main_category: category })
            req.productslist = productslist
        }
이재연's avatar
0113    
이재연 committed
85
86
87
88
89
        next()
    } catch (error) {
        res.status(500).send('상품을 불러오지 못했습니다.')
    }
}
이재연's avatar
dd    
이재연 committed
90

박상호's avatar
박상호 committed
91
const subname = async (req, res) => {
박상호's avatar
박상호 committed
92
    console.log("req.query", req.query)
kusang96's avatar
kusang96 committed
93
    try {
박상호's avatar
박상호 committed
94
        const findSubname = await Product.find({ sub_category: req.query.subname })
박상호's avatar
박상호 committed
95
96
        console.log("findSubname111=", findSubname)
        res.send(findSubname)
이재연's avatar
dd    
이재연 committed
97
    } catch (error) {
박상호's avatar
박상호 committed
98
        res.send('상품을 불러오지 못했습니다.')
이재연's avatar
dd    
이재연 committed
99
100
101
    }
}

102
103
104
105
106
107
const plusPurchase = async (req, res) => {
    const { products } = req.body
    try {
        for (let i = 0; i < products.length; i++) {
            const count = products[i].count
            const product = await Product.findOne(
박상호's avatar
박상호 committed
108
                { _id: products[i].productId._id }
109
110
            )
            const purchase = product.purchase
111
            const stock = product.stock
112
113
            await Product.updateOne(
                { _id: products[i].productId._id },
114
115
116
117
118
119
                { $set: 
                    { 
                        purchase: count + purchase, 
                        stock: stock - count 
                    } 
                }
120
121
            )
        }
122
        res.send("구매수 늘리기, 재고수 줄이기 성공")
123
124
125
126
    } catch (error) {
        res.status(500).send('구매숫자를 늘리지 못함')
    }
}
이재연's avatar
dd    
이재연 committed
127

박상호's avatar
박상호 committed
128
export default { imageUpload, regist, getToHome, getAll, categoryId, getlist, subname, plusPurchase }