Bundle.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /**
  2. * @params sumary Map() 所有数据的集合
  3. * @params bundling Map() 套装数据的集合
  4. * @params goods_list 需要遍历的数据 array, 每个item是object, goods_id, goods_num, bl_id // bl_id > 0,查bundling 反之goods_id查sumary
  5. */
  6. // bl_id: 12, bl_name: "222", bl_price: 122, goods: Array(4), goods_num: 3 有套餐返回的数据样式, 渲染时判断bl_id 再循环goods即可。。。 goods_num通用
  7. // goods_id: 4807, goods_num: 1, bl_id: 0, goods_summary{} 无套餐返回的数据样式, 渲染时取goods_summary数据即可
  8. export default class Bundle {
  9. constructor(goods_list,sumary,bundling) {
  10. this.goods_list = goods_list
  11. this.sumary = sumary
  12. this.bundling = bundling
  13. // this.createOrders()
  14. }
  15. createOrders() {
  16. let arr = []
  17. this.goods_list.map(item => {
  18. if(item['bl_id'] > 0) {
  19. // 有套餐, 生成套餐数据
  20. let data = this.createBuildings(item)
  21. data = Object.assign({}, item, data)
  22. // data['goods_num'] = item['goods_num']
  23. let totalPrice = 0;
  24. data['goods'].map(value => {
  25. value['goods_summary'] = this.sumary.get(value['goods_id'])
  26. totalPrice += parseFloat(value['goods_summary']['goods_price'])
  27. })
  28. data['totalPrice'] = totalPrice
  29. arr.push(data)
  30. }
  31. else {
  32. let defaultData = this.createDefault(item)
  33. item['goods_summary'] = defaultData
  34. arr.push(item)
  35. }
  36. })
  37. return arr
  38. }
  39. createBuildings(item) {
  40. return this.bundling.get(item['bl_id'])
  41. }
  42. createDefault(item) {
  43. return this.sumary.get(item['goods_id'])
  44. }
  45. }