p_xianshi.model.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. <?php
  2. /**
  3. * 限时折扣活动模型
  4. *
  5. *
  6. *
  7. *
  8. */
  9. defined('InShopNC') or exit('Access Invalid!');
  10. class p_xianshiModel extends Model{
  11. const XIANSHI_STATE_NORMAL = 1;
  12. const XIANSHI_STATE_CLOSE = 2;
  13. const XIANSHI_STATE_CANCEL = 3;
  14. private $xianshi_state_array = array(
  15. 0 => '全部',
  16. self::XIANSHI_STATE_NORMAL => '正常',
  17. self::XIANSHI_STATE_CLOSE => '已结束',
  18. self::XIANSHI_STATE_CANCEL => '管理员关闭'
  19. );
  20. public function __construct(){
  21. parent::__construct('p_xianshi');
  22. }
  23. /**
  24. * 读取限时折扣列表
  25. * @param array $condition 查询条件
  26. * @param int $page 分页数
  27. * @param string $order 排序
  28. * @param string $field 所需字段
  29. * @return array 限时折扣列表
  30. *
  31. */
  32. public function getXianshiList($condition, $page=null, $order='', $field='*') {
  33. $xianshi_list = $this->field($field)->where($condition)->page($page)->order($order)->select();
  34. if(!empty($xianshi_list)) {
  35. for($i =0, $j = count($xianshi_list); $i < $j; $i++) {
  36. $xianshi_list[$i] = $this->getXianshiExtendInfo($xianshi_list[$i]);
  37. }
  38. }
  39. return $xianshi_list;
  40. }
  41. /**
  42. * 根据条件读取限制折扣信息
  43. * @param array $condition 查询条件
  44. * @return array 限时折扣信息
  45. *
  46. */
  47. public function getXianshiInfo($condition) {
  48. $xianshi_info = $this->where($condition)->find();
  49. $xianshi_info = $this->getXianshiExtendInfo($xianshi_info);
  50. return $xianshi_info;
  51. }
  52. /**
  53. * 根据限时折扣编号读取限制折扣信息
  54. * @param array $xianshi_id 限制折扣活动编号
  55. * @param int $store_id 如果提供店铺编号,判断是否为该店铺活动,如果不是返回null
  56. * @return array 限时折扣信息
  57. *
  58. */
  59. public function getXianshiInfoByID($xianshi_id, $store_id = 0) {
  60. if(intval($xianshi_id) <= 0) {
  61. return null;
  62. }
  63. $condition = array();
  64. $condition['xianshi_id'] = $xianshi_id;
  65. $xianshi_info = $this->getXianshiInfo($condition);
  66. if($store_id > 0 && $xianshi_info['store_id'] != $store_id) {
  67. return null;
  68. } else {
  69. return $xianshi_info;
  70. }
  71. }
  72. /**
  73. * 限时折扣状态数组
  74. *
  75. */
  76. public function getXianshiStateArray() {
  77. return $this->xianshi_state_array;
  78. }
  79. /*
  80. * 增加
  81. * @param array $param
  82. * @return bool
  83. *
  84. */
  85. public function addXianshi($param){
  86. $param['state'] = self::XIANSHI_STATE_NORMAL;
  87. return $this->insert($param);
  88. }
  89. /*
  90. * 更新
  91. * @param array $update
  92. * @param array $condition
  93. * @return bool
  94. *
  95. */
  96. public function editXianshi($update, $condition){
  97. return $this->where($condition)->update($update);
  98. }
  99. /*
  100. * 删除限时折扣活动,同时删除限时折扣商品
  101. * @param array $condition
  102. * @return bool
  103. *
  104. */
  105. public function delXianshi($condition){
  106. $xianshi_list = $this->getXianshiList($condition);
  107. $xianshi_id_string = '';
  108. if(!empty($xianshi_list)) {
  109. foreach ($xianshi_list as $value) {
  110. $xianshi_id_string .= $value['xianshi_id'] . ',';
  111. }
  112. }
  113. //删除限时折扣商品
  114. if($xianshi_id_string !== '') {
  115. $model_xianshi_goods = Model('p_xianshi_goods');
  116. $model_xianshi_goods->delXianshiGoods(array('xianshi_id'=>array('in', $xianshi_id_string)));
  117. }
  118. return $this->where($condition)->delete();
  119. }
  120. /*
  121. * 取消限时折扣活动,同时取消限时折扣商品
  122. * @param array $condition
  123. * @return bool
  124. *
  125. */
  126. public function cancelXianshi($condition){
  127. $xianshi_list = $this->getXianshiList($condition);
  128. $xianshi_id_string = '';
  129. if(!empty($xianshi_list)) {
  130. foreach ($xianshi_list as $value) {
  131. $xianshi_id_string .= $value['xianshi_id'] . ',';
  132. }
  133. }
  134. $update = array();
  135. $update['state'] = self::XIANSHI_STATE_CANCEL;
  136. //删除限时折扣商品
  137. if($xianshi_id_string !== '') {
  138. $model_xianshi_goods = Model('p_xianshi_goods');
  139. $model_xianshi_goods->editXianshiGoods($update, array('xianshi_id'=>array('in', $xianshi_id_string)));
  140. }
  141. return $this->editXianshi($update, $condition);
  142. }
  143. /**
  144. * 获取限时折扣扩展信息,包括状态文字和是否可编辑状态
  145. * @param array $xianshi_info
  146. * @return string
  147. *
  148. */
  149. public function getXianshiExtendInfo($xianshi_info) {
  150. if($xianshi_info['end_time'] > TIMESTAMP) {
  151. $xianshi_info['xianshi_state_text'] = $this->xianshi_state_array[$xianshi_info['state']];
  152. } else {
  153. $xianshi_info['xianshi_state_text'] = '已结束';
  154. }
  155. if($xianshi_info['state'] == self::XIANSHI_STATE_NORMAL && $xianshi_info['end_time'] > TIMESTAMP) {
  156. $xianshi_info['editable'] = true;
  157. } else {
  158. $xianshi_info['editable'] = false;
  159. }
  160. return $xianshi_info;
  161. }
  162. /**
  163. * 过期修改状态
  164. */
  165. public function editExpireXianshi($condition) {
  166. $condition['end_time'] = array('lt', TIMESTAMP);
  167. // 更新商品促销价格
  168. $xianshigoods_list = Model('p_xianshi_goods')->getXianshiGoodsList($condition);
  169. if (!empty($xianshigoods_list)) {
  170. $goodsid_array = array();
  171. foreach ($xianshigoods_list as $val) {
  172. $goodsid_array[] = $val['goods_id'];
  173. }
  174. // 更新商品促销价格,需要考虑抢购是否在进行中
  175. QueueClient::push('updateGoodsPromotionPriceByGoodsId', $goodsid_array);
  176. }
  177. $condition['state'] = self::XIANSHI_STATE_NORMAL;
  178. $updata = array();
  179. $update['state'] = self::XIANSHI_STATE_CLOSE;
  180. $this->editXianshi($update, $condition);
  181. return true;
  182. }
  183. }