add vclaimreference

This commit is contained in:
vanilia
2025-11-21 10:39:37 +07:00
parent 990f50e50c
commit 0b0676214c
6 changed files with 61 additions and 26 deletions
@@ -0,0 +1,14 @@
-- Create "VclaimReference" table
CREATE TABLE "public"."VclaimReference" (
"Id" bigserial NOT NULL,
"CreatedAt" timestamptz NULL,
"UpdatedAt" timestamptz NULL,
"DeletedAt" timestamptz NULL,
"Encounter_Id" bigint NULL,
"Date" timestamptz NULL,
"SrcCode" text NULL,
"SrcName" text NULL,
"Number" text NULL,
PRIMARY KEY ("Id"),
CONSTRAINT "fk_Encounter_VclaimReference" FOREIGN KEY ("Encounter_Id") REFERENCES "public"."Encounter" ("Id") ON UPDATE NO ACTION ON DELETE NO ACTION
);
+3 -2
View File
@@ -1,4 +1,4 @@
h1:4U2KWXwY59v9g8NqCRfUlRU8S0gFHP+2zZo3VIYCy80=
h1:9o177sOy5hbZmLRLBxkW8WN1dveIe0pyAXoU84eeq0Y=
20250904105930.sql h1:MEM6blCgke9DzWQSTnLzasbPIrcHssNNrJqZpSkEo6k=
20250904141448.sql h1:J8cmYNk4ZrG9fhfbi2Z1IWz7YkfvhFqTzrLFo58BPY0=
20250908062237.sql h1:Pu23yEW/aKkwozHoOuROvHS/GK4ngARJGdO7FB7HZuI=
@@ -126,4 +126,5 @@ h1:4U2KWXwY59v9g8NqCRfUlRU8S0gFHP+2zZo3VIYCy80=
20251119072302.sql h1:qCuI2WMEMF/XNbjV+RXPjBnuCKLu1Fia+mR9HiLWBIs=
20251119072450.sql h1:Xg+bTwqGyKPNFEQhJylvpz1wifdfmDJvcAq6vmNf0Ng=
20251120005512.sql h1:Ek6qpacAI/qVuTYxKno+uJyzn7s5z9pf3t7VA8gTzm4=
20251120074415.sql h1:4gmYBcmga1SBxRwrVaovGVvpRZFMV7vYzce0/IalryY=
20251120074415.sql h1:NNUeJVA03EeBHJhHqPXEZoDv/PnC6yK1/cRhmukyaJo=
20251121033803.sql h1:1s3DvgbqF+lh/or9X6WGN2lwnYCZkP8JH6uJFHql15g=
@@ -1,16 +1,16 @@
package vclaimsep
package vclaimreference
import (
ecore "simrs-vx/internal/domain/base-entities/core"
evsh "simrs-vx/internal/domain/bpjs-entities/vclaim-sep-hist"
"time"
)
type CreateDto struct {
Encounter_Id *uint `json:"encounter_id"`
Number *string `json:"number" validate:"maxLength=19"`
RequestPayload []byte `json:"requestPayload" validate:"maxLength=1024"`
VclaimSepHist evsh.CreateDto
Encounter_Id *uint `json:"encounter_id"`
Date *time.Time `json:"date"`
SrcCode *string `json:"src_code"`
SrcName *string `json:"src_name"`
Number *string `json:"number"`
}
type ReadListDto struct {
@@ -21,12 +21,11 @@ type ReadListDto struct {
}
type FilterDto struct {
Number *string `json:"number"`
Encounter_Id *uint `json:"encounter-id"`
}
type ReadDetailDto struct {
Id uint `json:"id"`
Number *string `json:"number"`
Id uint `json:"id"`
}
type UpdateDto struct {
@@ -35,8 +34,7 @@ type UpdateDto struct {
}
type DeleteDto struct {
Id uint `json:"id"`
Number *string `json:"number"`
Id uint `json:"id"`
}
type MetaDto struct {
@@ -47,27 +45,29 @@ type MetaDto struct {
type ResponseDto struct {
ecore.Main
Encounter_Id *uint `json:"encounter_id"`
Number *string `json:"number"`
Encounter_Id *uint `json:"encounter_id"`
Date *time.Time `json:"date"`
SrcCode *string `json:"src_code"`
SrcName *string `json:"src_name"`
Number *string `json:"number"`
}
func (d VclaimSep) ToResponse() ResponseDto {
func (d VclaimReference) ToResponse() ResponseDto {
resp := ResponseDto{
Encounter_Id: d.Encounter_Id,
Date: d.Date,
SrcCode: d.SrcCode,
SrcName: d.SrcName,
Number: d.Number,
}
resp.Main = d.Main
return resp
}
func ToResponseList(data []VclaimSep) []ResponseDto {
func ToResponseList(data []VclaimReference) []ResponseDto {
resp := make([]ResponseDto, len(data))
for i, u := range data {
resp[i] = u.ToResponse()
}
return resp
}
func (c CreateDto) IsMessageSuccess() bool {
return c.VclaimSepHist.Message == "Sukses"
}
@@ -0,0 +1,15 @@
package vclaimreference
import (
ecore "simrs-vx/internal/domain/base-entities/core"
"time"
)
type VclaimReference struct {
ecore.Main
Encounter_Id *uint `json:"encounter_id"`
Date *time.Time `json:"date"`
SrcCode *string `json:"src_code"`
SrcName *string `json:"src_name"`
Number *string `json:"number"`
}
@@ -1,7 +1,13 @@
package encounter
import (
"time"
erc "simrs-vx/internal/domain/references/common"
ere "simrs-vx/internal/domain/references/encounter"
ecore "simrs-vx/internal/domain/base-entities/core"
evr "simrs-vx/internal/domain/bpjs-entities/vclaim-reference"
evs "simrs-vx/internal/domain/bpjs-entities/vclaim-sep"
eam "simrs-vx/internal/domain/main-entities/ambulatory"
ea "simrs-vx/internal/domain/main-entities/appointment"
@@ -19,10 +25,6 @@ import (
es "simrs-vx/internal/domain/main-entities/specialist"
ess "simrs-vx/internal/domain/main-entities/subspecialist"
eu "simrs-vx/internal/domain/main-entities/unit"
erc "simrs-vx/internal/domain/references/common"
ere "simrs-vx/internal/domain/references/encounter"
"time"
)
type Encounter struct {
@@ -74,6 +76,7 @@ type Encounter struct {
RehabChildren *[]er.Basic `json:"rehabChildren,omitempty" gorm:"foreignKey:Parent_Encounter_Id;references:Id"`
EncounterDocuments *[]eed.EncounterDocument `json:"encounterDocuments,omitempty" gorm:"foreignKey:Encounter_Id;references:Id"`
GeneralConsents *[]egc.GeneralConsent `json:"generalConsents,omitempty" gorm:"foreignKey:Encounter_Id;references:Id"`
VclaimReference *evr.VclaimReference `json:"vclaimReference,omitempty" gorm:"foreignKey:Encounter_Id;references:Id"`
}
func (d Encounter) IsDone() bool {
@@ -103,6 +103,7 @@ import (
///BPJS
vclaimmember "simrs-vx/internal/domain/bpjs-entities/vclaim-member"
vclaimreference "simrs-vx/internal/domain/bpjs-entities/vclaim-reference"
vclaimsep "simrs-vx/internal/domain/bpjs-entities/vclaim-sep"
vclaimsepcontrolletter "simrs-vx/internal/domain/bpjs-entities/vclaim-sep-control-letter"
vclaimsephist "simrs-vx/internal/domain/bpjs-entities/vclaim-sep-hist"
@@ -215,5 +216,6 @@ func getMainEntities() []any {
&fileattachemnt.EncounterDocument{},
&vclaimsepcontrolletter.VclaimSepControlLetter{},
&resume.Resume{},
&vclaimreference.VclaimReference{},
}
}