done
This commit is contained in:
200
routes/afterSales.js
Normal file
200
routes/afterSales.js
Normal file
@@ -0,0 +1,200 @@
|
||||
// routes/afterSales.js —— 售后管理 CRUD
|
||||
const { pool } = require('../db')
|
||||
|
||||
function pagination(query) {
|
||||
const page = Math.max(Number(query.page) || 1, 1)
|
||||
const pageSize = Math.min(Math.max(Number(query.pageSize) || 10, 1), 100)
|
||||
const offset = (page - 1) * pageSize
|
||||
return { page, pageSize, offset }
|
||||
}
|
||||
|
||||
const LIST_SELECT = `
|
||||
SELECT
|
||||
a.*,
|
||||
cu.name AS customer_name,
|
||||
e.name AS employee_name
|
||||
FROM after_sales a
|
||||
LEFT JOIN customers cu ON a.customer_id = cu.id
|
||||
LEFT JOIN employees e ON a.employee_id = e.id
|
||||
`
|
||||
|
||||
// GET /api/after-sales —— 列表
|
||||
async function list(req, res) {
|
||||
try {
|
||||
const { page, pageSize, offset } = pagination(req.query)
|
||||
const { handle_status, customer_name } = req.query
|
||||
|
||||
let where = 'WHERE 1=1'
|
||||
const params = []
|
||||
|
||||
if (handle_status) {
|
||||
where += ' AND a.handle_status = ?'
|
||||
params.push(handle_status)
|
||||
}
|
||||
if (customer_name) {
|
||||
where += ' AND cu.name LIKE ?'
|
||||
params.push(`%${customer_name}%`)
|
||||
}
|
||||
|
||||
const [[{ total }]] = await pool.query(
|
||||
`SELECT COUNT(*) AS total FROM after_sales a
|
||||
LEFT JOIN customers cu ON a.customer_id = cu.id
|
||||
LEFT JOIN employees e ON a.employee_id = e.id
|
||||
${where}`,
|
||||
params
|
||||
)
|
||||
|
||||
const [rows] = await pool.query(
|
||||
`${LIST_SELECT} ${where} ORDER BY a.id DESC LIMIT ? OFFSET ?`,
|
||||
[...params, pageSize, offset]
|
||||
)
|
||||
|
||||
res.json({
|
||||
code: 0,
|
||||
message: 'ok',
|
||||
data: {
|
||||
list: rows,
|
||||
total,
|
||||
page,
|
||||
pageSize,
|
||||
totalPages: Math.ceil(total / pageSize),
|
||||
},
|
||||
})
|
||||
} catch (e) {
|
||||
console.error('[after-sales list] error:', e)
|
||||
res.status(500).json({ code: 500, message: e.message })
|
||||
}
|
||||
}
|
||||
|
||||
// GET /api/after-sales/:id —— 详情
|
||||
async function detail(req, res) {
|
||||
try {
|
||||
const [rows] = await pool.query(
|
||||
`${LIST_SELECT} WHERE a.id = ?`,
|
||||
[req.params.id]
|
||||
)
|
||||
if (rows.length === 0) {
|
||||
return res.status(404).json({ code: 404, message: '售后记录不存在' })
|
||||
}
|
||||
res.json({ code: 0, message: 'ok', data: rows[0] })
|
||||
} catch (e) {
|
||||
console.error('[after-sales detail] error:', e)
|
||||
res.status(500).json({ code: 500, message: e.message })
|
||||
}
|
||||
}
|
||||
|
||||
// POST /api/after-sales —— 新增
|
||||
async function create(req, res) {
|
||||
const {
|
||||
customer_id, feedback, employee_id, handle_method,
|
||||
handle_status, service_date, remark,
|
||||
} = req.body || {}
|
||||
|
||||
if (!customer_id) {
|
||||
return res.status(400).json({ code: 400, message: '客户ID必填' })
|
||||
}
|
||||
if (!feedback) {
|
||||
return res.status(400).json({ code: 400, message: '售后反馈内容必填' })
|
||||
}
|
||||
|
||||
try {
|
||||
// 校验客户存在
|
||||
const [cust] = await pool.query('SELECT id FROM customers WHERE id = ?', [customer_id])
|
||||
if (cust.length === 0) {
|
||||
return res.status(400).json({ code: 400, message: '关联客户不存在' })
|
||||
}
|
||||
// 校验业务员
|
||||
if (employee_id) {
|
||||
const [emp] = await pool.query('SELECT id FROM employees WHERE id = ?', [employee_id])
|
||||
if (emp.length === 0) {
|
||||
return res.status(400).json({ code: 400, message: '关联业务员不存在' })
|
||||
}
|
||||
}
|
||||
|
||||
const [result] = await pool.query(
|
||||
`INSERT INTO after_sales
|
||||
(customer_id, feedback, employee_id, handle_method, handle_status, service_date, remark)
|
||||
VALUES (?, ?, ?, ?, ?, ?, ?)`,
|
||||
[customer_id, feedback,
|
||||
employee_id || null,
|
||||
handle_method || null,
|
||||
handle_status || '待处理',
|
||||
service_date || null,
|
||||
remark || null]
|
||||
)
|
||||
|
||||
const [rows] = await pool.query(`${LIST_SELECT} WHERE a.id = ?`, [result.insertId])
|
||||
res.json({ code: 0, message: 'ok', data: rows[0] })
|
||||
} catch (e) {
|
||||
console.error('[after-sales create] error:', e)
|
||||
res.status(500).json({ code: 500, message: e.message })
|
||||
}
|
||||
}
|
||||
|
||||
// PUT /api/after-sales/:id —— 更新
|
||||
async function update(req, res) {
|
||||
const { id } = req.params
|
||||
const fields = [
|
||||
'customer_id', 'feedback', 'employee_id', 'handle_method',
|
||||
'handle_status', 'service_date', 'remark',
|
||||
]
|
||||
|
||||
try {
|
||||
const [existing] = await pool.query('SELECT id FROM after_sales WHERE id = ?', [id])
|
||||
if (existing.length === 0) {
|
||||
return res.status(404).json({ code: 404, message: '售后记录不存在' })
|
||||
}
|
||||
|
||||
if (req.body.customer_id) {
|
||||
const [cust] = await pool.query('SELECT id FROM customers WHERE id = ?', [req.body.customer_id])
|
||||
if (cust.length === 0) {
|
||||
return res.status(400).json({ code: 400, message: '关联客户不存在' })
|
||||
}
|
||||
}
|
||||
if (req.body.employee_id) {
|
||||
const [emp] = await pool.query('SELECT id FROM employees WHERE id = ?', [req.body.employee_id])
|
||||
if (emp.length === 0) {
|
||||
return res.status(400).json({ code: 400, message: '关联业务员不存在' })
|
||||
}
|
||||
}
|
||||
|
||||
const sets = []
|
||||
const params = []
|
||||
for (const f of fields) {
|
||||
if (req.body[f] !== undefined) {
|
||||
sets.push(`${f} = ?`)
|
||||
params.push(req.body[f])
|
||||
}
|
||||
}
|
||||
if (sets.length === 0) {
|
||||
return res.status(400).json({ code: 400, message: '没有需要更新的字段' })
|
||||
}
|
||||
|
||||
params.push(id)
|
||||
await pool.query(`UPDATE after_sales SET ${sets.join(', ')} WHERE id = ?`, params)
|
||||
|
||||
const [rows] = await pool.query(`${LIST_SELECT} WHERE a.id = ?`, [id])
|
||||
res.json({ code: 0, message: 'ok', data: rows[0] })
|
||||
} catch (e) {
|
||||
console.error('[after-sales update] error:', e)
|
||||
res.status(500).json({ code: 500, message: e.message })
|
||||
}
|
||||
}
|
||||
|
||||
// DELETE /api/after-sales/:id —— 删除
|
||||
async function remove(req, res) {
|
||||
const { id } = req.params
|
||||
try {
|
||||
const [existing] = await pool.query('SELECT id FROM after_sales WHERE id = ?', [id])
|
||||
if (existing.length === 0) {
|
||||
return res.status(404).json({ code: 404, message: '售后记录不存在' })
|
||||
}
|
||||
await pool.query('DELETE FROM after_sales WHERE id = ?', [id])
|
||||
res.json({ code: 0, message: 'ok' })
|
||||
} catch (e) {
|
||||
console.error('[after-sales delete] error:', e)
|
||||
res.status(500).json({ code: 500, message: e.message })
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = { list, detail, create, update, remove }
|
||||
Reference in New Issue
Block a user