feat (vclaim-sep): create, read, delete done

This commit is contained in:
dpurbosakti
2025-11-28 16:10:35 +07:00
parent abfbc568b0
commit 2a39301563
24 changed files with 343 additions and 75 deletions
-3
View File
@@ -57,9 +57,6 @@ corsCfg:
satuSehatCfg:
host: localhost:8200
bpjsCfg:
host: localhost:8200
corsCfg:
allowedOrigins:
- http://example.com
-3
View File
@@ -57,9 +57,6 @@ corsCfg:
satuSehatCfg:
host: localhost:8200
bpjsCfg:
host: localhost:8200
corsCfg:
allowedOrigins:
- http://example.com
+136 -5
View File
@@ -1,6 +1,7 @@
package vclaimsep
import (
"encoding/json"
ecore "simrs-vx/internal/domain/base-entities/core"
evsh "simrs-vx/internal/domain/bpjs-entities/vclaim-sep-hist"
)
@@ -8,7 +9,7 @@ import (
type CreateDto struct {
Encounter_Id *uint `json:"encounter_id"`
Number *string `json:"number" validate:"maxLength=19"`
RequestPayload []byte `json:"requestPayload" validate:"maxLength=1024"`
RequestPayload string `json:"requestPayload" validate:"maxLength=1024"`
VclaimSepHist evsh.CreateDto
}
@@ -25,8 +26,9 @@ type FilterDto struct {
}
type ReadDetailDto struct {
Id uint `json:"id"`
Number *string `json:"number"`
Id uint `json:"id"`
Number *string `json:"number"`
Encounter_Id *uint `json:"encounter_id"`
}
type UpdateDto struct {
@@ -47,14 +49,16 @@ type MetaDto struct {
type ResponseDto struct {
ecore.Main
Encounter_Id *uint `json:"encounter_id"`
Number *string `json:"number"`
Encounter_Id *uint `json:"encounter_id"`
Number *string `json:"number"`
Detail *SepDetail `json:"detail,omitempty"`
}
func (d VclaimSep) ToResponse() ResponseDto {
resp := ResponseDto{
Encounter_Id: d.Encounter_Id,
Number: d.Number,
Detail: d.Detail,
}
resp.Main = d.Main
return resp
@@ -71,3 +75,130 @@ func ToResponseList(data []VclaimSep) []ResponseDto {
func (c CreateDto) IsMessageSuccess() bool {
return c.VclaimSepHist.Message == "Sukses"
}
func (c CreateDto) RequestPayloadIntoJson() ([]byte, error) {
payload := map[string]interface{}{}
err := json.Unmarshal([]byte(c.RequestPayload), &payload)
if err != nil {
return nil, err
}
return json.Marshal(payload)
}
func (c CreateDto) RequestPayloadWithEncounterId() ([]byte, error) {
payload := map[string]interface{}{}
err := json.Unmarshal([]byte(c.RequestPayload), &payload)
if err != nil {
return nil, err
}
payload["encounter_id"] = c.Encounter_Id
return json.Marshal(payload)
}
type SepResponse struct {
MetaData MetaData `json:"metaData"`
Response *SepDetail `json:"response"`
}
type MetaData struct {
Code string `json:"code"`
Message string `json:"message"`
}
type SepDetail struct {
AssestmenPel AssestmenPel `json:"assestmenPel"`
Catatan string `json:"catatan"`
Cob string `json:"cob"`
Diagnosa string `json:"diagnosa"`
Dpjp Dpjp `json:"dpjp"`
ESep string `json:"eSEP"`
FlagProcedure FlagProcedure `json:"flagProcedure"`
Informasi any `json:"informasi"` // null = interface{}
JnsPelayanan string `json:"jnsPelayanan"`
Katarak string `json:"katarak"`
KdPenunjang KdPenunjang `json:"kdPenunjang"`
KdStatusKecelakaan string `json:"kdStatusKecelakaan"`
KelasRawat string `json:"kelasRawat"`
KlsRawat KlsRawat `json:"klsRawat"`
Kontrol Kontrol `json:"kontrol"`
LokasiKejadian LokasiKejadian `json:"lokasiKejadian"`
NmStatusKecelakaan string `json:"nmstatusKecelakaan"`
NoRujukan string `json:"noRujukan"`
NoSep string `json:"noSep"`
Penjamin any `json:"penjamin"` // null
Peserta Peserta `json:"peserta"`
Poli string `json:"poli"`
PoliEksekutif string `json:"poliEksekutif"`
TglSep string `json:"tglSep"`
TujuanKunj TujuanKunj `json:"tujuanKunj"`
}
type AssestmenPel struct {
Kode string `json:"kode"`
Nama string `json:"nama"`
}
type Dpjp struct {
KdDPJP string `json:"kdDPJP"`
NmDPJP string `json:"nmDPJP"`
}
type FlagProcedure struct {
Kode string `json:"kode"`
Nama string `json:"nama"`
}
type KdPenunjang struct {
Kode string `json:"kode"`
Nama string `json:"nama"`
}
type KlsRawat struct {
KlsRawatHak string `json:"klsRawatHak"`
KlsRawatNaik *string `json:"klsRawatNaik"` // nullable
Pembiayaan *string `json:"pembiayaan"` // nullable
PenanggungJawab *string `json:"penanggungJawab"` // nullable
}
type Kontrol struct {
KdDokter *string `json:"kdDokter"` // null
NmDokter *string `json:"nmDokter"` // null
NoSurat *string `json:"noSurat"` // null
}
type LokasiKejadian struct {
KdKab *string `json:"kdKab"`
KdKec *string `json:"kdKec"`
KdProp *string `json:"kdProp"`
KetKejadian *string `json:"ketKejadian"`
Lokasi *string `json:"lokasi"`
TglKejadian *string `json:"tglKejadian"`
}
type Peserta struct {
Asuransi any `json:"asuransi"`
HakKelas string `json:"hakKelas"`
JnsPeserta string `json:"jnsPeserta"`
Kelamin string `json:"kelamin"`
Nama string `json:"nama"`
NoKartu string `json:"noKartu"`
NoMR string `json:"noMr"`
TglLahir string `json:"tglLahir"`
}
type TujuanKunj struct {
Kode string `json:"kode"`
Nama string `json:"nama"`
}
type SepDeleteRequest struct {
Request struct {
TSep struct {
NoSep string `json:"noSep"`
User string `json:"user"`
} `json:"t_sep"`
} `json:"request"`
}
@@ -12,4 +12,5 @@ type VclaimSep struct {
Number *string `json:"number" gorm:"unique;size:19"`
Prints []*evsp.VclaimSepPrint `json:"prints,omitempty" gorm:"foreignKey:VclaimSep_Number;references:Number"`
ControlLetters []*evscl.VclaimSepControlLetter `json:"controlLetters,omitempty" gorm:"foreignKey:VclaimSep_Number;references:Number"`
Detail *SepDetail `json:"detail,omitempty" gorm:"-"`
}
@@ -87,5 +87,5 @@ func (d Encounter) IsSameResponsibleDoctor(input *string) bool {
if input == nil {
return false
}
return d.Responsible_Doctor_Code == input
return *d.Responsible_Doctor_Code == *input
}
@@ -4,12 +4,12 @@ import (
"net/http"
/******************** main / transaction ********************/
member "simrs-vx/internal/interface/bpjs-handler/member"
monitoring "simrs-vx/internal/interface/bpjs-handler/monitoring"
reference "simrs-vx/internal/interface/bpjs-handler/reference"
vclaimsep "simrs-vx/internal/interface/bpjs-handler/vclaim-sep"
vclaimsephist "simrs-vx/internal/interface/bpjs-handler/vclaim-sep-hist"
vclaimsepprint "simrs-vx/internal/interface/bpjs-handler/vclaim-sep-print"
member "simrs-vx/internal/interface/main-handler/member"
monitoring "simrs-vx/internal/interface/main-handler/monitoring"
reference "simrs-vx/internal/interface/main-handler/reference"
vclaimsep "simrs-vx/internal/interface/main-handler/vclaim-sep"
vclaimsephist "simrs-vx/internal/interface/main-handler/vclaim-sep-hist"
vclaimsepprint "simrs-vx/internal/interface/main-handler/vclaim-sep-print"
/******************** actor ********************/
@@ -49,7 +49,7 @@ func SetRoutes() http.Handler {
hk.GroupRoutes("/v1/vclaim-sep", r, hk.MapHandlerFunc{
"POST /": vclaimsep.O.Create,
"PATCH /{id}": vclaimsep.O.Update,
"PATCH /{id}": vclaimsep.O.GetDetail,
"DELETE /{id}": vclaimsep.O.Delete,
})
@@ -120,9 +120,17 @@ import (
regency "simrs-vx/internal/interface/main-handler/regency"
village "simrs-vx/internal/interface/main-handler/village"
///// Internal
/******************** Internal ********************/
validation "simrs-vx/internal/interface/main-handler/helper/validation"
"simrs-vx/internal/interface/main-handler/home"
/******************** BPJS ********************/
member "simrs-vx/internal/interface/main-handler/member"
monitoring "simrs-vx/internal/interface/main-handler/monitoring"
reference "simrs-vx/internal/interface/main-handler/reference"
vclaimsep "simrs-vx/internal/interface/main-handler/vclaim-sep"
vclaimsephist "simrs-vx/internal/interface/main-handler/vclaim-sep-hist"
vclaimsepprint "simrs-vx/internal/interface/main-handler/vclaim-sep-print"
)
// One place route to relatively easier to manage, ESPECIALLY in tracking
@@ -138,6 +146,7 @@ func SetRoutes() http.Handler {
a.RegisterExtCall(validation.RegisterValidation)
a.RegisterExtCall(simgossync.SetConfig)
a.RegisterExtCall(docscfg.ParseCfg)
a.RegisterExtCall(ibpjs.SetConfig)
r := http.NewServeMux()
@@ -371,6 +380,43 @@ func SetRoutes() http.Handler {
hc.RegCrudByCode(r, "/v1/province", province.O)
hc.RegCrudByCode(r, "/v1/postal-region", postalregion.O)
/******************** BPJS ********************/
hk.GroupRoutes("/v1/vclaim-sep", r, hk.MapHandlerFunc{
"POST /": vclaimsep.O.Create,
"GET /{id}": vclaimsep.O.GetDetail,
"DELETE /{id}": vclaimsep.O.Delete,
})
hk.GroupRoutes("/v1/vclaim-sep-hist", r, hk.MapHandlerFunc{
"GET /": vclaimsephist.O.GetList,
})
hk.GroupRoutes("/v1/vclaim-sep-print", r, hk.MapHandlerFunc{
"POST /": vclaimsepprint.O.Create,
})
hk.GroupRoutes("/v1/reference", r, hk.MapHandlerFunc{
"GET /province": reference.GetListProvince,
"GET /regency/{provinceCode}": reference.GetListCities,
"GET /district/{regencyCode}": reference.GetListDistrict,
"GET /diagnose/{keyword}": reference.GetListDiagnose,
"GET /diagnose-prb": reference.GetListDiagnosePrb,
"GET /medicine-prb/{keyword}": reference.GetListMedicinePrb,
"GET /unit/{unitCode}": reference.GetListUnit,
"GET /healthcare/{healthcare}/{healthcareType}": reference.GetListHealthcare,
"GET /responsible-doctor/{serviceType}/{serviceDate}/{specialistCode}": reference.GetListDoctor,
})
hk.GroupRoutes("/v1/member", r, hk.MapHandlerFunc{
"GET /bpjs/{cardNumber}/{sepDate}": member.GetListByBpjsNumber,
"GET /nik/{nik}/{sepDate}": member.GetListByNik,
})
hk.GroupRoutes("/v1/monitoring", r, hk.MapHandlerFunc{
"GET /visit/{date}/{serviceType}": monitoring.GetListVisit,
"GET /hist/{cardNumber}/{startDate}/{endDate}": monitoring.GetListHist,
})
/////
return cmw.SetCors(handlerlogger.SetLog(r))
}
@@ -99,9 +99,6 @@ func Verify(w http.ResponseWriter, r *http.Request) {
}
dto := e.UpdateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
dto.Id = uint(id)
dto.Status_Code = erc.DVCVerified
dto.AuthInfo = *authInfo
@@ -120,9 +117,6 @@ func Validate(w http.ResponseWriter, r *http.Request) {
}
dto := e.UpdateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
dto.Id = uint(id)
dto.Status_Code = erc.DVCValidated
dto.AuthInfo = *authInfo
@@ -1,7 +1,6 @@
package vclaimsep
import (
"io"
"net/http"
rw "github.com/karincake/risoles"
@@ -16,14 +15,9 @@ var O myBase
func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
dto := e.CreateDto{}
body, err := io.ReadAll(r.Body)
if err != nil {
http.Error(w, "failed to read body", http.StatusBadRequest)
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
defer r.Body.Close()
dto.RequestPayload = body
res, err := u.Create(dto)
rw.DataResponse(w, res, err)
}
@@ -35,39 +29,39 @@ func (obj myBase) Create(w http.ResponseWriter, r *http.Request) {
// rw.DataResponse(w, res, err)
// }
// func (obj myBase) GetDetail(w http.ResponseWriter, r *http.Request) {
// id := rw.ValidateInt(w, "id", r.PathValue("id"))
// if id <= 0 {
func (obj myBase) GetDetail(w http.ResponseWriter, r *http.Request) {
id := rw.ValidateInt(w, "id", r.PathValue("id"))
if id <= 0 {
return
}
dto := e.ReadDetailDto{}
dto.Id = uint(id)
res, err := u.ReadDetail(dto)
rw.DataResponse(w, res, err)
}
// func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
// number := rw.ValidateString(w, "number", r.PathValue("number"))
// if number != "" {
// return
// }
// dto := e.ReadDetailDto{}
// dto.Id = uint(id)
// res, err := u.ReadDetail(dto)
// dto := e.UpdateDto{}
// if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
// return
// }
// dto.Number = &number
// res, err := u.Update(dto)
// rw.DataResponse(w, res, err)
// }
func (obj myBase) Update(w http.ResponseWriter, r *http.Request) {
number := rw.ValidateString(w, "number", r.PathValue("number"))
if number != "" {
return
}
dto := e.UpdateDto{}
if res := rw.ValidateStructByIOR(w, r.Body, &dto); !res {
return
}
dto.Number = &number
res, err := u.Update(dto)
rw.DataResponse(w, res, err)
}
func (obj myBase) Delete(w http.ResponseWriter, r *http.Request) {
number := rw.ValidateString(w, "number", r.PathValue("number"))
if number != "" {
id := rw.ValidateInt(w, "id", r.PathValue("id"))
if id <= 0 {
return
}
dto := e.DeleteDto{}
dto.Number = &number
dto.Id = uint(id)
res, err := u.Delete(dto)
rw.DataResponse(w, res, err)
}
@@ -14,7 +14,11 @@ import (
)
func CreateSep(input *e.CreateDto, data *e.VclaimSep, tx *gorm.DB) error {
req, err := http.NewRequest("POST", ibpjs.O.BaseUrl+"/sep", bytes.NewReader(input.RequestPayload))
payload, err := input.RequestPayloadIntoJson()
if err != nil {
return err
}
req, err := http.NewRequest("POST", ibpjs.O.BaseUrl+"sep", bytes.NewBuffer(payload))
if err != nil {
return err
}
@@ -43,7 +47,11 @@ func CreateSep(input *e.CreateDto, data *e.VclaimSep, tx *gorm.DB) error {
}
// Save request/response details in DTO for further use
input.VclaimSepHist.RequestPayload = string(input.RequestPayload)
reqPayload, err := input.RequestPayloadWithEncounterId()
if err != nil {
return err
}
input.VclaimSepHist.RequestPayload = string(reqPayload)
input.VclaimSepHist.ResponseBody = string(body)
input.VclaimSepHist.Message = msg
input.Number = func() *string {
@@ -56,3 +64,72 @@ func CreateSep(input *e.CreateDto, data *e.VclaimSep, tx *gorm.DB) error {
return nil
}
func ReadDetailSep(input *e.ReadDetailDto, data *e.VclaimSep, tx *gorm.DB) error {
endpoint := fmt.Sprintf("sep/%s", *data.Number)
req, err := http.NewRequest("GET", ibpjs.O.BaseUrl+endpoint, nil)
if err != nil {
return err
}
req.Header.Set("Content-Type", "application/json")
resp, err := http.DefaultClient.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
body, err := io.ReadAll(resp.Body)
if err != nil {
return err
}
var detail e.SepResponse
if err := json.Unmarshal(body, &detail); err != nil {
return fmt.Errorf("failed to parse response JSON: %w", err)
}
data.Detail = detail.Response
return nil
}
func DeleteSep(input *e.DeleteDto, data *e.VclaimSep, tx *gorm.DB) error {
payload := e.SepDeleteRequest{}
payload.Request.TSep.NoSep = *data.Number
payload.Request.TSep.User = "Coba Ws"
jsonPayload, err := json.Marshal(payload)
if err != nil {
return err
}
req, err := http.NewRequest("DELETE", ibpjs.O.BaseUrl+"sep", bytes.NewBuffer(jsonPayload))
if err != nil {
return err
}
req.Header.Set("Content-Type", "application/json")
resp, err := http.DefaultClient.Do(req)
if err != nil {
return err
}
defer resp.Body.Close()
body, err := io.ReadAll(resp.Body)
if err != nil {
return err
}
var detail e.SepResponse
if err := json.Unmarshal(body, &detail); err != nil {
return fmt.Errorf("failed to parse response JSON: %w", err)
}
if detail.MetaData.Message == SepNotFound {
return fmt.Errorf("sep with number %s not found", *data.Number)
}
return nil
}
@@ -10,3 +10,5 @@ type vclaimResponse struct {
} `json:"sep"`
} `json:"response"`
}
const SepNotFound = "Data Tidak Ditemukan"
@@ -1,6 +1,7 @@
package vclaimsep
import (
"fmt"
"strconv"
e "simrs-vx/internal/domain/bpjs-entities/vclaim-sep"
@@ -31,6 +32,17 @@ func Create(input e.CreateDto) (*d.Data, error) {
pl.SetLogInfo(&event, input, "started", "create")
err := dg.I.Transaction(func(tx *gorm.DB) error {
rDto := e.ReadDetailDto{Encounter_Id: input.Encounter_Id}
if vSep, err := ReadDetailData(rDto, &event, tx); err != nil {
if !pu.IsDataNotFoundError(err) {
return err
}
if vSep != nil {
return fmt.Errorf("sep with encounter id %d already exist with number %s", input.Encounter_Id, *vSep.Number)
}
}
mwRunner := newMiddlewareRunner(&event, tx)
mwRunner.setMwType(pu.MWTPre)
// Run pre-middleware
@@ -38,12 +50,12 @@ func Create(input e.CreateDto) (*d.Data, error) {
return err
}
if _, err := uvsh.CreateData(input.VclaimSepHist, &event, tx); err != nil {
if _, err := uvsh.CreateData(input.VclaimSepHist, &event); err != nil {
return err
}
if !input.IsMessageSuccess() {
return nil
return fmt.Errorf("%s", input.VclaimSepHist.Message)
}
if resData, err := CreateData(input, &event, tx); err != nil {
@@ -234,7 +246,7 @@ func Update(input e.UpdateDto) (*d.Data, error) {
}
func Delete(input e.DeleteDto) (*d.Data, error) {
rdDto := e.ReadDetailDto{Number: input.Number}
rdDto := e.ReadDetailDto{Id: input.Id}
var data *e.VclaimSep
var err error
@@ -255,7 +267,7 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
mwRunner := newMiddlewareRunner(&event, tx)
mwRunner.setMwType(pu.MWTPre)
// Run pre-middleware
if err := mwRunner.RunDeleteMiddleware(readDetailPreMw, &rdDto, data); err != nil {
if err := mwRunner.RunDeleteMiddleware(deletePreMw, &e.DeleteDto{}, data); err != nil {
return err
}
@@ -265,7 +277,7 @@ func Delete(input e.DeleteDto) (*d.Data, error) {
mwRunner.setMwType(pu.MWTPost)
// Run post-middleware
if err := mwRunner.RunDeleteMiddleware(readDetailPostMw, &rdDto, data); err != nil {
if err := mwRunner.RunDeleteMiddleware(deletePostMw, &e.DeleteDto{}, data); err != nil {
return err
}
@@ -87,6 +87,9 @@ func ReadDetailData(input e.ReadDetailDto, event *pl.Event, dbx ...*gorm.DB) (*e
if input.Id != 0 {
tx = tx.Where("\"Id\" = ?", input.Id)
}
if input.Encounter_Id != nil {
tx = tx.Where("\"Encounter_Id\" = ?", *input.Encounter_Id)
}
if err := tx.First(&data).Error; err != nil {
if processedErr := pu.HandleReadError(err, event, source, input.Id, data); processedErr != nil {
@@ -83,7 +83,7 @@ func (me *middlewareRunner) RunUpdateMiddleware(middlewares []readDetailMw, inpu
return nil
}
func (me *middlewareRunner) RunDeleteMiddleware(middlewares []readDetailMw, input *e.ReadDetailDto, data *e.VclaimSep) error {
func (me *middlewareRunner) RunDeleteMiddleware(middlewares []deleteMw, input *e.DeleteDto, data *e.VclaimSep) error {
for _, middleware := range middlewares {
logData := pu.GetLogData(input, data)
@@ -9,5 +9,10 @@ func init() {
createPreMw = append(createPreMw,
createMw{Name: "create-sep", Func: pvs.CreateSep},
)
readDetailPostMw = append(readDetailPostMw,
readDetailMw{Name: "read-detail-sep", Func: pvs.ReadDetailSep},
)
deletePreMw = append(deletePreMw,
deleteMw{Name: "delete-sep", Func: pvs.DeleteSep},
)
}
@@ -29,8 +29,12 @@ type readDetailMw struct {
Func func(input *e.ReadDetailDto, data *e.VclaimSep, tx *gorm.DB) error
}
type deleteMw struct {
Name string
Func func(input *e.DeleteDto, data *e.VclaimSep, tx *gorm.DB) error
}
type UpdateMw = readDetailMw
type DeleteMw = readDetailMw
var createPreMw []createMw // preprocess middleware
var createPostMw []createMw // postprocess middleware
@@ -40,5 +44,5 @@ var readDetailPreMw []readDetailMw
var readDetailPostMw []readDetailMw
var updatePreMw []readDetailMw
var updatePostMw []readDetailMw
var deletePreMw []readDetailMw
var deletePostMw []readDetailMw
var deletePreMw []deleteMw
var deletePostMw []deleteMw
@@ -244,6 +244,10 @@ func generateResume(input GenerateDto, event pl.Event, tx *gorm.DB) (*ResponseDt
return nil, err
}
if !r.IsValidated() {
return nil, errors.New("resume is not validated")
}
if r.FileUrl != nil {
if err := removeFile(string(input.EntityType_Code), *r.FileUrl); err != nil {
return nil, err
@@ -50,7 +50,6 @@ func Create(input e.CreateDto) (*d.Data, error) {
return errors.New("encounter is already done")
}
input.Status_Code = erc.DVCNew
if resData, err := CreateData(input, &event, tx); err != nil {
return err
} else {
@@ -345,16 +344,16 @@ func UpdateStatusCode(input e.UpdateDto) (*d.Data, error) {
switch input.Status_Code {
case erc.DVCValidated:
if !enc.IsSameResponsibleDoctor(input.AuthInfo.Doctor_Code) {
return errors.New("validation doctor is not the same as encounter responsible doctor")
}
if data.IsNew() {
return errors.New("resume need to be verified first")
}
if data.IsValidated() {
return errors.New("resume already validated")
}
if !enc.IsSameResponsibleDoctor(input.AuthInfo.Doctor_Code) {
return errors.New("validation doctor is not the same as encounter responsible doctor")
}
data.Status_Code = erc.DVCValidated
err = tx.Save(&data).Error
if err != nil {
@@ -6,12 +6,15 @@ package resume
import (
e "simrs-vx/internal/domain/main-entities/resume"
erc "simrs-vx/internal/domain/references/common"
)
func setData[T *e.CreateDto | *e.UpdateDto](input T, data *e.Resume) {
var inputSrc *e.CreateDto
if inputT, ok := any(input).(*e.CreateDto); ok {
inputSrc = inputT
data.Status_Code = erc.DVCNew
} else {
inputTemp := any(input).(*e.UpdateDto)
inputSrc = &inputTemp.CreateDto
@@ -20,5 +23,4 @@ func setData[T *e.CreateDto | *e.UpdateDto](input T, data *e.Resume) {
data.Encounter_Id = inputSrc.Encounter_Id
data.Doctor_Code = inputSrc.AuthInfo.Doctor_Code
data.Value = inputSrc.Value
data.Status_Code = inputSrc.Status_Code
}