points.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. <?php
  2. /**
  3. * 积分管理
  4. *
  5. ***/
  6. defined('InShopNC') or exit('Access Invalid!');
  7. class pointsControl extends SystemControl
  8. {
  9. const EXPORT_SIZE = 5000;
  10. public function __construct(){
  11. parent::__construct();
  12. Language::read('points');
  13. //判断系统是否开启积分功能
  14. if (C('points_isuse') != 1){
  15. showMessage(Language::get('admin_points_unavailable'),'index.php?act=dashboard&op=welcome','','error');
  16. }
  17. }
  18. /**
  19. * 积分添加
  20. */
  21. public function addpointsOp(){
  22. if (chksubmit()){
  23. $obj_validate = new Validator();
  24. $obj_validate->validateparam = array(
  25. array("input"=>$_POST["member_id"], "require"=>"true", "message"=>Language::get('admin_points_member_error_again')),
  26. array("input"=>$_POST["pointsnum"], "require"=>"true",'validator'=>'Compare','operator'=>' >= ','to'=>1,"message"=>Language::get('admin_points_points_min_error'))
  27. );
  28. $error = $obj_validate->validate();
  29. if ($error != ''){
  30. showMessage($error,'','','error');
  31. }
  32. //查询会员信息
  33. $obj_member = Model('member');
  34. $member_id = intval($_POST['member_id']);
  35. $member_info = $obj_member->getMemberInfo(array('member_id'=>$member_id));
  36. if (!is_array($member_info) || count($member_info)<=0){
  37. showMessage(Language::get('admin_points_userrecord_error'),'index.php?act=points&op=addpoints','','error');
  38. }
  39. $pointsnum = intval($_POST['pointsnum']);
  40. if ($_POST['operatetype'] == 2 && $pointsnum > intval($member_info['member_points'])){
  41. showMessage(Language::get('admin_points_points_short_error').$member_info['member_points'],'index.php?act=points&op=addpoints','','error');
  42. }
  43. $obj_points = Model('points');
  44. $insert_arr['pl_memberid'] = $member_info['member_id'];
  45. $insert_arr['pl_membername'] = $member_info['member_name'];
  46. $admininfo = $this->getAdminInfo();
  47. $insert_arr['pl_adminid'] = $admininfo['id'];
  48. $insert_arr['pl_adminname'] = $admininfo['name'];
  49. if ($_POST['operatetype'] == 2){
  50. $insert_arr['pl_points'] = -$_POST['pointsnum'];
  51. }else {
  52. $insert_arr['pl_points'] = $_POST['pointsnum'];
  53. }
  54. if ($_POST['pointsdesc']){
  55. $insert_arr['pl_desc'] = trim($_POST['pointsdesc']);
  56. } else {
  57. $insert_arr['pl_desc'] = Language::get('admin_points_system_desc');
  58. }
  59. $result = $obj_points->savePointsLog('system',$insert_arr,true);
  60. if ($result){
  61. $this->log(L('admin_points_mod_tip').$member_info['member_name'].'['.(($_POST['operatetype'] == 2)?'':'+').strval($insert_arr['pl_points']).']',null);
  62. showMessage(Language::get('nc_common_save_succ'),'index.php?act=points&op=addpoints');
  63. }else {
  64. showMessage(Language::get('nc_common_save_fail'),'index.php?act=points&op=addpoints','','error');
  65. }
  66. }else {
  67. Tpl::showpage('points.add');
  68. }
  69. }
  70. public function checkmemberOp(){
  71. $name = trim($_GET['name']);
  72. if (!$name){
  73. echo ''; die;
  74. }
  75. /**
  76. * 转码
  77. */
  78. if(strtoupper(CHARSET) == 'GBK'){
  79. $name = Language::getGBK($name);
  80. }
  81. $obj_member = Model('member');
  82. $member_info = $obj_member->getMemberInfo(array('member_name'=>$name));
  83. if (is_array($member_info) && count($member_info)>0){
  84. if(strtoupper(CHARSET) == 'GBK'){
  85. $member_info['member_name'] = Language::getUTF8($member_info['member_name']);
  86. }
  87. echo json_encode(array('id'=>$member_info['member_id'],'name'=>$member_info['member_name'],'points'=>$member_info['member_points']));
  88. }else {
  89. echo ''; die;
  90. }
  91. }
  92. /**
  93. * 积分日志列表
  94. */
  95. public function pointslogOp(){
  96. $condition_arr = array();
  97. $condition_arr['pl_membername_like'] = trim($_GET['mname']);
  98. $condition_arr['pl_adminname_like'] = trim($_GET['aname']);
  99. if ($_GET['stage']){
  100. $condition_arr['pl_stage'] = trim($_GET['stage']);
  101. }
  102. $condition_arr['saddtime'] = strtotime($_GET['stime']);
  103. $condition_arr['eaddtime'] = strtotime($_GET['etime']);
  104. if($condition_arr['eaddtime'] > 0) {
  105. $condition_arr['eaddtime'] += 86400;
  106. }
  107. $condition_arr['pl_desc_like'] = trim($_GET['description']);
  108. //分页
  109. $page = new Page();
  110. $page->setEachNum(10);
  111. $page->setStyle('admin');
  112. //查询积分日志列表
  113. $points_model = Model('points');
  114. $list_log = $points_model->getPointsLogList($condition_arr,$page,'*','');
  115. //信息输出
  116. Tpl::output('show_page',$page->show());
  117. Tpl::output('list_log',$list_log);
  118. Tpl::showpage('pointslog');
  119. }
  120. /**
  121. * 积分日志列表导出
  122. */
  123. public function export_step1Op(){
  124. $condition_arr = array();
  125. $condition_arr['pl_membername_like'] = trim($_GET['mname']);
  126. $condition_arr['pl_adminname_like'] = trim($_GET['aname']);
  127. if ($_GET['stage']){
  128. $condition_arr['pl_stage'] = trim($_GET['stage']);
  129. }
  130. $condition_arr['saddtime'] = strtotime($_GET['stime']);
  131. $condition_arr['eaddtime'] = strtotime($_GET['etime']);
  132. if($condition_arr['eaddtime'] > 0) {
  133. $condition_arr['eaddtime'] += 86400;
  134. }
  135. $condition_arr['pl_desc_like'] = trim($_GET['description']);
  136. $page = new Page();
  137. $page->setEachNum(self::EXPORT_SIZE);
  138. $points_model = Model('points');
  139. $list_log = $points_model->getPointsLogList($condition_arr,$page,'*','');
  140. if (!is_numeric($_GET['curpage'])){
  141. $count = $page->getTotalNum();
  142. $array = array();
  143. if ($count > self::EXPORT_SIZE ){ //显示下载链接
  144. $page = ceil($count/self::EXPORT_SIZE);
  145. for ($i=1;$i<=$page;$i++){
  146. $limit1 = ($i-1)*self::EXPORT_SIZE + 1;
  147. $limit2 = $i*self::EXPORT_SIZE > $count ? $count : $i*self::EXPORT_SIZE;
  148. $array[$i] = $limit1.' ~ '.$limit2 ;
  149. }
  150. Tpl::output('list',$array);
  151. Tpl::output('murl','index.php?act=pointslog&op=pointslog');
  152. Tpl::showpage('export.excel');
  153. }else{ //如果数量小,直接下载
  154. $this->createExcel($list_log);
  155. }
  156. }else{ //下载
  157. $this->createExcel($list_log);
  158. }
  159. }
  160. /**
  161. * 生成excel
  162. *
  163. * @param array $data
  164. */
  165. private function createExcel($data = array()){
  166. Language::read('export');
  167. import('libraries.excel');
  168. $excel_obj = new Excel();
  169. $excel_data = array();
  170. //设置样式
  171. $excel_obj->setStyle(array('id'=>'s_title','Font'=>array('FontName'=>'宋体','Size'=>'12','Bold'=>'1')));
  172. //header
  173. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_pi_member'));
  174. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_pi_system'));
  175. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_pi_point'));
  176. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_pi_time'));
  177. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_pi_jd'));
  178. $excel_data[0][] = array('styleid'=>'s_title','data'=>L('exp_pi_ms'));
  179. $state_cn = array(Language::get('admin_points_stage_regist'),Language::get('admin_points_stage_login'),Language::get('admin_points_stage_comments'),Language::get('admin_points_stage_order'),Language::get('admin_points_stage_system'),Language::get('admin_points_stage_pointorder'),Language::get('admin_points_stage_app'));
  180. foreach ((array)$data as $k=>$v){
  181. $tmp = array();
  182. $tmp[] = array('data'=>$v['pl_membername']);
  183. $tmp[] = array('data'=>$v['pl_adminname']);
  184. $tmp[] = array('format'=>'Number','data'=>ncPriceFormat($v['pl_points']));
  185. $tmp[] = array('data'=>date('Y-m-d H:i:s',$v['pl_addtime']));
  186. $tmp[] = array('data'=>str_replace(array('regist','login','comments','order','system','pointorder','app'),$state_cn,$v['pl_stage']));
  187. $tmp[] = array('data'=>$v['pl_desc']);
  188. $excel_data[] = $tmp;
  189. }
  190. $excel_data = $excel_obj->charset($excel_data,CHARSET);
  191. $excel_obj->addArray($excel_data);
  192. $excel_obj->addWorksheet($excel_obj->charset(L('exp_pi_jfmx'),CHARSET));
  193. $excel_obj->generateXML($excel_obj->charset(L('exp_pi_jfmx'),CHARSET).$_GET['curpage'].'-'.date('Y-m-d-H',time()));
  194. }
  195. }