warhouse_service.go 20KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550
  1. package service
  2. //
  3. //import (
  4. // "XT_New/models"
  5. // "XT_New/utils"
  6. // "errors"
  7. // "fmt"
  8. // _ "fmt"
  9. // "github.com/jinzhu/gorm"
  10. // "math"
  11. // "strconv"
  12. // "strings"
  13. // "time"
  14. //)
  15. //
  16. //// 药品出库
  17. //
  18. //func DrugsDelivery(orgID int64, advice *models.DoctorAdvice) (err error) {
  19. // // 1.判断药品是否来自专用字典的药品库
  20. // // 2.判断当天当前机构有没有创建出库单,没有则创建
  21. // // 3.创建出库流程
  22. // // 3.1 实现先进先出逻辑 由于药品执行后,不可以修改和删除,所以不考虑出库后的退库和修改出库数量等
  23. // isHasWay := false
  24. // record_time := int64(0)
  25. // if advice.Way == 1 {
  26. // isHasWay = true
  27. // record_time = advice.RecordDate
  28. // }
  29. // if isHasWay {
  30. // //判断当天当前机构有没有创建出库单,没有则创建
  31. // out, err := FindDrugStockOutByIsSys(orgID, 1, record_time)
  32. // if err == gorm.ErrRecordNotFound {
  33. // timeStr := time.Now().Format("2006-01-02")
  34. // timeArr := strings.Split(timeStr, "-")
  35. // total, _ := FindAllDrugWarehouseOut(orgID)
  36. // total = total + 1
  37. // warehousing_out_order := strconv.FormatInt(orgID, 10) + timeArr[0] + timeArr[1] + timeArr[2] + "000"
  38. // number, _ := strconv.ParseInt(warehousing_out_order, 10, 64)
  39. // number = number + total
  40. // warehousing_out_order = "YPCKD" + strconv.FormatInt(number, 10)
  41. // // creater := adminUserInfo.AdminUser.Id
  42. // warehouseOut := models.DrugWarehouseOut{
  43. // WarehouseOutOrderNumber: warehousing_out_order,
  44. // OperationTime: time.Now().Unix(),
  45. // OrgId: orgID,
  46. // Creater: 0,
  47. // Ctime: time.Now().Unix(),
  48. // Status: 1,
  49. // WarehouseOutTime: record_time,
  50. // Dealer: 0,
  51. // Manufacturer: 0,
  52. // Type: 1,
  53. // IsSys: 1,
  54. // }
  55. // err := AddSigleDrugWarehouseOut(&warehouseOut)
  56. // if err != nil {
  57. // utils.TraceLog("创建出库单失败 err = %v", err)
  58. // return err
  59. // } else {
  60. // out = warehouseOut
  61. // }
  62. // }
  63. //
  64. // // 出库流程
  65. // // 1.查询改药品在药品库的规格信息,并将处方里的规格进行换算(尽量将拆零单位转换成包装单位)
  66. // drup, _ := FindBaseDrugLibRecord(orgID, advice.DrugId)
  67. // if drup.ID > 0 {
  68. // prescribingNumber := advice.PrescribingNumber
  69. // DrugDeliverInfo(orgID, prescribingNumber, &out, &drup, advice)
  70. // } else {
  71. // return errors.New("药品信息不存在")
  72. // }
  73. //
  74. // }
  75. //
  76. // return
  77. //}
  78. //
  79. //// 药品出库 递归方式
  80. //func DrugDeliverInfo(orgID int64, prescribingNumber float64, warehouseout *models.DrugWarehouseOut, drup *models.BaseDrugLib, advice *models.DoctorAdvice) (err error) {
  81. // // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
  82. // var deliver_number int64 = 0
  83. // var stock_number int64 = 0
  84. //
  85. // prescribingNumber_temp := strconv.FormatFloat(math.Abs(prescribingNumber), 'f', 0, 64)
  86. // count, _ := strconv.ParseInt(prescribingNumber_temp, 10, 64)
  87. // if advice.PrescribingNumberUnit == drup.MaxUnit {
  88. // deliver_number = count * drup.MinNumber
  89. // } else {
  90. // deliver_number = count
  91. // }
  92. //
  93. // // 根据先进先出原则,查询最先入库的批次,进行出库
  94. // // 如果没有对应的库存,则报错
  95. // warehouse, err := FindLastDrugWarehousingInfoByID(advice.DrugId)
  96. // fmt.Println("查询222222222222222222222222222222222222222222222222", err)
  97. // if err != nil {
  98. // return err
  99. // }
  100. //
  101. // // 将该批次的剩余库存数量转换为拆零数量
  102. // stock_number = warehouse.StockMaxNumber*drup.MinNumber + warehouse.StockMinNumber
  103. // // 当库存数量大于或等于出库数量的话,则正常出库该批次
  104. // if stock_number >= deliver_number {
  105. // warehouseOutInfo := &models.DrugWarehouseOutInfo{
  106. // WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
  107. // WarehouseOutId: warehouseout.ID,
  108. // Status: 1,
  109. // Ctime: time.Now().Unix(),
  110. // Remark: "",
  111. // OrgId: orgID,
  112. // Type: 1,
  113. // Manufacturer: 0,
  114. // Dealer: 0,
  115. // IsSys: 1,
  116. // SysRecordTime: advice.RecordDate,
  117. // DrugId: advice.DrugId,
  118. // }
  119. // warehouseOutInfo.Count = deliver_number
  120. // warehouseOutInfo.CountUnit = drup.MinUnit
  121. // errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
  122. // if errOne != nil {
  123. // return errOne
  124. // } else {
  125. // // prescribingNumber := strconv.FormatFloat(math.Abs(item.PrescribingNumber), 'f', 0, 64)
  126. // // count, _ := strconv.ParseInt(prescribingNumber, 10, 64)
  127. // details := &models.DrugAutomaticReduceDetail{
  128. // WarehouseOutId: warehouseOutInfo.ID,
  129. // WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
  130. // PatientId: advice.PatientId,
  131. // Ctime: time.Now().Unix(),
  132. // Mtime: time.Now().Unix(),
  133. // Status: 1,
  134. // RecordTime: advice.RecordDate,
  135. // OrgId: orgID,
  136. // DrugId: advice.DrugId,
  137. // Count: deliver_number,
  138. // CountUnit: drup.MinUnit,
  139. // }
  140. // errTwo := AddSigleDrugAutoReduceRecordInfo(details)
  141. // if errTwo != nil {
  142. // return errTwo
  143. // }
  144. // }
  145. // // 出库完成后,要减去对应批次的库存数量
  146. // // 判断处方里药品单位是拆零单位还是包装单位, 如果是拆零单位,则根据规格,将拆零数量转为包装数量
  147. // var maxNumber int64 = 0
  148. // var minNumber int64 = 0
  149. // if advice.PrescribingNumberUnit == drup.MinUnit {
  150. // maxNumber = count / drup.MinNumber
  151. // minNumber = count % drup.MinNumber
  152. // } else {
  153. // maxNumber = count
  154. // }
  155. //
  156. // if warehouse.StockMaxNumber < maxNumber {
  157. // return errors.New("库存数量不足")
  158. // }
  159. //
  160. // warehouse.StockMaxNumber = warehouse.StockMaxNumber - maxNumber
  161. // warehouse.Mtime = time.Now().Unix()
  162. // if warehouse.StockMinNumber < minNumber {
  163. // warehouse.StockMaxNumber = warehouse.StockMaxNumber - 1
  164. // warehouse.StockMinNumber = warehouse.StockMinNumber + drup.MinNumber - minNumber
  165. // } else {
  166. // warehouse.StockMinNumber = warehouse.StockMinNumber - minNumber
  167. // }
  168. //
  169. // if warehouse.StockMaxNumber < 0 {
  170. // return errors.New("库存数量不足")
  171. // }
  172. // errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
  173. // if errThree != nil {
  174. // return errThree
  175. // }
  176. //
  177. // return nil
  178. // } else {
  179. // // 当改批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
  180. // warehouseOutInfo := &models.DrugWarehouseOutInfo{
  181. // WarehouseOutOrderNumber: warehouseout.WarehouseOutOrderNumber,
  182. // WarehouseOutId: warehouseout.ID,
  183. // Status: 1,
  184. // Ctime: time.Now().Unix(),
  185. // Remark: "",
  186. // OrgId: orgID,
  187. // Type: 1,
  188. // Manufacturer: 0,
  189. // Dealer: 0,
  190. // IsSys: 1,
  191. // SysRecordTime: advice.RecordDate,
  192. // DrugId: advice.DrugId,
  193. // }
  194. // // prescribingNumber := strconv.FormatFloat(math.Abs(item.PrescribingNumber), 'f', 0, 64)
  195. // // count, _ := strconv.ParseInt(prescribingNumber, 10, 64)
  196. // warehouseOutInfo.Count = stock_number
  197. // warehouseOutInfo.CountUnit = drup.MinUnit
  198. //
  199. // errOne := AddSigleDrugWarehouseOutInfo(warehouseOutInfo)
  200. // if errOne != nil {
  201. // return errOne
  202. // } else {
  203. // details := &models.DrugAutomaticReduceDetail{
  204. // WarehouseOutId: warehouseOutInfo.ID,
  205. // WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
  206. // PatientId: advice.PatientId,
  207. // Ctime: time.Now().Unix(),
  208. // Mtime: time.Now().Unix(),
  209. // Status: 1,
  210. // RecordTime: advice.RecordDate,
  211. // OrgId: orgID,
  212. // DrugId: advice.DrugId,
  213. // Count: stock_number,
  214. // CountUnit: drup.MinUnit,
  215. // }
  216. // errTwo := AddSigleDrugAutoReduceRecordInfo(details)
  217. // if errTwo != nil {
  218. // return errTwo
  219. // }
  220. // }
  221. // // 出库完成后,要将该批次库存清零
  222. // warehouse.StockMaxNumber = 0
  223. // warehouse.StockMinNumber = 0
  224. // warehouse.Mtime = time.Now().Unix()
  225. // errThree := UpDateDrugWarehouseInfoByStock(&warehouse)
  226. // if errThree != nil {
  227. // return errThree
  228. // }
  229. // // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
  230. // prescribingNumber_two_temp := deliver_number - stock_number
  231. // advice.PrescribingNumber = float64(prescribingNumber_two_temp)
  232. // advice.PrescribingNumberUnit = drup.MinUnit
  233. // DrugDeliverInfo(orgID, prescribingNumber, warehouseout, drup, advice)
  234. // }
  235. // return
  236. //}
  237. //
  238. //// 耗材出库
  239. //func ConsumablesDeliveryTotal(orgID int64,patient_id int64,record_time int64,goods []models.DialysisBeforePrepareGoods) (err error) {
  240. // //查询该患者当天已经出库的耗材信息
  241. // goods_yc,_ := FindConsumablesByDateTwo(orgID, patient_id, record_time)
  242. // // 和新请求的出库数据进行对比,分出那些是继续出库的,那些是需要删除出库的
  243. // for i := len(goods_yc) - 1; i >= 0; i--{
  244. // goods_yc_temp := goods_yc[i]
  245. // for j := len(goods) - 1; j >= 0; j-- {
  246. // goods_temp := goods[j]
  247. // // 已经出库和新请求出库都存在该耗材,则判断出库数量,分成是继续出库,还是删除出库
  248. // if goods_yc_temp.GoodTypeId == goods_temp.GoodTypeId && goods_yc_temp.GoodId == goods_temp.GoodId{
  249. // // 已经出库和新请求出库的出库数量一致,则清除两个结构体里的数据(既不出库,也不删除出库)
  250. // if goods_yc_temp.Count == goods_temp.Count {
  251. // goods_yc = append(goods_yc[:i],goods_yc[i+1:]...)
  252. // goods = append(goods[:j],goods[j+1:]...)
  253. // }
  254. //
  255. // // 如果已经出库的数量 大于 新请求出库的数量,则代表需要删除出库
  256. // if goods_yc_temp.Count > goods_temp.Count {
  257. // temp_count := goods_yc_temp.Count - goods_temp.Count
  258. // goods_yc[i].Count = temp_count
  259. // goods = append(goods[:j],goods[j+1:]...)
  260. // }
  261. //
  262. // // 如果已经出库的数量 小于 新请求出库的梳理,则代表需要增加出库
  263. // if goods_yc_temp.Count < goods_temp.Count {
  264. // temp_count := goods_temp.Count - goods_yc_temp.Count
  265. // goods[j].Count = temp_count
  266. // goods_yc = append(goods_yc[:i],goods_yc[i+1:]...)
  267. // }
  268. // }
  269. // }
  270. // }
  271. //
  272. // // goods_yc 这个数据就是需要已经出库了,但是现在需要删除出库的耗材数据
  273. // // goods 这个数据就是需要出库的耗材的数据
  274. // if len(goods) > 0 {
  275. // out, err := FindStockOutByIsSys(orgID, 1, record_time)
  276. // if err == gorm.ErrRecordNotFound {
  277. // //没有记录,则创建出库单
  278. // timeStr := time.Now().Format("2006-01-02")
  279. // timeArr := strings.Split(timeStr, "-")
  280. // total, _ := FindAllWarehouseOut(orgID)
  281. // total = total + 1
  282. // warehousing_out_order := strconv.FormatInt(orgID, 10) + timeArr[0] + timeArr[1] + timeArr[2] + "000"
  283. // number, _ := strconv.ParseInt(warehousing_out_order, 10, 64)
  284. // number = number + total
  285. // warehousing_out_order = "CKD" + strconv.FormatInt(number, 10)
  286. // warehouseOut := models.WarehouseOut{
  287. // WarehouseOutOrderNumber: warehousing_out_order,
  288. // OperationTime: time.Now().Unix(),
  289. // OrgId: orgID,
  290. // Creater: 0,
  291. // Ctime: time.Now().Unix(),
  292. // Status: 1,
  293. // WarehouseOutTime: record_time,
  294. // Dealer: 0,
  295. // Manufacturer: 0,
  296. // Type: 1,
  297. // IsSys: 1,
  298. // }
  299. // err := AddSigleWarehouseOut(&warehouseOut)
  300. // if err != nil {
  301. // utils.TraceLog("创建出库单失败 err = %v", err)
  302. // return err
  303. // } else {
  304. // out = warehouseOut
  305. // }
  306. // }
  307. // for _,good := range goods {
  308. // ConsumablesDelivery(orgID ,patient_id ,record_time ,good,out )
  309. // }
  310. // }
  311. //
  312. // if len(goods_yc) > 0 {
  313. // for _,good_yc := range goods_yc{
  314. // ConsumablesDeliveryDelete(orgID ,patient_id ,record_time ,good_yc ,out )
  315. // }
  316. // }
  317. //
  318. // return nil
  319. //}
  320. //
  321. //// 耗材出库
  322. //func ConsumablesDelivery(orgID int64,patient_id int64,record_time int64,goods models.DialysisBeforePrepareGoods,warehouseOut models.WarehouseOut) (err error) {
  323. // // 判断处方里药品单位是拆零单位还是包装单位, 如果是包装单位,则根据规格,将包装数量转为拆零数量
  324. // var deliver_number int64 = 0
  325. // var stock_number int64 = 0
  326. //
  327. // deliver_number = good.Count
  328. //
  329. //
  330. // // 根据先进先出原则,查询最先入库的批次,进行出库
  331. // // 如果没有对应的库存,则报错
  332. // warehouse, err := FindFirstWarehousingInfoByStock(goods.GoodId,goods.GoodTypeId)
  333. // if err != nil {
  334. // return err
  335. // }
  336. //
  337. // // 将该批次的剩余库存数量转换为拆零数量
  338. // stock_number = warehouse.StockCount
  339. // // 当库存数量大于或等于出库数量的话,则正常出库该批次
  340. // if stock_number >= deliver_number {
  341. // warehouseOutInfo := &models.WarehouseOutInfo{
  342. // WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
  343. // WarehouseOutId: warehouseOut.ID,
  344. // WarehouseInfoId: warehouse.ID,
  345. // Status: 1,
  346. // Ctime: time.Now().Unix(),
  347. // Remark: "",
  348. // OrgId: orgID,
  349. // Type: 1,
  350. // Manufacturer: 0,
  351. // Dealer: 0,
  352. // IsSys: 1,
  353. // SysRecordTime: record_time,
  354. // GoodTypeId: goods.GoodTypeId,
  355. // GoodId: goods.GoodId,
  356. // PatientId: patient_id,
  357. // }
  358. // warehouseOutInfo.Count = goods.Count
  359. // stockInInfo, _ := FindLastStockInInfoRecord(goods.GoodId, orgID)
  360. // warehouseOutInfo.Price = stockInInfo.Price
  361. // errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
  362. // if errOne != nil {
  363. // return errOne
  364. // } else {
  365. // details := &models.AutomaticReduceDetail{
  366. // WarehouseOutId: warehouseOutInfo.ID,
  367. // WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
  368. // PatientId: patient_id,
  369. // Ctime: time.Now().Unix(),
  370. // Mtime: time.Now().Unix(),
  371. // Status: 1,
  372. // RecordTime: record_time,
  373. // OrgId: orgID,
  374. // GoodId: goods.GoodId,
  375. // GoodTypeId: goods.GoodTypeId,
  376. // Count: goods.Count,
  377. // }
  378. // errTwo := service.AddSigleAutoReduceRecordInfo(details)
  379. // if errTwo != nil {
  380. // return errTwo
  381. // }
  382. // }
  383. //
  384. // // 出库完成后,要减去对应批次的库存数量
  385. //
  386. // maxNumber = goods.Count
  387. //
  388. //
  389. // if warehouse.StockMaxNumber < maxNumber {
  390. // return errors.New("库存数量不足")
  391. // }
  392. //
  393. // warehouse.StockNumber = warehouse.StockMaxNumber - maxNumber
  394. // warehouse.Mtime = time.Now().Unix()
  395. //
  396. //
  397. // if warehouse.StockNumber < 0 {
  398. // return errors.New("库存数量不足")
  399. // }
  400. // errThree := UpDateWarehouseInfoByStock(&warehouse)
  401. // if errThree != nil {
  402. // return errThree
  403. // }
  404. //
  405. // return nil
  406. // } else {
  407. // // 当改批次的库存数量小于出库数量的话,则先把该批次出库完后,再进行递归出库
  408. // warehouseOutInfo := &models.WarehouseOutInfo{
  409. // WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
  410. // WarehouseOutId: warehouseOut.ID,
  411. // WarehouseInfoId: warehouse.ID,
  412. // Status: 1,
  413. // Ctime: time.Now().Unix(),
  414. // Remark: "",
  415. // OrgId: orgID,
  416. // Type: 1,
  417. // Manufacturer: 0,
  418. // Dealer: 0,
  419. // IsSys: 1,
  420. // SysRecordTime: record_time,
  421. // GoodTypeId: goods.GoodTypeId,
  422. // GoodId: goods.GoodId,
  423. // PatientId: patient_id,
  424. // }
  425. // warehouseOutInfo.Count = stock_number
  426. // stockInInfo, _ := service.FindLastStockInInfoRecord(goods.GoodId, orgID)
  427. // warehouseOutInfo.Price = stockInInfo.Price
  428. // errOne := service.AddSigleWarehouseOutInfo(warehouseOutInfo)
  429. // if errOne != nil {
  430. // return errOne
  431. // } else {
  432. // details := &models.AutomaticReduceDetail{
  433. // WarehouseOutId: warehouseOutInfo.ID,
  434. // WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
  435. // PatientId: patient_id,
  436. // Ctime: time.Now().Unix(),
  437. // Mtime: time.Now().Unix(),
  438. // Status: 1,
  439. // RecordTime: record_time,
  440. // OrgId: orgID,
  441. // GoodId: goods.GoodId,
  442. // GoodTypeId: goods.GoodTypeId,
  443. // Count: goods.Count,
  444. // }
  445. // errTwo := service.AddSigleAutoReduceRecordInfo(details)
  446. // if errTwo != nil {
  447. // return errTwo
  448. // }
  449. // }
  450. // // 出库完成后,要将该批次库存清零
  451. // warehouse.StockNumber = 0
  452. // warehouse.Mtime = time.Now().Unix()
  453. // errThree := UpDateWarehouseInfoByStock(&warehouse)
  454. // if errThree != nil {
  455. // return errThree
  456. // }
  457. // // 清零完该库存后,还有剩余出库未出完,进行对应的递归操作
  458. // goods.Count := deliver_number - stock_number
  459. //
  460. // ConsumablesDelivery(orgID ,patient_id ,record_time ,good,out )
  461. // }
  462. // return nil
  463. //}
  464. //
  465. //// 耗材出库删除
  466. //func ConsumablesDeliveryDelete(orgID int64,patient_id int64,record_time int64,good_yc models.DialysisBeforePrepare,warehouseOut models.WarehouseOut) (err error) {
  467. // // 先根据相关信息查询当天该耗材的出库信息
  468. // warehouseOutInfos,err :=FindStockOutInfoByStock(orgID,good_yc.GoodTypeId,good_yc.GoodId,record_time,patient_id)
  469. // if err != nil {
  470. // return err
  471. // }
  472. //
  473. // var delete_count int64 = 0
  474. //
  475. // for _ , ware := range warehouseOutInfos{
  476. // // 判断当前出库的数据和删除出库数量
  477. // if good_yc.Count <= ware.Count {
  478. // delete_count = good_yc.Count
  479. // } else {
  480. // delete_count = ware.Count
  481. // }
  482. // // 在出库记录表里记录退库详情
  483. // warehouseOutInfo := &models.WarehouseOutInfo{
  484. // WarehouseOutOrderNumber: warehouseOut.WarehouseOutOrderNumber,
  485. // WarehouseOutId: warehouseOut.ID,
  486. // WarehouseInfoId: warehouse.ID,
  487. // Status: 1,
  488. // Ctime: time.Now().Unix(),
  489. // Remark: "",
  490. // OrgId: orgID,
  491. // Type: 1,
  492. // Manufacturer: 0,
  493. // Dealer: 0,
  494. // IsSys: 2,
  495. // SysRecordTime: record_time,
  496. // GoodTypeId: goods.GoodTypeId,
  497. // GoodId: goods.GoodId,
  498. // PatientId: patient_id,
  499. // }
  500. // warehouseOutInfo.Count = delete_count
  501. // stockInInfo, _ := FindLastStockInInfoRecord(goods.GoodId, orgID)
  502. // warehouseOutInfo.Price = stockInInfo.Price
  503. // errOne := AddSigleWarehouseOutInfo(warehouseOutInfo)
  504. // if errOne != nil {
  505. // return errOne
  506. // } else {
  507. // details := &models.AutomaticReduceDetail{
  508. // WarehouseOutId: warehouseOutInfo.ID,
  509. // WarehouseOutOrderNumber: warehouseOutInfo.WarehouseOutOrderNumber,
  510. // PatientId: patient_id,
  511. // Ctime: time.Now().Unix(),
  512. // Mtime: time.Now().Unix(),
  513. // Status: 1,
  514. // RecordTime: record_time,
  515. // OrgId: orgID,
  516. // GoodId: goods.GoodId,
  517. // GoodTypeId: goods.GoodTypeId,
  518. // Count: delete_count,
  519. // Type: 2,
  520. // }
  521. // errTwo := AddSigleAutoReduceRecordInfo(details)
  522. // if errTwo != nil {
  523. // return errTwo
  524. // }
  525. // }
  526. //
  527. // // 删除出库完成后,要增加对应批次的库存数量
  528. //
  529. //
  530. //
  531. // errThree := UpDateWarehouseInfoByStockDelete(ware.WarehouseInfoId,delete_count)
  532. // if errThree != nil {
  533. // return errThree
  534. // }
  535. //
  536. // // 增加了对应的库存后,看看还有多少需要退库的
  537. // good_yc.Count = goods_yc.Count - delete_count
  538. // if good_yc.Count == 0 {
  539. // return nil
  540. // }
  541. // }
  542. //
  543. // if good_yd.Count == 0 {
  544. // return nil
  545. // } else {
  546. // return errors.New("退库和出库数据不匹配")
  547. // }
  548. //}