Bale.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace addon\bale\model;
  11. use app\model\BaseModel;
  12. use app\model\system\Cron;
  13. /**
  14. * 微信小程序配置
  15. */
  16. class Bale extends BaseModel
  17. {
  18. /**
  19. * 添加一口价活动
  20. * @param $data
  21. * @param $sku_ids
  22. * @return array
  23. */
  24. public function addBale($param)
  25. {
  26. if (empty($param[ 'sku_ids' ])) return $this->error([], "请选择参与活动的商品");
  27. $sku_id_array = explode(',', $param[ 'sku_ids' ]);
  28. foreach ($sku_id_array as $k => $v) {
  29. $sku_info = model('goods_sku')->getInfo([ [ 'sku_id', '=', $v ] ], 'is_virtual');
  30. if ($sku_info[ "is_virtual" ] == 1) {
  31. return $this->error([], "不能包含虚拟商品");
  32. }
  33. }
  34. $data = [
  35. 'site_id' => $param[ 'site_id' ],
  36. 'name' => $param[ 'name' ],
  37. 'num' => $param[ 'num' ],
  38. 'price' => $param[ 'price' ],
  39. 'goods_ids' => ',' . $param[ 'goods_ids' ] . ',',
  40. 'sku_ids' => ',' . $param[ 'sku_ids' ] . ',',
  41. 'start_time' => $param[ 'start_time' ],
  42. 'end_time' => $param[ 'end_time' ],
  43. 'create_time' => time(),
  44. 'status' => 0,
  45. 'shipping_fee_type' => $param[ 'shipping_fee_type' ]
  46. ];
  47. if ($param[ 'start_time' ] <= time()) {
  48. $data[ 'status' ] = 1;
  49. }
  50. $bale_id = model("promotion_bale")->add($data);
  51. $cron = new Cron();
  52. if ($data[ 'status' ] == 1) {
  53. $cron->addCron(1, 0, "打包一口价活动关闭", "CloseBale", $data[ 'end_time' ], $bale_id);
  54. } else {
  55. $cron->addCron(1, 0, "打包一口价活动开启", "OpenBale", $data[ 'start_time' ], $bale_id);
  56. $cron->addCron(1, 0, "打包一口价活动关闭", "CloseBale", $data[ 'end_time' ], $bale_id);
  57. }
  58. return $this->success($bale_id);
  59. }
  60. /**
  61. * 编辑一口价活动
  62. * @param $param
  63. */
  64. public function editBale($param)
  65. {
  66. if (empty($param[ 'sku_ids' ])) return $this->error([], "请选择参与活动的商品");
  67. $sku_id_array = explode(',', $param[ 'sku_ids' ]);
  68. foreach ($sku_id_array as $k => $v) {
  69. $sku_info = model('goods_sku')->getInfo([ [ 'sku_id', '=', $v ] ], 'is_virtual');
  70. if ($sku_info[ "is_virtual" ] == 1) {
  71. return $this->error([], "不能包含虚拟商品");
  72. }
  73. }
  74. $data = [
  75. 'site_id' => $param[ 'site_id' ],
  76. 'name' => $param[ 'name' ],
  77. 'num' => $param[ 'num' ],
  78. 'price' => $param[ 'price' ],
  79. 'goods_ids' => ',' . $param[ 'goods_ids' ] . ',',
  80. 'sku_ids' => ',' . $param[ 'sku_ids' ] . ',',
  81. 'start_time' => $param[ 'start_time' ],
  82. 'end_time' => $param[ 'end_time' ],
  83. 'shipping_fee_type' => $param[ 'shipping_fee_type' ]
  84. ];
  85. if ($param[ 'start_time' ] < time()) {
  86. $data[ 'status' ] = 1;
  87. } else {
  88. $data[ 'status' ] = 0;
  89. }
  90. $res = model("promotion_bale")->update($data, [ [ 'bale_id', '=', $param[ 'bale_id' ] ], [ 'site_id', '=', $param[ 'site_id' ] ] ]);
  91. $cron = new Cron();
  92. if ($data[ 'status' ] == 1) {
  93. $cron->deleteCron([ [ 'event', '=', 'OpenBale' ], [ 'relate_id', '=', $param[ 'bale_id' ] ] ]);
  94. $cron->deleteCron([ [ 'event', '=', 'CloseBale' ], [ 'relate_id', '=', $param[ 'bale_id' ] ] ]);
  95. $cron->addCron(1, 0, "打包一口价活动关闭", "CloseBale", $data[ 'end_time' ], $param[ 'bale_id' ]);
  96. } else {
  97. $cron->deleteCron([ [ 'event', '=', 'OpenBale' ], [ 'relate_id', '=', $param[ 'bale_id' ] ] ]);
  98. $cron->deleteCron([ [ 'event', '=', 'CloseBale' ], [ 'relate_id', '=', $param[ 'bale_id' ] ] ]);
  99. $cron->addCron(1, 0, "打包一口价活动开启", "OpenBale", $data[ 'start_time' ], $param[ 'bale_id' ]);
  100. $cron->addCron(1, 0, "打包一口价活动关闭", "CloseBale", $data[ 'end_time' ], $param[ 'bale_id' ]);
  101. }
  102. return $this->success($res);
  103. }
  104. /**
  105. * 删除活动
  106. * @param $ids
  107. * @param $site_id
  108. * @return array
  109. */
  110. public function deleteBale($bale_id, $site_id)
  111. {
  112. $info = model('promotion_bale')->getInfo([ [ 'bale_id', '=', $bale_id ], [ 'site_id', '=', $site_id ] ], 'status');
  113. if (empty($info)) {
  114. return $this->success();
  115. }
  116. if ($info[ 'status' ] != 2) {
  117. return $this->error('', '请先关闭活动后,在进行删除');
  118. }
  119. $res = model('promotion_bale')->delete([ [ 'bale_id', '=', $bale_id ], [ 'site_id', '=', $site_id ] ]);
  120. return $this->success($res);
  121. }
  122. /**
  123. * 开启活动
  124. * @param $bale_id
  125. * @return array
  126. */
  127. public function cronOpenBale($bale_id)
  128. {
  129. $info = model('promotion_bale')->getInfo([ [ 'bale_id', '=', $bale_id ] ], 'status');
  130. if (empty($info)) {
  131. return $this->error('', '活动不存在');
  132. }
  133. if ($info[ 'status' ] == 1) {
  134. return $this->success();
  135. }
  136. $res = model('promotion_bale')->update([ 'status' => 1 ], [ [ 'bale_id', '=', $bale_id ] ]);
  137. return $this->success($res);
  138. }
  139. /**
  140. * 关闭活动
  141. * @param $bale_id
  142. * @return array
  143. */
  144. public function cronCloseBale($bale_id)
  145. {
  146. $info = model('promotion_bale')->getInfo([ [ 'bale_id', '=', $bale_id ] ], 'status');
  147. if (empty($info)) {
  148. return $this->error('', '活动不存在');
  149. }
  150. if ($info[ 'status' ] == 2) {
  151. return $this->success();
  152. }
  153. $res = model('promotion_bale')->update([ 'status' => 2 ], [ [ 'bale_id', '=', $bale_id ] ]);
  154. return $this->success($res);
  155. }
  156. /**
  157. * 获取一口价活动信息
  158. * @param array $where
  159. * @param bool $field
  160. * @param string $alias
  161. * @param null $join
  162. * @return array
  163. */
  164. public function getBaleInfo($where = [], $field = true, $alias = 'a', $join = null)
  165. {
  166. $info = model('promotion_bale')->getInfo($where, $field, $alias, $join);
  167. return $this->success($info);
  168. }
  169. /**
  170. * 获取一口价活动详情
  171. * @param $id
  172. * @param $site_id
  173. * @return array
  174. */
  175. public function getBaleDetail($id, $site_id)
  176. {
  177. $info = model('promotion_bale')->getInfo([ [ 'bale_id', '=', $id ], [ 'site_id', '=', $site_id ] ], '*');
  178. if (!empty($info)) {
  179. $alias = 'gs';
  180. $condition = [
  181. [ 'gs.sku_id', 'in', $info[ 'sku_ids' ] ],
  182. [ 'gs.site_id', '=', $site_id ],
  183. ];
  184. $join = [
  185. [ 'goods g', 'gs.sku_id = g.sku_id', 'inner' ]
  186. ];
  187. $field = 'gs.goods_id,gs.sku_id,gs.sku_name,gs.price,gs.discount_price,gs.stock
  188. ,gs.sku_image,gs.goods_name,g.goods_spec_format,g.goods_state
  189. ,gs.promotion_type,g.goods_image
  190. ,gs.max_buy,gs.min_buy,gs.unit,gs.is_limit,gs.limit_type
  191. ,gs.goods_spec_format as goods_sku_spec_format,gs.sku_spec_format';
  192. $sku_list = model('goods_sku')->getList($condition, $field, 'g.sort,g.create_time desc', $alias, $join);
  193. foreach ($sku_list as $k => $v) {
  194. $sku_list[ $k ][ 'stock' ] = numberFormat($sku_list[ $k ][ 'stock' ]);
  195. $field = 'gs.goods_id,gs.sku_id,g.goods_image,gs.sku_name,gs.sku_spec_format,gs.price,gs.discount_price,gs.promotion_type,gs.stock,gs.sku_image,gs.sku_images,gs.goods_spec_format,gs.unit';
  196. $join = [
  197. [ 'goods g', 'g.goods_id = gs.goods_id', 'inner' ],
  198. ];
  199. $sku_list[ $k ][ 'sku_list' ] = model('goods_sku')->getList([ [ 'gs.goods_id', '=', $v[ 'goods_id' ] ], [ 'gs.site_id', '=', $site_id ], [ 'gs.is_delete', '=', 0 ] ], $field, 'gs.sku_id asc', 'gs', $join);
  200. if (!empty($sku_list[ $k ][ 'sku_list' ])) {
  201. foreach ($sku_list[ $k ][ 'sku_list' ] as $ck => $cv) {
  202. $sku_list[ $k ][ 'sku_list' ][ $ck ][ 'stock' ] = numberFormat($sku_list[ $k ][ 'sku_list' ][ $ck ][ 'stock' ]);
  203. }
  204. }
  205. }
  206. $info[ 'sku_list' ] = $sku_list;
  207. $info[ 'sku_list_count' ] = count($sku_list);
  208. }
  209. return $this->success($info);
  210. }
  211. /**
  212. * 获取分页列表
  213. * @param array $condition
  214. * @param int $page
  215. * @param int $page_size
  216. * @param string $order
  217. * @param string $field
  218. * @return array
  219. */
  220. public function getBalePageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = 'create_time desc', $field = '*')
  221. {
  222. $list = model('promotion_bale')->pageList($condition, $field, $order, $page, $page_size);
  223. return $this->success($list);
  224. }
  225. /**
  226. * 关闭活动
  227. * @param $bale_id
  228. * @return array
  229. */
  230. public function closeBale($bale_id)
  231. {
  232. $res = model("promotion_bale")->update([ 'status' => 2 ], [ [ 'bale_id', '=', $bale_id ] ]);
  233. $cron = new Cron();
  234. if ($res == 1) {
  235. $cron->deleteCron([ [ 'event', '=', 'CloseBale' ], [ 'relate_id', '=', $bale_id ] ]);
  236. }
  237. return $this->success($res);
  238. }
  239. /**
  240. * 活动推广链接
  241. * @param $page
  242. * @param $qrcode_param
  243. * @param string $promotion_type
  244. * @param $site_id
  245. * @return array
  246. */
  247. public function urlQrcode($page, $qrcode_param, $promotion_type, $site_id)
  248. {
  249. $params = [
  250. 'site_id' => $site_id,
  251. 'data' => $qrcode_param,
  252. 'page' => $page,
  253. 'promotion_type' => $promotion_type,
  254. 'h5_path' => $page . '?id=' . $qrcode_param[ 'id' ],
  255. 'qrcode_path' => 'upload/qrcode/bale',
  256. 'qrcode_name' => 'bale_qrcode_' . $promotion_type . '_' . $qrcode_param[ 'id' ] . '_' . $site_id
  257. ];
  258. $solitaire = event('ExtensionInformation', $params, true);
  259. return $this->success($solitaire);
  260. }
  261. }