fix[BE]: menggunakan base dto dari dto utama entity ketimbang buat simple dto baru

This commit is contained in:
aguhh18
2025-10-21 11:48:54 +07:00
parent 1afbdea4ff
commit b1b63d266a
2 changed files with 73 additions and 111 deletions
@@ -4,68 +4,42 @@ import (
"time" "time"
entity "gitlab.com/mbugroup/lti-api.git/internal/entities" entity "gitlab.com/mbugroup/lti-api.git/internal/entities"
areaBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/master/areas/dto"
fcrBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/master/fcrs/dto"
flockBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/master/flocks/dto"
kandangBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/master/kandangs/dto"
locationBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/master/locations/dto"
productCategoryBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/master/product-categories/dto"
userBaseDTO "gitlab.com/mbugroup/lti-api.git/internal/modules/users/dto"
) )
// === DTO Structs (ordered) === // === DTO Structs (ordered) ===
type FlockDTO struct { type ChickinBaseDTO struct {
Id uint `json:"id"` Id uint `json:"id"`
Name string `json:"name"` ProjectFlockKandang *ProjectFlockKandangDTO `json:"project_flock_kandang"`
} ChickInDate time.Time `json:"chick_in_date"`
Quantity float64 `json:"quantity"`
type KandangDTO struct { Note string `json:"note"`
Id uint `json:"id"`
Name string `json:"name"`
}
type ProductCategoryDTO struct {
Id uint `json:"id"`
Name string `json:"name"`
}
type AreaDTO struct {
Id uint `json:"id"`
Name string `json:"name"`
}
type FcrDTO struct {
Id uint `json:"id"`
Name string `json:"name"`
}
type LocationDTO struct {
Id uint `json:"id"`
Name string `json:"name"`
} }
type ProjectFlockDTO struct { type ProjectFlockDTO struct {
Id uint `json:"id"` Id uint `json:"id"`
Period int `json:"period"` Period int `json:"period"`
Flock *FlockDTO `json:"flock"` Flock *flockBaseDTO.FlockBaseDTO `json:"flock"`
ProductCategory *ProductCategoryDTO `json:"product_category"` ProductCategory *productCategoryBaseDTO.ProductCategoryBaseDTO `json:"product_category"`
Area *AreaDTO `json:"area"` Area *areaBaseDTO.AreaBaseDTO `json:"area"`
Fcr *FcrDTO `json:"fcr"` Fcr *fcrBaseDTO.FcrBaseDTO `json:"fcr"`
Location *LocationDTO `json:"location"` Location *locationBaseDTO.LocationBaseDTO `json:"location"`
} }
type ProjectFlockKandangDTO struct { type ProjectFlockKandangDTO struct {
Id uint `json:"id"` Id uint `json:"id"`
ProjectFlock *ProjectFlockDTO `json:"project_flock"` ProjectFlock *ProjectFlockDTO `json:"project_flock"`
Kandang *KandangDTO `json:"kandang"` Kandang *kandangBaseDTO.KandangBaseDTO `json:"kandang"`
} }
type UserBaseDTO struct { // gunakan base DTO dari package users
Id uint `json:"id"`
Name string `json:"name"`
}
type ChickinBaseDTO struct {
Id uint `json:"id"`
ProjectFlocKandangId uint `json:"project_floc_kandang_id"`
ChickInDate time.Time `json:"chick_in_date"`
Quantity float64 `json:"quantity"`
Note string `json:"note"`
}
type ChickinSimpleDTO struct { type ChickinSimpleDTO struct {
Id uint `json:"id"` Id uint `json:"id"`
@@ -78,10 +52,10 @@ type ChickinSimpleDTO struct {
type ChickinListDTO struct { type ChickinListDTO struct {
ChickinBaseDTO ChickinBaseDTO
ProjectFlockKandang *ProjectFlockKandangDTO `json:"project_flock_kandang"` ProjectFlockKandang *ProjectFlockKandangDTO `json:"project_flock_kandang"`
CreatedUser *UserBaseDTO `json:"created_user"` CreatedUser *userBaseDTO.UserBaseDTO `json:"created_user"`
CreatedAt time.Time `json:"created_at"` CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Time `json:"updated_at"` UpdatedAt time.Time `json:"updated_at"`
} }
type ChickinDetailDTO struct { type ChickinDetailDTO struct {
@@ -90,72 +64,58 @@ type ChickinDetailDTO struct {
// === Mapper Functions (ordered) === // === Mapper Functions (ordered) ===
func ToFlockDTO(e entity.Flock) FlockDTO { func ToFlockDTO(e entity.Flock) flockBaseDTO.FlockBaseDTO {
return FlockDTO{ return flockBaseDTO.ToFlockBaseDTO(e)
Id: e.Id,
Name: e.Name,
}
} }
func ToKandangDTO(e entity.Kandang) KandangDTO { func ToKandangDTO(e entity.Kandang) kandangBaseDTO.KandangBaseDTO {
return KandangDTO{ return kandangBaseDTO.ToKandangBaseDTO(e)
Id: e.Id,
Name: e.Name,
}
} }
func ToProductCategoryDTO(e entity.ProductCategory) ProductCategoryDTO { func ToProductCategoryDTO(e entity.ProductCategory) productCategoryBaseDTO.ProductCategoryBaseDTO {
return ProductCategoryDTO{ return productCategoryBaseDTO.ToProductCategoryBaseDTO(e)
Id: e.Id,
Name: e.Name,
}
} }
func ToAreaDTO(e entity.Area) AreaDTO { func ToAreaDTO(e entity.Area) areaBaseDTO.AreaBaseDTO {
return AreaDTO{ return areaBaseDTO.ToAreaBaseDTO(e)
Id: e.Id,
Name: e.Name,
}
} }
func ToFcrDTO(e entity.Fcr) FcrDTO { func ToFcrDTO(e entity.Fcr) fcrBaseDTO.FcrBaseDTO {
return FcrDTO{ return fcrBaseDTO.ToFcrBaseDTO(e)
Id: e.Id,
Name: e.Name,
}
} }
func ToLocationDTO(e entity.Location) LocationDTO { func ToLocationDTO(e entity.Location) locationBaseDTO.LocationBaseDTO {
return LocationDTO{ return locationBaseDTO.ToLocationBaseDTO(e)
Id: e.Id, }
Name: e.Name,
} func ToUserBaseDTO(e entity.User) userBaseDTO.UserBaseDTO {
return userBaseDTO.ToUserBaseDTO(e)
} }
func ToProjectFlockDTO(e entity.ProjectFlock) ProjectFlockDTO { func ToProjectFlockDTO(e entity.ProjectFlock) ProjectFlockDTO {
var flock *FlockDTO var flock *flockBaseDTO.FlockBaseDTO
if e.Flock.Id != 0 { if e.Flock.Id != 0 {
mapped := ToFlockDTO(e.Flock) mapped := flockBaseDTO.ToFlockBaseDTO(e.Flock)
flock = &mapped flock = &mapped
} }
var productCategory *ProductCategoryDTO var productCategory *productCategoryBaseDTO.ProductCategoryBaseDTO
if e.ProductCategory.Id != 0 { if e.ProductCategory.Id != 0 {
mapped := ToProductCategoryDTO(e.ProductCategory) mapped := productCategoryBaseDTO.ToProductCategoryBaseDTO(e.ProductCategory)
productCategory = &mapped productCategory = &mapped
} }
var area *AreaDTO var area *areaBaseDTO.AreaBaseDTO
if e.Area.Id != 0 { if e.Area.Id != 0 {
mapped := ToAreaDTO(e.Area) mapped := areaBaseDTO.ToAreaBaseDTO(e.Area)
area = &mapped area = &mapped
} }
var fcr *FcrDTO var fcr *fcrBaseDTO.FcrBaseDTO
if e.Fcr.Id != 0 { if e.Fcr.Id != 0 {
mapped := ToFcrDTO(e.Fcr) mapped := fcrBaseDTO.ToFcrBaseDTO(e.Fcr)
fcr = &mapped fcr = &mapped
} }
var location *LocationDTO var location *locationBaseDTO.LocationBaseDTO
if e.Location.Id != 0 { if e.Location.Id != 0 {
mapped := ToLocationDTO(e.Location) mapped := locationBaseDTO.ToLocationBaseDTO(e.Location)
location = &mapped location = &mapped
} }
return ProjectFlockDTO{ return ProjectFlockDTO{
@@ -175,9 +135,9 @@ func ToProjectFlockKandangDTO(e entity.ProjectFlockKandang) ProjectFlockKandangD
mapped := ToProjectFlockDTO(e.ProjectFlock) mapped := ToProjectFlockDTO(e.ProjectFlock)
pf = &mapped pf = &mapped
} }
var kandang *KandangDTO var kandang *kandangBaseDTO.KandangBaseDTO
if e.Kandang.Id != 0 { if e.Kandang.Id != 0 {
mapped := ToKandangDTO(e.Kandang) mapped := kandangBaseDTO.ToKandangBaseDTO(e.Kandang)
kandang = &mapped kandang = &mapped
} }
return ProjectFlockKandangDTO{ return ProjectFlockKandangDTO{
@@ -187,20 +147,18 @@ func ToProjectFlockKandangDTO(e entity.ProjectFlockKandang) ProjectFlockKandangD
} }
} }
func ToUserBaseDTO(e entity.User) UserBaseDTO {
return UserBaseDTO{
Id: e.Id,
Name: e.Name,
}
}
func ToChickinBaseDTO(e entity.ProjectChickin) ChickinBaseDTO { func ToChickinBaseDTO(e entity.ProjectChickin) ChickinBaseDTO {
var pfk *ProjectFlockKandangDTO
if e.ProjectFlockKandang.Id != 0 {
mapped := ToProjectFlockKandangDTO(e.ProjectFlockKandang)
pfk = &mapped
}
return ChickinBaseDTO{ return ChickinBaseDTO{
Id: e.Id, Id: e.Id,
ProjectFlocKandangId: e.ProjectFlockKandangId, ProjectFlockKandang: pfk,
ChickInDate: e.ChickInDate, ChickInDate: e.ChickInDate,
Quantity: e.Quantity, Quantity: e.Quantity,
Note: e.Note, Note: e.Note,
} }
} }
@@ -216,9 +174,9 @@ func ToChickinSimpleDTO(e entity.ProjectChickin) ChickinSimpleDTO {
} }
func ToChickinListDTO(e entity.ProjectChickin) ChickinListDTO { func ToChickinListDTO(e entity.ProjectChickin) ChickinListDTO {
var createdUser *UserBaseDTO var createdUser *userBaseDTO.UserBaseDTO
if e.CreatedUser.Id != 0 { if e.CreatedUser.Id != 0 {
mapped := ToUserBaseDTO(e.CreatedUser) mapped := userBaseDTO.ToUserBaseDTO(e.CreatedUser)
createdUser = &mapped createdUser = &mapped
} }
var pfk *ProjectFlockKandangDTO var pfk *ProjectFlockKandangDTO
@@ -62,12 +62,16 @@ func (s chickinService) withRelations(db *gorm.DB) *gorm.DB {
return db. return db.
Preload("CreatedUser"). Preload("CreatedUser").
Preload("ProjectFlockKandang.Kandang"). Preload("ProjectFlockKandang.Kandang").
Preload("ProjectFlockKandang.Kandang.Location").
Preload("ProjectFlockKandang.Kandang.Location.Area").
Preload("ProjectFlockKandang.Kandang.Pic").
Preload("ProjectFlockKandang.ProjectFlock"). Preload("ProjectFlockKandang.ProjectFlock").
Preload("ProjectFlockKandang.ProjectFlock.Flock"). Preload("ProjectFlockKandang.ProjectFlock.Flock").
Preload("ProjectFlockKandang.ProjectFlock.ProductCategory"). Preload("ProjectFlockKandang.ProjectFlock.ProductCategory").
Preload("ProjectFlockKandang.ProjectFlock.Area"). Preload("ProjectFlockKandang.ProjectFlock.Area").
Preload("ProjectFlockKandang.ProjectFlock.Fcr"). Preload("ProjectFlockKandang.ProjectFlock.Fcr").
Preload("ProjectFlockKandang.ProjectFlock.Location") Preload("ProjectFlockKandang.ProjectFlock.Location").
Preload("ProjectFlockKandang.ProjectFlock.Location.Area")
} }