12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505 |
- 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
- }
- fmt.Println("isHasway99999999999999999999999999999999", isHasWay)
- 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
-
- 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)
-
- fmt.Println("单位1", advice.PrescribingNumber)
- fmt.Println("单位2", drup.MaxUnit)
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- deliver_number = count * drup.MinNumber
- } else {
- deliver_number = count
- }
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
- //开启事物
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
-
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
- fmt.Println("stock_number999999999999", stock_number)
- fmt.Println("deliver_number88888888888", deliver_number)
-
- //查找药品信息
- 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: baseInfo.RetailPrice,
- CountUnit: advice.PrescribingNumberUnit,
- RetailPrice: baseInfo.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- Count: count,
- }
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- fmt.Println("hhhhhhhhhhhhhhhhhhhhhhhh2323232323232322323")
- if errOne != nil {
- return errOne
- } else {
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseOutInfo.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: count,
- CountUnit: advice.PrescribingNumberUnit,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
- }
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
- if advice.PrescribingNumberUnit == drup.MinUnit {
- maxNumber = count / drup.MinNumber
- minNumber = count % drup.MinNumber
- } else {
- maxNumber = count
- }
-
- if warehouse.StockMaxNumber < maxNumber {
- fmt.Println("尽量323223232")
- 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: baseInfo.RetailPrice,
- CountUnit: advice.PrescribingNumberUnit,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- Count: count,
- }
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- } else {
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseOutInfo.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: count,
- CountUnit: advice.PrescribingNumberUnit,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
- }
- // 出库完成后,要将该批次库存清零
- 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
- overPlusNumber := float64(prescribingNumber_two_temp)
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- DrugDeliverInfo(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) {
-
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- 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)
- fmt.Println("单位99999999999999999999999999", advice.PrescribingNumberUnit)
- fmt.Println("drup777777777777766666666", drup.MaxUnit)
- if advice.PrescribingNumberUnit == drup.MaxUnit {
- deliver_number = count * drup.MinNumber
- } else {
- deliver_number = count
- }
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
- //开启事物
-
- warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
- //查找药品信息
- baseInfo, _ := FindBaseDrugLibRecord(advice.UserOrgId, advice.DrugId)
- if err != nil {
-
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
-
- stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
- fmt.Println("拆零数量2222222222222222222", stock_number)
- fmt.Println("出库数量55555555555555555555", deliver_number)
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- 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: baseInfo.RetailPrice,
- CountUnit: baseInfo.MaxUnit,
- RetailPrice: baseInfo.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- }
-
- warehouseOutInfo.Count = count
- warehouseOutInfo.CountUnit = advice.PrescribingNumberUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
-
- if errOne != nil {
- return errOne
- } else {
-
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseOutInfo.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: count,
- CountUnit: advice.PrescribingNumberUnit,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
- }
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
- if advice.PrescribingNumberUnit == drup.MinUnit {
- maxNumber = count / drup.MinNumber
- minNumber = count % drup.MinNumber
- } else {
- maxNumber = count
- }
-
- 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: baseInfo.RetailPrice,
- RetailPrice: baseInfo.RetailPrice,
- ProductDate: warehouse.ProductDate,
- ExpiryDate: warehouse.ExpiryDate,
- PatientId: advice.PatientId,
- }
-
- warehouseOutInfo.Count = count
-
- warehouseOutInfo.CountUnit = advice.PrescribingNumberUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- } else {
- details := &models.DrugAutomaticReduceDetail{
- WarehouseOutId: warehouseOutInfo.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: count,
- CountUnit: advice.PrescribingNumberUnit,
- }
- errTwo := AddSigleDrugAutoReduceRecordInfo(details)
- if errTwo != nil {
- return errTwo
- }
- }
- // 出库完成后,要将该批次库存清零
- 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
- overPlusNumber := float64(prescribingNumber_two_temp)
- advice.PrescribingNumber = float64(prescribingNumber_two_temp)
- advice.PrescribingNumberUnit = advice.PrescribingNumberUnit
-
- HisDrugDeliverInfo(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
-
- fmt.Println("单位1", advice.CountUnit)
- fmt.Println("单位2", drup.MaxUnit)
-
- 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
-
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- fmt.Println("价格表32322222222222222222232322332", advice.Price)
- 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: advice.Dealer,
- IsSys: 0,
- SysRecordTime: advice.Ctime,
- DrugId: advice.DrugId,
- ExpiryDate: advice.ExpiryDate,
- ProductDate: advice.ProductDate,
- Number: advice.Number,
- BatchNumber: advice.BatchNumber,
- Count: advice.Count,
- RetailPrice: advice.RetailPrice,
- Price: advice.Price,
- }
-
- warehouseOutInfo.Count = prescribingNumber
- warehouseOutInfo.CountUnit = advice.CountUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
-
- if errOne != nil {
- return errOne
- }
- // 出库完成后,要减去对应批次的库存数量
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
- var maxNumber int64 = 0
- var minNumber int64 = 0
- if advice.CountUnit == drup.MinUnit {
- maxNumber = prescribingNumber / drup.MinNumber
- minNumber = prescribingNumber % drup.MinNumber
- } 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
- }
-
- 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: advice.Dealer,
- IsSys: 0,
- SysRecordTime: advice.Ctime,
- DrugId: advice.DrugId,
- ExpiryDate: advice.ExpiryDate,
- ProductDate: advice.ProductDate,
- Number: advice.Number,
- BatchNumber: advice.BatchNumber,
- Count: advice.Count,
- RetailPrice: advice.RetailPrice,
- Price: advice.Price,
- }
- warehouseOutInfo.Count = prescribingNumber
-
- warehouseOutInfo.CountUnit = advice.CountUnit
-
- errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- // 出库完成后,要将该批次库存清零
- 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
-
- 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 这个数据就是需要出库的耗材的数据(新增的数据)
- fmt.Println("goods222222222222", goods)
- fmt.Println("goodsy999999999999", goods_yc)
- 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,
- }
-
- 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) {
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
- var maxNumber int64 = 0
-
- deliver_number = goods.Count
- fmt.Println("添加数量", deliver_number)
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
-
- warehouse, err := FindFirstWarehousingInfoByStock(goods.GoodId, goods.GoodTypeId)
-
- if err != nil {
- return
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
- 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: info.PackingPrice,
- ExpiryDate: warehouse.ExpiryDate,
- ProductDate: warehouse.ProductDate,
- }
- warehouseOutInfo.Count = count
- stockInInfo, _ := FindLastStockInInfoRecord(goods.GoodId, orgID)
- warehouseOutInfo.Price = stockInInfo.Price
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- } else {
- 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,
- }
- //查询当天耗材是否已经存在数据
- _, errcode := GetAutoMaticReduceDetail(orgID, patient_id, record_time, goods.GoodId, goods.GoodTypeId)
-
- if errcode == gorm.ErrRecordNotFound {
- errTwo := CreateAutoReduceRecord(&details)
- if errTwo != nil {
- return errTwo
- }
- } else if errcode == nil {
- 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: info.PackingPrice,
- ExpiryDate: warehouse.ExpiryDate,
- ProductDate: warehouse.ProductDate,
- }
- 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
-
- 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 ConsumablesDeliveryTotalOne(orgID int64, patient_id int64, record_time int64, goods []*models.DialysisBeforePrepareGoods, goodOne []*models.NewDialysisBeforePrepareGoods) (err error) {
-
- //查询该患者当天已经出库的耗材信息
- goods_yc, _ := FindConsumablesByDateTwo(orgID, patient_id, record_time)
- for _, item := range goods_yc {
- fmt.Println("item0000000000000", item.Count)
- }
- for _, item := range goods {
- fmt.Println("item1111111111111", item.Count)
- }
- // 和新请求的出库数据进行对比,分出那些是继续出库的,那些是需要删除出库的
- 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:]...)
- }
- fmt.Println("998888888888888", goods_yc_temp.Count)
- fmt.Println("7777777777777777", goods_temp.Count)
- // 如果已经出库的数量 大于 新请求出库的数量,则代表需要删除出库
- if goods_yc_temp.Count > goods_temp.Count {
- fmt.Println("进来了是吗")
- temp_count := goods_yc_temp.Count - goods_temp.Count
-
- goods_yc[i].Count = temp_count
- goods = append(goods[:j], goods[j+1:]...)
- break
- }
- fmt.Println("555555555555", goods_yc_temp.Count)
- fmt.Println("444444444444", goods_temp.Count)
- // 如果已经出库的数量 小于 新请求出库的梳理,则代表需要增加出库
- 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)
- }
- }
- }
- }
-
- // goods_yc 这个数据就是需要已经出库了,但是现在需要删除出库的耗材数据
- // goods 这个数据就是需要出库的耗材的数据
- fmt.Println("goods222222222222", goods)
- fmt.Println("goodsy999999999999", goods_yc)
- 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: 0,
- 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 {
- for _, it := range goodOne {
- if item.GoodTypeId == it.GoodTypeId && it.GoodId == it.GoodId {
- it.NewCount = item.Count
- }
- }
- }
-
- for _, item := range goodOne {
- //prepare := models.DialysisBeforePrepare{
- // GoodTypeId: item.GoodTypeId,
- // GoodId: item.GoodId,
- // Count: item.Count,
- // NewCount: item.NewCount,
- //}
- info := models.WarehouseOutInfo{
- GoodTypeId: item.GoodTypeId,
- GoodId: item.GoodId,
- Count: item.Count,
- }
- ConsumablesDeliveryOne(orgID, record_time, &info, &out, item.Count)
- }
- }
-
- if len(goods_yc) > 0 {
- for _, good_yc := range goods_yc {
- out, _ := FindStockOutByIsSys(orgID, 1, record_time)
- ConsumablesDeliveryDeleteOne(orgID, record_time, good_yc, &out)
- }
- }
-
- return nil
- }
-
- //耗材出库
- func ConsumablesDeliveryOne(orgID int64, record_time int64, goods *models.WarehouseOutInfo, warehouseOut *models.WarehouseOut, count int64) (err error) {
- // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
- var deliver_number int64 = 0
- var stock_number int64 = 0
- var maxNumber int64 = 0
-
- deliver_number = goods.Count
- fmt.Println("添加数量", deliver_number)
-
- // 根据先进先出原则,查询最先入库的批次,进行出库
- // 如果没有对应的库存,则报错
- warehouse, err := FindFirstWarehousingInfoByStock(goods.GoodId, goods.GoodTypeId)
- fmt.Println("err222222222222222222222", warehouse.StockCount)
- if err != nil {
- fmt.Println("232323232323进来")
- return err
- }
-
- // 将该批次的剩余库存数量转换为拆零数量
- stock_number = warehouse.StockCount
- fmt.Println("3434343434343434", stock_number)
- fmt.Println("8888888888888888888", deliver_number)
- // 当库存数量大于或等于出库数量的话,则正常出库该批次
- if stock_number >= deliver_number {
- fmt.Println("g2332232332323232232323322332", goods.Price)
- 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: goods.Number,
- Price: goods.Price,
- LicenseNumber: goods.LicenseNumber,
- }
- warehouseOutInfo.Count = goods.Count
- //stockInInfo, _ := FindLastStockInInfoRecord(goods.GoodId, orgID)
- //warehouseOutInfo.Price = stockInInfo.Price
-
- 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
- }
- } else {
- fmt.Println("中国共产党万岁22322332323232322323232323232323")
- // 当改批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
- 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: goods.Number,
- Price: goods.Price,
- LicenseNumber: goods.LicenseNumber,
- }
- warehouseOutInfo.Count = stock_number
- //stockInInfo, _ := FindLastStockInInfoRecord(goods.GoodId, orgID)
- //fmt.Println("stockINFO2232232323223322332323223323223", stockInInfo)
- //warehouseOutInfo.Price = stockInInfo.Price
-
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- fmt.Println("errOne2232323232323232333232323", errOne)
- 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
- fmt.Println("goods3333333333333333333333", goods.Count)
- ConsumablesDeliveryOne(orgID, record_time, goods, warehouseOut, count)
-
- }
- return nil
- }
-
- //耗材出库删除
- func ConsumablesDeliveryDeleteOne(orgID int64, record_time int64, good_yc *models.DialysisBeforePrepare, warehouseOut *models.WarehouseOut) (err error) {
- // 先根据相关信息查询当天该耗材的出库信息
- warehouseOutInfos, err := FindStockOutInfoByStockOne(orgID, good_yc.GoodTypeId, good_yc.GoodId, record_time)
- 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: 0,
- SysRecordTime: record_time,
- GoodTypeId: good_yc.GoodTypeId,
- GoodId: good_yc.GoodId,
- }
- warehouseOutInfo.Count = delete_count
- stockInInfo, _ := FindLastStockInInfoRecord(good_yc.GoodId, orgID)
- warehouseOutInfo.Price = stockInInfo.Price
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- // 删除出库完成后,要增加对应批次的库存数量
-
- 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 ConsumablesDeliveryTotalSix(orgID int64, patient_id int64, record_time int64, goods []*models.DialysisBeforePrepareGoods, goodOne []*models.NewDialysisBeforePrepareGoods) (err error) {
-
- //查询该患者当天已经出库的耗材信息
- goods_yc, _ := FindConsumablesByDateThree(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 这个数据就是需要出库的耗材的数据(新增的数据)
- fmt.Println("goods222222222222", goods)
- fmt.Println("goodsy999999999999", goods_yc)
- 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: 0,
- 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,
- }
-
- 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)
- ConsumablesDeliveryDeleteThree(orgID, record_time, good_yc, &out)
- }
- }
-
- return nil
- }
-
- //耗材出库删除
- func ConsumablesDeliveryDeleteThree(orgID int64, record_time int64, good_yc *models.BloodAutomaticReduceDetail, warehouseOut *models.WarehouseOut) (err error) {
- // 先根据相关信息查询当天该耗材的出库信息
- warehouseOutInfos, err := FindStockOutInfoByStockOne(orgID, good_yc.GoodTypeId, good_yc.GoodId, record_time)
- 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: 0,
- SysRecordTime: record_time,
- GoodTypeId: good_yc.GoodTypeId,
- GoodId: good_yc.GoodId,
- }
- warehouseOutInfo.Count = delete_count
- stockInInfo, _ := FindLastStockInInfoRecord(good_yc.GoodId, orgID)
- warehouseOutInfo.Price = stockInInfo.Price
- errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
- if errOne != nil {
- return errOne
- }
- // 删除出库完成后,要增加对应批次的库存数量
-
- 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("退库和出库数据不匹配")
- }
- }
|