mirror of
https://gitlab.com/mbugroup/lti-api.git
synced 2026-05-23 23:05:44 +00:00
fix[BE]: menggunakan base dto dari dto utama entity ketimbang buat simple dto baru
This commit is contained in:
@@ -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")
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user