1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223 |
- package service
-
- import (
- "XT_New/models"
- "XT_New/utils"
- "errors"
- "fmt"
- _ "fmt"
- "github.com/jinzhu/gorm"
- "math"
- "strconv"
- "strings"
- "time"
- )
-
- // 药品出库
-
- func DrugsDelivery(orgID int64, creater int64, advice *models.DoctorAdvice) (err error) {
- // 1.判断药品是否来自专用字典的药品库
- // 2.判断当天当前机构有没有创建出库单,没有则创建
- // 3.创建出库流程
- // 3.1 实现先进先出逻辑 由于药品执行后,不可以修改和删除,所以不考虑出库后的退库和修改出库数量等
- isHasWay := false
- record_time := int64(0)
- if advice.Way == 1 {
- isHasWay = true
- record_time = advice.RecordDate
- }
-
- if isHasWay {
- //判断当天当前机构有没有创建出库单,没有则创建
- out, err := FindDrugStockOutByIsSys(orgID, 1, record_time)
- if err == gorm.ErrRecordNotFound {
- timeStr := time.Now().Format("2006-01-02")
- timeArr := strings.Split(timeStr, "-")
- total, _ := FindAllDrugWarehouseOut(orgID)
- total = total + 1
- warehousing_out_order := strconv.FormatInt(orgID, 10) + timeArr[0] + timeArr[1] + timeArr[2] + "000"
- number, _ := strconv.ParseInt(warehousing_out_order, 10, 64)
- number = number + total
- warehousing_out_order = "YPCKD" + strconv.FormatInt(number, 10)
-
- warehouseOut := models.DrugWarehouseOut{
- WarehouseOutOrderNumber: warehousing_out_order,
- OperationTime: time.Now().Unix(),
- OrgId: orgID,
- Creater: creater,
- Ctime: time.Now().Unix(),
- Status: 1,
- WarehouseOutTime: record_time,
- Dealer: 0,
- Manufacturer: 0,
- Type: 1,
- IsSys: 1,
- }
- err := AddSigleDrugWarehouseOut(&warehouseOut)
- if err != nil {
- utils.TraceLog("创建出库单失败 err = %v", err)
- return err
- } else {
- out = warehouseOut
- }
- }
-
- // 出库流程
- // 1.查询该药品在药品库的规格信息,并将处方里的规格进行换算(尽量将拆零单位转换成包装单位)
- drup, _ := FindBaseDrugLibRecord(orgID, advice.DrugId)
- if drup.ID > 0 {
- prescribingNumber := advice.PrescribingNumber
-
- DrugDeliverInfo(orgID, prescribingNumber, &out, &drup, advice)
-
- } else {
- return errors.New("药品信息不存在")
- }
-
- }
-
- return
- }
-
- // 药品出库 递归方式
- func DrugDeliverInfo(orgID int64, prescribingNumber float64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.DoctorAdvice) (err error) {
-
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
-
- prescribingNumber_temp := strconv.FormatFloat(math.Abs(prescribingNumber), 'f', 0, 64)
- count, _ := strconv.ParseInt(prescribingNumber_temp, 10, 64)
-
- var drug_price float64
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- deliver_number = count * drup.MinNumber
-
- } else {
- deliver_number = count
-
- }
-
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- drug_price = drup.RetailPrice
- }
- fmt.Println(drug_price)
-
- if advice.PrescribingNumberUnit == drup.MinUnit {
- drug_price = drup.MinPrice
- }
-
- if advice.PrescribingNumberUnit != drup.MaxUnit || advice.PrescribingNumberUnit != drup.MinUnit {
- drug_price = drup.RetailPrice
- }
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
-
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- //查找药品信息
- //baseInfo, _ := FindBaseDrugLibRecord(advice.UserOrgId, advice.DrugId)
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
-
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- CountUnit: drup.MinUnit,
- RetailPrice: warehouse.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- Count: deliver_number, //出最小单位
- WarehouseInfoId: warehouse.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number, //按最小单位计算,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- SystemTime: advice.AdviceDate,
- WarehousingDetailId: warehouse.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- CreateDrugFlowOne(drugflow)
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- fmt.Println(errOne)
- //查询是否存在数据
-
- //_, errcodes := GetDrugWarehouseOutInfoIsExit(advice.DrugId, advice.PatientId, advice.RecordDate)
- //if errcodes == gorm.ErrRecordNotFound {
- // errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- // if errOne != nil {
- // return errOne
- // }
- //} else if errcodes == nil {
- // //service.GetLastDrugWarehouseOutInfoByPatientId(advice.DrugId, advice.PatientId, advice.RecordDate)
- // UpdatedDrugWarehouseOutInfo(warehouseOutInfo, advice.DrugId, advice.PatientId, advice.RecordDate, advice.UserOrgId)
- //}
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: count,
- CountUnit: advice.PrescribingNumberUnit,
- WarehouseInfoId: warehouse.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
-
- //if advice.PrescribingNumberUnit == drup.MaxUnit {
- // maxNumber = deliver_number / drup.MinNumber
- // minNumber = deliver_number % drup.MinNumber
- //
- //} else {
- // minNumber = deliver_number
- //}
- maxNumber = deliver_number / drup.MinNumber
- minNumber = deliver_number % drup.MinNumber
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
-
- if warehouse.StockMaxNumber < maxNumber {
-
- return errors.New("库存数量不足")
- }
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
-
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockMinNumber < minNumber {
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
-
- } else {
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
- }
-
- if warehouse.StockMaxNumber < 0 {
- return errors.New("库存数量不足")
- }
-
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- CountUnit: drup.MinUnit,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- Count: deliver_number,
- WarehouseInfoId: warehouse.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: deliver_number,
- CountUnit: drup.MinUnit,
- WarehouseInfoId: warehouse.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- info := models.XtDrugWarehouseInfo{
- ID: warehouse.ID,
- WarehousingId: warehouse.WarehousingId,
- DrugId: warehouse.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- WarehousingCount: warehouse.WarehousingCount,
- Price: warehouse.RetailPrice,
- TotalPrice: warehouse.TotalPrice,
- Dealer: warehouse.Dealer,
- Manufacturer: warehouse.Manufacturer,
- Remark: warehouse.Remark,
- Ctime: warehouse.Ctime,
- Mtime: warehouse.Mtime,
- Status: 1,
- OrgId: warehouse.OrgId,
- IsReturn: warehouse.IsReturn,
- WarehousingOrder: warehouse.WarehousingOrder,
- Type: warehouse.Type,
- RetailPrice: warehouse.RetailPrice,
- RetailTotalPrice: warehouse.RetailPrice,
- StockMaxNumber: 0,
- StockMinNumber: 0,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: warehouse.MaxUnit,
- WarehousingInfoId: warehouse.WarehousingInfoId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //扣减库存
- errThree := UpDateDrugWarehouseInfoByStock(&info)
- //fmt.Println("w我的事件23232332hh23323232233322332323232233232332323232323232",errThree)
-
- if errThree != nil {
- return errThree
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: stock_number,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- WarehousingDetailId: warehouse.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- CreateDrugFlowOne(drugflow)
-
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := deliver_number - stock_number
-
- overPlusNumber := float64(prescribingNumber_two_temp)
-
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- NewDrugDeliverInfo(orgID, overPlusNumber, warehouseout, drup, advice)
- }
-
- return
- }
-
- // 药品出库
-
- func HisDrugsDelivery(orgID int64, creater int64, advice *models.HisDoctorAdviceInfo) (err error) {
- // 1.判断药品是否来自专用字典的药品库
- // 2.判断当天当前机构有没有创建出库单,没有则创建
- // 3.创建出库流程
- // 3.1 实现先进先出逻辑 由于药品执行后,不可以修改和删除,所以不考虑出库后的退库和修改出库数量等
- isHasWay := false
- record_time := int64(0)
- isHasWay = true
- record_time = advice.RecordDate
- if isHasWay {
- //判断当天当前机构有没有创建出库单,没有则创建
- out, err := FindDrugStockOutByIsSys(orgID, 1, record_time)
- if err == gorm.ErrRecordNotFound {
- timeStr := time.Now().Format("2006-01-02")
- timeArr := strings.Split(timeStr, "-")
- total, _ := FindAllDrugWarehouseOut(orgID)
- total = total + 1
- warehousing_out_order := strconv.FormatInt(orgID, 10) + timeArr[0] + timeArr[1] + timeArr[2] + "000"
- number, _ := strconv.ParseInt(warehousing_out_order, 10, 64)
- number = number + total
- warehousing_out_order = "YPCKD" + strconv.FormatInt(number, 10)
- // creater := adminUserInfo.AdminUser.Id
- warehouseOut := models.DrugWarehouseOut{
- WarehouseOutOrderNumber: warehousing_out_order,
- OperationTime: time.Now().Unix(),
- OrgId: orgID,
- Creater: creater,
- Ctime: time.Now().Unix(),
- Status: 1,
- WarehouseOutTime: record_time,
- Dealer: 0,
- Manufacturer: 0,
- Type: 1,
- IsSys: 1,
- }
- err := AddSigleDrugWarehouseOut(&warehouseOut)
- if err != nil {
- utils.TraceLog("创建出库单失败 err = %v", err)
- return err
- } else {
- out = warehouseOut
- }
- }
-
- // 出库流程
- // 1.查询改药品在药品库的规格信息,并将处方里的规格进行换算(尽量将拆零单位转换成包装单位)
- drup, _ := FindBaseDrugLibRecord(orgID, advice.DrugId)
- if drup.ID > 0 {
- prescribingNumber := advice.PrescribingNumber
- HisDrugDeliverInfo(orgID, prescribingNumber, &out, &drup, advice)
-
- } else {
- return errors.New("药品信息不存在")
- }
-
- }
-
- return
- }
-
- // 药品出库 递归方式
- func HisDrugDeliverInfo(orgID int64, prescribingNumber float64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.HisDoctorAdviceInfo) (err error) {
-
- //fmt.Println("进来了吗323222222222222222222222222222222222222222222222222222222222222222222")
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
-
- prescribingNumber_temp := strconv.FormatFloat(math.Abs(prescribingNumber), 'f', 0, 64)
- count, _ := strconv.ParseInt(prescribingNumber_temp, 10, 64)
-
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- deliver_number = count * drup.MinNumber
- } else {
- deliver_number = count
- }
-
- var min_price float64
-
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- min_price = drup.RetailPrice
- }
- if advice.PrescribingNumberUnit == drup.MinUnit {
- min_price = drup.MinPrice
- }
-
- if advice.PrescribingNumberUnit != drup.MaxUnit && advice.PrescribingNumberUnit != drup.MinUnit {
- min_price = drup.RetailPrice
- }
- fmt.Println(min_price)
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
-
- //查找药品信息
- //baseInfo, _ := FindBaseDrugLibRecord(advice.UserOrgId, advice.DrugId)
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- CountUnit: drup.MinUnit,
- RetailPrice: warehouse.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- WarehouseInfoId: warehouse.ID,
- Count: deliver_number,
- AdviceId: advice.ID,
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- SystemTime: advice.AdviceDate,
- WarehousingDetailId: warehouse.ID,
- AdviceId: advice.ID,
- }
-
- CreateDrugFlowOne(drugflow)
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: deliver_number,
- CountUnit: drup.MinUnit,
- WarehouseInfoId: warehouse.ID,
- AdviceId: advice.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
- var stock_max_number int64 = 0
- stock_max_number = warehouse.StockMaxNumber
-
- maxNumber = deliver_number / drup.MinNumber
- minNumber = deliver_number % drup.MinNumber
-
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
-
- if drup.MaxUnit != drup.MinUnit {
- if warehouse.StockMaxNumber < maxNumber && warehouse.StockMinNumber < minNumber {
- return errors.New("库存数量不足")
- }
- }
- fmt.Println("minNumber23323323232323232322332", maxNumber, minNumber)
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
-
- if warehouse.StockMaxNumber < 0 {
- warehouse.StockMaxNumber = 0
- }
- if warehouse.StockMinNumber < 0 {
- warehouse.StockMinNumber = 0
- }
-
- warehouse.Mtime = time.Now().Unix()
- fmt.Println("w23332233232232332", warehouse.StockMinNumber, minNumber)
-
- if warehouse.StockMinNumber < minNumber {
- fmt.Println("进来的风3232332322323")
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
- } else {
- fmt.Println("进3232332322323")
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
- }
-
- if maxNumber == 1 && minNumber == 0 && drup.MaxUnit != drup.MinUnit {
- fmt.Println("2223232332322323", warehouse.StockMinNumber)
- warehouse.StockMinNumber = warehouse.StockMinNumber - deliver_number
- if warehouse.StockMinNumber == 0 {
- warehouse.StockMaxNumber = stock_max_number
- }
- }
-
- if drup.MaxUnit != drup.MinUnit {
- if warehouse.StockMaxNumber < 0 && warehouse.StockMinNumber < 0 {
- return errors.New("库存数量不足")
- }
- }
- if warehouse.StockMinNumber <= 0 {
- warehouse.StockMinNumber = 0
- }
-
- //扣减库存232332332332
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- RetailPrice: warehouse.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- WarehouseInfoId: warehouse.ID,
- Count: stock_number,
- CountUnit: drup.MinUnit,
- AdviceId: advice.ID,
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: stock_number,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- SystemTime: advice.AdviceDate,
- WarehousingDetailId: warehouse.ID,
- AdviceId: advice.ID,
- }
-
- CreateDrugFlowOne(drugflow)
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- //查询是否存在数据
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: stock_number,
- CountUnit: drup.MinUnit,
- WarehouseInfoId: warehouse.ID,
- AdviceId: advice.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- info := models.XtDrugWarehouseInfo{
- ID: warehouse.ID,
- WarehousingId: warehouse.WarehousingId,
- DrugId: warehouse.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- WarehousingCount: warehouse.WarehousingCount,
- Price: warehouse.Price,
- TotalPrice: warehouse.TotalPrice,
- Dealer: warehouse.Dealer,
- Manufacturer: warehouse.Manufacturer,
- Remark: warehouse.Remark,
- Ctime: warehouse.Ctime,
- Mtime: warehouse.Mtime,
- Status: 1,
- OrgId: warehouse.OrgId,
- IsReturn: warehouse.IsReturn,
- WarehousingOrder: warehouse.WarehousingOrder,
- Type: warehouse.Type,
- RetailPrice: warehouse.RetailPrice,
- RetailTotalPrice: warehouse.RetailPrice,
- StockMaxNumber: 0,
- StockMinNumber: 0,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: warehouse.MaxUnit,
- WarehousingInfoId: warehouse.WarehousingInfoId,
- }
- errThree := UpDateDrugWarehouseInfoByStock(&info)
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := deliver_number - stock_number
-
- overPlusNumber := float64(prescribingNumber_two_temp)
-
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
-
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- NewHisDrugDeliverInfo(orgID, overPlusNumber, warehouseout, drup, advice)
- }
-
- return
- }
-
- // 药品出库 递归方式
- func AutoDrugDeliverInfo(orgID int64, prescribingNumber int64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.DrugWarehouseOutInfo) (err error) {
-
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
-
- if advice.CountUnit == drup.MaxUnit {
- deliver_number = prescribingNumber * drup.MinNumber
- } else {
- deliver_number = prescribingNumber
- }
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
- //开启事物
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
-
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- fmt.Println("库存1", stock_number)
- fmt.Println("c出库数量", deliver_number)
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
-
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: advice.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: advice.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 0,
- SysRecordTime: advice.Ctime,
- DrugId: advice.DrugId,
- ExpiryDate: advice.ExpiryDate,
- ProductDate: advice.ProductDate,
- Number: advice.Number,
- BatchNumber: warehouse.BatchNumber,
- Count: deliver_number,
- RetailPrice: advice.RetailPrice,
- Price: advice.Price,
- WarehouseInfoId: warehouse.ID,
- CountUnit: drup.MinUnit,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- warehouseOutInfo.Count = prescribingNumber
- warehouseOutInfo.CountUnit = advice.CountUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- drugWareInfo, _ := GetLastWarehouseOutInfoById(advice.DrugId)
- drugflow := models.DrugFlow{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: advice.ProductDate,
- ExpireDate: advice.ExpiryDate,
- Count: deliver_number,
- Price: advice.Price,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: advice.OrgId,
- Manufacturer: advice.Manufacturer,
- Dealer: advice.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 2,
- IsEdit: 1,
- Creator: 0,
- IsSys: 0,
- WarehouseOutDetailId: drugWareInfo.ID,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- CreateDrugFlowOne(drugflow)
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
- if advice.CountUnit == drup.MinUnit {
- maxNumber = prescribingNumber / drup.MinNumber
- minNumber = prescribingNumber % drup.MinNumber
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
- } else {
- maxNumber = prescribingNumber
- }
-
- if warehouse.StockMaxNumber < maxNumber {
-
- return errors.New("库存数量不足")
- }
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockMinNumber < minNumber {
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
- } else {
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
- }
- fmt.Println("ware233232322332323232", warehouse.StockMaxNumber)
- fmt.Println("ware233232322332323232", warehouse.StockMinNumber)
- if warehouse.StockMaxNumber == 1 && warehouse.StockMinNumber == 1 && drup.MaxUnit == drup.MinUnit {
- warehouse.StockMinNumber = 0
- }
-
- if warehouse.StockMaxNumber < 0 {
- return errors.New("库存数量不足")
- }
-
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: advice.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: advice.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 0,
- SysRecordTime: advice.Ctime,
- DrugId: advice.DrugId,
- ExpiryDate: warehouse.ExpiryDate,
- ProductDate: warehouse.ProductDate,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Count: stock_number,
- RetailPrice: advice.RetailPrice,
- Price: advice.Price,
- WarehouseInfoId: warehouse.ID,
- CountUnit: drup.MinUnit,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- warehouseOutInfo.Count = stock_number
-
- //warehouseOutInfo.CountUnit = advice.CountUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- drugWareInfo, _ := GetLastWarehouseOutInfoById(advice.DrugId)
- drugflow := models.DrugFlow{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: advice.ProductDate,
- ExpireDate: advice.ExpiryDate,
- Count: stock_number,
- Price: advice.Price,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: advice.OrgId,
- Manufacturer: advice.Manufacturer,
- Dealer: advice.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 2,
- IsEdit: 1,
- Creator: 0,
- IsSys: 0,
- WarehouseOutDetailId: drugWareInfo.ID,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- CreateDrugFlowOne(drugflow)
- // 出库完成后,要将该批次库存清零
- warehouse.StockMaxNumber = 0
- warehouse.StockMinNumber = 0
- warehouse.Mtime = time.Now().Unix()
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := deliver_number - stock_number
- fmt.Println("剩余库存323323223232323232323323223", prescribingNumber_two_temp)
- advice.CountUnit = drup.MinUnit
-
- AutoDrugDeliverInfo(orgID, prescribingNumber_two_temp, warehouseout, drup, advice)
- }
-
- return
- }
-
- // 耗材出库
- func ConsumablesDeliveryTotal(orgID int64, patient_id int64, record_time int64, goods []*models.DialysisBeforePrepareGoods, goodOne []*models.NewDialysisBeforePrepareGoods, creator int64) (err error) {
-
- //查询该患者当天已经出库的耗材信息
- goods_yc, _ := FindConsumablesByDateTwo(orgID, patient_id, record_time)
- // 和新请求的出库数据进行对比,分出那些是继续出库的,那些是需要删除出库的
- for i := len(goods_yc) - 1; i >= 0; i-- {
- goods_yc_temp := goods_yc[i]
- for j := len(goods) - 1; j >= 0; j-- {
- goods_temp := goods[j]
- // 已经出库和新请求出库都存在该耗材,则判断出库数量,分成是继续出库,还是删除出库
- if goods_yc_temp.GoodTypeId == goods_temp.GoodTypeId && goods_yc_temp.GoodId == goods_temp.GoodId {
- // 已经出库和新请求出库的出库数量一致,则清除两个结构体里的数据(既不出库,也不删除出库)
- if goods_yc_temp.Count == goods_temp.Count {
- goods_yc = append(goods_yc[:i], goods_yc[i+1:]...)
- goods = append(goods[:j], goods[j+1:]...)
- break
- }
- // 如果已经出库的数量 大于 新请求出库的数量,则代表需要删除出库
- if goods_yc_temp.Count > goods_temp.Count {
-
- temp_count := goods_yc_temp.Count - goods_temp.Count
- goods_yc[i].Count = temp_count
- goods = append(goods[:j], goods[j+1:]...)
- break
- }
- // 如果已经出库的数量 小于 新请求出库的梳理,则代表需要增加出库
- if goods_yc_temp.Count < goods_temp.Count {
- temp_count := goods_temp.Count - goods_yc_temp.Count
- //fmt.Println("988888888888888", temp_count)
- goods[j].Count = temp_count
- goods_yc = append(goods_yc[:i], goods_yc[i+1:]...)
- //fmt.Println("888888888", goods_yc)
- break
- }
- }
- }
- }
-
- // goods_yc 这个数据就是需要已经出库了,但是现在需要删除出库的耗材数据
- // goods 这个数据就是需要出库的耗材的数据(新增的数据)
-
- if len(goods) > 0 {
- out, err := FindStockOutByIsSys(orgID, 1, record_time)
- if err == gorm.ErrRecordNotFound {
- //没有记录,则创建出库单
- timeStr := time.Now().Format("2006-01-02")
- timeArr := strings.Split(timeStr, "-")
- total, _ := FindAllWarehouseOut(orgID)
- total = total + 1
- warehousing_out_order := strconv.FormatInt(orgID, 10) + timeArr[0] + timeArr[1] + timeArr[2] + "000"
- number, _ := strconv.ParseInt(warehousing_out_order, 10, 64)
- number = number + total
- warehousing_out_order = "CKD" + strconv.FormatInt(number, 10)
- warehouseOut := models.WarehouseOut{
- WarehouseOutOrderNumber: warehousing_out_order,
- OperationTime: time.Now().Unix(),
- OrgId: orgID,
- Creater: creator,
- Ctime: time.Now().Unix(),
- Status: 1,
- WarehouseOutTime: record_time,
- Dealer: 0,
- Manufacturer: 0,
- Type: 1,
- IsSys: 1,
- }
- err := AddSigleWarehouseOut(&warehouseOut)
- if err != nil {
- utils.TraceLog("创建出库单失败 err = %v", err)
- return err
- } else {
- out = warehouseOut
- }
- }
-
- for _, item := range goods {
- var newCount int64 = 0
- for _, it := range goodOne {
- if item.GoodTypeId == it.GoodTypeId && item.GoodId == it.GoodId {
- newCount = it.Count
- }
- }
- prepare := models.DialysisBeforePrepare{
- GoodTypeId: item.GoodTypeId,
- GoodId: item.GoodId,
- Count: item.Count,
- ProjectId: item.ProjectId,
- }
-
- ConsumablesDelivery(orgID, patient_id, record_time, &prepare, &out, newCount)
-
- }
-
- }
-
- if len(goods_yc) > 0 {
- for _, good_yc := range goods_yc {
- out, _ := FindStockOutByIsSys(orgID, 1, record_time)
- ConsumablesDeliveryDelete(orgID, patient_id, record_time, good_yc, &out)
- }
- }
-
- return nil
- }
-
- //耗材出库
- func ConsumablesDelivery(orgID int64, patient_id int64, record_time int64, goods *models.DialysisBeforePrepare, warehouseOut *models.WarehouseOut, count int64) (err error) {
-
- fmt.Println("count23323223233232323232332232323", count, goods.Count)
- var deliver_number int64 = 0
- var stock_number int64 = 0
- var maxNumber int64 = 0
-
- deliver_number = goods.Count
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
-
- warehouse, err := FindFirstWarehousingInfoByStock(goods.GoodId, goods.GoodTypeId)
- if err != nil {
-
- return errors.New("库存数量不足")
- }
-
- stock_number = warehouse.StockCount
-
- //获取耗材信息
- info, _ := GetGoodInformationByGoodId(goods.GoodId)
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: record_time,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- PatientId: patient_id,
- Number: warehouse.Number,
- LicenseNumber: warehouse.LicenseNumber,
- Price: warehouse.PackingPrice,
- ExpiryDate: warehouse.ExpiryDate,
- ProductDate: warehouse.ProductDate,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- warehouseOutInfo.Count = count
-
- _, errcodes := GetWarehouseOutInfoIsExistOne(goods.GoodId, patient_id, record_time)
- if errcodes == gorm.ErrRecordNotFound {
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- } else if errcodes == nil {
- UpdatedWarehouseOutInfo(warehouseOutInfo, goods.GoodId, patient_id, record_time)
- }
-
- details := models.BloodAutomaticReduceDetail{
- WarehouseOutId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
- PatientId: patient_id,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: record_time,
- OrgId: orgID,
- GoodId: goods.GoodId,
- GoodTypeId: goods.GoodTypeId,
- Count: count,
- ProjectId: goods.ProjectId,
- }
- //查询当天耗材是否已经存在数据
- _, errcode := GetAutoMaticReduceDetail(orgID, patient_id, record_time, goods.GoodId, goods.GoodTypeId)
-
- if errcode == gorm.ErrRecordNotFound {
- errTwo := CreateAutoReduceRecord(&details)
- if errTwo != nil {
- return errTwo
- }
- //插入库存流水表
- flow := models.VmStockFlow{
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //查询流水是否存在
- exsit, errflow := GetStockFlowIsExsit(warehouse.ID, patient_id, record_time, goods.GoodId)
-
- if errflow == gorm.ErrRecordNotFound {
- errThre := CreateStockFlowOne(flow)
- if errThre != nil {
- return errThre
- }
- } else if errflow == nil {
- flow := models.VmStockFlow{
- ID: exsit.ID,
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: exsit.Count + goods.Count,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ReturnCount: exsit.Count + (exsit.Count + deliver_number),
- ProjectId: goods.ProjectId,
- }
-
- errFour := UpdatedStockFlowOne(flow, warehouse.ID, patient_id, record_time, goods.GoodId)
- if errFour != nil {
- return errFour
- }
- }
-
- } else if errcode == nil {
- flow := models.VmStockFlow{
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //查询流水是否存在
- exsit, errflow := GetStockFlowIsExsit(warehouse.ID, patient_id, record_time, goods.GoodId)
-
- if errflow == gorm.ErrRecordNotFound {
- CreateStockFlowOne(flow)
- DeleteAutoRedeceDetailTwo(orgID, patient_id, record_time, goods.GoodId, goods.GoodTypeId)
- CreateAutoReduceRecord(&details)
- } else if errflow == nil {
- flow := models.VmStockFlow{
- ID: exsit.ID,
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: exsit.Count + goods.Count,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ReturnCount: exsit.Count + (exsit.Count + deliver_number),
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //UpdatedStockFlow(flow)
- UpdatedStockFlowOne(flow, warehouse.ID, patient_id, record_time, goods.GoodId)
- DeleteAutoRedeceDetailTwo(orgID, patient_id, record_time, goods.GoodId, goods.GoodTypeId)
- CreateAutoReduceRecord(&details)
- }
-
- }
-
- maxNumber = goods.Count
-
- if warehouse.StockCount < maxNumber {
- return errors.New("库存数量不足")
- }
-
- warehouse.StockCount = warehouse.StockCount - maxNumber
-
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockCount < 0 {
- return errors.New("库存数量不足")
- }
- errThree := UpDateWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
-
- // 当刚批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: record_time,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- PatientId: patient_id,
- Number: warehouse.Number,
- LicenseNumber: warehouse.LicenseNumber,
- Price: warehouse.PackingPrice,
- ExpiryDate: warehouse.ExpiryDate,
- ProductDate: warehouse.ProductDate,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- warehouseOutInfo.Count = stock_number
-
- _, errcodes := GetWarehouseOutInfoIsExistOne(goods.GoodId, goods.PatientId, record_time)
-
- if errcodes == gorm.ErrRecordNotFound {
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
-
- if errOne != nil {
- return errOne
- }
- //插入库存流水表
- flow := models.VmStockFlow{
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: stock_number,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //查询流水是否存在
- exsit, errflows := GetStockFlowIsExsit(warehouse.ID, patient_id, record_time, goods.GoodId)
-
- if errflows == gorm.ErrRecordNotFound {
- CreateStockFlowOne(flow)
- } else if errflows == nil {
- flow := models.VmStockFlow{
- ID: exsit.ID,
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: exsit.Count + goods.Count,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ReturnCount: exsit.Count + (exsit.Count + deliver_number),
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //UpdatedStockFlow(flow)
- UpdatedStockFlowOne(flow, warehouse.ID, patient_id, record_time, goods.GoodId)
- }
-
- } else if errcodes == nil {
-
- goods.Count = deliver_number - stock_number
- //更新数量为 该批次剩余数量 + 还有未出的数量
- warehouseOutInfo.Count = stock_number
- UpdatedWarehouseOutInfo(warehouseOutInfo, goods.GoodId, goods.PatientId, record_time)
- //插入库存流水表
- flow := models.VmStockFlow{
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: stock_number,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //查询流水是否存在
- exsit, errflows := GetStockFlowIsExsit(warehouse.ID, patient_id, record_time, goods.GoodId)
- if errflows == gorm.ErrRecordNotFound {
- CreateStockFlowOne(flow)
- } else if errflows == nil {
-
- flow := models.VmStockFlow{
- ID: exsit.ID,
- WarehouseOutId: warehouseOut.ID,
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: exsit.Count + goods.Count,
- Price: warehouse.PackingPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: info.Manufacturer,
- Dealer: info.Dealer,
- LicenseNumber: warehouse.LicenseNumber,
- IsEdit: 2,
- Creator: warehouseOut.Creater,
- SystemTime: record_time,
- ConsumableType: 3,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsSys: 1,
- PatientId: patient_id,
- ProjectId: goods.ProjectId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //UpdatedStockFlow(flow)
- UpdatedStockFlowOne(flow, warehouse.ID, patient_id, record_time, goods.GoodId)
- }
- }
-
- // 出库完成后,要将该批次库存清零
- warehouse.StockCount = 0
- warehouse.Mtime = time.Now().Unix()
- errThree := UpDateWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- goods.Count = deliver_number - stock_number
-
- ConsumablesDelivery(orgID, patient_id, record_time, goods, warehouseOut, count)
-
- }
- return nil
- }
-
- //耗材出库删除
- func ConsumablesDeliveryDelete(orgID int64, patient_id int64, record_time int64, good_yc *models.DialysisBeforePrepare, warehouseOut *models.WarehouseOut) (err error) {
- // 先根据相关信息查询当天该耗材的出库信息
- warehouseOutInfos, err := FindStockOutInfoByStock(orgID, good_yc.GoodTypeId, good_yc.GoodId, record_time, patient_id)
- if err != nil {
- return err
- }
-
- var delete_count int64 = 0
-
- for _, ware := range warehouseOutInfos {
- // 判断当前出库的数据和删除出库数量
- if good_yc.Count <= ware.Count {
- delete_count = good_yc.Count
- } else {
- delete_count = ware.Count
- }
- // 在出库记录表里记录退库详情
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- //WarehouseInfoId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: "",
- OrgId: orgID,
- Type: 1,
- Manufacturer: 0,
- Dealer: 0,
- IsSys: 2,
- SysRecordTime: record_time,
- GoodTypeId: good_yc.GoodTypeId,
- GoodId: good_yc.GoodId,
- PatientId: patient_id,
- }
- warehouseOutInfo.Count = ware.Count - delete_count
- stockInInfo, _ := FindLastStockInInfoRecord(good_yc.GoodId, orgID)
- warehouseOutInfo.Price = stockInInfo.Price
- errOne := UpdateAutoMaticReduceDetail(good_yc.GoodId, good_yc.GoodTypeId, record_time, patient_id, orgID, warehouseOutInfo)
- if errOne != nil {
- return errOne
- } else {
- details := &models.AutomaticReduceDetail{
- WarehouseOutId: warehouseOutInfo.ID,
- WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
- PatientId: patient_id,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: record_time,
- OrgId: orgID,
- GoodId: good_yc.GoodId,
- GoodTypeId: good_yc.GoodTypeId,
- Count: warehouseOutInfo.Count,
- Type: 2,
- }
- //查询是否当天已经存在数据
- _, errcode := GetAutoMaticReduceDetail(orgID, patient_id, record_time, good_yc.GoodId, good_yc.GoodTypeId)
- if errcode == gorm.ErrRecordNotFound {
- errTwo := AddSigleAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
- } else if errcode == nil {
- DeleteAutoRedeceDetailTwo(orgID, patient_id, record_time, good_yc.GoodId, good_yc.GoodTypeId)
-
- AddSigleAutoReduceRecordInfo(details)
- }
- }
-
- // 删除出库完成后,要增加对应批次的库存数量
-
- errThree := UpDateWarehouseInfoByStockDelete(ware.WarehouseInfotId, delete_count)
- if errThree != nil {
- return errThree
- }
-
- // 增加了对应的库存后,看看还有多少需要退库的
- good_yc.Count = good_yc.Count - delete_count
- if good_yc.Count == 0 {
- return nil
- }
- }
-
- if good_yc.Count == 0 {
- return nil
- } else {
- return errors.New("退库和出库数据不匹配")
- }
- }
-
- func GetAutoReduceRecordInfoByPatientId(orgid int64, patient_id int64, recordTime int64) (autoReduce []*models.AutomaticReduceDetail, err error) {
-
- err = XTReadDB().Model(&autoReduce).Where("org_id = ? and patient_id = ? and record_time = ? and status = 1", orgid, patient_id, recordTime).Find(&autoReduce).Error
- return autoReduce, err
- }
-
- func DeleteDialysisBefor(orgid int64, patient_id int64, record_date int64, goodid int64, goodtypeid int64) error {
- prepare := models.DialysisBeforePrepare{}
- err := XTWriteDB().Model(&prepare).Where("user_org_id = ? and patient_id = ? and record_date = ? and status = 1 and good_id = ? and good_type_id = ?", orgid, patient_id, record_date, goodid, goodtypeid).Updates(map[string]interface{}{"status": 0, "count": 0, "mtime": time.Now().Unix()}).Error
- return err
- }
-
- func DeleteDialysisBeforThree(orgid int64, patient_id int64, record_date int64) error {
- prepare := models.DialysisBeforePrepare{}
- err := XTWriteDB().Model(&prepare).Where("user_org_id = ? and patient_id = ? and record_date = ? and status = 1", orgid, patient_id, record_date).Updates(map[string]interface{}{"status": 0, "count": 0, "mtime": time.Now().Unix()}).Error
- return err
- }
-
- func GetWarehouseById(id int64) (models.WarehouseOut, error) {
- out := models.WarehouseOut{}
- err := XTReadDB().Where("id=? and status = 1", id).Find(&out).Error
- return out, err
- }
-
- //耗材出库
- func ConsumablesDeliveryOne(orgID int64, record_time int64, goods *models.WarehouseOutInfo, warehouseOut *models.WarehouseOut, count int64, creator int64) (err error) {
-
- var deliver_number int64 = 0
- var stock_number int64 = 0
- var maxNumber int64 = 0
-
- deliver_number = goods.Count
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
-
- // 如果没有对应的库存,则报错
- warehouse, err := FindFirstWarehousingInfoByStock(goods.GoodId, goods.GoodTypeId)
- if err != nil {
-
- return err
- }
-
- stock_number = warehouse.StockCount
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
-
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: goods.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- IsSys: 0,
- SysRecordTime: record_time,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- ExpiryDate: goods.ExpiryDate,
- ProductDate: goods.ProductDate,
- Number: warehouse.Number,
- Price: goods.Price,
- LicenseNumber: goods.LicenseNumber,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- warehouseOutInfo.Count = goods.Count
- //添加出库单详情
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- stockFlow := models.VmStockFlow{
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- LicenseNumber: goods.LicenseNumber,
- Count: goods.Count,
- UserOrgId: goods.OrgId,
- PatientId: goods.PatientId,
- SystemTime: record_time,
- ConsumableType: 2,
- IsSys: goods.IsSys,
- WarehousingOrder: "",
- WarehouseOutId: warehouseOut.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsEdit: 1,
- CancelStockId: 0,
- CancelOrderNumber: "",
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- Creator: creator,
- UpdateCreator: 0,
- Status: 1,
- Ctime: time.Now().Unix(),
- Mtime: 0,
- Price: warehouse.PackingPrice,
- WarehousingDetailId: 0,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- CancelOutDetailId: 0,
- ProductDate: goods.ProductDate,
- ExpireDate: goods.ExpiryDate,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- //创建出库流水
- CreateStockFlowOne(stockFlow)
-
- maxNumber = goods.Count
-
- if warehouse.StockCount < maxNumber {
- return errors.New("库存数量不足")
- }
-
- warehouse.StockCount = warehouse.StockCount - maxNumber
- warehouse.Mtime = time.Now().Unix()
-
- //扣减库存
- errThree := UpDateWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
-
- } else {
-
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: goods.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- IsSys: 0,
- SysRecordTime: record_time,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- ExpiryDate: goods.ExpiryDate,
- ProductDate: goods.ProductDate,
- Number: warehouse.Number,
- Price: warehouse.PackingPrice,
- LicenseNumber: goods.LicenseNumber,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- warehouseOutInfo.Count = stock_number
-
- //查询是否已经生成出库单
- info, errcodes := GetStockInRecoredByGoodIdOne(goods.GoodId, goods.GoodTypeId, goods.SysRecordTime, goods.OrgId)
- if errcodes == gorm.ErrRecordNotFound {
- //创建出库单
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- } else {
- warehouseOutInfo.Count = info.Count + stock_number
-
- UpdateAutoMaticReduceDetailOne(goods.GoodId, goods.GoodTypeId, goods.SysRecordTime, goods.OrgId, warehouseOutInfo)
- }
-
- stockFlow := models.VmStockFlow{
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- LicenseNumber: goods.LicenseNumber,
- Count: stock_number,
- UserOrgId: goods.OrgId,
- PatientId: 0,
- SystemTime: record_time,
- ConsumableType: 2,
- IsSys: 0,
- WarehousingOrder: "",
- WarehouseOutId: warehouseOut.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsEdit: 1,
- CancelStockId: 0,
- CancelOrderNumber: "",
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- Creator: creator,
- UpdateCreator: 0,
- Status: 1,
- Ctime: time.Now().Unix(),
- Mtime: 0,
- Price: warehouse.PackingPrice,
- WarehousingDetailId: 0,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- CancelOutDetailId: 0,
- ProductDate: goods.ProductDate,
- ExpireDate: goods.ExpiryDate,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- //创建出库明细
- CreateStockFlowOne(stockFlow)
- // 出库完成后,要将该批次库存清零
- warehouse.StockCount = 0
- warehouse.Mtime = time.Now().Unix()
-
- errThree := UpDateWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- goods.Count = deliver_number - stock_number
-
- ConsumablesDeliveryOne(orgID, record_time, goods, warehouseOut, count, creator)
-
- }
- return nil
- }
-
- //退库逻辑
- func ConsumablesDeliveryTwo(orgID int64, goods *models.WarehouseOutInfo, count int64) (err error) {
-
- var deliver_number int64 = 0
- var stock_number int64 = 0
- var maxNumber int64 = 0
-
- deliver_number = goods.Count
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- warehouse, err := FindFirstWarehousingInfoByGoodId(goods.GoodId, goods.ID)
-
- if err != nil {
- return err
- }
-
- stock_number = warehouse.StockCount
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: goods.WarehouseOutOrderNumber,
- WarehouseOutId: goods.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: goods.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- IsSys: 0,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- ExpiryDate: goods.ExpiryDate,
- ProductDate: goods.ProductDate,
- Number: goods.Number,
- Price: warehouse.PackingPrice,
- LicenseNumber: goods.LicenseNumber,
- ConsumableType: 2,
- }
- warehouseOutInfo.Count = goods.Count
-
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- maxNumber = goods.Count
-
- if warehouse.StockCount < maxNumber {
- return errors.New("库存数量不足")
- }
-
- warehouse.StockCount = warehouse.StockCount - maxNumber
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockCount <= 0 {
-
- return errors.New("库存数量不足")
- }
- errThree := UpDateWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
- return
- } else {
-
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: goods.WarehouseOutOrderNumber,
- WarehouseOutId: goods.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: goods.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- IsSys: 0,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- ExpiryDate: goods.ExpiryDate,
- ProductDate: goods.ProductDate,
- Number: goods.Number,
- Price: warehouse.PackingPrice,
- LicenseNumber: goods.LicenseNumber,
- ConsumableType: 2,
- }
- warehouseOutInfo.Count = stock_number
-
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- // 出库完成后,要将该批次库存清零
- warehouse.StockCount = 0
- warehouse.Mtime = time.Now().Unix()
- errThree := UpDateWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
-
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- goods.Count = deliver_number - stock_number
-
- ConsumablesDeliveryTwo(orgID, goods, count)
-
- }
- return nil
- }
-
- func DeleteWarehouseInfo(id int64) error {
- err := XTWriteDB().Model(models.WarehousingInfo{}).Where("id = ? and status = 1", id).Updates(map[string]interface{}{"stock_count": 0}).Error
- return err
- }
-
- // 药品出库 递归方式
- func NewDrugDeliverInfo(orgID int64, prescribingNumber float64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.DoctorAdvice) (err error) {
-
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
-
- prescribingNumber_temp := strconv.FormatFloat(math.Abs(prescribingNumber), 'f', 0, 64)
- count, _ := strconv.ParseInt(prescribingNumber_temp, 10, 64)
-
- var drug_price float64
-
- //按最小单位数据计算
- deliver_number = count
-
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- drug_price = drup.RetailPrice
- }
-
- if advice.PrescribingNumberUnit == drup.MinUnit {
- drug_price = drup.MinPrice
- }
-
- if advice.PrescribingNumberUnit != drup.MaxUnit || advice.PrescribingNumberUnit != drup.MinUnit {
- drug_price = drup.RetailPrice
- }
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
-
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- CountUnit: drup.MinUnit,
- RetailPrice: drug_price,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- Count: deliver_number, //出最小单位
- WarehouseInfoId: warehouse.ID,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number, //按最小单位计算,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- WarehousingDetailId: warehouse.ID,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- CreateDrugFlowOne(drugflow)
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- //查询是否存在数据
- //_, errcodes := GetDrugWarehouseOutInfoIsExit(advice.DrugId, advice.PatientId, advice.RecordDate)
- //if errcodes == gorm.ErrRecordNotFound {
- // errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- // if errOne != nil {
- // return errOne
- // }
- //} else if errcodes == nil {
- // UpdatedDrugWarehouseOutInfo(warehouseOutInfo, advice.DrugId, advice.PatientId, advice.RecordDate, advice.UserOrgId)
- //}
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: count,
- CountUnit: advice.PrescribingNumberUnit,
- WarehouseInfoId: warehouse.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
-
- //将拆零数量转为 最大包装单位 和 最小单位
- maxNumber = deliver_number / drup.MinNumber
- minNumber = deliver_number % drup.MinNumber
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
-
- if warehouse.StockMaxNumber < maxNumber {
-
- return errors.New("库存数量不足")
- }
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
-
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockMinNumber < minNumber {
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
-
- } else {
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
- }
-
- if warehouse.StockMaxNumber < 0 {
- return errors.New("库存数量不足")
- }
-
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- CountUnit: drup.MinUnit,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- Count: deliver_number,
- WarehouseInfoId: warehouse.ID,
- AdviceId: advice.ID,
- }
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- //查询是否存在数据
- //_, errcodes := GetDrugWarehouseOutInfoIsExit(advice.DrugId, advice.PatientId, advice.RecordDate)
- //if errcodes == gorm.ErrRecordNotFound {
- // errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- // if errOne != nil {
- // return errOne
- // }
- //} else if errcodes == nil {
- // UpdatedDrugWarehouseOutInfo(warehouseOutInfo, advice.DrugId, advice.PatientId, advice.RecordDate, advice.UserOrgId)
- //}
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: deliver_number,
- CountUnit: drup.MinUnit,
- WarehouseInfoId: warehouse.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- // 出库完成后,要将该批次库存清零
- //warehouse.StockMaxNumber = 0
- //warehouse.StockMinNumber = 0
- //warehouse.Mtime = time.Now().Unix()
-
- info := models.XtDrugWarehouseInfo{
- ID: warehouse.ID,
- WarehousingId: warehouse.WarehousingId,
- DrugId: warehouse.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- WarehousingCount: warehouse.WarehousingCount,
- Price: warehouse.Price,
- TotalPrice: warehouse.TotalPrice,
- Dealer: warehouse.Dealer,
- Manufacturer: warehouse.Manufacturer,
- Remark: warehouse.Remark,
- Ctime: warehouse.Ctime,
- Mtime: warehouse.Mtime,
- Status: 1,
- OrgId: warehouse.OrgId,
- IsReturn: warehouse.IsReturn,
- WarehousingOrder: warehouse.WarehousingOrder,
- Type: warehouse.Type,
- RetailPrice: warehouse.RetailPrice,
- RetailTotalPrice: warehouse.RetailPrice,
- StockMaxNumber: 0,
- StockMinNumber: 0,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: warehouse.MaxUnit,
- WarehousingInfoId: warehouse.WarehousingInfoId,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
- //扣减库存
- errThree := UpDateDrugWarehouseInfoByStock(&info)
-
- if errThree != nil {
- return errThree
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- WarehousingDetailId: warehouse.ID,
- AdviceId: advice.ID,
- SupplyWarehouseId: warehouse.SupplyWarehouseId,
- }
-
- CreateDrugFlowOne(drugflow)
-
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := deliver_number - stock_number
-
- overPlusNumber := float64(prescribingNumber_two_temp)
-
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- NewDrugDeliverInfo(orgID, overPlusNumber, warehouseout, drup, advice)
- }
-
- return
- }
-
- // 药品出库 递归方式
- func NewHisDrugDeliverInfo(orgID int64, prescribingNumber float64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.HisDoctorAdviceInfo) (err error) {
-
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
-
- prescribingNumber_temp := strconv.FormatFloat(math.Abs(prescribingNumber), 'f', 0, 64)
- count, _ := strconv.ParseInt(prescribingNumber_temp, 10, 64)
-
- deliver_number = count
-
- var min_price float64
-
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- min_price = drup.RetailPrice
- }
- if advice.PrescribingNumberUnit == drup.MinUnit {
- min_price = drup.MinPrice
- }
-
- if advice.PrescribingNumberUnit != drup.MaxUnit && advice.PrescribingNumberUnit != drup.MinUnit {
- min_price = drup.RetailPrice
- }
- fmt.Println(min_price)
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
- //开启事物
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
- //查找药品信息
- //baseInfo, _ := FindBaseDrugLibRecord(advice.UserOrgId, advice.DrugId)
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- CountUnit: drup.MinUnit,
- RetailPrice: warehouse.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- WarehouseInfoId: warehouse.ID,
- Count: deliver_number,
- AdviceId: advice.ID,
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: deliver_number,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- SystemTime: advice.RecordDate,
- WarehousingDetailId: warehouse.ID,
- AdviceId: advice.ID,
- }
-
- CreateDrugFlowOne(drugflow)
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: deliver_number,
- CountUnit: drup.MinUnit,
- WarehouseInfoId: warehouse.ID,
- AdviceId: advice.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
-
- var maxNumber int64 = 0
- var minNumber int64 = 0
-
- //把拆零单位转为最大单位 和 最小单位
- maxNumber = deliver_number / drup.MinNumber
- minNumber = deliver_number % drup.MinNumber
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
- if warehouse.StockMaxNumber < maxNumber {
- return errors.New("库存数量不足")
- }
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
- if warehouse.StockMaxNumber < 0 {
- warehouse.StockMaxNumber = 0
- }
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockMinNumber < minNumber {
- fmt.Println("233323232233223")
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
- } else {
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
- }
-
- if warehouse.StockMaxNumber < 0 {
- return errors.New("库存数量不足")
- }
- if warehouse.StockMinNumber <= 0 {
- warehouse.StockMinNumber = 0
- }
-
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: warehouse.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 1,
- SysRecordTime: advice.RecordDate,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Price: warehouse.RetailPrice,
- RetailPrice: warehouse.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- WarehouseInfoId: warehouse.ID,
- Count: stock_number,
- CountUnit: drup.MinUnit,
- AdviceId: advice.ID,
- }
-
- drugflow := models.DrugFlow{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseout.ID,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpireDate: warehouse.ExpiryDate,
- Count: stock_number,
- Price: warehouse.RetailPrice,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: orgID,
- Manufacturer: warehouse.Manufacturer,
- Dealer: warehouse.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 3,
- IsEdit: 1,
- Creator: advice.ExecutionStaff,
- IsSys: 1,
- PatientId: advice.PatientId,
- SystemTime: advice.RecordDate,
- WarehousingDetailId: warehouse.ID,
- AdviceId: advice.ID,
- }
-
- CreateDrugFlowOne(drugflow)
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseout.ID,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- PatientId: advice.PatientId,
- Ctime: time.Now().Unix(),
- Mtime: time.Now().Unix(),
- Status: 1,
- RecordTime: advice.RecordDate,
- OrgId: orgID,
- DrugId: advice.DrugId,
- Count: stock_number,
- CountUnit: drup.MinUnit,
- WarehouseInfoId: warehouse.ID,
- AdviceId: advice.ID,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
-
- info := models.XtDrugWarehouseInfo{
- ID: warehouse.ID,
- WarehousingId: warehouse.WarehousingId,
- DrugId: warehouse.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- WarehousingCount: warehouse.WarehousingCount,
- Price: warehouse.RetailPrice,
- TotalPrice: warehouse.TotalPrice,
- Dealer: warehouse.Dealer,
- Manufacturer: warehouse.Manufacturer,
- Remark: warehouse.Remark,
- Ctime: warehouse.Ctime,
- Mtime: warehouse.Mtime,
- Status: 1,
- OrgId: warehouse.OrgId,
- IsReturn: warehouse.IsReturn,
- WarehousingOrder: warehouse.WarehousingOrder,
- Type: warehouse.Type,
- RetailPrice: warehouse.RetailPrice,
- RetailTotalPrice: warehouse.RetailPrice,
- StockMaxNumber: 0,
- StockMinNumber: 0,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: warehouse.MaxUnit,
- WarehousingInfoId: warehouse.WarehousingInfoId,
- }
- errThree := UpDateDrugWarehouseInfoByStock(&info)
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := deliver_number - stock_number
- overPlusNumber := float64(prescribingNumber_two_temp)
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- NewHisDrugDeliverInfo(orgID, overPlusNumber, warehouseout, drup, advice)
- }
-
- return
- }
-
- // 药品出库 递归方式
- func HisAuToReduce(orgID int64, prescribingNumber float64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.HisDoctorAdviceInfo) (err error) {
-
- //查询最后一次出库数据
- drugInfo, _ := GetDrugWarehouseOutInfoIsExit(advice.DrugId, advice.PatientId, advice.RecordDate)
-
- prescribingNumber_temp := strconv.FormatFloat(math.Abs(prescribingNumber), 'f', 0, 64)
- count, _ := strconv.ParseInt(prescribingNumber_temp, 10, 64)
- var count_number int64
- var device_number int64
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- device_number = count * drup.MinNumber
- }
- if advice.PrescribingNumberUnit == drup.MinUnit {
- device_number = count
- }
-
- if drugInfo.CountUnit == drup.MaxUnit {
- count_number = drugInfo.Count * drup.MinNumber
- }
- if drugInfo.CountUnit == drup.MinUnit {
- count_number = drugInfo.Count
- }
-
- // 比较数据大小
- //如果当期医嘱数量小于最后一次出库则退库
- if device_number < count_number {
- fmt.Println("进来了吗")
- var cha_number int64
- var maxNumber int64
- var minNumber int64
- cha_number = count_number - device_number
- maxNumber = cha_number / drup.MinNumber
- minNumber = cha_number % drup.MinNumber
- //更改库存
- ModifyDrugWarehouse(drugInfo.WarehouseInfoId, maxNumber, minNumber)
-
- //修改出库表
- info := models.DrugWarehouseOutInfo{
- Count: device_number,
- CountUnit: advice.PrescribingNumberUnit,
- }
-
- ModifyDrugWarehouseOutInfo(info, advice.DrugId, advice.PatientId, advice.RecordDate)
-
- //修改自动出库表
- detail := models.DrugAutomaticReduceDetail{
- Count: device_number,
- CountUnit: advice.PrescribingNumberUnit,
- }
- ModifyAutoMaticReduce(detail, advice.PatientId, advice.RecordDate, advice.DrugId)
- //修改流水
- flow := models.DrugFlow{
- Count: device_number,
- MaxUnit: drup.MinUnit,
- }
- ModifyDrugFlow(flow, drugInfo.WarehouseOutOrderNumber, advice.DrugId, advice.PatientId)
-
- }
- fmt.Println("医嘱数量44444444444444", device_number)
- fmt.Println("最后一次出库数量", count_number)
- //如果当期医嘱数量大于最后一次出库则需要出库
- if device_number > count_number {
- var cha_number int64
- cha_number = device_number - count_number
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
- //查找药品信息
- //baseInfo, _ := FindBaseDrugLibRecord(advice.UserOrgId, advice.DrugId)
- if err != nil {
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
- var stock_number int64
- var maxNumber int64
- var minNumber int64
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- //如果库存数量大于出库数据,正常出库
- if stock_number >= cha_number {
- //扣减库存
- maxNumber = cha_number / drup.MinNumber
- minNumber = cha_number % drup.MinNumber
-
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
-
- if drup.MaxUnit != drup.MinUnit {
- if warehouse.StockMaxNumber < maxNumber {
- return errors.New("库存数量不足")
- }
- }
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
- if warehouse.StockMaxNumber < 0 {
- warehouse.StockMaxNumber = 0
- }
-
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockMinNumber < minNumber {
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
- } else {
-
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
-
- }
-
- if drup.MaxUnit != drup.MinUnit {
- if warehouse.StockMaxNumber < 0 {
- return errors.New("库存数量不足")
- }
- }
-
- //扣减库存232332332332
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
-
- //修改出库表
- info := models.DrugWarehouseOutInfo{
- Count: device_number,
- CountUnit: advice.PrescribingNumberUnit,
- }
- ModifyDrugWarehouseOutInfoOne(info, advice.DrugId, advice.PatientId, advice.RecordDate, warehouse.ID)
- //修改自动出库表
- detail := models.DrugAutomaticReduceDetail{
- Count: device_number,
- CountUnit: advice.PrescribingNumberUnit,
- }
- ModifyAutoMaticReduceOne(detail, advice.PatientId, advice.RecordDate, advice.DrugId, warehouse.ID)
- //修改流水
- flow := models.DrugFlow{
- Count: device_number,
- MaxUnit: advice.PrescribingNumberUnit,
- }
- ModifyDrugFlowOne(flow, drugInfo.WarehouseOutOrderNumber, advice.DrugId, advice.PatientId, warehouse.ID)
- }
- //如果库存数量小于出库数据,则需要出库到下一个批次
- if stock_number < cha_number {
-
- //修改出库表
- info := models.DrugWarehouseOutInfo{
- Count: cha_number,
- CountUnit: advice.PrescribingNumberUnit,
- }
- ModifyDrugWarehouseOutInfoOne(info, advice.DrugId, advice.PatientId, advice.RecordDate, warehouse.ID)
- //修改自动出库表
- detail := models.DrugAutomaticReduceDetail{
- Count: cha_number,
- CountUnit: advice.PrescribingNumberUnit,
- }
- ModifyAutoMaticReduceOne(detail, advice.PatientId, advice.RecordDate, advice.DrugId, warehouse.ID)
- //修改流水
- flow := models.DrugFlow{
- Count: cha_number,
- MaxUnit: advice.PrescribingNumberUnit,
- }
- ModifyDrugFlowOne(flow, drugInfo.WarehouseOutOrderNumber, advice.DrugId, advice.PatientId, warehouse.ID)
-
- druginfo := &models.XtDrugWarehouseInfo{
- ID: warehouse.ID,
- WarehousingId: warehouse.WarehousingId,
- DrugId: warehouse.DrugId,
- Number: warehouse.Number,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- WarehousingCount: warehouse.WarehousingCount,
- Price: warehouse.Price,
- TotalPrice: warehouse.TotalPrice,
- Dealer: warehouse.Dealer,
- Manufacturer: warehouse.Manufacturer,
- Remark: warehouse.Remark,
- Ctime: warehouse.Ctime,
- Mtime: warehouse.Mtime,
- Status: 1,
- OrgId: warehouse.OrgId,
- IsReturn: warehouse.IsReturn,
- WarehousingOrder: warehouse.WarehousingOrder,
- Type: warehouse.Type,
- RetailPrice: warehouse.RetailPrice,
- RetailTotalPrice: warehouse.RetailPrice,
- StockMaxNumber: 0,
- StockMinNumber: 0,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: warehouse.MaxUnit,
- WarehousingInfoId: warehouse.WarehousingInfoId,
- }
- errThree := UpDateDrugWarehouseInfoByStock(druginfo)
- if errThree != nil {
- return errThree
- }
-
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := cha_number - stock_number
-
- overPlusNumber := float64(prescribingNumber_two_temp)
-
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
-
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- NewHisDrugDeliverInfo(orgID, overPlusNumber, warehouseout, drup, advice)
-
- }
- }
-
- return
- }
-
- //采购管理耗材出库逻辑
- func ConsumablesDeliveryNight(orgID int64, record_time int64, goods *models.WarehouseOutInfo, warehouseOut *models.WarehouseOut, count int64, creator int64, warehouse_out_id int64, cancel_out_id int64) (err error) {
-
- var deliver_number int64 = 0
- var stock_number int64 = 0
- var maxNumber int64 = 0
-
- deliver_number = goods.Count
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
-
- // 如果没有对应的库存,则报错
- warehouse, err := FindFirstWarehousingInfoByStockNight(goods.GoodId, goods.GoodTypeId, warehouse_out_id, goods.IsSource)
- if err != nil {
-
- return err
- }
-
- stock_number = warehouse.StockCount
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
-
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: goods.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- IsSys: 0,
- SysRecordTime: record_time,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- ExpiryDate: goods.ExpiryDate,
- ProductDate: goods.ProductDate,
- Number: warehouse.Number,
- Price: goods.Price,
- LicenseNumber: goods.LicenseNumber,
- SupplyCancelOutId: warehouseOut.SupplyCancelOutId,
- }
- warehouseOutInfo.Count = goods.Count
- //添加出库单详情
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- stockFlow := models.VmStockFlow{
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- LicenseNumber: goods.LicenseNumber,
- Count: goods.Count,
- UserOrgId: goods.OrgId,
- PatientId: goods.PatientId,
- SystemTime: record_time,
- ConsumableType: 2,
- IsSys: goods.IsSys,
- WarehousingOrder: "",
- WarehouseOutId: warehouseOut.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsEdit: 1,
- CancelStockId: 0,
- CancelOrderNumber: "",
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- Creator: creator,
- UpdateCreator: 0,
- Status: 1,
- Ctime: time.Now().Unix(),
- Mtime: 0,
- Price: warehouse.PackingPrice,
- WarehousingDetailId: 0,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- CancelOutDetailId: 0,
- ProductDate: goods.ProductDate,
- ExpireDate: goods.ExpiryDate,
- SupplyCancelOutId: warehouseOut.SupplyCancelOutId,
- SupplyWarehouseId: warehouseOut.SupplyWarehouseId,
- }
-
- //创建出库流水
- CreateStockFlowOne(stockFlow)
-
- maxNumber = goods.Count
-
- if warehouse.StockCount < maxNumber {
- return errors.New("库存数量不足")
- }
-
- warehouse.StockCount = warehouse.StockCount - maxNumber
- warehouse.Mtime = time.Now().Unix()
-
- //扣减库存
- errThree := UpDateWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
-
- } else {
-
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.WarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- WarehouseOutId: warehouseOut.ID,
- WarehouseInfotId: warehouse.ID,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: goods.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- IsSys: 0,
- SysRecordTime: record_time,
- GoodTypeId: goods.GoodTypeId,
- GoodId: goods.GoodId,
- ExpiryDate: goods.ExpiryDate,
- ProductDate: goods.ProductDate,
- Number: warehouse.Number,
- Price: warehouse.PackingPrice,
- LicenseNumber: goods.LicenseNumber,
- SupplyCancelOutId: warehouseOut.SupplyCancelOutId,
- }
- warehouseOutInfo.Count = stock_number
-
- //查询是否已经生成出库单
- info, errcodes := GetStockInRecoredByGoodIdOne(goods.GoodId, goods.GoodTypeId, goods.SysRecordTime, goods.OrgId)
- if errcodes == gorm.ErrRecordNotFound {
- //创建出库单
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- } else {
- warehouseOutInfo.Count = info.Count + stock_number
-
- UpdateAutoMaticReduceDetailOne(goods.GoodId, goods.GoodTypeId, goods.SysRecordTime, goods.OrgId, warehouseOutInfo)
- }
-
- stockFlow := models.VmStockFlow{
- WarehousingId: warehouse.ID,
- GoodId: goods.GoodId,
- Number: warehouse.Number,
- LicenseNumber: goods.LicenseNumber,
- Count: stock_number,
- UserOrgId: goods.OrgId,
- PatientId: 0,
- SystemTime: record_time,
- ConsumableType: 2,
- IsSys: 0,
- WarehousingOrder: "",
- WarehouseOutId: warehouseOut.ID,
- WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
- IsEdit: 1,
- CancelStockId: 0,
- CancelOrderNumber: "",
- Manufacturer: goods.Manufacturer,
- Dealer: goods.Dealer,
- Creator: creator,
- UpdateCreator: 0,
- Status: 1,
- Ctime: time.Now().Unix(),
- Mtime: 0,
- Price: warehouse.PackingPrice,
- WarehousingDetailId: 0,
- WarehouseOutDetailId: warehouseOutInfo.ID,
- CancelOutDetailId: 0,
- ProductDate: goods.ProductDate,
- ExpireDate: goods.ExpiryDate,
- SupplyCancelOutId: warehouseOut.SupplyCancelOutId,
- SupplyWarehouseId: warehouseOut.SupplyWarehouseId,
- }
-
- //创建出库明细
- CreateStockFlowOne(stockFlow)
- // 出库完成后,要将该批次库存清零
- warehouse.StockCount = 0
- warehouse.Mtime = time.Now().Unix()
-
- errThree := UpDateWarehouseInfoByStock(&warehouse)
-
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- goods.Count = deliver_number - stock_number
-
- ConsumablesDeliveryNight(orgID, record_time, goods, warehouseOut, count, creator, warehouse_out_id, cancel_out_id)
-
- }
- return nil
- }
-
- func FindFirstWarehousingInfoByStockNight(good_id int64, good_type_id int64, warehouse_out_id int64, is_source int64) (info models.WarehousingInfo, err error) {
-
- fmt.Println("is_source2233232233232323232232323", is_source)
- if is_source == 1 {
- err = readDb.Model(&models.WarehousingInfo{}).Where("good_id = ? AND good_type_id = ? AND status = 1 and stock_count > 0 and supply_warehouse_id = ?", good_id, good_type_id, warehouse_out_id).Order("ctime").First(&info).Error
-
- }
- if is_source == 2 || is_source == 0 {
- err = readDb.Model(&models.WarehousingInfo{}).Where("good_id = ? AND good_type_id = ? AND status = 1 and stock_count > 0", good_id, good_type_id).Order("ctime").First(&info).Error
- }
- return info, err
- }
-
- // 药品出库 递归方式
- func AutoDrugDeliverInfoNight(orgID int64, prescribingNumber int64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.DrugWarehouseOutInfo, warehouse_out_id int64, cancel_out_id int64) (err error) {
-
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
-
- if advice.CountUnit == drup.MaxUnit {
- deliver_number = prescribingNumber * drup.MinNumber
- } else {
- deliver_number = prescribingNumber
- }
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
- //开启事物
-
- warehouse, err := FindLastDrugWarehousingInfoByIDSix(advice.DrugId, warehouse_out_id, advice.IsSource)
-
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
-
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: advice.WarehouseOutId,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: advice.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: advice.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 0,
- SysRecordTime: advice.SysRecordTime,
- DrugId: advice.DrugId,
- ExpiryDate: advice.ExpiryDate,
- ProductDate: advice.ProductDate,
- Number: advice.Number,
- BatchNumber: warehouse.BatchNumber,
- Count: deliver_number,
- RetailPrice: advice.RetailPrice,
- Price: advice.Price,
- WarehouseInfoId: warehouse.ID,
- CountUnit: drup.MinUnit,
- AdviceId: advice.ID,
- SupplyCancelOutId: warehouseout.SupplyCancelOutId,
- SupplyWarehouseId: warehouseout.SupplyWarehouseId,
- }
-
- warehouseOutInfo.Count = prescribingNumber
- warehouseOutInfo.CountUnit = advice.CountUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
-
- drugWareInfo, _ := GetLastWarehouseOutInfoById(advice.DrugId)
- drugflow := models.DrugFlow{
- WarehouseOutId: advice.WarehouseOutId,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: advice.ProductDate,
- ExpireDate: advice.ExpiryDate,
- Count: deliver_number,
- Price: advice.Price,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: advice.OrgId,
- Manufacturer: advice.Manufacturer,
- Dealer: advice.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 2,
- IsEdit: 1,
- Creator: 0,
- IsSys: 0,
- WarehouseOutDetailId: drugWareInfo.ID,
- AdviceId: advice.ID,
- SupplyCancelOutId: warehouseout.SupplyCancelOutId,
- SupplyWarehouseId: warehouseout.SupplyWarehouseId,
- SystemTime: advice.SysRecordTime,
- }
-
- CreateDrugFlowOne(drugflow)
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
- if advice.CountUnit == drup.MinUnit {
- maxNumber = prescribingNumber / drup.MinNumber
- minNumber = prescribingNumber % drup.MinNumber
- if warehouse.StockMaxNumber == 0 && drup.MaxUnit == drup.MinUnit {
- minNumber = maxNumber
- }
- } else {
- maxNumber = prescribingNumber
- }
- fmt.Println("maxNUMBER23323232323323322323", maxNumber)
- fmt.Println("MIN_NUMBWEEEWEWEWWEEWEWEWWE", minNumber)
- fmt.Println("编辑55555555555555")
- if warehouse.StockMaxNumber < maxNumber {
-
- return errors.New("库存数量不足")
- }
-
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
- if warehouse.StockMaxNumber < 0 {
- warehouse.StockMaxNumber = 0
- }
-
- warehouse.Mtime = time.Now().Unix()
-
- if warehouse.StockMinNumber < minNumber {
- warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
- warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
- } else {
- warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
- }
-
- if warehouse.StockMaxNumber < 0 {
- return errors.New("库存数量不足")
- }
- if warehouse.StockMaxNumber == 1 && warehouse.StockMinNumber == 1 && drup.MaxUnit == drup.MinUnit {
- warehouse.StockMinNumber = 0
- }
-
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
-
- return nil
- } else {
- // 当该批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- warehouseOutInfo := &models.DrugWarehouseOutInfo{
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- WarehouseOutId: advice.WarehouseOutId,
- Status: 1,
- Ctime: time.Now().Unix(),
- Remark: advice.Remark,
- OrgId: orgID,
- Type: 1,
- Manufacturer: advice.Manufacturer,
- Dealer: warehouse.Dealer,
- IsSys: 0,
- SysRecordTime: advice.SysRecordTime,
- DrugId: advice.DrugId,
- ExpiryDate: warehouse.ExpiryDate,
- ProductDate: warehouse.ProductDate,
- Number: warehouse.Number,
- BatchNumber: warehouse.BatchNumber,
- Count: stock_number,
- RetailPrice: advice.RetailPrice,
- Price: advice.Price,
- WarehouseInfoId: warehouse.ID,
- CountUnit: drup.MinUnit,
- AdviceId: advice.ID,
- SupplyCancelOutId: warehouseout.SupplyCancelOutId,
- SupplyWarehouseId: warehouseout.SupplyWarehouseId,
- }
- warehouseOutInfo.Count = stock_number
-
- //warehouseOutInfo.CountUnit = advice.CountUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- drugWareInfo, _ := GetLastWarehouseOutInfoById(advice.DrugId)
- drugflow := models.DrugFlow{
- WarehouseOutId: advice.WarehouseOutId,
- WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
- DrugId: advice.DrugId,
- Number: warehouse.Number,
- ProductDate: advice.ProductDate,
- ExpireDate: advice.ExpiryDate,
- Count: stock_number,
- Price: advice.Price,
- Status: 1,
- Ctime: time.Now().Unix(),
- UserOrgId: advice.OrgId,
- Manufacturer: advice.Manufacturer,
- Dealer: advice.Dealer,
- BatchNumber: warehouse.BatchNumber,
- MaxUnit: drup.MinUnit,
- ConsumableType: 2,
- IsEdit: 1,
- Creator: 0,
- IsSys: 0,
- WarehouseOutDetailId: drugWareInfo.ID,
- AdviceId: advice.ID,
- SupplyCancelOutId: warehouseout.SupplyCancelOutId,
- SupplyWarehouseId: warehouseout.SupplyWarehouseId,
- SystemTime: advice.SysRecordTime,
- }
- CreateDrugFlowOne(drugflow)
- // 出库完成后,要将该批次库存清零
- warehouse.StockMaxNumber = 0
- warehouse.StockMinNumber = 0
- warehouse.Mtime = time.Now().Unix()
- errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
- if errThree != nil {
- return errThree
- }
- // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
- prescribingNumber_two_temp := deliver_number - stock_number
- advice.CountUnit = drup.MinUnit
-
- AutoDrugDeliverInfoNight(orgID, prescribingNumber_two_temp, warehouseout, drup, advice, warehouse_out_id, cancel_out_id)
- }
-
- return
- }
|