Add Daily Sales and Distributed Payment

This commit is contained in:
aditya.siregar 2024-08-02 15:16:28 +07:00
parent eff502b24a
commit 6a1dffa750
7 changed files with 101 additions and 1 deletions

View File

@ -187,3 +187,8 @@ type ProductDailySales struct {
PaymentType string PaymentType string
Total float64 Total float64
} }
type PaymentTypeDistribution struct {
PaymentType string
Count int
}

View File

@ -26,6 +26,7 @@ func (h *Handler) Route(group *gin.RouterGroup, jwt gin.HandlerFunc) {
route.GET("/ticket-sold", jwt, h.CountSoldOfTicket) route.GET("/ticket-sold", jwt, h.CountSoldOfTicket)
route.GET("/sum-amount", jwt, h.SumAmount) route.GET("/sum-amount", jwt, h.SumAmount)
route.GET("/daily-sales", jwt, h.GetDailySalesTicket) route.GET("/daily-sales", jwt, h.GetDailySalesTicket)
route.GET("/payment-distribution", jwt, h.GetPaymentDistributionChart)
} }
func NewHandler(service services.Order) *Handler { func NewHandler(service services.Order) *Handler {
@ -264,6 +265,29 @@ func (h *Handler) GetDailySalesTicket(c *gin.Context) {
}) })
} }
func (h *Handler) GetPaymentDistributionChart(c *gin.Context) {
var req request.OrderParam
if err := c.ShouldBindQuery(&req); err != nil {
response.ErrorWrapper(c, errors.ErrorBadRequest)
return
}
ctx := request.GetMyContext(c)
resp, err := h.service.GetPaymentDistribution(ctx, req.ToOrderEntity(ctx))
if err != nil {
response.ErrorWrapper(c, err)
return
}
c.JSON(http.StatusOK, response.BaseResponse{
Success: true,
Status: http.StatusOK,
Data: h.toPaymentDistributionChart(resp),
})
}
func (h *Handler) toHistoryOrderList(resp []*entity.HistoryOrder, total int64, req request.OrderParam) response.HistoryOrderList { func (h *Handler) toHistoryOrderList(resp []*entity.HistoryOrder, total int64, req request.OrderParam) response.HistoryOrderList {
var orders []response.HistoryOrder var orders []response.HistoryOrder
for _, b := range resp { for _, b := range resp {
@ -291,3 +315,14 @@ func (h *Handler) toDailySales(resp []entity.ProductDailySales) []response.Produ
} }
return dailySales return dailySales
} }
func (h *Handler) toPaymentDistributionChart(resp []entity.PaymentTypeDistribution) []response.PaymentDistribution {
var dailySales []response.PaymentDistribution
for _, b := range resp {
dailySales = append(dailySales, response.PaymentDistribution{
PaymentType: b.PaymentType,
Count: b.Count,
})
}
return dailySales
}

View File

@ -119,3 +119,8 @@ type ProductDailySales struct {
PaymentType string `json:"payment_type"` PaymentType string `json:"payment_type"`
Total float64 `json:"total"` Total float64 `json:"total"`
} }
type PaymentDistribution struct {
PaymentType string `json:"payment_type"`
Count int `json:"count"`
}

View File

