Coupon.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. <?php
  2. namespace app\admin\controller;
  3. use GatewayWorker\Lib\Db;
  4. use think\facade\View;
  5. use think\facade\Lang;
  6. class Coupon extends AdminControl
  7. {
  8. /**
  9. * 卡券消费列表
  10. */
  11. public function coupon_expense_list()
  12. {
  13. $this->getExpenseList();
  14. return View::fetch('coupon_expense_list');
  15. }
  16. /**
  17. * 卡券管理列表
  18. */
  19. public function coupon_list()
  20. {
  21. // $this->get_complain_list(self::STATE_NEW, 'complain_new_list');
  22. $this->getCouponList();
  23. return View::fetch('coupon_list');
  24. // $complain_model = model('complain');
  25. // //搜索条件
  26. // $condition = array();
  27. // $condition[]=array('accuser_name','like', "%" . input('param.input_complain_accuser') . "%");
  28. // $condition[]=array('accused_name','like', "%" . input('param.input_complain_accused') . "%");
  29. // $condition[]=array('complain_subject_content','like', "%" . input('param.input_complain_subject_content') . "%");
  30. // if(input('param.input_complain_datetime_end')) {
  31. // $stime = strtotime(input('param.input_complain_datetime_start'));
  32. // $condition[]=array('complain_datetime','>=', $stime);
  33. // }
  34. // if(input('param.input_complain_datetime_end')){
  35. // $etime = strtotime(input('param.input_complain_datetime_end'))+86399;
  36. // $condition[]=array('complain_datetime','<=', $etime);
  37. // }
  38. // if ($action === 'complain_finish_list') {
  39. // $order= 'complain_id desc';
  40. // } else {
  41. // $order = 'complain_id asc';
  42. // }
  43. // $condition[]=array('complain_state','=',$complain_state);
  44. // $complain_list = $complain_model->getComplainList($condition, 10 ,$order);
  45. // $this->setAdminCurItem($action);
  46. // View::assign('complain_list', $complain_list);
  47. // View::assign('show_page', $complain_model->page_info->render());
  48. }
  49. /**
  50. * 卡券详情
  51. */
  52. public function coupon_info()
  53. {
  54. return View::fetch('coupon_info');
  55. }
  56. /**
  57. * 卡券消费列表
  58. */
  59. private function getExpenseList()
  60. {
  61. $where = [];
  62. $model = model('coupon');
  63. $expenseList = $model->getExpenseList($where,10,'expense_time desc');
  64. // echo json_encode($expenseList);exit;
  65. if(!empty($expenseList)){
  66. //用户数据
  67. $userIds = array_column($expenseList,'member_id');
  68. $userIds = array_values(array_unique($userIds));
  69. $map = [];
  70. $map[] = ['member_id','in',$userIds];
  71. $userList = model('member')->getMemberList($map,'member_id,member_nickname,member_name,member_avatar');
  72. $memberList = [];
  73. foreach($userList as $k =>$v){
  74. $memberList[$v['member_id']] = $v;
  75. }
  76. $virOrderIds = [];
  77. $orderIds = [];
  78. foreach($expenseList as $v){
  79. if($v['is_vir'] == 0){
  80. $orderIds[] = $v['order_id'];
  81. }else{
  82. $virOrderIds[] = $v['order_id'];
  83. }
  84. }
  85. //常规订单数据
  86. $orderList = [];
  87. if(!empty($orderIds)){
  88. $orderModel = model('order');
  89. $orderMap = [];
  90. $orderMap[] = ['order_id','in',$orderIds];
  91. $orderData = $orderModel->getOrderList($orderMap,'','order_id,order_sn,order_state,order_amount,buyer_name,store_name,add_time');
  92. if(!empty($orderData)){
  93. foreach($orderData as $k=>$v){
  94. $orderList[$v['order_id']] = $v;
  95. }
  96. }
  97. }
  98. //虚拟订单数据
  99. $virOrderList = [];
  100. if(!empty($virOrderIds)){
  101. $virModel = model('vrorder');
  102. $virMap = [];
  103. $virMap[] = ['order_id','in',$virOrderIds];
  104. $virData = $virModel->getVrorderList($virMap,'','order_id,order_sn,order_state,order_amount,buyer_name,store_name,add_time');
  105. if(!empty($virData)){
  106. foreach($virData as $k=>$v){
  107. $virOrderList[$v['order_id']] = $v;
  108. }
  109. }
  110. }
  111. //卡券数据
  112. $cardIds = array_values(array_unique(array_column($expenseList,'card_id')));
  113. $cardMap = [];
  114. $cardMap[] = ['id','in',$cardIds];
  115. $cardModel = model('coupon');
  116. $cardData = $cardModel->getCardList($cardMap,'','id,card_no');
  117. $cardList = [];
  118. if(!empty($cardData)){
  119. foreach($cardData as $k=>$v){
  120. $cardList[$v['id']] = $v;
  121. }
  122. }
  123. foreach($expenseList as $k=>$v){
  124. $expenseList[$k]['expense_time'] = date('Y-m-d H:i:s',$v['expense_time']);
  125. //卡券的
  126. if(!empty($cardList[$v['card_id']])){
  127. $cardInfo = $cardList[$v['card_id']];
  128. $expenseList[$k]['card_no'] = $cardInfo['card_no'];
  129. }else{
  130. $expenseList[$k]['card_no'] = '';
  131. }
  132. if($v['is_vir'] == 1){
  133. //虚拟订单的
  134. if(!empty($virOrderList[$v['order_id']])){
  135. $orderInfo = $virOrderList[$v['order_id']];
  136. $expenseList[$k]['order_id'] = $v['order_id'];
  137. $expenseList[$k]['order_sn'] = $orderInfo['order_sn'];
  138. $expenseList[$k]['order_amount'] = $orderInfo['order_amount'];
  139. $expenseList[$k]['buyer_name'] = $orderInfo['buyer_name'];
  140. $expenseList[$k]['store_name'] = $orderInfo['store_name'];
  141. $expenseList[$k]['add_time'] = date('Y-m-d H:i:s',$orderInfo['add_time']);
  142. }else{
  143. $expenseList[$k]['order_id'] = '';
  144. $expenseList[$k]['order_sn'] = '';
  145. $expenseList[$k]['order_amount'] = '';
  146. $expenseList[$k]['buyer_name'] = '';
  147. $expenseList[$k]['store_name'] = '';
  148. $expenseList[$k]['add_time'] = '';
  149. }
  150. }else{
  151. //实物订单的
  152. if(!empty($orderList[$v['order_id']])){
  153. $orderInfo = $orderList[$v['order_id']];
  154. $expenseList[$k]['order_id'] = $v['order_id'];
  155. $expenseList[$k]['order_sn'] = $orderInfo['order_sn'];
  156. $expenseList[$k]['order_amount'] = $orderInfo['order_amount'];
  157. $expenseList[$k]['buyer_name'] = $orderInfo['buyer_name'];
  158. $expenseList[$k]['store_name'] = $orderInfo['store_name'];
  159. $expenseList[$k]['add_time'] = date('Y-m-d H:i:s',$orderInfo['add_time']);
  160. }else{
  161. $expenseList[$k]['order_id'] = '';
  162. $expenseList[$k]['order_sn'] = '';
  163. $expenseList[$k]['order_amount'] = '';
  164. $expenseList[$k]['buyer_name'] = '';
  165. $expenseList[$k]['store_name'] = '';
  166. $expenseList[$k]['add_time'] = '';
  167. }
  168. }
  169. //用户的
  170. if(!empty($memberList[$v['member_id']])){
  171. $memberInfo = $memberList[$v['member_id']];
  172. $expenseList[$k]['member_nickname'] = $memberInfo['member_nickname'];
  173. if(empty($memberInfo['member_avatar']) || $memberInfo['member_avatar'] == null){
  174. $expenseList[$k]['member_avatar'] = HOME_SITE_ROOT . '/images/member/default_image.png';
  175. }else{
  176. $expenseList[$k]['member_avatar'] = $memberInfo['member_avatar'];
  177. }
  178. }else{
  179. $expenseList[$k]['member_nickname'] = '';
  180. $expenseList[$k]['member_avatar'] = HOME_SITE_ROOT . '/images/member/default_image.png';
  181. }
  182. $expenseList[$k]['expense_amount'] = number_format($v['expense_amount'],2);
  183. }
  184. }
  185. $action = 'coupon_expense_list';
  186. $this->setAdminCurItem($action);
  187. View::assign('expense_list', $expenseList);
  188. View::assign('show_page', $model->page_info->render());
  189. }
  190. /**
  191. * 卡券列表
  192. */
  193. private function getCouponList()
  194. {
  195. $where = [];
  196. $card_model = model('coupon');
  197. $card_list = $card_model->getCardList($where,10,'create_time desc');
  198. if(!empty($card_list)){
  199. $userIds = array_column($card_list,'member_id');
  200. $userIds = array_values(array_unique($userIds));
  201. $map = [];
  202. $map[] = ['member_id','in',$userIds];
  203. $userList = model('member')->getMemberList($map,'member_id,member_nickname,member_name,member_avatar');
  204. $rel = [];
  205. foreach($userList as $k =>$v){
  206. $rel[$v['member_id']] = $v;
  207. }
  208. foreach($card_list as $k =>$v){
  209. if(!empty($rel[$v['member_id']])){
  210. $userInfo = $rel[$v['member_id']];
  211. $card_list[$k]['member_nickname'] = $userInfo['member_nickname'];
  212. $card_list[$k]['member_avatar'] = $userInfo['member_avatar'];
  213. }else{
  214. $card_list[$k]['member_nickname'] = '';
  215. $card_list[$k]['member_avatar'] = '';
  216. }
  217. $card_list[$k]['balance'] = number_format($v['balance'],2);
  218. $card_list[$k]['worth'] = number_format($v['worth'],2);
  219. }
  220. }
  221. $action = 'coupon_list';
  222. $this->setAdminCurItem($action);
  223. View::assign('card_list', $card_list);
  224. View::assign('show_page', $card_model->page_info->render());
  225. }
  226. protected function getAdminItemList()
  227. {
  228. $menu_array = array(
  229. array(
  230. 'name' => 'coupon_list',
  231. 'text' => '卡券列表',
  232. 'url' => (string)url('coupon/coupon_list')
  233. ),
  234. array(
  235. 'name' => 'coupon_expense_list',
  236. 'text' => '消费记录',
  237. 'url' => (string)url('coupon/coupon_expense_list')
  238. )
  239. );
  240. if (request()->action() == 'complain_progress') {
  241. $menu_array[] = array(
  242. 'name' => 'complain_progress',
  243. 'text' => lang('complain_progress'),
  244. 'url' => '###'
  245. );
  246. }
  247. return $menu_array;
  248. }
  249. }