Membercard.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 上海牛之云网络科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
  9. * 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
  10. * =========================================================
  11. */
  12. namespace addon\cardservice\storeapi\controller;
  13. use addon\cardservice\model\MemberCard as MemberCardModel;
  14. use app\storeapi\controller\BaseStoreApi;
  15. /**
  16. * 会员管理 控制器
  17. */
  18. class Membercard extends BaseStoreApi
  19. {
  20. /**
  21. * 会员卡项
  22. */
  23. public function lists()
  24. {
  25. $member_id = isset($this->params[ 'member_id' ]) ? $this->params[ 'member_id' ] : 0;
  26. $page = isset($this->params[ 'page' ]) ? $this->params[ 'page' ] : 1;
  27. $page_size = isset($this->params[ 'page_size' ]) ? $this->params[ 'page_size' ] : PAGE_LIST_ROWS;
  28. $status = $this->params[ 'status' ] ?? 'all';
  29. $member_oncecard_model = new MemberCardModel();
  30. $condition = [
  31. [ 'mgc.member_id', '=', $member_id ],
  32. [ 'mgc.site_id', '=', $this->site_id ],
  33. [ 'g.is_delete', '=', 0 ]
  34. ];
  35. if ($status != 'all') $condition[] = [ 'mgc.status', '=', $status ];
  36. $field = 'mgc.card_id, mgc.create_time, mgc.end_time, mgc.status, mgc.card_code, mgc.card_type, mgc.goods_name, mgc.total_num, mgc.total_use_num';
  37. $res = $member_oncecard_model->getCardPageList($condition, $field, 'mgc.create_time desc', $page, $page_size, 'mgc', [
  38. [ 'goods g', 'g.goods_id = mgc.goods_id', 'inner' ]
  39. ]);
  40. if (empty($res[ 'data' ])) return $res;
  41. foreach ($res[ 'data' ][ 'list' ] as $k => $v) {
  42. $alias = 'i';
  43. $join = [
  44. [ 'goods g', 'i.goods_id = g.goods_id', 'inner' ],
  45. [ 'goods_sku gs', 'i.sku_id = gs.sku_id', 'inner' ],
  46. [ 'verify mv', 'i.member_verify_id = mv.id', 'inner' ],
  47. [ 'store_goods_sku sgs', 'i.sku_id=sgs.sku_id and sgs.store_id=' . $this->store_id, 'inner' ],
  48. [ 'store s', 's.store_id = sgs.store_id', 'left' ]
  49. ];
  50. $field = 'i.*, gs.sku_name,gs.sku_image, gs.is_virtual, mv.verify_code, IF(g.is_unify_price = 1,gs.price,sgs.price) as price,IF(s.stock_type = "store",sgs.stock, gs.stock) as stock';
  51. $order = 'i.item_id asc';
  52. $res[ 'data' ][ 'list' ][ $k ][ 'item_list' ] = $member_oncecard_model->getCartItemList([
  53. [ 'i.card_id', '=', $v[ 'card_id' ] ],
  54. [ 'i.site_id', '=', $this->site_id ],
  55. [ 'i.member_id', '=', $member_id ],
  56. [ 'sgs.status', '=', 1 ],
  57. [ 'g.is_delete', '=', 0 ]
  58. ], $field, $order, $alias, $join)[ 'data' ];
  59. foreach ($res[ 'data' ][ 'list' ][ $k ][ 'item_list' ] as $ck => $cv) {
  60. $res[ 'data' ][ 'list' ][ $k ][ 'item_list' ][ $ck ][ 'stock' ] = numberFormat($res[ 'data' ][ 'list' ][ $k ][ 'item_list' ][ $ck ][ 'stock' ]);
  61. }
  62. }
  63. return $this->response($res);
  64. }
  65. /**
  66. * 卡项详情
  67. */
  68. public function detail()
  69. {
  70. $card_id = $this->params[ 'card_id' ] ?? 0;
  71. $member_id = $this->params[ 'member_id' ] ?? 0;
  72. if (empty($card_id) || empty($card_id)) {
  73. return $this->response($this->error('', 'REQUEST_ID'));
  74. }
  75. $model = new MemberCardModel();
  76. $condition = [
  77. [ 'mgc.site_id', '=', $this->site_id ],
  78. [ 'mgc.member_id', '=', $member_id ],
  79. [ 'mgc.card_id', '=', $card_id ],
  80. [ 'g.is_delete', '=', 0 ],
  81. ];
  82. $field = 'mgc.*, g.goods_name,g.price,g.goods_image,g.introduction,g.goods_content';
  83. $join = [
  84. [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
  85. ];
  86. $info = $model->getCardInfo($condition, $field, 'mgc', $join)[ 'data' ];
  87. if (empty($info)) return $this->response($this->error('', '未获取到卡项信息'));
  88. $condition = [
  89. [ 'mgci.card_id', '=', $info[ 'card_id' ] ],
  90. [ 'sku.is_delete', '=', 0 ],
  91. ];
  92. $info[ 'card_item' ] = $model->getCartItemList($condition, 'mgci.*,sku.sku_name,sku.price,sku.sku_image,sku.sku_images,sku.goods_class_name,sku.stock,
  93. v.verify_code,v.verify_type,v.verify_type_name,v.verify_content_json,v.verifier_id,v.verifier_name,v.is_verify,v.verify_time,v.expire_time,v.verify_from,v.verify_remark,v.verify_total_count,v.verify_use_num', 'mgci.card_id asc', 'mgci', [
  94. [ 'goods_sku sku', 'mgci.sku_id = sku.sku_id', 'inner' ],
  95. [ 'verify v', 'mgci.member_verify_id = v.id', 'left' ],
  96. ])[ 'data' ] ?? [];
  97. foreach ($info[ 'card_item' ] as $k => $v) {
  98. $info[ 'card_item' ][ $k ][ 'stock' ] = numberFormat($info[ 'card_item' ][ $k ][ 'stock' ]);
  99. }
  100. return $this->response($this->success($info));
  101. }
  102. /**
  103. * 使用记录
  104. */
  105. public function records()
  106. {
  107. $card_id = $this->params[ 'card_id' ] ?? 0;
  108. $item_id = $this->params[ 'item_id' ] ?? 0;
  109. $member_id = $this->params[ 'member_id' ] ?? 0;
  110. $page = isset($this->params[ 'page' ]) ? $this->params[ 'page' ] : 1;
  111. $page_size = isset($this->params[ 'page_size' ]) ? $this->params[ 'page_size' ] : PAGE_LIST_ROWS;
  112. if (empty($member_id) || ( empty($card_id) && empty($item_id) )) {
  113. return $this->response($this->error([], '请传入必要参数'));
  114. }
  115. $condition = [];
  116. $condition[] = [ 'cr.site_id', '=', $this->site_id ];
  117. $condition[] = [ 'ci.member_id', '=', $member_id ];
  118. if (!empty($item_id)) {
  119. $condition[] = [ 'cr.card_item_id', '=', $item_id ];
  120. }
  121. if (!empty($card_id)) {
  122. $condition[] = [ 'cr.card_id', '=', $card_id ];
  123. }
  124. $alias = 'cr';
  125. $prefix = config('database.connections.mysql.prefix');
  126. $field = 'cr.*, sku.sku_name,sku.sku_image,sku.sku_images,sku.price,ci.num as item_num,
  127. IF(cr.type = \'order\', (select order_id from `' . $prefix . 'order_goods` og where og.order_goods_id = cr.relation_id), 0) as order_id';
  128. $join = [
  129. [ 'member_goods_card_item ci', 'ci.item_id = cr.card_item_id', 'left' ],
  130. [ 'goods_sku sku', 'ci.sku_id = sku.sku_id', 'left' ],
  131. ];
  132. $model = new MemberCardModel();
  133. $list = $model->getMemberCardRecordsPageList($condition, $field, 'cr.create_time desc', $page, $page_size, $alias, $join);
  134. return $this->response($list);
  135. }
  136. }