TopicGoods.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <?php
  2. // +---------------------------------------------------------------------+
  3. // | NiuCloud | [ WE CAN DO IT JUST NiuCloud ]  |
  4. // +---------------------------------------------------------------------+
  5. // | Copy right 2019-2029 www.niucloud.com  |
  6. // +---------------------------------------------------------------------+
  7. // | Author | NiuCloud <niucloud@outlook.com>  |
  8. // +---------------------------------------------------------------------+
  9. // | Repository | https://github.com/niucloud/framework.git  |
  10. // +---------------------------------------------------------------------+
  11. namespace addon\topic\model;
  12. use app\model\BaseModel;
  13. /**
  14. * 专题活动
  15. */
  16. class TopicGoods extends BaseModel
  17. {
  18. /**
  19. * 添加专题商品
  20. * @param unknown $topic_id
  21. * @param unknown $site_id
  22. * @param unknown $sku_ids
  23. * @return multitype:string
  24. */
  25. public function addTopicGoods($topic_id, $site_id, $sku_ids)
  26. {
  27. $sku_list = model("goods_sku")->getList([
  28. [ 'sku_id', 'in', $sku_ids ],
  29. [ 'site_id', '=', $site_id ],
  30. ], 'goods_id, sku_id, price');
  31. $topic_info = model("promotion_topic")->getInfo([ [ 'topic_id', '=', $topic_id ] ], 'start_time, end_time');
  32. $data = [];
  33. foreach ($sku_list as $val) {
  34. $goods_count = model("promotion_topic_goods")->getCount([ 'topic_id' => $topic_id, 'sku_id' => $val['sku_id'] ]);
  35. if (empty($goods_count)) {
  36. $data[] = [
  37. 'topic_id' => $topic_id,
  38. 'site_id' => $site_id,
  39. 'goods_id' => $val['goods_id'],
  40. 'sku_id' => $val['sku_id'],
  41. 'topic_price' => $val['price'],
  42. 'start_time' => $topic_info['start_time'],
  43. 'end_time' => $topic_info['end_time']
  44. ];
  45. }
  46. }
  47. model("promotion_topic_goods")->addList($data);
  48. return $this->success();
  49. }
  50. /**
  51. * 修改专题商品
  52. * @param unknown $topic_id
  53. * @param unknown $site_id
  54. * @param unknown $sku_id
  55. * @param unknown $price
  56. * @return multitype:string
  57. */
  58. public function editTopicGoods($topic_id, $site_id, $sku_id, $price)
  59. {
  60. $data = [
  61. 'topic_id' => $topic_id,
  62. 'site_id' => $site_id,
  63. 'sku_id' => $sku_id,
  64. 'topic_price' => $price
  65. ];
  66. model("promotion_topic_goods")->update($data, [ [ 'topic_id', '=', $topic_id ], [ 'sku_id', '=', $sku_id ], [ 'site_id', '=', $site_id ] ]);
  67. return $this->success();
  68. }
  69. /**
  70. * 删除专题商品
  71. * @param unknown $topic_id
  72. * @param unknown $site_id
  73. * @param unknown $sku_id
  74. * @return multitype:string
  75. */
  76. public function deleteTopicGoods($topic_id, $site_id, $sku_id)
  77. {
  78. model("promotion_topic_goods")->delete([ [ 'topic_id', '=', $topic_id ], [ 'sku_id', '=', $sku_id ], [ 'site_id', '=', $site_id ] ]);
  79. return $this->success();
  80. }
  81. /**
  82. * 获取专题商品详情
  83. * @param int $id
  84. * @return mixed
  85. */
  86. public function getTopicGoodsDetail($id)
  87. {
  88. $condition = [
  89. [ 'ptg.id', '=', $id ],
  90. [ 'pt.status', '=', 1 ]
  91. ];
  92. $alias = 'ptg';
  93. $join = [
  94. [ 'goods_sku sku', 'ptg.sku_id = sku.sku_id', 'left' ],
  95. [ 'promotion_topic pt', 'pt.topic_id = ptg.topic_id', 'left' ],
  96. ];
  97. $list = model('promotion_topic_goods')->getInfo($condition, 'sku.goods_id,sku.sku_id,sku.sku_name,sku.sku_spec_format,sku.price,sku.promotion_type,sku.stock,sku.click_num,sku.sale_num,sku.collect_num,sku.sku_image,sku.sku_images,sku.goods_id,sku.site_id,sku.goods_content,sku.goods_state,sku.verify_state,sku.is_virtual,sku.is_free_shipping,sku.goods_spec_format,sku.goods_attr_format,sku.introduction,sku.unit,sku.video_url,sku.evaluate,sku.category_id,sku.category_id_1,sku.category_id_2,sku.category_id_3,sku.category_name,ptg.id,ptg.topic_id,ptg.start_time,ptg.end_time,ptg.topic_price,pt.topic_name', $alias, $join);
  98. return $this->success($list);
  99. }
  100. /**
  101. * 获取专题商品列表
  102. * @param array $condition
  103. * @param int $page
  104. * @param int $page_size
  105. * @param string $order
  106. * @param string $field
  107. * @return mixed
  108. */
  109. public function getTopicGoodsPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = '', $field = '')
  110. {
  111. if (empty($field)) {
  112. $field = 'ngs.sku_id, ngs.sku_name, ngs.sku_no, ngs.sku_spec_format, ngs.price, ngs.market_price,
  113. ngs.cost_price, ngs.discount_price, ngs.promotion_type, ngs.stock,
  114. ngs.weight, ngs.volume, ngs.click_num, ngs.sale_num, ngs.collect_num, ngs.sku_image,
  115. ngs.sku_images, ngs.goods_id, ngs.goods_class, ngs.goods_class_name, ngs.goods_attr_class,
  116. ngs.goods_attr_name, ngs.goods_name, ngs.site_id, ngs.site_name, ngs.website_id, ngs.category_id,
  117. ngs.category_id_1, ngs.category_id_2, ngs.category_id_3, ngs.category_name, ngs.brand_id, ngs.brand_name,
  118. ngs.goods_content, ngs.is_own, ngs.goods_state, ngs.verify_state, ngs.verify_state_remark, ngs.goods_stock_alarm,
  119. ngs.is_virtual, ngs.virtual_indate, ngs.is_free_shipping, ngs.shipping_template, ngs.goods_spec_format,
  120. ngs.goods_attr_format, ngs.is_delete, ngs.introduction, ngs.keywords, ngs.unit, ngs.sort,npt.topic_name,
  121. npt.topic_adv, npt.status, nptg.start_time, nptg.end_time, nptg.topic_price, npt.topic_id';
  122. }
  123. $alias = 'nptg';
  124. $join = [
  125. [ 'goods_sku ngs', 'nptg.sku_id = ngs.sku_id', 'inner' ],
  126. [ 'promotion_topic npt', 'nptg.topic_id = npt.topic_id', 'inner' ],
  127. ];
  128. $list = model('promotion_topic_goods')->pageList($condition, $field, $order, $page, $page_size, $alias, $join);
  129. return $this->success($list);
  130. }
  131. }