stock_service.go 54KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238
  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) OR (type = 1 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("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) OR (type = 1 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.Joins("JOIN xt_warehouse_info AS info ON info.good_id=xt_good_information.id AND info.status = 1").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) OR (status = 1 AND type = 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) OR (xt_goods_type.type = 1 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 UpDateWarehouse(warehouse *models.Warehousing) (err error) {
  576. 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
  577. return
  578. }
  579. func UpDateWarehouseOut(warehouseOut *models.WarehouseOut) (err error) {
  580. 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
  581. return
  582. }
  583. func UpDateWarehouseInfo(warehouseInfo *models.WarehousingInfo) (err error) {
  584. err = readDb.Model(&models.WarehousingInfo{}).Where("warehousing_order = ? AND status = 1", warehouseInfo.WarehousingOrder).Update(map[string]interface{}{"good_type_id": warehouseInfo.GoodTypeId,
  585. "good_id": warehouseInfo.GoodId,
  586. "number": warehouseInfo.Number,
  587. "product_date": warehouseInfo.ProductDate,
  588. "expiry_date": warehouseInfo.ExpiryDate,
  589. "warehousing_count": warehouseInfo.WarehousingCount,
  590. "price": warehouseInfo.Price,
  591. "total_price": warehouseInfo.TotalPrice,
  592. "mtime": warehouseInfo.Mtime,
  593. "remark": warehouseInfo.Remark,
  594. }).Error
  595. return
  596. }
  597. func UpDateWarehouseStatus(id int64) (err error) {
  598. err = readDb.Model(&models.WarehousingInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  599. return
  600. }
  601. func DeleteWarehouse(ids []string) (err error) {
  602. ut := writeDb.Begin()
  603. err = ut.Model(&models.Warehousing{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  604. if err != nil {
  605. ut.Rollback()
  606. return
  607. }
  608. err = ut.Model(&models.WarehousingInfo{}).Where("warehousing_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  609. if err != nil {
  610. ut.Rollback()
  611. return
  612. }
  613. ut.Commit()
  614. return
  615. }
  616. func FindWareHouseById(orderNumber string) (*models.Warehousing, error) {
  617. warehouse := &models.Warehousing{}
  618. err := readDb.Model(&models.Warehousing{}).Where("warehousing_order = ? AND status = 1", orderNumber).First(&warehouse).Error
  619. return warehouse, err
  620. }
  621. func FindWareHouseOutById(id int64) (*models.WarehouseOut, error) {
  622. warehouseOut := &models.WarehouseOut{}
  623. err := readDb.Model(&models.WarehouseOut{}).Where("id = ? AND status = 1", id).First(&warehouseOut).Error
  624. return warehouseOut, err
  625. }
  626. func FindWarehouseInfoByOrderNumber(orderNumber string) (info []*models.WarehousingInfo, err error) {
  627. err = readDb.Model(&models.WarehousingInfo{}).Where("warehousing_order = ? AND status = 1", orderNumber).Find(&info).Error
  628. return
  629. }
  630. func FindWarehouseOutInfoByOrderNumber(orderNumber string) (info []*models.WarehouseOutInfo, err error) {
  631. err = readDb.Model(&models.WarehouseOutInfo{}).Where("warehouse_out_order_number = ? AND status = 1", orderNumber).Find(&info).Error
  632. return
  633. }
  634. func DeleteStockInRecordByOrderNumber(orderNumber string, id int64) (err error) {
  635. err = readDb.Model(&models.WarehousingInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  636. err = readDb.Model(&models.Warehousing{}).Where("warehousing_order = ? AND status = 1", orderNumber).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  637. return
  638. }
  639. func DeleteStockInRecordByReocordId(id int64) (err error) {
  640. err = readDb.Model(&models.WarehousingInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  641. return
  642. }
  643. func FindAllGoodByManufactureId(manufacturer_id int64, dealer_id int64, org_id int64) (goodInfo []*models.GoodInfo, err error) {
  644. db := readDb.Model(&models.GoodInfo{}).Where("org_id = ? AND status = 1", org_id)
  645. if manufacturer_id > 0 {
  646. db = db.Where("manufacturer = ?", manufacturer_id)
  647. }
  648. if dealer_id > 0 {
  649. db = db.Where("dealer = ?", dealer_id)
  650. }
  651. err = db.Preload("GoodsType", "status = 1 AND (org_id = ? OR type = 1)", org_id).Find(&goodInfo).Error
  652. return goodInfo, err
  653. }
  654. func FindAllWarehouseByKeyword(orgId int64, page int64, limit int64, keywords string) (list []*models.Warehousing, total int64, err error) {
  655. db := readDb.Model(&models.Warehousing{})
  656. likekey := "%" + keywords + "%"
  657. db = db.Where("org_id = ? AND status = 1 ", orgId)
  658. db = db.Where("warehousing_order LIKE ? ", likekey)
  659. db = db.Count(&total)
  660. offset := (page - 1) * limit
  661. err = db.Offset(offset).Limit(limit).Order("ctime desc").Find(&list).Error
  662. return
  663. }
  664. func UpDateWarehousingInfo(info *models.WarehousingInfo) (err error) {
  665. err = writeDb.Save(&info).Error
  666. return err
  667. }
  668. func EditWarehousing(warehouse models.Warehousing) {
  669. 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
  670. }
  671. func FindAllWarehouse(org_id int64, types int64) (list []*models.Warehousing, err error) {
  672. 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
  673. return list, err
  674. }
  675. func FindAllWarehouseInfo(org_id int64, types int64) (list []*models.WarehousingInfoConfig, err error) {
  676. err = readDb.Model(&models.WarehousingInfoConfig{}).Preload("WarehousingGoodInfo", func(db *gorm.DB) *gorm.DB {
  677. return db.Where("status = 1 AND org_id = ?", org_id).Preload("GoodsType", "(status = 1 AND org_id = ?)OR(type = 1 AND status = 1)", org_id).Preload("Manufacturers", "status = 1 AND org_id = ?", org_id).Preload("Dealers", "status = 1 AND org_id = ?", org_id)
  678. }).Where("org_id = ? AND status = 1 AND type = ?", org_id, types).Find(&list).Error
  679. return list, err
  680. }
  681. func DeleteSalesReturn(ids []string) (err error) {
  682. ut := writeDb.Begin()
  683. err = ut.Model(&models.SalesReturn{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  684. if err != nil {
  685. ut.Rollback()
  686. return
  687. }
  688. err = ut.Model(&models.SalesReturnInfo{}).Where("sales_return_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  689. if err != nil {
  690. ut.Rollback()
  691. return
  692. }
  693. ut.Commit()
  694. return
  695. }
  696. func FindAllSalesReturnInfoById(id int64) (list []*models.SalesReturnInfo, err error) {
  697. err = readDb.Model(&models.SalesReturnInfo{}).Where("sales_return_id = ? AND status = 1", id).Find(&list).Error
  698. return
  699. }
  700. func FindAllSalesReturnById(id int64) (salesReturn models.SalesReturn, err error) {
  701. err = readDb.Model(&models.SalesReturnInfo{}).Where("id = ? AND status = 1", id).First(&salesReturn).Error
  702. return
  703. }
  704. func UpDateSaleReturnStatus(id int64) (err error) {
  705. err = readDb.Model(&models.SalesReturnInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  706. return
  707. }
  708. func FindSalesReturnById(id int64) (salesReturn models.SalesReturn, err error) {
  709. err = readDb.Model(&models.SalesReturn{}).Where("id = ? AND status = 1", id).First(&salesReturn).Error
  710. return salesReturn, err
  711. }
  712. func EditSaleReturn(sales models.SalesReturn) {
  713. 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
  714. }
  715. func UpDateSalesReturnInfo(info *models.SalesReturnInfo) (err error) {
  716. err = writeDb.Save(&info).Error
  717. return err
  718. }
  719. func DeleteWarehouseOut(ids []string) (err error) {
  720. ut := writeDb.Begin()
  721. err = ut.Model(&models.WarehouseOut{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  722. if err != nil {
  723. ut.Rollback()
  724. return
  725. }
  726. err = ut.Model(&models.WarehouseOutInfo{}).Where("warehouse_out_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  727. if err != nil {
  728. ut.Rollback()
  729. return
  730. }
  731. ut.Commit()
  732. return
  733. }
  734. func UpDateWarehouseOutStatus(id int64) (err error) {
  735. err = readDb.Model(&models.WarehouseOutInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  736. return
  737. }
  738. func EditWarehouseOut(warehouseOut models.WarehouseOut) {
  739. 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
  740. }
  741. func UpDateWarehouseOutInfo(info *models.WarehouseOutInfo) (err error) {
  742. err = writeDb.Save(&info).Error
  743. return err
  744. }
  745. func FindAllCancelList(orgId int64, page int64, limit int64, startTime int64, endTime int64, types int64, keywords string) (list []*models.CancelStock, total int64, err error) {
  746. db := readDb.Model(&models.CancelStock{})
  747. db = db.Where("xt_cancel_stock.org_id = ? AND xt_cancel_stock.status = 1 AND xt_cancel_stock.type = ?", orgId, types)
  748. if len(keywords) > 0 {
  749. likeKey := "%" + keywords + "%"
  750. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_cancel_stock.creater")
  751. db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_cancel_stock.manufacturer")
  752. 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")
  753. }
  754. if startTime > 0 {
  755. db = db.Where("xt_cancel_stock.opera_time >=?", startTime)
  756. }
  757. if endTime > 0 {
  758. db = db.Where("xt_cancel_stock.opera_time<= ?", endTime)
  759. }
  760. db = db.Count(&total)
  761. offset := (page - 1) * limit
  762. err = db.Offset(offset).Limit(limit).Order("xt_cancel_stock.ctime desc").Find(&list).Error
  763. return
  764. }
  765. func DeleteCancelStock(ids []string) (err error) {
  766. ut := writeDb.Begin()
  767. err = ut.Model(&models.CancelStock{}).Where("id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  768. if err != nil {
  769. ut.Rollback()
  770. return
  771. }
  772. err = ut.Model(&models.CancelStockInfo{}).Where("cancel_stock_id IN (?)", ids).Updates(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  773. if err != nil {
  774. ut.Rollback()
  775. return
  776. }
  777. ut.Commit()
  778. return
  779. }
  780. func UpDateCancleStockStatus(id int64) (err error) {
  781. err = readDb.Model(&models.CancelStockInfo{}).Where("id = ? AND status = 1", id).Update(map[string]interface{}{"status": 0, "mtime": time.Now().Unix()}).Error
  782. return
  783. }
  784. func EditCancelStock(sales models.CancelStock) {
  785. 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
  786. }
  787. func FindCancelStockById(id int64) (cancelStock models.CancelStock, err error) {
  788. err = readDb.Model(&models.CancelStock{}).Where("id = ? AND status = 1", id).First(&cancelStock).Error
  789. return cancelStock, err
  790. }
  791. func UpDateCancelStockInfo(info *models.CancelStockInfo) (err error) {
  792. err = writeDb.Save(&info).Error
  793. return err
  794. }
  795. func FindWarehouseOutList(org_id int64, types int64) (list []*models.WarehouseOut, err error) {
  796. 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
  797. return list, err
  798. }
  799. func FindAllWarehouseOutInfo(org_id int64, types int64) (list []*models.WarehousingOutInfoConfig, err error) {
  800. err = readDb.Model(&models.WarehousingOutInfoConfig{}).Preload("WarehousingGoodInfo", func(db *gorm.DB) *gorm.DB {
  801. return db.Where("status = 1 AND org_id = ?", org_id).Preload("GoodsType", "(status = 1 AND org_id = ?) OR (status = 1 AND type = 1) ", org_id).Preload("Manufacturers", "status = 1 AND org_id = ?", org_id).Preload("Dealers", "status = 1 AND org_id = ?", org_id)
  802. }).Where("org_id = ? AND status = 1 AND type = ?", org_id, types).Find(&list).Error
  803. return list, err
  804. }
  805. type StockDetailModel struct {
  806. GoodId int64 `gorm:"good_id" json:"good_id"`
  807. GoodTypeId int64 `gorm:"good_type_id" json:"good_type_id"`
  808. WarehousingOrder string `gorm:"warehousing_order" json:"warehousing_order"`
  809. Price float64 `gorm:"price" json:"price"`
  810. WarehousingCount int64 `gorm:"warehousing_count" json:"warehousing_count"`
  811. Type int `gorm:"type" json:"type"`
  812. Creater int64 `gorm:"creater" json:"creater"`
  813. WarehousingTime int64 `gorm:"warehousing_time" json:"warehousing_time"`
  814. Types int64 `gorm:"types" json:"types"`
  815. }
  816. 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) {
  817. db := readDb.Model(&models.WarehousingInfo{})
  818. db = db.Where("xt_warehouse_info.org_id = ? AND xt_warehouse_info.status = 1", orgId)
  819. if len(keywords) > 0 {
  820. likeKey := "%" + keywords + "%"
  821. //db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND ")
  822. 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)
  823. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse.creater")
  824. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_info.good_id")
  825. //db = db.Joins("join xt_manufacturer on xt_manufacturer.id = xt_warehouse.manufacturer")
  826. //db = db.Where(" sgj_user_admin_role.user_name LIKE ?", likeKey).Group("xt_warehouse_info.id")
  827. 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")
  828. } else {
  829. 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)
  830. }
  831. if manufacturer > 0 {
  832. db = db.Joins("join xt_warehouse as wa on wa.id = xt_warehouse_info.warehousing_id AND wa.manufacturer =?", manufacturer)
  833. }
  834. if order_type > 0 {
  835. db = db.Where("xt_warehouse_info.type = ?", order_type)
  836. }
  837. db = db.Preload("Warehousing", "status = 1 AND org_id = ?", orgId)
  838. db = db.Count(&total)
  839. offset := (page - 1) * limit
  840. err = db.Offset(offset).Limit(limit).Order("xt_warehouse_info.ctime desc").Find(&list).Error
  841. return
  842. }
  843. func GetStockInDetailTotal(orgId int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (err error, totalPrice float64) {
  844. db := readDb.Model(&models.WarehousingInfo{})
  845. db = db.Where("xt_warehouse_info.org_id = ? AND xt_warehouse_info.status = 1", orgId)
  846. if len(keywords) > 0 {
  847. likeKey := "%" + keywords + "%"
  848. //db = db.Joins("join xt_warehouse on xt_warehouse.id = xt_warehouse_info.warehousing_id AND ")
  849. 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)
  850. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse.creater")
  851. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_info.good_id")
  852. 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")
  853. } else {
  854. 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)
  855. }
  856. if manufacturer > 0 {
  857. db = db.Joins("join xt_warehouse as wa on wa.id = xt_warehouse_info.warehousing_id AND wa.manufacturer =?", manufacturer)
  858. }
  859. if order_type > 0 {
  860. db = db.Where("xt_warehouse_info.type = ?", order_type)
  861. }
  862. type PriceAmount struct {
  863. Total float64
  864. }
  865. var result []PriceAmount
  866. err = db.Select("total_price as total").Scan(&result).Error
  867. var total float64
  868. for _, value := range result {
  869. total = total + value.Total
  870. }
  871. total, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", total), 64)
  872. return err, total
  873. }
  874. func FloatRound(f float64, n int) float64 {
  875. format := "%." + strconv.Itoa(n) + "f"
  876. res, _ := strconv.ParseFloat(fmt.Sprintf(format, f), 64)
  877. return res
  878. }
  879. 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) {
  880. db := readDb.Model(&models.WarehouseOutInfo{})
  881. 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)
  882. if len(keywords) > 0 {
  883. likeKey := "%" + keywords + "%"
  884. 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)
  885. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse_out.creater")
  886. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_out_info.good_id")
  887. 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")
  888. } else {
  889. 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)
  890. }
  891. if manufacturer > 0 {
  892. db = db.Joins("join xt_warehouse_out as wa on wa.id = xt_warehouse_out_info.warehouse_out_id AND wa.manufacturer =?", manufacturer)
  893. }
  894. if order_type > 0 {
  895. db = db.Where("xt_warehouse_out_info.type = ?", order_type)
  896. }
  897. db = db.Preload("WarehouseOut", "status = 1 AND org_id = ?", orgId)
  898. db = db.Count(&total)
  899. offset := (page - 1) * limit
  900. err = db.Offset(offset).Limit(limit).Order("xt_warehouse_out_info.ctime desc").Find(&list).Error
  901. return
  902. }
  903. func GetStockOutDetailTotal(orgId int64, startTime int64, endTime int64, keywords string, manufacturer int64, order_type int64, dealer int64) (err error, totalPrice float64) {
  904. db := readDb.Model(&models.WarehouseOutInfo{})
  905. 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)
  906. if len(keywords) > 0 {
  907. likeKey := "%" + keywords + "%"
  908. 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)
  909. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_warehouse_out.creater")
  910. db = db.Joins("join xt_good_information on xt_good_information.id = xt_warehouse_out_info.good_id")
  911. 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")
  912. } else {
  913. 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)
  914. }
  915. if manufacturer > 0 {
  916. db = db.Joins("join xt_warehouse_out as wa on wa.id = xt_warehouse_out_info.warehouse_out_id AND wa.manufacturer =?", manufacturer)
  917. }
  918. if order_type > 0 {
  919. db = db.Where("xt_warehouse_out_info.type = ?", order_type)
  920. }
  921. type PriceAmount struct {
  922. Total float64
  923. }
  924. var result []PriceAmount
  925. err = db.Select("(count * price) as total").Scan(&result).Error
  926. var total float64
  927. for _, value := range result {
  928. total = total + value.Total
  929. }
  930. total, _ = strconv.ParseFloat(fmt.Sprintf("%.2f", total), 64)
  931. fmt.Println(total)
  932. return err, total
  933. }
  934. 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) {
  935. db := readDb.Model(&models.SalesReturnInfo{})
  936. db = db.Where("xt_sales_return_info.org_id = ? AND xt_sales_return_info.status = 1", orgId)
  937. if len(keywords) > 0 {
  938. likeKey := "%" + keywords + "%"
  939. 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)
  940. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_sales_return.creater")
  941. db = db.Joins("join xt_good_information on xt_good_information.id = xt_sales_return_info.good_id")
  942. 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")
  943. } else {
  944. 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)
  945. }
  946. if manufacturer > 0 {
  947. db = db.Joins("join xt_sales_return as sr on sr.id = xt_sales_return_info.sales_return_id AND sr.manufacturer =?", manufacturer)
  948. }
  949. if order_type > 0 {
  950. db = db.Where("xt_sales_return_info.type = ?", order_type)
  951. }
  952. db = db.Preload("SalesReturn", "status = 1 AND org_id = ?", orgId)
  953. offset := (page - 1) * limit
  954. db = db.Count(&total)
  955. err = db.Offset(offset).Limit(limit).Order("xt_sales_return_info.ctime desc").Find(&list).Error
  956. return
  957. }
  958. 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) {
  959. db := readDb.Model(&models.CancelStockInfo{})
  960. db = db.Where("xt_cancel_stock_info.org_id = ? AND xt_cancel_stock_info.status = 1", orgId)
  961. if len(keywords) > 0 {
  962. likeKey := "%" + keywords + "%"
  963. 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)
  964. db = db.Joins("join sgj_users.sgj_user_admin_role on sgj_user_admin_role.admin_user_id = xt_cancel_stock.creater")
  965. db = db.Joins("join xt_good_information on xt_good_information.id = xt_cancel_stock_info.good_id")
  966. 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")
  967. } else {
  968. 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)
  969. }
  970. if manufacturer > 0 {
  971. db = db.Joins("join xt_cancel_stock as cs on cs.id = xt_cancel_stock_info.cancel_stock_id AND cs.manufacturer =?", manufacturer)
  972. }
  973. if order_type > 0 {
  974. db = db.Where("xt_cancel_stock_info.type = ?", order_type)
  975. }
  976. db = db.Preload("CancelStock", "status = 1 AND org_id = ?", orgId)
  977. db = db.Count(&total)
  978. offset := (page - 1) * limit
  979. err = db.Offset(offset).Limit(limit).Order("xt_cancel_stock_info.ctime desc").Find(&list).Error
  980. return
  981. }
  982. func FindStockInByDealerId(id int64) (total int64, err error) {
  983. err = readDb.Model(&models.Warehousing{}).Where("dealer = ? AND status = 1", id).Count(&total).Error
  984. return
  985. }
  986. func FindStockInByManufacturerId(id int64) (total int64, err error) {
  987. err = readDb.Model(&models.Warehousing{}).Where("manufacturer = ? AND status = 1", id).Count(&total).Error
  988. return
  989. }
  990. func FindGoodTypeByName(name string, org_id int64) (total int64) {
  991. readDb.Model(&models.GoodsType{}).Where("(org_id = ? OR type = 1) AND status = 1 AND type_name = ? ", org_id, name).Count(&total)
  992. return
  993. }
  994. func FindGoodInfoByName(name string, org_id int64) (total int64) {
  995. readDb.Model(&models.GoodInfo{}).Where("org_id = ? AND status = 1 AND specification_name = ? ", org_id, name).Count(&total)
  996. return
  997. }
  998. func FindAllGoodTypeByType(types int64) (goodType []*models.GoodsType, err error) {
  999. err = readDb.Model(&models.GoodsType{}).Where("type = ? AND status = 1", types).Find(&goodType).Error
  1000. return goodType, err
  1001. }
  1002. func FindWarehouseInfoByGoodType(good_type_id int64, org_id int64) (info []*models.WarehousingInfo, err error) {
  1003. err = readDb.Model(&models.WarehousingInfo{}).Preload("GoodInfo", "status = 1 AND org_id = ?", org_id).Where("good_type_id = ? AND status = 1 AND org_id = ?", good_type_id, org_id).Find(&info).Error
  1004. return info, err
  1005. }
  1006. func FindStockOutByIsSys(org_id int64, is_sys int, record_time int64) (out models.WarehouseOut, err error) {
  1007. 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
  1008. return
  1009. }
  1010. func FindLastStockInInfoRecord(good_id int64, org_id int64) (in models.WarehousingInfo, err error) {
  1011. err = readDb.Model(&models.WarehousingInfo{}).Where("status = 1 AND org_id = ? AND good_id = ?", org_id, good_id).Last(&in).Error
  1012. return
  1013. }
  1014. func AddSigleWarehouseOutInfo(info *models.WarehouseOutInfo) error {
  1015. err := writeDb.Create(&info).Error
  1016. return err
  1017. }
  1018. func AddSigleAutoReduceRecordInfo(detail *models.AutomaticReduceDetail) error {
  1019. err := writeDb.Create(&detail).Error
  1020. return err
  1021. }
  1022. func FindStockOutInfoByTypeId(org_id int64, good_type_id int64, good_id int64, number string) (out models.WarehouseOutInfo, err error) {
  1023. 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_order_number = ?", org_id, good_type_id, good_id, number).First(&out).Error
  1024. return
  1025. }
  1026. func UpdateStockOutInfoCount(org_id int64, id int64) {
  1027. writeDb.Model(&models.WarehouseOutInfo{}).Where("status = 1 AND org_id = ? AND id = ?", org_id, id).UpdateColumn("count", gorm.Expr("count + ?", 1))
  1028. }
  1029. func FindUserDetailById(org_id int64, id int64) (user []*models.AutomaticReduceDetail, err error, total int64) {
  1030. db := readDb.Model(&models.AutomaticReduceDetail{})
  1031. db = db.Preload("GoodInfo", "org_id = ? AND status = 1", org_id)
  1032. db = db.Preload("GoodsType", "type = 1 AND status = 1")
  1033. db = db.Preload("Patients", "user_org_id = ? AND status = 1", org_id)
  1034. db = db.Where("status = 1 AND org_id = ? AND warehouse_out_id = ? AND good_id != 0", org_id, id)
  1035. db = db.Count(&total)
  1036. err = db.Find(&user).Error
  1037. return
  1038. }