125 lines
3.5 KiB
Go
125 lines
3.5 KiB
Go
package service
|
||
|
||
import (
|
||
"dianshang/internal/model"
|
||
"fmt"
|
||
"time"
|
||
|
||
"gorm.io/gorm"
|
||
)
|
||
|
||
// AfterSaleService 售后服务
|
||
type AfterSaleService struct {
|
||
db *gorm.DB
|
||
}
|
||
|
||
// NewAfterSaleService 创建售后服务
|
||
func NewAfterSaleService(db *gorm.DB) *AfterSaleService {
|
||
return &AfterSaleService{
|
||
db: db,
|
||
}
|
||
}
|
||
|
||
// GetUserAfterSales 获取用户售后列表
|
||
func (s *AfterSaleService) GetUserAfterSales(userID uint, page, pageSize int, status int) ([]model.AfterSale, int64, error) {
|
||
var afterSales []model.AfterSale
|
||
var total int64
|
||
|
||
query := s.db.Model(&model.AfterSale{}).Where("user_id = ?", userID)
|
||
|
||
// 如果指定了状态,添加状态过滤
|
||
if status > 0 {
|
||
query = query.Where("status = ?", status)
|
||
}
|
||
|
||
// 获取总数
|
||
if err := query.Count(&total).Error; err != nil {
|
||
return nil, 0, err
|
||
}
|
||
|
||
// 分页查询,预加载关联数据
|
||
offset := (page - 1) * pageSize
|
||
if err := query.Preload("Order").Preload("OrderItem").Preload("User").
|
||
Order("created_at DESC").
|
||
Offset(offset).Limit(pageSize).
|
||
Find(&afterSales).Error; err != nil {
|
||
return nil, 0, err
|
||
}
|
||
|
||
return afterSales, total, nil
|
||
}
|
||
|
||
// GetAfterSaleDetail 获取售后详情
|
||
func (s *AfterSaleService) GetAfterSaleDetail(userID, afterSaleID uint) (*model.AfterSale, error) {
|
||
var afterSale model.AfterSale
|
||
|
||
if err := s.db.Where("id = ? AND user_id = ?", afterSaleID, userID).
|
||
Preload("Order").Preload("OrderItem").Preload("User").
|
||
First(&afterSale).Error; err != nil {
|
||
return nil, err
|
||
}
|
||
|
||
return &afterSale, nil
|
||
}
|
||
|
||
// CreateAfterSale 创建售后申请
|
||
func (s *AfterSaleService) CreateAfterSale(userID uint, req *CreateAfterSaleRequest) (*model.AfterSale, error) {
|
||
// 验证订单是否存在且属于该用户
|
||
var order model.Order
|
||
if err := s.db.Where("id = ? AND user_id = ?", req.OrderID, userID).First(&order).Error; err != nil {
|
||
return nil, fmt.Errorf("订单不存在或无权限")
|
||
}
|
||
|
||
// 验证订单项是否存在
|
||
var orderItem model.OrderItem
|
||
if err := s.db.Where("id = ? AND order_id = ?", req.OrderItemID, req.OrderID).First(&orderItem).Error; err != nil {
|
||
return nil, fmt.Errorf("订单项不存在")
|
||
}
|
||
|
||
// 创建售后记录
|
||
afterSale := &model.AfterSale{
|
||
OrderID: req.OrderID,
|
||
OrderItemID: req.OrderItemID,
|
||
UserID: userID,
|
||
Type: req.Type,
|
||
Reason: req.Reason,
|
||
Description: req.Description,
|
||
Images: req.Images,
|
||
Status: 1, // 1待审核
|
||
CreatedAt: time.Now(),
|
||
UpdatedAt: time.Now(),
|
||
}
|
||
|
||
if err := s.db.Create(afterSale).Error; err != nil {
|
||
return nil, err
|
||
}
|
||
|
||
// 预加载关联数据
|
||
if err := s.db.Preload("Order").Preload("OrderItem").Preload("User").
|
||
First(afterSale, afterSale.ID).Error; err != nil {
|
||
return nil, err
|
||
}
|
||
|
||
return afterSale, nil
|
||
}
|
||
|
||
// CreateAfterSaleRequest 创建售后申请请求
|
||
type CreateAfterSaleRequest struct {
|
||
OrderID uint `json:"order_id" binding:"required"`
|
||
OrderItemID uint `json:"order_item_id" binding:"required"`
|
||
Type int `json:"type" binding:"required"` // 1退货,2换货,3维修
|
||
Reason string `json:"reason" binding:"required"`
|
||
Description string `json:"description"`
|
||
Images model.JSONSlice `json:"images"`
|
||
}
|
||
|
||
// UpdateAfterSaleStatus 更新售后状态
|
||
func (s *AfterSaleService) UpdateAfterSaleStatus(afterSaleID uint, status int, adminRemark string) error {
|
||
return s.db.Model(&model.AfterSale{}).
|
||
Where("id = ?", afterSaleID).
|
||
Updates(map[string]interface{}{
|
||
"status": status,
|
||
"admin_remark": adminRemark,
|
||
"updated_at": time.Now(),
|
||
}).Error
|
||
} |