You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

183 lines
6.5 KiB

6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. <?php
  2. namespace App\Http\Logic;
  3. use App\Common\ReturnData;
  4. use App\Http\Model\UserBonus;
  5. use App\Http\Requests\UserBonusRequest;
  6. use Validator;
  7. class UserBonusLogic extends BaseLogic
  8. {
  9. public function __construct()
  10. {
  11. parent::__construct();
  12. }
  13. public function getModel()
  14. {
  15. return new UserBonus();
  16. }
  17. public function getValidate($data, $scene_name)
  18. {
  19. //数据验证
  20. $validate = new UserBonusRequest();
  21. return Validator::make($data, $validate->getSceneRules($scene_name), $validate->getSceneRulesMessages());
  22. }
  23. //列表
  24. public function getList($where = array(), $order = '', $field = '*', $offset = '', $limit = '')
  25. {
  26. $res = $this->getModel()->getList($where, $order, $field, $offset, $limit);
  27. if($res['count'] > 0)
  28. {
  29. foreach($res['list'] as $k=>$v)
  30. {
  31. $res['list'][$k] = $this->getDataView($v);
  32. $res['list'][$k]->bonus = model('Bonus')->getOne(['id'=>$v->bonus_id]);
  33. }
  34. }
  35. return $res;
  36. }
  37. //分页html
  38. public function getPaginate($where = array(), $order = '', $field = '*', $limit = '')
  39. {
  40. $res = $this->getModel()->getPaginate($where, $order, $field, $limit);
  41. return $res;
  42. }
  43. //全部列表
  44. public function getAll($where = array(), $order = '', $field = '*', $limit = '')
  45. {
  46. $res = $this->getModel()->getAll($where, $order, $field, $limit);
  47. /* if($res)
  48. {
  49. foreach($res as $k=>$v)
  50. {
  51. $res[$k] = $this->getDataView($v);
  52. }
  53. } */
  54. return $res;
  55. }
  56. //详情
  57. public function getOne($where = array(), $field = '*')
  58. {
  59. $res = $this->getModel()->getOne($where, $field);
  60. if(!$res){return false;}
  61. $res = $this->getDataView($res);
  62. $res->bonus = model('Bonus')->getOne(['id'=>$res->bonus_id]);
  63. return $res;
  64. }
  65. //用户获取优惠券
  66. public function add($data = array(), $type=0)
  67. {
  68. if(empty($data)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  69. $validator = $this->getValidate($data, 'add');
  70. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  71. $data['get_time'] = time();
  72. $bonus = model('Bonus')->getOne(['id'=>$data['bonus_id']]);
  73. if(!$bonus){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'亲,您来晚了啦,已被抢光了');}
  74. if($bonus->num==-1 || $bonus->num>0){}else{return ReturnData::create(ReturnData::PARAMS_ERROR,null,'亲,您来晚了啦,已被抢光了');}
  75. if($this->getModel()->getOne(['bonus_id'=>$data['bonus_id'],'user_id'=>$data['user_id']])){return ReturnData::create(ReturnData::PARAMS_ERROR,null,'亲,您已获取!');}
  76. $data['get_time'] = time(); //优惠券获取时间
  77. $res = $this->getModel()->add($data,$type);
  78. if($res)
  79. {
  80. if($bonus->num>0){model('Bonus')->getDb()->where(array('id'=>$data['bonus_id']))->decrement('num', 1);}
  81. return ReturnData::create(ReturnData::SUCCESS,$res);
  82. }
  83. return ReturnData::create(ReturnData::FAIL);
  84. }
  85. //修改
  86. public function edit($data, $where = array())
  87. {
  88. if(empty($data)){return ReturnData::create(ReturnData::SUCCESS);}
  89. $validator = $this->getValidate($data, 'edit');
  90. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  91. $res = $this->getModel()->edit($data,$where);
  92. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  93. return ReturnData::create(ReturnData::FAIL);
  94. }
  95. //删除
  96. public function del($where)
  97. {
  98. if(empty($where)){return ReturnData::create(ReturnData::PARAMS_ERROR);}
  99. $validator = $this->getValidate($where,'del');
  100. if ($validator->fails()){return ReturnData::create(ReturnData::PARAMS_ERROR, null, $validator->errors()->first());}
  101. $res = $this->getModel()->del($where);
  102. if($res){return ReturnData::create(ReturnData::SUCCESS,$res);}
  103. return ReturnData::create(ReturnData::FAIL);
  104. }
  105. /**
  106. * 数据获取器
  107. * @param array $data 要转化的数据
  108. * @return array
  109. */
  110. private function getDataView($data = array())
  111. {
  112. return getDataAttr($this->getModel(),$data);
  113. }
  114. /**
  115. * 商品结算时,获取优惠券列表
  116. * @param float $param['min_amount'] 最小金额可以用的优惠券
  117. * @return array
  118. */
  119. public function getAvailableBonusList(array $param)
  120. {
  121. $where['user_bonus.user_id'] = $param['user_id'];
  122. if(isset($status)){$where['bonus.status'] = 0;}
  123. $model = model('UserBonus')->getDb();
  124. if(isset($param['min_amount'])){$model = $model->where('bonus.min_amount', '<=', $param['min_amount'])->where('bonus.money', '<=', $param['min_amount']);} //满多少使用
  125. $model = $model->where('bonus.end_time', '>=', date('Y-m-d H:i:s')); //有效期
  126. $bonus_list = $model->join('bonus', 'bonus.id', '=', 'user_bonus.bonus_id')->where($where)
  127. ->select('bonus.*', 'user_bonus.user_id', 'user_bonus.used_time', 'user_bonus.get_time', 'user_bonus.status as user_bonus_status', 'user_bonus.id as user_bonus_id')
  128. ->orderBy('bonus.money','desc')->get();
  129. $res['list'] = $bonus_list;
  130. return $res;
  131. }
  132. public function getUserBonusByid(array $param)
  133. {
  134. $where['user_bonus.user_id'] = $param['user_id'];
  135. $where['bonus.status'] = 0;
  136. $where['user_bonus.id'] = $param['user_bonus_id'];
  137. $model = model('UserBonus')->getDb();
  138. if(isset($param['min_amount'])){$model = $model->where('bonus.min_amount', '<=', $param['min_amount'])->where('bonus.money', '<=', $param['min_amount']);} //满多少使用
  139. $model = $model->where('bonus.end_time', '>=', date('Y-m-d H:i:s')); //有效期
  140. $bonus = $model->join('bonus', 'bonus.id', '=', 'user_bonus.bonus_id')->where($where)
  141. ->select('bonus.*', 'user_bonus.user_id', 'user_bonus.used_time', 'user_bonus.get_time', 'user_bonus.status as user_bonus_status', 'user_bonus.id as user_bonus_id')
  142. ->first();
  143. return $bonus;
  144. }
  145. }