面包店
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

9 місяці тому
7 місяці тому
9 місяці тому
7 місяці тому
9 місяці тому
8 місяці тому
9 місяці тому
8 місяці тому
9 місяці тому
7 місяці тому
9 місяці тому
7 місяці тому
9 місяці тому
6 місяці тому
7 місяці тому
9 місяці тому
9 місяці тому
9 місяці тому
9 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
7 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
6 місяці тому
7 місяці тому
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644
  1. package svc
  2. import (
  3. md2 "applet/app/admin/md"
  4. "applet/app/bigData/md"
  5. "applet/app/db"
  6. "applet/app/db/model"
  7. "applet/app/utils"
  8. "encoding/json"
  9. "fmt"
  10. "github.com/gin-gonic/gin"
  11. "strings"
  12. "time"
  13. )
  14. func LeftDataForMake() (resp []md.LeftDataForMakeResp, err error) {
  15. //now := time.Now()
  16. //startDate := now.Format("2006-01-02") + " 00:00:00"
  17. //endDate := now.AddDate(0, 0, 1).Format("2006-01-02") + " 00:00:00"
  18. //engine := db.Db
  19. //var enterprise []model.Enterprise
  20. //err = engine.Where("1=1").Find(&enterprise)
  21. //if err != nil {
  22. // return
  23. //}
  24. //var enterpriseMap = map[int]model.Enterprise{}
  25. //for _, v := range enterprise {
  26. // enterpriseMap[v.Id] = v
  27. //}
  28. //
  29. ////1、查找当天的 order 数据(大于 待制作)
  30. //var orders []model.Order
  31. //err = engine.Where("create_at >= ?", startDate).And("create_at < ?", endDate).And("state > ? and state != 5", 0).Find(&orders)
  32. //if err != nil {
  33. // return
  34. //}
  35. //var oIds []int64
  36. //for _, v := range orders {
  37. // oIds = append(oIds, v.Oid)
  38. //}
  39. //
  40. ////2、查找对应的订单产品记录
  41. //var orderGoods []model.OrderGoods
  42. //err = engine.In("oid", oIds).Find(&orderGoods)
  43. //if err != nil {
  44. // return
  45. //}
  46. //var orderGoodsMap = map[int64][]model.OrderGoods{}
  47. //var records []int
  48. //for _, v := range orderGoods {
  49. // if orderGoodsMap[v.Oid] == nil {
  50. // orderGoodsMap[v.Oid] = []model.OrderGoods{}
  51. // }
  52. // orderGoodsMap[v.Oid] = append(orderGoodsMap[v.Oid], v)
  53. // records = append(records, v.Id)
  54. //}
  55. //
  56. ////3、用户订单商品操作流程
  57. //var orderGoodsDoingFlows []model.OrderGoodsDoingFlow
  58. //err = engine.Where("state = 2").In("record_id", records).Find(&orderGoodsDoingFlows)
  59. //if err != nil {
  60. // return
  61. //}
  62. //var orderGoodsDoingFlowsMap = map[int]model.OrderGoodsDoingFlow{}
  63. //for _, v := range orderGoodsDoingFlows {
  64. // orderGoodsDoingFlowsMap[v.RecordId] = v
  65. //}
  66. //
  67. ////4、整合数据
  68. //orderStateArr := []string{"待制作", "制作中", "烘焙完成", "分拣完成", "已取消"}
  69. //for _, v := range orders {
  70. // var list []md.LeftDataForMakeList
  71. // if len(orderGoodsMap[v.Oid]) > 0 {
  72. // orderGoodsStateArr := []string{"待制作", "制作中"}
  73. // for _, vv := range orderGoodsMap[v.Oid] {
  74. // skuData := make([]md2.Sku, 0)
  75. // json.Unmarshal([]byte(vv.Sku), &skuData)
  76. // skuStr := ""
  77. // for _, v1 := range skuData {
  78. // if skuStr != "" {
  79. // skuStr += ";"
  80. // }
  81. // skuStr += v1.Value
  82. // }
  83. // var stateZh = "已完成"
  84. // if vv.State <= 1 {
  85. // stateZh = orderGoodsStateArr[vv.State]
  86. // }
  87. // list = append(list, md.LeftDataForMakeList{
  88. // GoodsName: vv.GoodsTitle,
  89. // Sku: skuStr,
  90. // Num: vv.Num,
  91. // SuccessNum: orderGoodsDoingFlowsMap[vv.Id].SuccessNum,
  92. // StateZh: stateZh,
  93. // State: vv.State,
  94. // })
  95. // }
  96. //
  97. // resp = append(resp, md.LeftDataForMakeResp{
  98. // EnterpriseName: enterpriseMap[v.EnterpriseId].Name,
  99. // EnterpriseId: v.EnterpriseId,
  100. // StateZh: orderStateArr[v.State],
  101. // State: v.State,
  102. // List: list,
  103. // })
  104. // }
  105. //}
  106. return
  107. }
  108. func LeftDataForBaking() (resp []md.LeftDataForMakeResp, err error) {
  109. //now := time.Now()
  110. //startDate := now.Format("2006-01-02") + " 00:00:00"
  111. //endDate := now.AddDate(0, 0, 1).Format("2006-01-02") + " 00:00:00"
  112. //engine := db.Db
  113. //var enterprise []model.Enterprise
  114. //err = engine.Where("1=1").Find(&enterprise)
  115. //if err != nil {
  116. // return
  117. //}
  118. //var enterpriseMap = map[int]model.Enterprise{}
  119. //for _, v := range enterprise {
  120. // enterpriseMap[v.Id] = v
  121. //}
  122. //
  123. ////1、查找当天的 order 数据(大于 待制作)
  124. //var orders []model.Order
  125. //err = engine.Where("create_at >= ?", startDate).And("create_at < ?", endDate).And("state > ? and state != 5", 1).Find(&orders)
  126. //if err != nil {
  127. // return
  128. //}
  129. //var oIds []int64
  130. //for _, v := range orders {
  131. // oIds = append(oIds, v.Oid)
  132. //}
  133. //
  134. ////2、查找对应的订单产品记录
  135. //var orderGoods []model.OrderGoods
  136. //err = engine.In("oid", oIds).Find(&orderGoods)
  137. //if err != nil {
  138. // return
  139. //}
  140. //var orderGoodsMap = map[int64][]model.OrderGoods{}
  141. //var records []int
  142. //for _, v := range orderGoods {
  143. // if orderGoodsMap[v.Oid] == nil {
  144. // orderGoodsMap[v.Oid] = []model.OrderGoods{}
  145. // }
  146. // orderGoodsMap[v.Oid] = append(orderGoodsMap[v.Oid], v)
  147. // records = append(records, v.Id)
  148. //}
  149. //
  150. ////3、用户订单商品操作流程
  151. //var orderGoodsDoingFlows []model.OrderGoodsDoingFlow
  152. //err = engine.Where("state = 2").In("record_id", records).Find(&orderGoodsDoingFlows)
  153. //if err != nil {
  154. // return
  155. //}
  156. //var orderGoodsDoingFlowsMap = map[int]model.OrderGoodsDoingFlow{}
  157. //for _, v := range orderGoodsDoingFlows {
  158. // orderGoodsDoingFlowsMap[v.RecordId] = v
  159. //}
  160. //
  161. ////4、整合数据
  162. //orderStateArr := []string{"待制作", "制作中", "制作完成", "烘焙完成", "分拣完成", "已取消"}
  163. //for _, v := range orders {
  164. // var list []md.LeftDataForMakeList
  165. // if len(orderGoodsMap[v.Oid]) > 0 {
  166. // for _, vv := range orderGoodsMap[v.Oid] {
  167. // skuData := make([]md2.Sku, 0)
  168. // json.Unmarshal([]byte(vv.Sku), &skuData)
  169. // skuStr := ""
  170. // for _, v1 := range skuData {
  171. // if skuStr != "" {
  172. // skuStr += ";"
  173. // }
  174. // skuStr += v1.Value
  175. // }
  176. // var stateZh = "已完成"
  177. // if vv.State == 2 {
  178. // stateZh = "烘焙中"
  179. // }
  180. //
  181. // list = append(list, md.LeftDataForMakeList{
  182. // GoodsName: vv.GoodsTitle,
  183. // Sku: skuStr,
  184. // Num: vv.Num,
  185. // SuccessNum: orderGoodsDoingFlowsMap[vv.Id].SuccessNum,
  186. // StateZh: stateZh,
  187. // State: vv.State,
  188. // })
  189. // }
  190. //
  191. // resp = append(resp, md.LeftDataForMakeResp{
  192. // EnterpriseName: enterpriseMap[v.EnterpriseId].Name,
  193. // EnterpriseId: v.EnterpriseId,
  194. // StateZh: orderStateArr[v.State],
  195. // State: v.State,
  196. // List: list,
  197. // })
  198. // }
  199. //}
  200. return
  201. }
  202. func LeftDataForSorting() (resp []md.LeftDataForMakeResp, err error) {
  203. engine := db.Db
  204. var enterprise []model.Enterprise
  205. err = engine.Where("1=1").Find(&enterprise)
  206. if err != nil {
  207. return
  208. }
  209. var enterpriseMap = map[int]model.Enterprise{}
  210. for _, v := range enterprise {
  211. enterpriseMap[v.Id] = v
  212. }
  213. //1、查找不等于4 5
  214. sysCfgDb := db.SysCfgDb{}
  215. sysCfgDb.Set()
  216. now := CommDate()
  217. var orders []model.Order
  218. err = engine.Where(" state != 4 and state != 5 and make_date=?", now).Find(&orders)
  219. if err != nil {
  220. return
  221. }
  222. var oIds []int64
  223. for _, v := range orders {
  224. v1 := v
  225. if v1.State == 4 || v1.State == 5 {
  226. continue
  227. }
  228. oIds = append(oIds, v.Oid)
  229. }
  230. //2、查找对应的订单产品记录
  231. var orderGoods []model.OrderGoods
  232. err = engine.In("oid", oIds).Find(&orderGoods)
  233. if err != nil {
  234. return
  235. }
  236. var orderGoodsMap = map[int64][]model.OrderGoods{}
  237. var records []int
  238. for _, v := range orderGoods {
  239. if orderGoodsMap[v.Oid] == nil {
  240. orderGoodsMap[v.Oid] = []model.OrderGoods{}
  241. }
  242. orderGoodsMap[v.Oid] = append(orderGoodsMap[v.Oid], v)
  243. records = append(records, v.Id)
  244. }
  245. //4、整合数据
  246. orderStateArr := []string{"待分拣", "待分拣", "待分拣", "待分拣", "已完成", "已取消"}
  247. for _, v := range orders {
  248. var list []md.LeftDataForMakeList
  249. if len(orderGoodsMap[v.Oid]) > 0 {
  250. orderGoodsStateArr := []string{"待分拣", "待分拣", "待分拣", "待分拣", "已完成"}
  251. for _, vv := range orderGoodsMap[v.Oid] {
  252. skuData := make([]md2.Sku, 0)
  253. json.Unmarshal([]byte(vv.Sku), &skuData)
  254. skuStr := ""
  255. for _, v1 := range skuData {
  256. if skuStr != "" {
  257. skuStr += ";"
  258. }
  259. skuStr += v1.Value
  260. }
  261. var stateZh = orderGoodsStateArr[vv.State]
  262. list = append(list, md.LeftDataForMakeList{
  263. GoodsName: vv.GoodsTitle,
  264. Sku: skuStr,
  265. Num: vv.Num,
  266. SuccessNum: vv.SuccessNum,
  267. StateZh: stateZh,
  268. State: vv.State,
  269. })
  270. }
  271. resp = append(resp, md.LeftDataForMakeResp{
  272. EnterpriseName: enterpriseMap[v.EnterpriseId].Name,
  273. EnterpriseId: v.EnterpriseId,
  274. StateZh: orderStateArr[v.State],
  275. State: v.State,
  276. List: list,
  277. })
  278. }
  279. }
  280. return
  281. }
  282. func RightDataForMake(req md.RightDataForMakeReq) (resp []md.RightDataForMakeResp, total int64, err error) {
  283. now := time.Now()
  284. startDate := now.Format("2006-01-02") + " 00:00:00"
  285. endDate := now.AddDate(0, 0, 1).Format("2006-01-02") + " 00:00:00"
  286. engine := db.Db
  287. var enterprise []model.Enterprise
  288. err = engine.Where("1=1").Find(&enterprise)
  289. if err != nil {
  290. return
  291. }
  292. var enterpriseMap = map[int]model.Enterprise{}
  293. for _, v := range enterprise {
  294. enterpriseMap[v.Id] = v
  295. }
  296. //1、查找当天的 order 数据(大于 待制作)
  297. var orders []model.Order
  298. total, err = engine.Where("create_at >= ?", startDate).And("create_at < ?", endDate).And("state > ? and state != 5", 0).
  299. Limit(req.Limit, (req.Page-1)*req.Limit).FindAndCount(&orders)
  300. if err != nil {
  301. return
  302. }
  303. var oIds []int64
  304. for _, v := range orders {
  305. oIds = append(oIds, v.Oid)
  306. }
  307. //2、整合数据
  308. orderStateArr := []string{"待制作", "制作中", "制作完成", "烘焙完成", "分拣完成", "已取消"}
  309. for _, v := range orders {
  310. resp = append(resp, md.RightDataForMakeResp{
  311. EnterpriseName: enterpriseMap[v.EnterpriseId].Name,
  312. EnterpriseId: v.EnterpriseId,
  313. StateZh: orderStateArr[v.State],
  314. State: v.State,
  315. })
  316. }
  317. return
  318. }
  319. func RightDataForBaking(req md.RightDataForMakeReq) (resp []md.RightDataForMakeResp, total int64, err error) {
  320. now := time.Now()
  321. startDate := now.Format("2006-01-02") + " 00:00:00"
  322. endDate := now.AddDate(0, 0, 1).Format("2006-01-02") + " 00:00:00"
  323. engine := db.Db
  324. var enterprise []model.Enterprise
  325. err = engine.Where("1=1").Find(&enterprise)
  326. if err != nil {
  327. return
  328. }
  329. var enterpriseMap = map[int]model.Enterprise{}
  330. for _, v := range enterprise {
  331. enterpriseMap[v.Id] = v
  332. }
  333. //1、查找当天的 order 数据(大于 待制作)
  334. var orders []model.Order
  335. total, err = engine.Where("create_at >= ?", startDate).And("create_at < ?", endDate).And("state > ? and state != 5", 1).
  336. Limit(req.Limit, (req.Page-1)*req.Limit).FindAndCount(&orders)
  337. if err != nil {
  338. return
  339. }
  340. var oIds []int64
  341. for _, v := range orders {
  342. oIds = append(oIds, v.Oid)
  343. }
  344. //2、整合数据
  345. orderStateArr := []string{"待制作", "制作中", "制作完成", "烘焙完成", "分拣完成", "已取消"}
  346. for _, v := range orders {
  347. resp = append(resp, md.RightDataForMakeResp{
  348. EnterpriseName: enterpriseMap[v.EnterpriseId].Name,
  349. EnterpriseId: v.EnterpriseId,
  350. StateZh: orderStateArr[v.State],
  351. State: v.State,
  352. })
  353. }
  354. return
  355. }
  356. func RightDataForSorting(req md.RightDataForMakeReq) (resp []md.RightDataForMakeResp, total int64, err error) {
  357. now := time.Now()
  358. startDate := now.Format("2006-01-02") + " 00:00:00"
  359. endDate := now.AddDate(0, 0, 1).Format("2006-01-02") + " 00:00:00"
  360. engine := db.Db
  361. var enterprise []model.Enterprise
  362. err = engine.Where("1=1").Find(&enterprise)
  363. if err != nil {
  364. return
  365. }
  366. var enterpriseMap = map[int]model.Enterprise{}
  367. for _, v := range enterprise {
  368. enterpriseMap[v.Id] = v
  369. }
  370. //1、查找当天的 order 数据(大于 待制作)
  371. var orders []model.Order
  372. total, err = engine.Where("create_at >= ?", startDate).And("create_at < ?", endDate).And("state > ? and state != 5", 2).
  373. Limit(req.Limit, (req.Page-1)*req.Limit).FindAndCount(&orders)
  374. if err != nil {
  375. return
  376. }
  377. var oIds []int64
  378. for _, v := range orders {
  379. oIds = append(oIds, v.Oid)
  380. }
  381. //2、整合数据
  382. orderStateArr := []string{"待制作", "制作中", "制作完成", "烘焙完成", "分拣完成", "已取消"}
  383. for _, v := range orders {
  384. resp = append(resp, md.RightDataForMakeResp{
  385. EnterpriseName: enterpriseMap[v.EnterpriseId].Name,
  386. EnterpriseId: v.EnterpriseId,
  387. StateZh: orderStateArr[v.State],
  388. State: v.State,
  389. })
  390. }
  391. return
  392. }
  393. func NewSortingCate(c *gin.Context) []map[string]string {
  394. engine := db.Db
  395. res := make([]map[string]string, 0)
  396. var args = make(map[string]string)
  397. c.ShouldBindJSON(&args)
  398. var enterprise []model.Enterprise
  399. sess := engine.Where("1=1")
  400. if args["name"] != "" {
  401. sess.And("name like ? or inside_name like ?", "%"+args["name"]+"%", "%"+args["name"]+"%")
  402. }
  403. err := sess.Find(&enterprise)
  404. if err != nil {
  405. return res
  406. }
  407. var enterpriseMap = map[int]model.Enterprise{}
  408. enterpriseId := []int{-1}
  409. for _, v := range enterprise {
  410. enterpriseMap[v.Id] = v
  411. enterpriseId = append(enterpriseId, v.Id)
  412. }
  413. //1、查找不等于4 5
  414. now := CommDate()
  415. var orders []model.Order
  416. sess1 := engine.Where(" state != 4 and state != 5 and make_date=?", now)
  417. if args["name"] != "" {
  418. sess1.In("enterprise_id", enterpriseId)
  419. }
  420. err = sess1.Find(&orders)
  421. if err != nil {
  422. return res
  423. }
  424. ids := make([]string, 0)
  425. orderStateArr := []string{"待分拣", "待分拣", "待分拣", "待分拣", "已完成", "已取消"}
  426. for _, v := range orders {
  427. if utils.InArr(utils.IntToStr(v.EnterpriseId), ids) {
  428. continue
  429. }
  430. tmp := map[string]string{
  431. "id": utils.IntToStr(v.EnterpriseId),
  432. "name": enterpriseMap[v.EnterpriseId].Name,
  433. "state": utils.IntToStr(v.State),
  434. "state_str": orderStateArr[v.State],
  435. }
  436. ids = append(ids, utils.IntToStr(v.EnterpriseId))
  437. res = append(res, tmp)
  438. }
  439. return res
  440. }
  441. func NewSortingData(c *gin.Context) []map[string]string {
  442. res := make([]map[string]string, 0)
  443. var args map[string]string
  444. if err := c.ShouldBindJSON(&args); err != nil {
  445. return res
  446. }
  447. engine := db.Db
  448. var enterprise []model.Enterprise
  449. err := engine.Where("1=1").Find(&enterprise)
  450. if err != nil {
  451. return res
  452. }
  453. var enterpriseMap = map[int]model.Enterprise{}
  454. for _, v := range enterprise {
  455. enterpriseMap[v.Id] = v
  456. }
  457. //1、查找不等于4 5
  458. now := CommDate()
  459. var orders []model.Order
  460. err = engine.Where(" state != 4 and state != 5 and make_date=? and enterprise_id=?", now, args["id"]).Find(&orders)
  461. if err != nil {
  462. return res
  463. }
  464. var oIds []string
  465. for _, v := range orders {
  466. v1 := v
  467. if v1.State == 4 || v1.State == 5 {
  468. continue
  469. }
  470. oIds = append(oIds, utils.Int64ToStr(v.Oid))
  471. }
  472. sql := `SELECT SUM(num) as num,SUM(success_num) as success_num,goods_title,sku FROM order_goods WHERE %s oid in (%s) and make_date=%s and goods_type=0 GROUP BY enterprise_id,goods_id,sku_id`
  473. str := ""
  474. if args["name"] != "" {
  475. str = " goods_title like %" + args["name"] + "% and "
  476. }
  477. sql = fmt.Sprintf(sql, str, strings.Join(oIds, ","), now)
  478. nativeString, err := db.QueryNativeString(engine, sql)
  479. for _, v := range nativeString {
  480. skuData := make([]md2.Sku, 0)
  481. json.Unmarshal([]byte(v["sku"]), &skuData)
  482. skuStr := ""
  483. for _, v1 := range skuData {
  484. if skuStr != "" {
  485. skuStr += ";"
  486. }
  487. skuStr += v1.Value
  488. }
  489. tmp := map[string]string{
  490. "goods_name": v["goods_title"],
  491. "sku": skuStr,
  492. "num": v["num"],
  493. "success_num": v["success_num"],
  494. "state": "1",
  495. "state_str": "待分拣",
  496. }
  497. if utils.StrToInt(v["num"]) <= utils.StrToInt(v["success_num"]) {
  498. tmp["state"] = "4"
  499. tmp["state_str"] = "分拣完成"
  500. }
  501. res = append(res, tmp)
  502. }
  503. return res
  504. }
  505. func NewSortingGoodsCate(c *gin.Context) []map[string]string {
  506. res := make([]map[string]string, 0)
  507. engine := db.Db
  508. //1、查找不等于4 5
  509. now := CommDate()
  510. var orders []model.Order
  511. var args = make(map[string]string)
  512. c.ShouldBindJSON(&args)
  513. err := engine.Where(" state != 4 and state != 5 and make_date=? ", now).Find(&orders)
  514. if err != nil {
  515. return res
  516. }
  517. var oIds []string
  518. for _, v := range orders {
  519. v1 := v
  520. if v1.State == 4 || v1.State == 5 {
  521. continue
  522. }
  523. oIds = append(oIds, utils.Int64ToStr(v.Oid))
  524. }
  525. sql := `SELECT SUM(num) as num,SUM(success_num) as success_num,goods_title,sku,goods_id,sku_id FROM order_goods WHERE %s oid in (%s) and goods_type=0 and make_date=%s GROUP BY goods_id,sku_id`
  526. str := ""
  527. if args["name"] != "" {
  528. str = " goods_title like %" + args["name"] + "% and "
  529. }
  530. sql = fmt.Sprintf(sql, str, strings.Join(oIds, ","), now)
  531. nativeString, err := db.QueryNativeString(engine, sql)
  532. for _, v := range nativeString {
  533. skuData := make([]md2.Sku, 0)
  534. json.Unmarshal([]byte(v["sku"]), &skuData)
  535. skuStr := ""
  536. for _, v1 := range skuData {
  537. if skuStr != "" {
  538. skuStr += ";"
  539. }
  540. skuStr += v1.Value
  541. }
  542. tmp := map[string]string{
  543. "goods_id": v["goods_id"],
  544. "sku_id": v["sku_id"],
  545. "goods_name": v["goods_title"],
  546. "sku": skuStr,
  547. "num": v["num"],
  548. "success_num": v["success_num"],
  549. "state": "1",
  550. "state_str": "待分拣",
  551. }
  552. if utils.StrToInt(v["num"]) <= utils.StrToInt(v["success_num"]) {
  553. tmp["state"] = "4"
  554. tmp["state_str"] = "分拣完成"
  555. }
  556. res = append(res, tmp)
  557. }
  558. return res
  559. }
  560. func NewSortingGoodsData(c *gin.Context, arg map[string]string) []map[string]string {
  561. engine := db.Db
  562. res := make([]map[string]string, 0)
  563. var enterprise []model.Enterprise
  564. err := engine.Where("1=1").Find(&enterprise)
  565. if err != nil {
  566. return res
  567. }
  568. var enterpriseMap = map[int]model.Enterprise{}
  569. for _, v := range enterprise {
  570. enterpriseMap[v.Id] = v
  571. }
  572. //1、查找不等于4 5
  573. now := CommDate()
  574. var args = make(map[string]string)
  575. c.ShouldBindJSON(&args)
  576. var orders []model.Order
  577. err = engine.Where(" state != 4 and state != 5 and make_date=? ", now).Find(&orders)
  578. if err != nil {
  579. return res
  580. }
  581. var oIds []string
  582. for _, v := range orders {
  583. v1 := v
  584. if v1.State == 4 || v1.State == 5 {
  585. continue
  586. }
  587. oIds = append(oIds, utils.Int64ToStr(v.Oid))
  588. }
  589. sql := `SELECT SUM(num) as num,SUM(success_num) as success_num,goods_title,sku,goods_id,sku_id,enterprise_id FROM order_goods WHERE %s oid in (%s) and goods_id=%s and goods_type=0 and sku_id=%s and make_date=%s GROUP BY enterprise_id ORDER BY id asc`
  590. str := ""
  591. if args["name"] != "" {
  592. str = " goods_title like %" + args["name"] + "% and "
  593. }
  594. sql = fmt.Sprintf(sql, str, strings.Join(oIds, ","), arg["goods_id"], arg["sku_id"], now)
  595. nativeString, err := db.QueryNativeString(engine, sql)
  596. for _, v := range nativeString {
  597. skuData := make([]md2.Sku, 0)
  598. json.Unmarshal([]byte(v["sku"]), &skuData)
  599. skuStr := ""
  600. for _, v1 := range skuData {
  601. if skuStr != "" {
  602. skuStr += ";"
  603. }
  604. skuStr += v1.Value
  605. }
  606. tmp := map[string]string{
  607. "enterprise_name": enterpriseMap[utils.StrToInt(v["enterprise_id"])].Name,
  608. "num": v["num"],
  609. "success_num": v["success_num"],
  610. "state": "1",
  611. "state_str": "待分拣",
  612. }
  613. if utils.StrToInt(v["num"]) <= utils.StrToInt(v["success_num"]) {
  614. tmp["state"] = "4"
  615. tmp["state_str"] = "分拣完成"
  616. }
  617. res = append(res, tmp)
  618. }
  619. return res
  620. }