stock_service.go 56KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287
  1. package service
  2. import (
  3. "XT_New/models"
  4. "fmt"
  5. "github.com/jinzhu/gorm"
  6. "strconv"
  7. "strings"
  8. "time"
  9. )
  10. func AddSigleDealer(dealer *models.Dealer) (error, *models.Dealer) {
  11. err := writeDb.Create(&dealer).Error
  12. return err, dealer
  13. }
  14. func ModifyDealer(dealer *models.Dealer) error {
  15. err := writeDb.Model(&models.Dealer{}).Where("id = ? AND status = 1", dealer.ID).Updates(map[string]interface{}{
  16. "dealer_name": dealer.DealerName,
  17. "contact": dealer.Contact,
  18. "contact_phone": dealer.ContactPhone,
  19. "platform_number": dealer.PlatformNumber,
  20. "email": dealer.Email,
  21. "contact_address": dealer.ContactAddress,
  22. "modifier": dealer.Modifier,
  23. "mtime": time.Now().Unix(),
  24. "remark": dealer.Remark,
  25. }).Error
  26. return err
  27. }
  28. func FindAllDealerTotal(orgId int64) (total int64) {
  29. db := readDb.Model(&models.Dealer{})
  30. db = db.Where("org_id = ? ", orgId).Count(&total)
  31. return
  32. }
  33. func FindAllDealerList(orgId int64, page int64, limit int64) (list []*models.Dealer, total int64, err error) {
  34. offset := (page - 1) * limit
  35. db := readDb.Model(&models.Dealer{})
  36. db = db.Where("org_id = ? AND status = 1", orgId)
  37. err = db.Count(&total).Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  38. return
  39. }
  40. func DeleteDealerById(id int64) error {
  41. err := writeDb.Model(&models.Dealer{}).Where("id = ? AND status = 1", id).Updates(map[string]interface{}{"mtime": time.Now().Unix(), "status": 0}).Error
  42. return err
  43. }
  44. func FindDealerById(id int64) (*models.Dealer, error) {
  45. dealer := &models.Dealer{}
  46. err := readDb.Model(&models.Dealer{}).Where("id = ? AND status = 1", id).First(&dealer).Error
  47. return dealer, err
  48. }
  49. func AddSigleManufacturer(manufacturer *models.Manufacturer) (error, *models.Manufacturer) {
  50. err := writeDb.Create(&manufacturer).Error
  51. return err, manufacturer
  52. }
  53. func ModifyManufacturer(manufacturer *models.Manufacturer) error {
  54. err := writeDb.Model(&models.Manufacturer{}).Where("id = ? AND status = 1", manufacturer.ID).Updates(map[string]interface{}{
  55. "manufacturer_name": manufacturer.ManufacturerName,
  56. "contact": manufacturer.Contact,
  57. "contact_phone": manufacturer.ContactPhone,
  58. "platform_number": manufacturer.PlatformNumber,
  59. "email": manufacturer.Email,
  60. "contact_address": manufacturer.ContactAddress,
  61. "modifier": manufacturer.Modifier,
  62. "mtime": time.Now().Unix(),
  63. "remark": manufacturer.Remark,
  64. }).Error
  65. return err
  66. }
  67. func FindAllManufacturerList(orgId int64, page int64, limit int64) (list []*models.Manufacturer, total int64, err error) {
  68. offset := (page - 1) * limit
  69. db := readDb.Model(&models.Manufacturer{})
  70. db = db.Where("org_id = ? AND status = 1", orgId)
  71. err = db.Count(&total).Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  72. return
  73. }
  74. func DeleteManufacturerById(id int64) error {
  75. err := writeDb.Model(&models.Manufacturer{}).Where("id = ? AND status = 1", id).Updates(map[string]interface{}{"mtime": time.Now().Unix(), "status": 0}).Error
  76. return err
  77. }
  78. func FindManufacturerById(id int64) (*models.Manufacturer, error) {
  79. dealer := &models.Manufacturer{}
  80. err := readDb.Model(&models.Manufacturer{}).Where("id = ? AND status = 1", id).First(&dealer).Error
  81. return dealer, err
  82. }
  83. func FindManufacturerTotal(orgId int64) (total int64) {
  84. db := readDb.Model(&models.Manufacturer{})
  85. db = db.Where("org_id = ?", orgId).Count(&total)
  86. return
  87. }
  88. func FindAllDealer(orgId int64) (dealers []*models.Dealer, err error) {
  89. err = readDb.Model(&models.Dealer{}).Where("org_id = ? AND status = 1", orgId).Find(&dealers).Error
  90. return dealers, err
  91. }
  92. func FindAllManufacturer(orgId int64) (manufacturer []*models.Manufacturer, err error) {
  93. err = readDb.Model(&models.Manufacturer{}).Where("org_id = ? AND status = 1", orgId).Find(&manufacturer).Error
  94. return manufacturer, err
  95. }
  96. func FindAllGoodTypeTotal(orgId int64) (total int64) {
  97. db := readDb.Model(&models.GoodsType{})
  98. db = db.Where("org_id = ?", orgId).Count(&total)
  99. return
  100. }
  101. func AddSigleGoodType(goodType *models.GoodsType) (error, *models.GoodsType) {
  102. err := writeDb.Create(&goodType).Error
  103. return err, goodType
  104. }
  105. func ModifyGoodType(goodType *models.GoodsType) (error, *models.GoodsType) {
  106. err := writeDb.Model(&models.GoodsType{}).Where("id = ? AND status = 1", goodType.ID).Updates(map[string]interface{}{
  107. "modifier": goodType.Modifier,
  108. "mtime": time.Now().Unix(),
  109. "remark": goodType.Remark,
  110. "type_name": goodType.TypeName,
  111. }).Error
  112. return err, goodType
  113. }
  114. func FindAllGoodTypeList(orgId int64, page int64, limit int64, keyword string) (list []*models.GoodsType, total int64, err error) {
  115. offset := (page - 1) * limit
  116. db := readDb.Model(&models.GoodsType{})
  117. db = db.Where("org_id=? AND status = 1", orgId)
  118. if len(keyword) > 0 {
  119. likeKey := "%" + keyword + "%"
  120. db = db.Where("type_code LIKE ? OR type_name LIKE ?", likeKey, likeKey)
  121. }
  122. err = db.Count(&total).Offset(offset).Limit(limit).Order("type desc, number desc,ctime desc").Find(&list).Error
  123. return
  124. }
  125. func DeleteGoodTypeById(id int64, operateId int64) error {
  126. err := writeDb.Model(&models.GoodsType{}).Where("id = ? AND status = 1", id).Updates(map[string]interface{}{"mtime": time.Now().Unix(), "status": 0, "modifier": operateId}).Error
  127. writeDb.Model(&models.GoodInfo{}).Where("good_type_id = ? AND status = 1", id).Updates(map[string]interface{}{"mtime": time.Now().Unix(), "status": 0, "modifier": operateId})
  128. return err
  129. }
  130. func FindGoodTypeById(id int64) (*models.GoodsType, error) {
  131. goodType := &models.GoodsType{}
  132. err := readDb.Model(&models.GoodsType{}).Where("id = ? AND status = 1", id).First(&goodType).Error
  133. return goodType, err
  134. }
  135. func FindAllGoodInfoTotal(orgId int64) (total int64) {
  136. db := readDb.Model(&models.GoodInfo{})
  137. db = db.Where("org_id = ?", orgId).Count(&total)
  138. return
  139. }
  140. func AddSigleGoodInfo(goodInfo *models.GoodInfo) (error, *models.GoodInfo) {
  141. err := writeDb.Create(&goodInfo).Error
  142. return err, goodInfo
  143. }
  144. func ModifyGoodInfo(goodInfo *models.GoodInfo) (error, *models.GoodInfo) {
  145. err := writeDb.Model(&models.GoodInfo{}).Where("id = ? AND status = 1", goodInfo.ID).Updates(map[string]interface{}{
  146. "good_type_id": goodInfo.GoodTypeId,
  147. "modifier": goodInfo.Modifier,
  148. "mtime": time.Now().Unix(),
  149. "remark": goodInfo.Remark,
  150. "specification_name": goodInfo.SpecificationName,
  151. "good_unit": goodInfo.GoodUnit,
  152. "buy_price": goodInfo.BuyPrice,
  153. "sell_price": goodInfo.SellPrice,
  154. "manufacturer": goodInfo.Manufacturer,
  155. "dealer": goodInfo.Dealer,
  156. "expiry_date_warn_day_count": goodInfo.ExpiryDateWarnDayCount,
  157. "stock_warn_count": goodInfo.StockWarnCount,
  158. "is_reuse": goodInfo.IsReuse,
  159. }).Error
  160. return err, goodInfo
  161. }
  162. func FindGoodInfoList(orgId int64, page int64, limit int64, keyword string) (list []*models.GoodInfo, total int64, err error) {
  163. offset := (page - 1) * limit
  164. db := readDb.Model(&models.GoodInfo{})
  165. db = db.Where("org_id = ? AND status = 1", orgId)
  166. if len(keyword) > 0 {
  167. likeKey := "%" + keyword + "%"
  168. db = db.Where("good_code LIKE ? OR specification_name LIKE ?", likeKey, likeKey)
  169. }
  170. err = db.Count(&total).Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  171. return
  172. }
  173. func DeleteGoodInfoById(id int64, operateId int64) error {
  174. err := writeDb.Model(&models.GoodInfo{}).Where("id = ? AND status = 1", id).Updates(map[string]interface{}{"mtime": time.Now().Unix(), "status": 0, "modifier": operateId}).Error
  175. return err
  176. }
  177. func FindGoodInfoByGoodId(id int64) (list []*models.GoodInfo, err error) {
  178. err = readDb.Model(&models.GoodInfo{}).Where("good_type_id = ? AND status = 1", id).Find(&list).Error
  179. return list, err
  180. }
  181. func FindStockOutDetailGoodInfoByGoodId(id int64) (list []*models.AutomaticReduceDetail, err error) {
  182. err = readDb.Model(&models.AutomaticReduceDetail{}).Where("good_type_id = ? AND status = 1", id).Find(&list).Error
  183. return list, err
  184. }
  185. func FindGoodInfoById(id int64) (*models.GoodInfo, error) {
  186. goodInfo := &models.GoodInfo{}
  187. err := readDb.Model(&models.GoodInfo{}).Where("id = ? AND status = 1", id).First(&goodInfo).Error
  188. return goodInfo, err
  189. }
  190. func FindAllGoodType(org_id int64) (goodType []*models.GoodsType, err error) {
  191. err = readDb.Model(&models.GoodsType{}).Where("org_id = ? AND status = 1", org_id).Find(&goodType).Error
  192. return goodType, err
  193. }
  194. func FindAllGoodInfo(org_id int64) (goodInfo []*models.GoodInfo, err error) {
  195. err = readDb.Model(&models.GoodInfo{}).Where("org_id = ? AND status = 1", org_id).Find(&goodInfo).Error
  196. return goodInfo, err
  197. }
  198. func FindAllWarehouseTotal(org_id int64) (total int64, err error) {
  199. err = readDb.Model(&models.Warehousing{}).Where("org_id = ?", org_id).Count(&total).Error
  200. return total, err
  201. }
  202. func AddSigleWarehouse(warehouse *models.Warehousing) error {
  203. err := writeDb.Create(&warehouse).Error
  204. return err
  205. }
  206. func AddSigleSalesReturn(salesReturn *models.SalesReturn) error {
  207. err := writeDb.Create(&salesReturn).Error
  208. return err
  209. }
  210. func UpDateGoodReturnStatus(ids []string) {
  211. writeDb.Model(&models.WarehousingInfo{}).Where("id IN (?)", ids).Update(map[string]interface{}{"is_return": 1})
  212. }
  213. func UpDateCanCelStockStatus(ids []string) {
  214. writeDb.Model(&models.WarehouseOutInfo{}).Where("id IN (?)", ids).Update(map[string]interface{}{"is_cancel": 1})
  215. }
  216. func CreateWarehousingInfo(warehousingInfo []*models.WarehousingInfo) (err error) {
  217. if len(warehousingInfo) > 0 {
  218. utx := writeDb.Begin()
  219. if len(warehousingInfo) > 0 {
  220. thisSQL := "INSERT INTO xt_warehouse_info (warehousing_id, good_id, good_type_id, number, product_date,expiry_date,warehousing_count,price,total_price,dealer,manufacturer,remark,ctime,mtime,status,org_id,warehousing_order,type) VALUES "
  221. insertParams := make([]string, 0)
  222. insertData := make([]interface{}, 0)
  223. for _, info := range warehousingInfo {
  224. insertParams = append(insertParams, "(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)")
  225. insertData = append(insertData, info.WarehousingId)
  226. insertData = append(insertData, info.GoodId)
  227. insertData = append(insertData, info.GoodTypeId)
  228. insertData = append(insertData, info.Number)
  229. insertData = append(insertData, info.ProductDate)
  230. insertData = append(insertData, info.ExpiryDate)
  231. insertData = append(insertData, info.WarehousingCount)
  232. insertData = append(insertData, info.Price)
  233. insertData = append(insertData, info.TotalPrice)
  234. insertData = append(insertData, info.Dealer)
  235. insertData = append(insertData, info.Manufacturer)
  236. insertData = append(insertData, info.Remark)
  237. insertData = append(insertData, info.Ctime)
  238. insertData = append(insertData, info.Mtime)
  239. insertData = append(insertData, info.Status)
  240. insertData = append(insertData, info.OrgId)
  241. insertData = append(insertData, info.WarehousingOrder)
  242. insertData = append(insertData, info.Type)
  243. }
  244. thisSQL += strings.Join(insertParams, ", ")
  245. err = utx.Exec(thisSQL, insertData...).Error
  246. if err != nil {
  247. utx.Rollback()
  248. return
  249. }
  250. }
  251. utx.Commit()
  252. }
  253. return
  254. }
  255. func FindLastWarehousingInfo(order string) (info models.WarehousingInfo, err error) {
  256. err = readDb.Model(&models.WarehousingInfo{}).Where("warehousing_order = ? AND status = 1", order).Last(&info).Error
  257. return info, err
  258. }
  259. func FindAllWarehousingList(orgId int64, page int64, limit int64, startTime int64, endTime int64, types int64, keywords string) (list []*models.Warehousing, total int64, err error) {
  260. db := readDb.Model(&models.Warehousing{})
  261. db = db.Where("xt_warehouse.org_id = ? AND xt_warehouse.status = 1 AND xt_warehouse.type = ?", orgId, types)
  262. if len(keywords) > 0 {
  263. likeKey := "%" + keywords + "%"
  264. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse.creater")
  265. db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_warehouse.manufacturer")
  266. db = db.Where("xt_manufacturer.manufacturer_name LIKE ? OR sgj_user_admin_role.user_name LIKE ? OR xt_warehouse.warehousing_order LIKE ?", likeKey, likeKey, likeKey).Group("xt_warehouse.id")
  267. }
  268. if startTime > 0 {
  269. db = db.Where("xt_warehouse.operation_time >=?", startTime)
  270. }
  271. if endTime > 0 {
  272. db = db.Where("xt_warehouse.operation_time<= ?", endTime)
  273. }
  274. db = db.Count(&total)
  275. offset := (page - 1) * limit
  276. err = db.Offset(offset).Limit(limit).Order("xt_warehouse.ctime desc").Find(&list).Error
  277. return
  278. }
  279. func FindWarehousingInfoById(id int64) (list []*models.WarehousingInfo, err error) {
  280. err = readDb.Model(&models.WarehousingInfo{}).Where("warehousing_id = ? AND status = 1", id).Find(&list).Error
  281. return list, err
  282. }
  283. func FindWarehousingById(id int64) (warehousing models.Warehousing, err error) {
  284. err = readDb.Model(&models.Warehousing{}).Where("id = ? AND status = 1 ", id).First(&warehousing).Error
  285. return warehousing, err
  286. }
  287. func GetInfoByIds(ids []string) (info []*models.WarehousingInfo, err error) {
  288. err = readDb.Model(&models.WarehousingInfo{}).Preload("Warehousing", "status = 1").Where("id in (?) AND status = 1", ids).Find(&info).Error
  289. return
  290. }
  291. func GetWarehousOutInfoByIds(ids []string) (info []*models.WarehouseOutInfo, err error) {
  292. err = readDb.Model(&models.WarehouseOutInfo{}).Preload("WarehouseOut", "status = 1").Where("id in (?) AND status = 1", ids).Find(&info).Error
  293. return
  294. }
  295. func CreateSalesReturnInfo(salesReturnInfo []*models.SalesReturnInfo) (err error) {
  296. if len(salesReturnInfo) > 0 {
  297. utx := writeDb.Begin()
  298. if len(salesReturnInfo) > 0 {
  299. thisSQL := "INSERT INTO xt_sales_return_info (good_id, sales_return_id, good_type_id, count, price,total,ctime,status,org_id,order_number,type,dealer,manufacturer) VALUES "
  300. insertParams := make([]string, 0)
  301. insertData := make([]interface{}, 0)
  302. for _, info := range salesReturnInfo {
  303. insertParams = append(insertParams, "(?,?,?,?,?,?,?,?,?,?,?,?,?)")
  304. insertData = append(insertData, info.GoodId)
  305. insertData = append(insertData, info.SalesReturnId)
  306. insertData = append(insertData, info.GoodTypeId)
  307. insertData = append(insertData, info.Count)
  308. insertData = append(insertData, info.Price)
  309. insertData = append(insertData, info.Total)
  310. insertData = append(insertData, info.Ctime)
  311. insertData = append(insertData, info.Status)
  312. insertData = append(insertData, info.OrgId)
  313. insertData = append(insertData, info.OrderNumber)
  314. insertData = append(insertData, info.Type)
  315. insertData = append(insertData, info.Dealer)
  316. insertData = append(insertData, info.Manufacturer)
  317. }
  318. thisSQL += strings.Join(insertParams, ", ")
  319. err = utx.Exec(thisSQL, insertData...).Error
  320. if err != nil {
  321. utx.Rollback()
  322. return
  323. }
  324. }
  325. utx.Commit()
  326. }
  327. return
  328. }
  329. func FindAllSalesReturnTotal(org_id int64) (total int64, err error) {
  330. err = readDb.Model(&models.SalesReturn{}).Where("org_id = ?", org_id).Count(&total).Error
  331. return total, err
  332. }
  333. func FindAllCancelStockTotal(org_id int64) (total int64, err error) {
  334. err = readDb.Model(&models.CancelStock{}).Where("org_id = ?", org_id).Count(&total).Error
  335. return total, err
  336. }
  337. func FindAllReturnList(orgId int64, page int64, limit int64, startTime int64, endTime int64, types int64, keywords string) (list []*models.SalesReturn, total int64, err error) {
  338. db := readDb.Model(&models.SalesReturn{})
  339. db = db.Where("xt_sales_return.org_id = ? AND xt_sales_return.status = 1 AND xt_sales_return.type = ?", orgId, types)
  340. if len(keywords) > 0 {
  341. likeKey := "%" + keywords + "%"
  342. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_sales_return.creater")
  343. db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_sales_return.manufacturer")
  344. db = db.Where("xt_manufacturer.manufacturer_name LIKE ? OR sgj_user_admin_role.user_name LIKE ? OR xt_sales_return.order_number LIKE ?", likeKey, likeKey, likeKey).Group("xt_sales_return.id")
  345. }
  346. if startTime > 0 {
  347. db = db.Where("xt_sales_return.opera_time >=?", startTime)
  348. }
  349. if endTime > 0 {
  350. db = db.Where("xt_sales_return.opera_time<= ?", endTime)
  351. }
  352. db = db.Count(&total)
  353. offset := (page - 1) * limit
  354. err = db.Offset(offset).Limit(limit).Order("xt_sales_return.ctime desc").Find(&list).Error
  355. return
  356. }
  357. func FindReturnInfoById(id int64) (list []*models.SalesReturnInfo, err error) {
  358. err = readDb.Model(&models.SalesReturnInfo{}).Where("sales_return_id = ? AND status = 1", id).Find(&list).Error
  359. return list, err
  360. }
  361. func FindCancelStockInfoById(id int64) (list []*models.CancelStockInfo, err error) {
  362. err = readDb.Model(&models.CancelStockInfo{}).Where("cancel_stock_id = ? AND status = 1", id).Find(&list).Error
  363. return list, err
  364. }
  365. func FindAllWarehousingInfo(orgId int64, page int64, limit int64, startTime int64, endTime int64) (list []*models.WarehousingInfo, total int64, err error) {
  366. db := readDb.Model(&models.WarehousingInfo{})
  367. db = db.Where("org_id = ? AND status = 1", orgId)
  368. db = db.Preload("Warehousing", "status = 1 AND org_id = ?", orgId)
  369. if startTime > 0 {
  370. db = db.Where("ctime >=?", startTime)
  371. }
  372. if endTime > 0 {
  373. db = db.Where("ctime<= ?", endTime)
  374. }
  375. db = db.Count(&total)
  376. offset := (page - 1) * limit
  377. err = db.Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  378. return list, total, err
  379. }
  380. func FindAllWarehouseOut(org_id int64) (total int64, err error) {
  381. err = readDb.Model(&models.WarehouseOut{}).Where("org_id = ?", org_id).Count(&total).Error
  382. return total, err
  383. }
  384. func AddSigleWarehouseOut(warehouseOut *models.WarehouseOut) error {
  385. err := writeDb.Create(&warehouseOut).Error
  386. return err
  387. }
  388. func CreateWarehousingOutInfo(warehouseOutInfo []*models.WarehouseOutInfo) (err error) {
  389. if len(warehouseOutInfo) > 0 {
  390. utx := writeDb.Begin()
  391. if len(warehouseOutInfo) > 0 {
  392. thisSQL := "INSERT INTO xt_warehouse_out_info (warehouse_out_id, good_id, good_type_id, product_date,expiry_date,count,price,total_price,remark,ctime,status,org_id,warehouse_out_order_number,type,dealer,manufacturer) VALUES "
  393. insertParams := make([]string, 0)
  394. insertData := make([]interface{}, 0)
  395. for _, info := range warehouseOutInfo {
  396. insertParams = append(insertParams, "(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)")
  397. insertData = append(insertData, info.WarehouseOutId)
  398. insertData = append(insertData, info.GoodId)
  399. insertData = append(insertData, info.GoodTypeId)
  400. insertData = append(insertData, info.ProductDate)
  401. insertData = append(insertData, info.ExpiryDate)
  402. insertData = append(insertData, info.Count)
  403. insertData = append(insertData, info.Price)
  404. insertData = append(insertData, info.TotalPrice)
  405. insertData = append(insertData, info.Remark)
  406. insertData = append(insertData, info.Ctime)
  407. insertData = append(insertData, info.Status)
  408. insertData = append(insertData, info.OrgId)
  409. insertData = append(insertData, info.WarehouseOutOrderNumber)
  410. insertData = append(insertData, info.Type)
  411. insertData = append(insertData, info.Dealer)
  412. insertData = append(insertData, info.Manufacturer)
  413. }
  414. thisSQL += strings.Join(insertParams, ", ")
  415. err = utx.Exec(thisSQL, insertData...).Error
  416. if err != nil {
  417. utx.Rollback()
  418. return
  419. }
  420. }
  421. utx.Commit()
  422. }
  423. return
  424. }
  425. func FindLastWarehousingOutInfo(order string) (info models.WarehouseOutInfo, err error) {
  426. err = readDb.Model(&models.WarehouseOutInfo{}).Where("warehouse_out_order_number = ? AND status = 1", order).Last(&info).Error
  427. return info, err
  428. }
  429. func FindAllWarehouseOutList(orgId int64, page int64, limit int64, startTime int64, endTime int64, types int64, keywords string) (list []*models.WarehouseOut, total int64, err error) {
  430. db := readDb.Model(&models.WarehouseOut{})
  431. db = db.Where("xt_warehouse_out.org_id = ? AND xt_warehouse_out.status = 1 AND xt_warehouse_out.type = ?", orgId, types)
  432. if len(keywords) > 0 {
  433. likeKey := "%" + keywords + "%"
  434. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse_out.creater")
  435. db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_warehouse_out.manufacturer")
  436. db = db.Where("xt_manufacturer.manufacturer_name LIKE ? OR sgj_user_admin_role.user_name LIKE ? OR xt_warehouse_out.warehouse_out_order_number LIKE ?", likeKey, likeKey, likeKey).Group("xt_warehouse_out.id")
  437. }
  438. if startTime > 0 {
  439. db = db.Where("xt_warehouse_out.ctime >=?", startTime)
  440. }
  441. if endTime > 0 {
  442. db = db.Where("xt_warehouse_out.ctime<= ?", endTime)
  443. }
  444. db = db.Count(&total)
  445. offset := (page - 1) * limit
  446. err = db.Offset(offset).Limit(limit).Order("xt_warehouse_out.ctime desc").Find(&list).Error
  447. return list, total, err
  448. return
  449. }
  450. func FindWarehouseOutInfoById(id int64) (list []*models.WarehouseOutInfo, err error) {
  451. err = readDb.Model(&models.WarehouseOutInfo{}).Where("warehouse_out_id = ? AND status = 1 AND count <> 0 AND good_id <> 0", id).Order("good_type_id desc").Find(&list).Error
  452. return list, err
  453. }
  454. func FindWarehouseInfoByGoodId(good_id int64) (int64, *models.WarehousingInfo) {
  455. info := &models.WarehousingInfo{}
  456. type WarehouseInfoCountAmount struct {
  457. Total int64
  458. }
  459. var result WarehouseInfoCountAmount
  460. readDb.Model(&models.WarehousingInfo{}).Where("good_id = ? AND status = 1", good_id).Select("sum(warehousing_count) as total").Scan(&result)
  461. readDb.Model(&models.WarehousingInfo{}).Where("good_id = ? AND status = 1", good_id).First(info)
  462. return result.Total, info
  463. }
  464. func FindAllSalesReturnCountByGoodId(good_id int64) (int64, error) {
  465. type SalesReturnCountAmount struct {
  466. Total int64
  467. }
  468. var result SalesReturnCountAmount
  469. err = readDb.Model(&models.SalesReturnInfo{}).Where("good_id = ? AND status = 1", good_id).Select("sum(count) as total").Scan(&result).Error
  470. return result.Total, err
  471. }
  472. func FindAllWarehouseOutInfoByGoodId(good_id int64) (int64, error) {
  473. type WarehouseOutInfoCountAmount struct {
  474. Total int64
  475. }
  476. var result WarehouseOutInfoCountAmount
  477. err = readDb.Model(&models.WarehouseOutInfo{}).Where("good_id = ? AND status = 1", good_id).Select("sum(count) as total").Scan(&result).Error
  478. return result.Total, err
  479. }
  480. func FindAllCancleStockInfoByGoodId(good_id int64) (int64, error) {
  481. type CancleStockoCountAmount struct {
  482. Total int64
  483. }
  484. var result CancleStockoCountAmount
  485. err = readDb.Model(&models.CancelStockInfo{}).Where("good_id = ? AND status = 1", good_id).Select("sum(count) as total").Scan(&result).Error
  486. return result.Total, err
  487. }
  488. func FindWarehouseInfoByGoodTypeId(good_type_id int64) (models.WarehousingInfo, error) {
  489. info := models.WarehousingInfo{}
  490. err := readDb.Model(&models.WarehousingInfo{}).Where("good_type_id = ? AND status = 1", good_type_id).First(&info).Error
  491. return info, err
  492. }
  493. func AddSigleCancelStock(cancelStock *models.CancelStock) error {
  494. err := writeDb.Create(&cancelStock).Error
  495. return err
  496. }
  497. func CreateCancelStockInfo(cancelStockInfo []*models.CancelStockInfo) (err error) {
  498. if len(cancelStockInfo) > 0 {
  499. utx := writeDb.Begin()
  500. if len(cancelStockInfo) > 0 {
  501. thisSQL := "INSERT INTO xt_cancel_stock_info (good_id, cancel_stock_id, good_type_id, count, price,total,ctime,status,org_id,order_number,type,dealer,manufacturer) VALUES "
  502. insertParams := make([]string, 0)
  503. insertData := make([]interface{}, 0)
  504. for _, info := range cancelStockInfo {
  505. insertParams = append(insertParams, "(?,?,?,?,?,?,?,?,?,?,?,?,?)")
  506. insertData = append(insertData, info.GoodId)
  507. insertData = append(insertData, info.CancelStockId)
  508. insertData = append(insertData, info.GoodTypeId)
  509. insertData = append(insertData, info.Count)
  510. insertData = append(insertData, info.Price)
  511. insertData = append(insertData, info.Total)
  512. insertData = append(insertData, info.Ctime)
  513. insertData = append(insertData, info.Status)
  514. insertData = append(insertData, info.OrgId)
  515. insertData = append(insertData, info.OrderNumber)
  516. insertData = append(insertData, info.Type)
  517. insertData = append(insertData, info.Dealer)
  518. insertData = append(insertData, info.Manufacturer)
  519. }
  520. thisSQL += strings.Join(insertParams, ", ")
  521. err = utx.Exec(thisSQL, insertData...).Error
  522. if err != nil {
  523. utx.Rollback()
  524. return
  525. }
  526. }
  527. utx.Commit()
  528. }
  529. return
  530. }
  531. func FindAllCancelStockList(orgId int64) (list []*models.CancelStock, err error) {
  532. db := readDb.Model(&models.CancelStock{})
  533. db = db.Where("org_id = ? AND status = 1", orgId)
  534. err = db.Order("ctime desc").Find(&list).Error
  535. return
  536. }
  537. func FindAllStockOutList(orgId int64, page int64, limit int64, startTime int64, endTime int64) (list []*models.WarehouseOutInfo, total int64, err error) {
  538. db := readDb.Model(&models.WarehousingInfo{})
  539. db = db.Where("org_id = ? AND status = 1", orgId)
  540. db = db.Preload("WarehouseOut", "status = 1 AND org_id = ?", orgId)
  541. if startTime > 0 {
  542. db = db.Where("ctime >=?", startTime)
  543. }
  544. if endTime > 0 {
  545. db = db.Where("ctime<= ?", endTime)
  546. }
  547. db = db.Count(&total)
  548. offset := (page - 1) * limit
  549. err = db.Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  550. return
  551. }
  552. func FindAllStockInfo(orgId int64, page int64, limit int64, keyword string) (list []*models.StockInfo, total int64, err error) {
  553. db := readDb.Model(&models.StockInfo{})
  554. db = db.Where("xt_good_information.org_id = ? AND xt_good_information.status = 1", orgId)
  555. db = db.Group("xt_good_information.id")
  556. db = db.Preload("QueryWarehousingInfo", func(db *gorm.DB) *gorm.DB {
  557. return db.Where("org_id = ? AND status = 1", orgId)
  558. })
  559. db = db.Preload("QuerySalesReturnInfo", "org_id = ? AND status = 1", orgId)
  560. db = db.Preload("QueryWarehouseOutInfo", func(db *gorm.DB) *gorm.DB {
  561. return db.Where("org_id = ? AND status = 1", orgId)
  562. })
  563. db = db.Preload("QueryCancelStockInfo", "org_id = ? AND status = 1", orgId)
  564. db = db.Preload("GoodsType", "org_id = ? AND status = 1", orgId)
  565. if len(keyword) > 0 {
  566. likeKey := "%" + keyword + "%"
  567. db = db.Joins("join xt_goods_type on xt_goods_type.id = xt_good_information.good_type_id AND xt_goods_type.org_id = ? AND xt_goods_type.status = 1", orgId)
  568. db = db.Where("xt_good_information.good_code LIKE ? OR xt_good_information.specification_name LIKE ? OR xt_goods_type.type_name LIKE ?", likeKey, likeKey, likeKey).Group("xt_good_information.id")
  569. }
  570. db = db.Count(&total)
  571. offset := (page - 1) * limit
  572. err = db.Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  573. return
  574. }
  575. func FindWarehouseInfoTotalByGoodId(goodId int64) (total int64, err error) {
  576. err = readDb.Model(&models.WarehousingInfo{}).Where("good_id = ? AND status = 1", goodId).Count(&total).Error
  577. return
  578. }
  579. func FindWarehouseOutInfoTotalByGoodId(goodId int64) (total int64, err error) {
  580. err = readDb.Model(&models.WarehouseOutInfo{}).Where("good_id = ? AND status = 1", goodId).Count(&total).Error
  581. return
  582. }
  583. func UpDateWarehouse(warehouse *models.Warehousing) (err error) {
  584. err = readDb.Model(&models.Warehousing{}).Where("warehousing_order = ? AND status = 1", warehouse.WarehousingOrder).Update(map[string]interface{}{"operation_time": warehouse.OperationTime, "mtime": warehouse.Mtime, "modifier": warehouse.Modifier}).Error
  585. return
  586. }
  587. func UpDateWarehouseOut(warehouseOut *models.WarehouseOut) (err error) {
  588. err = readDb.Model(&models.WarehouseOut{}).Where("warehouse_out_order_number = ? AND status = 1", warehouseOut.WarehouseOutOrderNumber).Update(map[string]interface{}{"operation_time": warehouseOut.OperationTime, "mtime": warehouseOut.Mtime, "modifier": warehouseOut.Modifier}).Error
  589. return
  590. }
  591. func UpDateWarehouseInfo(warehouseInfo *models.WarehousingInfo) (err error) {
  592. err = readDb.Model(&models.WarehousingInfo{}).Where("warehousing_order = ? AND status = 1", warehouseInfo.WarehousingOrder).Update(map[string]interface{}{"good_type_id": warehouseInfo.GoodTypeId,
  593. "good_id": warehouseInfo.GoodId,
  594. "number": warehouseInfo.Number,
  595. "product_date": warehouseInfo.ProductDate,
  596. "expiry_date": warehouseInfo.ExpiryDate,
  597. "warehousing_count": warehouseInfo.WarehousingCount,
  598. "price": warehouseInfo.Price,
  599. "total_price": warehouseInfo.TotalPrice,
  600. "mtime": warehouseInfo.Mtime,
  601. "remark": warehouseInfo.Remark,
  602. }).Error
  603. return
  604. }
  605. func UpDateWarehouseStatus(id int64) (err error) {
  606. err = readDb.Model(&models.WarehousingInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  607. return
  608. }
  609. func DeleteWarehouse(ids []string) (err error) {
  610. ut := writeDb.Begin()
  611. err = ut.Model(&models.Warehousing{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  612. if err != nil {
  613. ut.Rollback()
  614. return
  615. }
  616. err = ut.Model(&models.WarehousingInfo{}).Where("warehousing_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  617. if err != nil {
  618. ut.Rollback()
  619. return
  620. }
  621. ut.Commit()
  622. return
  623. }
  624. func FindWareHouseById(orderNumber string) (*models.Warehousing, error) {
  625. warehouse := &models.Warehousing{}
  626. err := readDb.Model(&models.Warehousing{}).Where("warehousing_order = ? AND status = 1", orderNumber).First(&warehouse).Error
  627. return warehouse, err
  628. }
  629. func FindWareHouseOutById(id int64) (*models.WarehouseOut, error) {
  630. warehouseOut := &models.WarehouseOut{}
  631. err := readDb.Model(&models.WarehouseOut{}).Where("id = ? AND status = 1", id).First(&warehouseOut).Error
  632. return warehouseOut, err
  633. }
  634. func FindWarehouseInfoByOrderNumber(orderNumber string) (info []*models.WarehousingInfo, err error) {
  635. err = readDb.Model(&models.WarehousingInfo{}).Where("warehousing_order = ? AND status = 1", orderNumber).Find(&info).Error
  636. return
  637. }
  638. func FindWarehouseOutInfoByOrderNumber(orderNumber string) (info []*models.WarehouseOutInfo, err error) {
  639. err = readDb.Model(&models.WarehouseOutInfo{}).Where("warehouse_out_order_number = ? AND status = 1", orderNumber).Find(&info).Error
  640. return
  641. }
  642. func DeleteStockInRecordByOrderNumber(orderNumber string, id int64) (err error) {
  643. err = readDb.Model(&models.WarehousingInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  644. err = readDb.Model(&models.Warehousing{}).Where("warehousing_order = ? AND status = 1", orderNumber).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  645. return
  646. }
  647. func DeleteStockInRecordByReocordId(id int64) (err error) {
  648. err = readDb.Model(&models.WarehousingInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  649. return
  650. }
  651. func FindAllGoodByManufactureId(manufacturer_id int64, dealer_id int64, org_id int64) (goodInfo []*models.GoodInfo, err error) {
  652. db := readDb.Model(&models.GoodInfo{}).Where("org_id = ? AND status = 1", org_id)
  653. if manufacturer_id > 0 {
  654. db = db.Where("manufacturer = ?", manufacturer_id)
  655. }
  656. if dealer_id > 0 {
  657. db = db.Where("dealer = ?", dealer_id)
  658. }
  659. err = db.Preload("GoodsType", "status = 1 AND org_id = ?", org_id).Find(&goodInfo).Error
  660. return goodInfo, err
  661. }
  662. func FindAllWarehouseByKeyword(orgId int64, page int64, limit int64, keywords string) (list []*models.Warehousing, total int64, err error) {
  663. db := readDb.Model(&models.Warehousing{})
  664. likekey := "%" + keywords + "%"
  665. db = db.Where("org_id = ? AND status = 1 ", orgId)
  666. db = db.Where("warehousing_order LIKE ? ", likekey)
  667. db = db.Count(&total)
  668. offset := (page - 1) * limit
  669. err = db.Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  670. return
  671. }
  672. func UpDateWarehousingInfo(info *models.WarehousingInfo) (err error) {
  673. err = writeDb.Save(&info).Error
  674. return err
  675. }
  676. func EditWarehousing(warehouse models.Warehousing) {
  677. err = readDb.Model(&models.Warehousing{}).Where("warehousing_order = ? AND status = 1", warehouse.WarehousingOrder).Update(map[string]interface{}{"mtime": time.Now().Unix(), "warehousing_time": warehouse.WarehousingTime, "modifier": warehouse.Modifier, "dealer": warehouse.Dealer, "manufacturer": warehouse.Manufacturer}).Error
  678. }
  679. func FindAllWarehouse(org_id int64, types int64) (list []*models.Warehousing, err error) {
  680. err = readDb.Model(&models.Warehousing{}).Preload("Manufacturers", "status = 1 AND org_id = ?", org_id).Preload("Dealers", "status = 1 AND org_id = ? ", org_id).Where("org_id = ? AND status = 1 AND type = ?", org_id, types).Find(&list).Error
  681. return list, err
  682. }
  683. func FindAllWarehouseInfo(org_id int64, types int64) (list []*models.WarehousingInfoConfig, err error) {
  684. err = readDb.Model(&models.WarehousingInfoConfig{}).Preload("WarehousingGoodInfo", func(db *gorm.DB) *gorm.DB {
  685. return db.Where("status = 1 AND org_id = ?", org_id).Preload("GoodsType", "status = 1 AND org_id = ?", org_id).Preload("Manufacturers", "status = 1 AND org_id = ?", org_id).Preload("Dealers", "status = 1 AND org_id = ?", org_id)
  686. }).Where("org_id = ? AND status = 1 AND type = ?", org_id, types).Find(&list).Error
  687. return list, err
  688. }
  689. func DeleteSalesReturn(ids []string) (err error) {
  690. ut := writeDb.Begin()
  691. err = ut.Model(&models.SalesReturn{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  692. if err != nil {
  693. ut.Rollback()
  694. return
  695. }
  696. err = ut.Model(&models.SalesReturnInfo{}).Where("sales_return_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  697. if err != nil {
  698. ut.Rollback()
  699. return
  700. }
  701. ut.Commit()
  702. return
  703. }
  704. func FindAllSalesReturnInfoById(id int64) (list []*models.SalesReturnInfo, err error) {
  705. err = readDb.Model(&models.SalesReturnInfo{}).Where("sales_return_id = ? AND status = 1", id).Find(&list).Error
  706. return
  707. }
  708. func FindAllSalesReturnById(id int64) (salesReturn models.SalesReturn, err error) {
  709. err = readDb.Model(&models.SalesReturnInfo{}).Where("id = ? AND status = 1", id).First(&salesReturn).Error
  710. return
  711. }
  712. func UpDateSaleReturnStatus(id int64) (err error) {
  713. err = readDb.Model(&models.SalesReturnInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  714. return
  715. }
  716. func FindSalesReturnById(id int64) (salesReturn models.SalesReturn, err error) {
  717. err = readDb.Model(&models.SalesReturn{}).Where("id = ? AND status = 1", id).First(&salesReturn).Error
  718. return salesReturn, err
  719. }
  720. func EditSaleReturn(sales models.SalesReturn) {
  721. err = readDb.Model(&models.SalesReturn{}).Where("id = ? AND status = 1", sales.ID).Update(map[string]interface{}{"mtime": time.Now().Unix(), "return_time": sales.ReturnTime, "dealer": sales.Dealer, "manufacturer": sales.Manufacturer}).Error
  722. }
  723. func UpDateSalesReturnInfo(info *models.SalesReturnInfo) (err error) {
  724. err = writeDb.Save(&info).Error
  725. return err
  726. }
  727. func DeleteWarehouseOut(ids []string) (err error) {
  728. ut := writeDb.Begin()
  729. err = ut.Model(&models.WarehouseOut{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  730. if err != nil {
  731. ut.Rollback()
  732. return
  733. }
  734. err = ut.Model(&models.WarehouseOutInfo{}).Where("warehouse_out_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  735. if err != nil {
  736. ut.Rollback()
  737. return
  738. }
  739. ut.Commit()
  740. return
  741. }
  742. func UpDateWarehouseOutStatus(id int64) (err error) {
  743. err = readDb.Model(&models.WarehouseOutInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  744. return
  745. }
  746. func EditWarehouseOut(warehouseOut models.WarehouseOut) {
  747. err = readDb.Model(&models.WarehouseOut{}).Where("id = ? AND status = 1", warehouseOut.ID).Update(map[string]interface{}{"mtime": time.Now().Unix(), "warehouse_out_time": warehouseOut.WarehouseOutTime, "dealer": warehouseOut.Dealer, "manufacturer": warehouseOut.Manufacturer}).Error
  748. }
  749. func UpDateWarehouseOutInfo(info *models.WarehouseOutInfo) (err error) {
  750. err = writeDb.Save(&info).Error
  751. return err
  752. }
  753. func FindAllCancelList(orgId int64, page int64, limit int64, startTime int64, endTime int64, types int64, keywords string) (list []*models.CancelStock, total int64, err error) {
  754. db := readDb.Model(&models.CancelStock{})
  755. db = db.Where("xt_cancel_stock.org_id = ? AND xt_cancel_stock.status = 1 AND xt_cancel_stock.type = ?", orgId, types)
  756. if len(keywords) > 0 {
  757. likeKey := "%" + keywords + "%"
  758. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_cancel_stock.creater")
  759. db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_cancel_stock.manufacturer")
  760. db = db.Where("xt_manufacturer.manufacturer_name LIKE ? OR sgj_user_admin_role.user_name LIKE ? OR xt_cancel_stock.order_number LIKE ?", likeKey, likeKey, likeKey).Group("xt_cancel_stock.id")
  761. }
  762. if startTime > 0 {
  763. db = db.Where("xt_cancel_stock.opera_time >=?", startTime)
  764. }
  765. if endTime > 0 {
  766. db = db.Where("xt_cancel_stock.opera_time<= ?", endTime)
  767. }
  768. db = db.Count(&total)
  769. offset := (page - 1) * limit
  770. err = db.Offset(offset).Limit(limit).Order("xt_cancel_stock.ctime desc").Find(&list).Error
  771. return
  772. }
  773. func DeleteCancelStock(ids []string) (err error) {
  774. ut := writeDb.Begin()
  775. err = ut.Model(&models.CancelStock{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  776. if err != nil {
  777. ut.Rollback()
  778. return
  779. }
  780. err = ut.Model(&models.CancelStockInfo{}).Where("cancel_stock_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  781. if err != nil {
  782. ut.Rollback()
  783. return
  784. }
  785. ut.Commit()
  786. return
  787. }
  788. func UpDateCancleStockStatus(id int64) (err error) {
  789. err = readDb.Model(&models.CancelStockInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  790. return
  791. }
  792. func EditCancelStock(sales models.CancelStock) {
  793. err = readDb.Model(&models.CancelStock{}).Where("id = ? AND status = 1", sales.ID).Update(map[string]interface{}{"mtime": time.Now().Unix(), "return_time": sales.ReturnTime, "dealer": sales.Dealer, "manufacturer": sales.Manufacturer}).Error
  794. }
  795. func FindCancelStockById(id int64) (cancelStock models.CancelStock, err error) {
  796. err = readDb.Model(&models.CancelStock{}).Where("id = ? AND status = 1", id).First(&cancelStock).Error
  797. return cancelStock, err
  798. }
  799. func UpDateCancelStockInfo(info *models.CancelStockInfo) (err error) {
  800. err = writeDb.Save(&info).Error
  801. return err
  802. }
  803. func FindWarehouseOutList(org_id int64, types int64) (list []*models.WarehouseOut, err error) {
  804. err = readDb.Model(&models.WarehouseOut{}).Preload("Manufacturers", "status = 1 AND org_id = ?", org_id).Preload("Dealers", "status = 1 AND org_id = ? ", org_id).Where("org_id = ? AND status = 1 AND type = ?", org_id, types).Find(&list).Error
  805. return list, err
  806. }
  807. func FindAllWarehouseOutInfo(org_id int64, types int64) (list []*models.WarehousingOutInfoConfig, err error) {
  808. err = readDb.Model(&models.WarehousingOutInfoConfig{}).Preload("WarehousingGoodInfo", func(db *gorm.DB) *gorm.DB {
  809. return db.Where("status = 1 AND org_id = ?", org_id).Preload("GoodsType", "status = 1 AND org_id = ? ", org_id).Preload("Manufacturers", "status = 1 AND org_id = ?", org_id).Preload("Dealers", "status = 1 AND org_id = ?", org_id)
  810. }).Where("org_id = ? AND status = 1 AND type = ?", org_id, types).Find(&list).Error
  811. return list, err
  812. }
  813. type StockDetailModel struct {
  814. GoodId int64 `gorm:"good_id" json:"good_id"`
  815. GoodTypeId int64 `gorm:"good_type_id" json:"good_type_id"`
  816. WarehousingOrder string `gorm:"warehousing_order" json:"warehousing_order"`
  817. Price float64 `gorm:"price" json:"price"`
  818. WarehousingCount int64 `gorm:"warehousing_count" json:"warehousing_count"`
  819. Type int `gorm:"type" json:"type"`
  820. Creater int64 `gorm:"creater" json:"creater"`
  821. WarehousingTime int64 `gorm:"warehousing_time" json:"warehousing_time"`
  822. Types int64 `gorm:"types" json:"types"`
  823. }
  824. func FindStockInDetailList(orgId int64, page int64, limit int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (list []*models.WarehousingInfo, total int64, err error) {
  825. db := readDb.Model(&models.WarehousingInfo{})
  826. db = db.Where("xt_warehouse_info.org_id = ? AND xt_warehouse_info.status = 1", orgId)
  827. if len(keywords) > 0 {
  828. likeKey := "%" + keywords + "%"
  829. //db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND ")
  830. db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND xt_warehouse.warehousing_time >=? AND xt_warehouse.warehousing_time<= ? AND xt_warehouse.status = 1 AND xt_warehouse.org_id = ?", startTime, endTime, orgId)
  831. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse.creater")
  832. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_info.good_id")
  833. //db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_warehouse.manufacturer")
  834. //db = db.Where(" sgj_user_admin_role.user_name LIKE ?", likeKey).Group("xt_warehouse_info.id")
  835. db = db.Where(" sgj_user_admin_role.user_name LIKE ? OR xt_warehouse_info.warehousing_order LIKE ? OR xt_good_information.specification_name LIKE ?", likeKey, likeKey, likeKey).Group("xt_warehouse_info.id")
  836. } else {
  837. db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND xt_warehouse.warehousing_time >=? AND xt_warehouse.warehousing_time<= ? AND xt_warehouse.status = 1 AND xt_warehouse.org_id = ?", startTime, endTime, orgId)
  838. }
  839. if manufacturer > 0 {
  840. db = db.Joins("join xt_warehouse as wa on wa.id = xt_warehouse_info.warehousing_id AND wa.manufacturer =?", manufacturer)
  841. }
  842. if order_type > 0 {
  843. db = db.Where("xt_warehouse_info.type = ?", order_type)
  844. }
  845. db = db.Preload("Warehousing", "status = 1 AND org_id = ?", orgId)
  846. db = db.Count(&total)
  847. offset := (page - 1) * limit
  848. err = db.Offset(offset).Limit(limit).Order("xt_warehouse_info.ctime desc").Find(&list).Error
  849. return
  850. }
  851. func GetStockInDetailTotal(orgId int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (err error, totalPrice float64) {
  852. db := readDb.Model(&models.WarehousingInfo{})
  853. db = db.Where("xt_warehouse_info.org_id = ? AND xt_warehouse_info.status = 1", orgId)
  854. if len(keywords) > 0 {
  855. likeKey := "%" + keywords + "%"
  856. //db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND ")
  857. db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND xt_warehouse.warehousing_time >=? AND xt_warehouse.warehousing_time<= ? AND xt_warehouse.status = 1 AND xt_warehouse.org_id = ?", startTime, endTime, orgId)
  858. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse.creater")
  859. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_info.good_id")
  860. db = db.Where("sgj_user_admin_role.user_name LIKE ? OR xt_warehouse_info.warehousing_order LIKE ? OR xt_good_information.specification_name LIKE ?", likeKey, likeKey, likeKey).Group("xt_warehouse_info.id")
  861. } else {
  862. db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND xt_warehouse.warehousing_time >=? AND xt_warehouse.warehousing_time<= ? AND xt_warehouse.status = 1 AND xt_warehouse.org_id = ?", startTime, endTime, orgId)
  863. }
  864. if manufacturer > 0 {
  865. db = db.Joins("join xt_warehouse as wa on wa.id = xt_warehouse_info.warehousing_id AND wa.manufacturer =?", manufacturer)
  866. }
  867. if order_type > 0 {
  868. db = db.Where("xt_warehouse_info.type = ?", order_type)
  869. }
  870. type PriceAmount struct {
  871. Total float64
  872. }
  873. var result []PriceAmount
  874. err = db.Select("total_price as total").Scan(&result).Error
  875. var total float64
  876. for _, value := range result {
  877. total = total + value.Total
  878. }
  879. total, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", total), 64)
  880. return err, total
  881. }
  882. func FloatRound(f float64, n int) float64 {
  883. format := "%." + strconv.Itoa(n) + "f"
  884. res, _ := strconv.ParseFloat(fmt.Sprintf(format, f), 64)
  885. return res
  886. }
  887. func FindStockOutDetailList(orgId int64, page int64, limit int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (list []*models.WarehouseOutInfo, total int64, err error) {
  888. db := readDb.Model(&models.WarehouseOutInfo{})
  889. db = db.Where("xt_warehouse_out_info.org_id = ? AND xt_warehouse_out_info.status = 1 AND xt_warehouse_out_info.good_id <> 0 AND xt_warehouse_out_info.count <> 0 ", orgId)
  890. if len(keywords) > 0 {
  891. likeKey := "%" + keywords + "%"
  892. db = db.Joins("join xt_warehouse_out on xt_warehouse_out.id = xt_warehouse_out_info.warehouse_out_id AND xt_warehouse_out.warehouse_out_time >=? AND xt_warehouse_out.warehouse_out_time<= ? AND xt_warehouse_out.status = 1 AND xt_warehouse_out.org_id = ?", startTime, endTime, orgId)
  893. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse_out.creater")
  894. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_out_info.good_id")
  895. db = db.Where("sgj_user_admin_role.user_name LIKE ? OR xt_warehouse_out_info.warehouse_out_order_number LIKE ? OR xt_good_information.specification_name LIKE ?", likeKey, likeKey, likeKey).Group("xt_warehouse_out_info.id")
  896. } else {
  897. db = db.Joins("join xt_warehouse_out on xt_warehouse_out.id = xt_warehouse_out_info.warehouse_out_id AND xt_warehouse_out.warehouse_out_time >=? AND xt_warehouse_out.warehouse_out_time<= ? AND xt_warehouse_out.status = 1 AND xt_warehouse_out.org_id = ?", startTime, endTime, orgId)
  898. }
  899. if manufacturer > 0 {
  900. db = db.Joins("join xt_warehouse_out as wa on wa.id = xt_warehouse_out_info.warehouse_out_id AND wa.manufacturer =?", manufacturer)
  901. }
  902. if order_type > 0 {
  903. db = db.Where("xt_warehouse_out_info.type = ?", order_type)
  904. }
  905. db = db.Preload("WarehouseOut", "status = 1 AND org_id = ?", orgId)
  906. db = db.Count(&total)
  907. offset := (page - 1) * limit
  908. err = db.Offset(offset).Limit(limit).Order("xt_warehouse_out_info.ctime desc").Find(&list).Error
  909. return
  910. }
  911. func GetStockOutDetailTotal(orgId int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (err error, totalPrice float64) {
  912. db := readDb.Model(&models.WarehouseOutInfo{})
  913. db = db.Where("xt_warehouse_out_info.org_id = ? AND xt_warehouse_out_info.status = 1 AND xt_warehouse_out_info.good_id <> 0 AND xt_warehouse_out_info.count <> 0", orgId)
  914. if len(keywords) > 0 {
  915. likeKey := "%" + keywords + "%"
  916. db = db.Joins("join xt_warehouse_out on xt_warehouse_out.id = xt_warehouse_out_info.warehouse_out_id AND xt_warehouse_out.warehouse_out_time >=? AND xt_warehouse_out.warehouse_out_time<= ? AND xt_warehouse_out.status = 1 AND xt_warehouse_out.org_id = ?", startTime, endTime, orgId)
  917. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse_out.creater")
  918. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_out_info.good_id")
  919. db = db.Where("sgj_user_admin_role.user_name LIKE ? OR xt_warehouse_out_info.warehouse_out_order_number LIKE ?", likeKey, likeKey).Group("xt_warehouse_out_info.id")
  920. } else {
  921. db = db.Joins("join xt_warehouse_out on xt_warehouse_out.id = xt_warehouse_out_info.warehouse_out_id AND xt_warehouse_out.warehouse_out_time >=? AND xt_warehouse_out.warehouse_out_time<= ? AND xt_warehouse_out.status = 1 AND xt_warehouse_out.org_id = ?", startTime, endTime, orgId)
  922. }
  923. if manufacturer > 0 {
  924. db = db.Joins("join xt_warehouse_out as wa on wa.id = xt_warehouse_out_info.warehouse_out_id AND wa.manufacturer =?", manufacturer)
  925. }
  926. if order_type > 0 {
  927. db = db.Where("xt_warehouse_out_info.type = ?", order_type)
  928. }
  929. type PriceAmount struct {
  930. Total float64
  931. }
  932. var result []PriceAmount
  933. err = db.Select("(count * price) as total").Scan(&result).Error
  934. var total float64
  935. for _, value := range result {
  936. total = total + value.Total
  937. }
  938. total, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", total), 64)
  939. fmt.Println(total)
  940. return err, total
  941. }
  942. func FindSalesReturnDetailList(orgId int64, page int64, limit int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (list []*models.SalesReturnInfo, total int64, err error) {
  943. db := readDb.Model(&models.SalesReturnInfo{})
  944. db = db.Where("xt_sales_return_info.org_id = ? AND xt_sales_return_info.status = 1", orgId)
  945. if len(keywords) > 0 {
  946. likeKey := "%" + keywords + "%"
  947. db = db.Joins("join xt_sales_return on xt_sales_return.id = xt_sales_return_info.sales_return_id AND xt_sales_return.return_time >=? AND xt_sales_return.return_time<= ? AND xt_sales_return.status = 1 AND xt_sales_return.org_id = ?", startTime, endTime, orgId)
  948. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_sales_return.creater")
  949. db = db.Joins("join xt_good_information on xt_good_information.id = xt_sales_return_info.good_id")
  950. db = db.Where("sgj_user_admin_role.user_name LIKE ? OR xt_sales_return_info.order_number LIKE ? OR xt_good_information.specification_name LIKE ?", likeKey, likeKey, likeKey).Group("xt_sales_return_info.id")
  951. } else {
  952. db = db.Joins("join xt_sales_return on xt_sales_return.id = xt_sales_return_info.sales_return_id AND xt_sales_return.return_time >=? AND xt_sales_return.return_time<= ? AND xt_sales_return.status = 1 AND xt_sales_return.org_id = ?", startTime, endTime, orgId)
  953. }
  954. if manufacturer > 0 {
  955. db = db.Joins("join xt_sales_return as sr on sr.id = xt_sales_return_info.sales_return_id AND sr.manufacturer =?", manufacturer)
  956. }
  957. if order_type > 0 {
  958. db = db.Where("xt_sales_return_info.type = ?", order_type)
  959. }
  960. db = db.Preload("SalesReturn", "status = 1 AND org_id = ?", orgId)
  961. offset := (page - 1) * limit
  962. db = db.Count(&total)
  963. err = db.Offset(offset).Limit(limit).Order("xt_sales_return_info.ctime desc").Find(&list).Error
  964. return
  965. }
  966. func FindCancelDetailList(orgId int64, page int64, limit int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (list []*models.CancelStockInfo, total int64, err error) {
  967. db := readDb.Model(&models.CancelStockInfo{})
  968. db = db.Where("xt_cancel_stock_info.org_id = ? AND xt_cancel_stock_info.status = 1", orgId)
  969. if len(keywords) > 0 {
  970. likeKey := "%" + keywords + "%"
  971. db = db.Joins("join xt_cancel_stock on xt_cancel_stock.id = xt_cancel_stock_info.cancel_stock_id AND xt_cancel_stock.return_time >=? AND xt_cancel_stock.return_time<= ? AND xt_cancel_stock.status = 1 AND xt_cancel_stock.org_id = ?", startTime, endTime, orgId)
  972. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_cancel_stock.creater")
  973. db = db.Joins("join xt_good_information on xt_good_information.id = xt_cancel_stock_info.good_id")
  974. db = db.Where("sgj_user_admin_role.user_name LIKE ? OR xt_cancel_stock_info.order_number LIKE ? OR xt_good_information.specification_name LIKE ?", likeKey, likeKey, likeKey).Group("xt_cancel_stock_info.id")
  975. } else {
  976. db = db.Joins("join xt_cancel_stock on xt_cancel_stock.id = xt_cancel_stock_info.cancel_stock_id AND xt_cancel_stock.return_time >=? AND xt_cancel_stock.return_time<= ? ", startTime, endTime)
  977. }
  978. if manufacturer > 0 {
  979. db = db.Joins("join xt_cancel_stock as cs on cs.id = xt_cancel_stock_info.cancel_stock_id AND cs.manufacturer =?", manufacturer)
  980. }
  981. if order_type > 0 {
  982. db = db.Where("xt_cancel_stock_info.type = ?", order_type)
  983. }
  984. db = db.Preload("CancelStock", "status = 1 AND org_id = ?", orgId)
  985. db = db.Count(&total)
  986. offset := (page - 1) * limit
  987. err = db.Offset(offset).Limit(limit).Order("xt_cancel_stock_info.ctime desc").Find(&list).Error
  988. return
  989. }
  990. func FindStockInByDealerId(id int64) (total int64, err error) {
  991. err = readDb.Model(&models.Warehousing{}).Where("dealer = ? AND status = 1", id).Count(&total).Error
  992. return
  993. }
  994. func FindStockInByManufacturerId(id int64) (total int64, err error) {
  995. err = readDb.Model(&models.Warehousing{}).Where("manufacturer = ? AND status = 1", id).Count(&total).Error
  996. return
  997. }
  998. func FindGoodTypeByName(name string, org_id int64) (total int64) {
  999. readDb.Model(&models.GoodsType{}).Where("org_id = ? AND status = 1 AND type_name = ? ", org_id, name).Count(&total)
  1000. return
  1001. }
  1002. func FindGoodInfoByName(name string, org_id int64) (total int64) {
  1003. readDb.Model(&models.GoodInfo{}).Where("org_id = ? AND status = 1 AND specification_name = ? ", org_id, name).Count(&total)
  1004. return
  1005. }
  1006. func FindAllGoodTypeByType(types int64) (goodType []*models.GoodsType, err error) {
  1007. err = readDb.Model(&models.GoodsType{}).Where("type = ? AND status = 1", types).Find(&goodType).Error
  1008. return goodType, err
  1009. }
  1010. func FindWarehouseInfoByGoodType(good_type_id int64, org_id int64) (info []*models.WarehousingInfo, err error) {
  1011. err = readDb.Model(&models.WarehousingInfo{}).Preload("GoodInfo", " org_id = ? AND good_type_id = ? AND status = 1 AND specification_name <> '' ", org_id, good_type_id).Where(" org_id = ? AND good_type_id = ? AND status = 1 ", org_id, good_type_id).Find(&info).Error
  1012. return info, err
  1013. }
  1014. func FindStockOutByIsSys(org_id int64, is_sys int, record_time int64) (out models.WarehouseOut, err error) {
  1015. err = readDb.Model(&models.WarehouseOut{}).Where("is_sys = ? AND status = 1 AND org_id = ? AND warehouse_out_time = ?", is_sys, org_id, record_time).First(&out).Error
  1016. return
  1017. }
  1018. func FindLastStockInInfoRecord(good_id int64, org_id int64) (in models.WarehousingInfo, err error) {
  1019. err = readDb.Model(&models.WarehousingInfo{}).Where("status = 1 AND org_id = ? AND good_id = ?", org_id, good_id).Last(&in).Error
  1020. return
  1021. }
  1022. func AddSigleWarehouseOutInfo(info *models.WarehouseOutInfo) error {
  1023. err := writeDb.Create(&info).Error
  1024. return err
  1025. }
  1026. func AddSigleAutoReduceRecordInfo(detail *models.AutomaticReduceDetail) error {
  1027. err := writeDb.Create(&detail).Error
  1028. return err
  1029. }
  1030. func FindStockOutInfoByTypeId(org_id int64, good_type_id int64, good_id int64, out_id int64, number string) (out models.WarehouseOutInfo, err error) {
  1031. err = readDb.Model(&models.WarehouseOutInfo{}).Where("status = 1 AND org_id = ? AND good_type_id = ? AND good_id = ? AND is_sys = 1 AND (warehouse_out_id = ? or warehouse_out_order_number = ?)", org_id, good_type_id, good_id, out_id, number).First(&out).Error
  1032. return
  1033. }
  1034. func UpdateStockOutInfoCount(org_id int64, id int64) {
  1035. writeDb.Model(&models.WarehouseOutInfo{}).Where("status = 1 AND org_id = ? AND id = ?", org_id, id).UpdateColumn("count", gorm.Expr("count + ?", 1))
  1036. }
  1037. func FindUserDetailById(org_id int64, id int64) (user []*models.AutomaticReduceDetail, err error, total int64) {
  1038. db := readDb.Model(&models.AutomaticReduceDetail{})
  1039. db = db.Preload("GoodInfo", "org_id = ? AND status = 1", org_id)
  1040. db = db.Preload("GoodsType", "status = 1")
  1041. db = db.Preload("Patients", "user_org_id = ? AND status = 1", org_id)
  1042. db = db.Where("status = 1 AND org_id = ? AND warehouse_out_id = ? AND good_id != 0", org_id, id)
  1043. db = db.Count(&total)
  1044. err = db.Find(&user).Error
  1045. return
  1046. }
  1047. func UpdateStockOutInfoCount2(org_id int64, id int64, count int64) {
  1048. writeDb.Model(&models.WarehouseOutInfo{}).Where("status = 1 AND org_id = ? AND id = ?", org_id, id).UpdateColumn("count", gorm.Expr("count + ?", count))
  1049. }
  1050. type VMWarehousingInfo struct {
  1051. ID int64 `gorm:"column:id" json:"id"`
  1052. WarehousingId int64 `gorm:"column:warehousing_id" json:"warehousing_id"`
  1053. GoodId int64 `gorm:"column:good_id" json:"good_id"`
  1054. GoodTypeId int64 `gorm:"column:good_type_id" json:"good_type_id"`
  1055. Status int64 `gorm:"column:status" json:"status"`
  1056. OrgId int64 `gorm:"column:org_id" json:"org_id"`
  1057. GoodInfo GoodInfo `gorm:"ForeignKey:GoodId;AssociationForeignKey:ID" json:"good_info"`
  1058. }
  1059. func (VMWarehousingInfo) TableName() string {
  1060. return "xt_warehouse_info"
  1061. }
  1062. type GoodInfo struct {
  1063. ID int64 `gorm:"column:id" json:"id"`
  1064. SpecificationName string `gorm:"column:specification_name" json:"specification_name"`
  1065. Status int64 `gorm:"column:status" json:"status"`
  1066. OrgId int64 `gorm:"column:org_id" json:"org_id"`
  1067. }
  1068. func (GoodInfo) TableName() string {
  1069. return "xt_good_information"
  1070. }
  1071. func GetStockInGoodInfo(orgId int64) (stockIn []*VMWarehousingInfo, err error) {
  1072. err = readDb.Model(&VMWarehousingInfo{}).Preload("GoodInfo", "status = 1 AND org_id = ?", orgId).Where("org_id = ? AND status = 1", orgId).Find(&stockIn).Error
  1073. return
  1074. }
  1075. func GetAllStockOutUserDetail(patient_id int64, orgId int64, record_time int64) (goodUser []*models.DialysisBeforePrepare, err error) {
  1076. err = readDb.Model(&models.DialysisBeforePrepare{}).Where("patient_id = ? AND user_org_id = ? AND record_date = ? AND status = 1", patient_id, orgId, record_time).Find(&goodUser).Error
  1077. return
  1078. }