points.model.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. <?php
  2. /**
  3. * 积分及积分日志管理
  4. *
  5. *
  6. *
  7. *
  8. */
  9. defined('InShopNC') or exit('Access Invalid!');
  10. class pointsModel {
  11. /**
  12. * 操作积分
  13. * @author ShopNC Develop Team
  14. * @param string $stage 操作阶段 regist(注册),login(登录),comments(评论),order(下单),system(系统),other(其他),pointorder(积分礼品兑换),app(同步积分兑换)
  15. * @param array $insertarr 该数组可能包含信息 array('pl_memberid'=>'会员编号','pl_membername'=>'会员名称','pl_adminid'=>'管理员编号','pl_adminname'=>'管理员名称','pl_points'=>'积分','pl_desc'=>'描述','orderprice'=>'订单金额','order_sn'=>'订单编号','order_id'=>'订单序号','point_ordersn'=>'积分兑换订单编号');
  16. * @param bool $if_repeat 是否可以重复记录的信息,true可以重复记录,false不可以重复记录,默认为true
  17. * @return bool
  18. */
  19. function savePointsLog($stage,$insertarr,$if_repeat = true){
  20. if (!$insertarr['pl_memberid']){
  21. return false;
  22. }
  23. //记录原因文字
  24. switch ($stage){
  25. case 'regist':
  26. if (!$insertarr['pl_desc']){
  27. $insertarr['pl_desc'] = '注册会员';
  28. }
  29. $insertarr['pl_points'] = intval(C('points_reg'));
  30. break;
  31. case 'login':
  32. if (!$insertarr['pl_desc']){
  33. $insertarr['pl_desc'] = '会员登录';
  34. }
  35. $insertarr['pl_points'] = intval(C('points_login'));
  36. break;
  37. case 'comments':
  38. if (!$insertarr['pl_desc']){
  39. $insertarr['pl_desc'] = '评论商品';
  40. }
  41. $insertarr['pl_points'] = intval(C('points_comments'));
  42. break;
  43. case 'order':
  44. if (!$insertarr['pl_desc']){
  45. $insertarr['pl_desc'] = '订单'.$insertarr['order_sn'].'购物消费';
  46. }
  47. $insertarr['pl_points'] = 0;
  48. if ($insertarr['orderprice']){
  49. $insertarr['pl_points'] = @intval($insertarr['orderprice']/C('points_orderrate'));
  50. if ($insertarr['pl_points'] > intval(C('points_ordermax'))){
  51. $insertarr['pl_points'] = intval(C('points_ordermax'));
  52. }
  53. }
  54. //订单添加赠送积分列
  55. $obj_order = Model('order');
  56. $data = array();
  57. $data['order_pointscount'] = array('exp','order_pointscount+'.$insertarr['pl_points']);
  58. $obj_order->editOrderCommon($data,array('order_id'=>$insertarr['order_id']));
  59. break;
  60. case 'system':
  61. break;
  62. case 'pointorder':
  63. if (!$insertarr['pl_desc']){
  64. $insertarr['pl_desc'] = '兑换礼品信息'.$insertarr['point_ordersn'].'消耗积分';
  65. }
  66. break;
  67. case 'app':
  68. if (!$insertarr['pl_desc']){
  69. $insertarr['pl_desc'] = Language::get('points_pointorderdesc_app');
  70. }
  71. //邀请积分返利 33 hao.co m v3
  72. break;
  73. case 'inviter':
  74. if (!$insertarr['pl_desc']){
  75. $insertarr['pl_desc'] = '邀请新会员['.$insertarr['invited'].']注册';
  76. }
  77. $insertarr['pl_points'] = intval($GLOBALS['setting_config']['points_invite']);
  78. break;
  79. case 'rebate':
  80. if (!$insertarr['pl_desc']){
  81. $insertarr['pl_desc'] = '被邀请人['.$_SESSION['member_name'].']消费';
  82. }
  83. $insertarr['pl_points'] = $insertarr['rebate_amount'];
  84. break;
  85. case 'other':
  86. break;
  87. }
  88. $save_sign = true;
  89. if ($if_repeat == false){
  90. //检测是否有相关信息存在,如果没有,入库
  91. $condition['pl_memberid'] = $insertarr['pl_memberid'];
  92. $condition['pl_stage'] = $stage;
  93. $log_array = self::getPointsInfo($condition,$page);
  94. if (!empty($log_array)){
  95. $save_sign = false;
  96. }
  97. }
  98. if ($save_sign == false){
  99. return true;
  100. }
  101. //新增日志
  102. $value_array = array();
  103. $value_array['pl_memberid'] = $insertarr['pl_memberid'];
  104. $value_array['pl_membername'] = $insertarr['pl_membername'];
  105. if ($insertarr['pl_adminid']){
  106. $value_array['pl_adminid'] = $insertarr['pl_adminid'];
  107. }
  108. if ($insertarr['pl_adminname']){
  109. $value_array['pl_adminname'] = $insertarr['pl_adminname'];
  110. }
  111. $value_array['pl_points'] = $insertarr['pl_points'];
  112. $value_array['pl_addtime'] = time();
  113. $value_array['pl_desc'] = $insertarr['pl_desc'];
  114. $value_array['pl_stage'] = $stage;
  115. $result = false;
  116. if($value_array['pl_points'] != '0'){
  117. $result = self::addPointsLog($value_array);
  118. }
  119. if ($result){
  120. //更新member内容
  121. $obj_member = Model('member');
  122. $upmember_array = array();
  123. $upmember_array['member_points'] = array('exp','member_points+'.$insertarr['pl_points']);
  124. $obj_member->editMember(array('member_id'=>$insertarr['pl_memberid']),$upmember_array);
  125. return true;
  126. }else {
  127. return false;
  128. }
  129. }
  130. /**
  131. * 添加积分日志信息
  132. *
  133. * @param array $param 添加信息数组
  134. */
  135. public function addPointsLog($param) {
  136. if(empty($param)) {
  137. return false;
  138. }
  139. $result = Db::insert('points_log',$param);
  140. return $result;
  141. }
  142. /**
  143. * 积分日志列表
  144. *
  145. * @param array $condition 条件数组
  146. * @param array $page 分页
  147. * @param array $field 查询字段
  148. * @param array $page 分页
  149. */
  150. public function getPointsLogList($condition,$page='',$field='*'){
  151. $condition_str = $this->getCondition($condition);
  152. $param = array();
  153. $param['table'] = 'points_log';
  154. $param['where'] = $condition_str;
  155. $param['field'] = $field;
  156. $param['order'] = $condition['order'] ? $condition['order'] : 'points_log.pl_id desc';
  157. $param['limit'] = $condition['limit'];
  158. $param['group'] = $condition['group'];
  159. return Db::select($param,$page);
  160. }
  161. /**
  162. * 积分日志详细信息
  163. *
  164. * @param array $condition 条件数组
  165. * @param array $field 查询字段
  166. */
  167. public function getPointsInfo($condition,$field='*'){
  168. //得到条件语句
  169. $condition_str = $this->getCondition($condition);
  170. $array = array();
  171. $array['table'] = 'points_log';
  172. $array['where'] = $condition_str;
  173. $array['field'] = $field;
  174. $list = Db::select($array);
  175. return $list[0];
  176. }
  177. /**
  178. * 将条件数组组合为SQL语句的条件部分
  179. *
  180. * @param array $condition_array
  181. * @return string
  182. */
  183. private function getCondition($condition_array){
  184. $condition_sql = '';
  185. //积分日志会员编号
  186. if ($condition_array['pl_memberid']) {
  187. $condition_sql .= " and `points_log`.pl_memberid = '{$condition_array['pl_memberid']}'";
  188. }
  189. //操作阶段
  190. if ($condition_array['pl_stage']) {
  191. $condition_sql .= " and `points_log`.pl_stage = '{$condition_array['pl_stage']}'";
  192. }
  193. //会员名称
  194. if ($condition_array['pl_membername_like']) {
  195. $condition_sql .= " and `points_log`.pl_membername like '%{$condition_array['pl_membername_like']}%'";
  196. }
  197. //管理员名称
  198. if ($condition_array['pl_adminname_like']) {
  199. $condition_sql .= " and `points_log`.pl_adminname like '%{$condition_array['pl_adminname_like']}%'";
  200. }
  201. //添加时间
  202. if ($condition_array['saddtime']){
  203. $condition_sql .= " and `points_log`.pl_addtime >= '{$condition_array['saddtime']}'";
  204. }
  205. if ($condition_array['eaddtime']){
  206. $condition_sql .= " and `points_log`.pl_addtime <= '{$condition_array['eaddtime']}'";
  207. }
  208. //描述
  209. if ($condition_array['pl_desc_like']){
  210. $condition_sql .= " and `points_log`.pl_desc like '%{$condition_array['pl_desc_like']}%'";
  211. }
  212. return $condition_sql;
  213. }
  214. }