@ -227,7 +227,7 @@ func (r *OrderRepository) GetDailySalesMetrics(ctx context.Context, req entity.O
// Build the query with GORM // Build the query with GORM
query := r.db.WithContext(ctx). query := r.db.WithContext(ctx).
Table("orders o"). Table("orders o").
Select(`DATE_TRUNC(?, o.created_at) AS day, s.id AS site_id, s.name AS site_name, o.payment_type, SUM(oi.qty * oi.price) AS total_quantity`, dateTrunc). Select(`DATE_TRUNC(?, o.created_at) AS day, s.id AS site_id, s.name AS site_name, o.payment_type, SUM(oi.qty * oi.price) AS total`, dateTrunc).
Joins("JOIN order_items oi ON o.id = oi.order_id"). Joins("JOIN order_items oi ON o.id = oi.order_id").
Joins("JOIN sites s ON o.site_id = s.id"). Joins("JOIN sites s ON o.site_id = s.id").
Where("o.status = ?", "PAID"). Where("o.status = ?", "PAID").
@ -250,3 +250,45 @@ func (r *OrderRepository) GetDailySalesMetrics(ctx context.Context, req entity.O
return sales, nil return sales, nil
} }
func (r *OrderRepository) GetPaymentTypeDistribution(ctx context.Context, req entity.OrderSearch) ([]entity.PaymentTypeDistribution, error) {
var distribution []entity.PaymentTypeDistribution
var periodFilter string
now := time.Now()
switch req.Period {
case "1d":
periodFilter = now.Add(-24 * time.Hour).Format("2006-01-02 15:04:05")
case "7d":
periodFilter = now.Add(-7 * 24 * time.Hour).Format("2006-01-02 15:04:05")
case "1m":
periodFilter = now.AddDate(0, -1, 0).Format("2006-01-02 15:04:05")
case "1y":
periodFilter = now.AddDate(-1, 0, 0).Format("2006-01-02 15:04:05")
default:
periodFilter = now.AddDate(0, -1, 0).Format("2006-01-02 15:04:05") // Default to last month
}
query := r.db.WithContext(ctx).
Table("orders o").
Select("payment_type, COUNT(*) as count").
Where("status = ?", "PAID").
Where("o.created_at >= ?", periodFilter)
if req.PartnerID != nil {
query = query.Where("o.partner_id = ?", *req.PartnerID)
}
if req.SiteID != nil {
query = query.Where("o.site_id = ?", *req.SiteID)
}
query = query.Group("payment_type")
if err := query.Scan(&distribution).Error; err != nil {
return nil, err
}
return distribution, nil
}

View File

@ -145,6 +145,7 @@ type Order interface {
SumAmount(ctx mycontext.Context, req entity.OrderSearch) (*entity.OrderDB, error) SumAmount(ctx mycontext.Context, req entity.OrderSearch) (*entity.OrderDB, error)
CountSoldOfTicket(ctx mycontext.Context, req entity.OrderSearch) (*entity.TicketSoldDB, error) CountSoldOfTicket(ctx mycontext.Context, req entity.OrderSearch) (*entity.TicketSoldDB, error)
GetDailySalesMetrics(ctx context.Context, req entity.OrderSearch) ([]entity.ProductDailySales, error) GetDailySalesMetrics(ctx context.Context, req entity.OrderSearch) ([]entity.ProductDailySales, error)
GetPaymentTypeDistribution(ctx context.Context, req entity.OrderSearch) ([]entity.PaymentTypeDistribution, error)
} }
type OSSRepository interface { type OSSRepository interface {

View File

@ -335,6 +335,17 @@ func (s OrderService) GetDailySales(ctx mycontext.Context, req entity.OrderSearc
return dailySales, nil return dailySales, nil
} }
func (s OrderService) GetPaymentDistribution(ctx mycontext.Context, req entity.OrderSearch) ([]entity.PaymentTypeDistribution, error) {
paymentDistribution, err := s.repo.GetPaymentTypeDistribution(ctx, req)
if err != nil {
logger.ContextLogger(ctx).Error("error when get all history orders", zap.Error(err))
return nil, err
}
return paymentDistribution, nil
}
func (s OrderService) SumAmount(ctx mycontext.Context, req entity.OrderSearch) (*entity.Order, error) { func (s OrderService) SumAmount(ctx mycontext.Context, req entity.OrderSearch) (*entity.Order, error) {
amount, err := s.repo.SumAmount(ctx, req) amount, err := s.repo.SumAmount(ctx, req)

View File

@ -115,6 +115,7 @@ type Order interface {
CountSoldOfTicket(ctx mycontext.Context, req entity.OrderSearch) (*entity.TicketSold, error) CountSoldOfTicket(ctx mycontext.Context, req entity.OrderSearch) (*entity.TicketSold, error)
SumAmount(ctx mycontext.Context, req entity.OrderSearch) (*entity.Order, error) SumAmount(ctx mycontext.Context, req entity.OrderSearch) (*entity.Order, error)
GetDailySales(ctx mycontext.Context, req entity.OrderSearch) ([]entity.ProductDailySales, error) GetDailySales(ctx mycontext.Context, req entity.OrderSearch) ([]entity.ProductDailySales, error)
GetPaymentDistribution(ctx mycontext.Context, req entity.OrderSearch) ([]entity.PaymentTypeDistribution, error)
} }
type OSSService interface { type OSSService interface {