解决创建商品时规格组合选择问题
This commit is contained in:
		| @@ -77,7 +77,7 @@ router.get('/', async (req, res) => { | ||||
|       SELECT  | ||||
|         o.id, o.order_no, o.user_id, o.total_amount, o.total_points,  | ||||
|         o.status, o.address, o.created_at, o.updated_at,o.total_rongdou, | ||||
|         u.username,salesperson_id | ||||
|         u.username, o.salesperson_id, o.delivery_code, o.logistics_company | ||||
|       FROM orders o | ||||
|       LEFT JOIN users u ON o.user_id = u.id | ||||
|       ${whereClause} | ||||
|   | ||||
| @@ -211,7 +211,7 @@ router.get('/:id', async (req, res) => { | ||||
|         `SELECT * FROM category WHERE id = ?`, | ||||
|         [category[0][0].parent_id] | ||||
|       ); | ||||
|       item.parentCategory_name = parentCategory[0][0].category_name; | ||||
|       item.parentCategory_name = parentCategory[0][0]?.category_name || '无'; | ||||
|     } | ||||
|     product.category = categories; | ||||
|      | ||||
| @@ -407,22 +407,30 @@ router.post('/', async (req, res) => { | ||||
|     const {  | ||||
|       name, description, price, points_price, rongdou_price = 0, stock, category,  | ||||
|       image_url, images = [], videos = [], details, status = 'active', | ||||
|       shop_name, shop_avatar, payment_methods = ['points', 'rongdou', 'points_rongdou'], | ||||
|       specifications = [], attributes = [] | ||||
|       shop_name, shop_avatar, payment_methods = ['points', 'rongdou', 'points_rongdou'], attributes = [] | ||||
|     } = req.body; | ||||
|      | ||||
|     if (!name || !price || (!points_price && !rongdou_price) || stock === undefined) { | ||||
|       return res.status(400).json({ message: '商品名称、原价、积分价格或融豆价格、库存不能为空' }); | ||||
|     } | ||||
|      | ||||
|     // const [result] = await getDB().execute( | ||||
|     //   `INSERT INTO products (name, description, price, points_price, rongdou_price, stock, category,  | ||||
|     //    image_url, images, videos, details, shop_name, shop_avatar, payment_methods, status, created_at, updated_at)  | ||||
|     //    VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, NOW(), NOW())`, | ||||
|     //   [name, description, price, points_price, rongdou_price, stock, category || null,  | ||||
|     //    image_url, JSON.stringify(images), JSON.stringify(videos), details,  | ||||
|     //    shop_name, shop_avatar, JSON.stringify(payment_methods), status] | ||||
|     // ); | ||||
|     const [result] = await getDB().execute( | ||||
|       `INSERT INTO products (name, description, price, points_price, rongdou_price, stock, category,  | ||||
|        image_url, images, videos, details, shop_name, shop_avatar, payment_methods, status, created_at, updated_at)  | ||||
|        VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, NOW(), NOW())`, | ||||
|       `UPDATE products  | ||||
|       SET name = ?, description = ?, price = ?, points_price = ?, rongdou_price = ?, stock = ?, category = ?,  | ||||
|       image_url = ?, images = ?, videos = ?, details = ?, shop_name = ?, shop_avatar = ?, payment_methods = ?, status = ?, updated_at = NOW() | ||||
|       WHERE name = ?`, | ||||
|       [name, description, price, points_price, rongdou_price, stock, category || null,  | ||||
|        image_url, JSON.stringify(images), JSON.stringify(videos), details,  | ||||
|        shop_name, shop_avatar, JSON.stringify(payment_methods), status] | ||||
|     ); | ||||
|       image_url, JSON.stringify(images), JSON.stringify(videos), details,  | ||||
|       shop_name, shop_avatar, JSON.stringify(payment_methods), status, 'temp'] | ||||
|     ) | ||||
|      | ||||
|     const productId = result.insertId; | ||||
|      | ||||
|   | ||||
| @@ -420,7 +420,7 @@ router.put('/combinations/:id', async (req, res) => { | ||||
|             barcode, | ||||
|             weight, | ||||
|             volume, | ||||
|             is_available | ||||
|             status | ||||
|         } = req.body; | ||||
|  | ||||
|         // 检查规格组合是否存在 | ||||
| @@ -477,9 +477,9 @@ router.put('/combinations/:id', async (req, res) => { | ||||
|             updateValues.push(volume); | ||||
|         } | ||||
|  | ||||
|         if (is_available !== undefined) { | ||||
|         if (status !== undefined) { | ||||
|             updateFields.push('status = ?'); | ||||
|             updateValues.push(is_available ? 'active' : 'inactive'); | ||||
|             updateValues.push(status); | ||||
|         } | ||||
|  | ||||
|         if (updateFields.length === 0) { | ||||
| @@ -648,9 +648,34 @@ router.post('/generate-combinations', async (req, res) => { | ||||
|             const values = []; | ||||
|             const placeholders = []; | ||||
|  | ||||
|             const createProduct = ` | ||||
|             INSERT INTO products (name, price) | ||||
|             VALUES ('temp', 0) | ||||
|             ` | ||||
|             const deleteProduct = ` | ||||
|             DELETE FROM products WHERE name = 'temp' | ||||
|             ` | ||||
|             var newProductId = null; | ||||
|             if (product_id === 'new') { | ||||
|  | ||||
|                 await getDB().execute(deleteProduct); | ||||
|                 await getDB().execute(createProduct); | ||||
|  | ||||
|                 // const deleteProduct = ` | ||||
|                 // DELETE FROM products WHERE name = 'temp' | ||||
|                 // ` | ||||
|                 // await getDB().execute(deleteProduct); | ||||
|  | ||||
|                 const getProductId = ` | ||||
|                 SELECT id FROM products WHERE name = 'temp' | ||||
|                 ` | ||||
|                 const [productResult] = await getDB().execute(getProductId); | ||||
|                 newProductId = productResult[0].id; | ||||
|             } | ||||
|  | ||||
|             newCombinations.forEach(item => { | ||||
|                 values.push( | ||||
|                     product_id, | ||||
|                     newProductId === null ? product_id : newProductId, | ||||
|                     item.key, | ||||
|                     JSON.stringify(item.combination), | ||||
|                     default_stock | ||||
| @@ -672,7 +697,8 @@ router.post('/generate-combinations', async (req, res) => { | ||||
|             data: { | ||||
|                 total_combinations: combinations.length, | ||||
|                 created: createdCount, | ||||
|                 skipped: skippedCount | ||||
|                 skipped: skippedCount, | ||||
|                 product_id: newProductId === null ? product_id : newProductId | ||||
|             } | ||||
|         }); | ||||
|     } catch (error) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user