stock_service.go 55KB

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