Membercard.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. /**
  3. * Niushop商城系统 - 团队十年电商经验汇集巨献!
  4. * =========================================================
  5. * Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
  6. * ----------------------------------------------
  7. * 官方网址: https://www.niushop.com
  8. * =========================================================
  9. */
  10. namespace addon\cardservice\api\controller;
  11. use addon\cardservice\model\MemberCard as MemberCardModel;
  12. use app\api\controller\BaseApi;
  13. use app\model\verify\Verify;
  14. /**
  15. * 会员卡项
  16. */
  17. class Membercard extends BaseApi
  18. {
  19. public function detail()
  20. {
  21. $card_id = isset($this->params[ 'card_id' ]) ? $this->params[ 'card_id' ] : 0;
  22. if (empty($card_id)) {
  23. return $this->response($this->error('', 'REQUEST_ID'));
  24. }
  25. $token = $this->checkToken();
  26. if ($token[ 'code' ] < 0) return $this->response($token);
  27. $model = new MemberCardModel();
  28. $condition = [
  29. [ 'mgc.site_id', '=', $this->site_id ],
  30. [ 'mgc.member_id', '=', $this->member_id ],
  31. [ 'mgc.card_id', '=', $card_id ],
  32. [ 'g.is_delete', '=', 0 ],
  33. ];
  34. $field = 'mgc.*, g.goods_name,g.price,g.goods_image,g.introduction,g.goods_content';
  35. $join = [
  36. [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
  37. ];
  38. $info = $model->getCardInfo($condition, $field, 'mgc', $join)[ 'data' ];
  39. $condition = [
  40. [ 'mgci.card_id', '=', $info[ 'card_id' ] ],
  41. ];
  42. $info[ 'card_item' ] = $model->getCartItemList($condition, 'mgci.*,sku.sku_name,sku.price,sku.sku_image,sku.sku_images,sku.goods_class_name,sku.stock,
  43. 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', [
  44. [ 'goods_sku sku', 'mgci.sku_id = sku.sku_id', 'inner' ],
  45. [ 'verify v', 'mgci.member_verify_id = v.id', 'left' ],
  46. ])[ 'data' ] ?? [];
  47. $verify = new Verify();
  48. foreach ($info[ 'card_item' ] as $k => $v) {
  49. if ($v[ 'member_verify_id' ] > 0) {
  50. $info[ 'card_item' ][ $k ][ 'verify_code_data' ] = $verify->qrcode($v[ 'verify_code' ], 'h5', 'pickup', $this->site_id, 'create')[ 'data' ] ?? [];
  51. $info[ 'card_item' ][ $k ][ 'barcode' ] = getBarcode($v[ 'verify_code' ], 'upload/qrcode/pickup');
  52. $info[ 'card_item' ][ $k ][ 'stock' ] = numberFormat($info[ 'card_item' ][ $k ][ 'stock' ]);
  53. }
  54. }
  55. return $this->response($this->success($info));
  56. }
  57. /**
  58. * 列表信息
  59. */
  60. public function page()
  61. {
  62. $token = $this->checkToken();
  63. if ($token[ 'code' ] < 0) return $this->response($token);
  64. $page = isset($this->params[ 'page' ]) ? $this->params[ 'page' ] : 1;
  65. $page_size = isset($this->params[ 'page_size' ]) ? $this->params[ 'page_size' ] : PAGE_LIST_ROWS;
  66. $status = isset($this->params[ 'status' ]) ? $this->params[ 'status' ] : 'all';
  67. $condition = [];
  68. $condition[] = [ 'mgc.site_id', '=', $this->site_id ];
  69. $condition[] = [ 'mgc.member_id', '=', $this->member_id ];
  70. if ($status !== 'all') {
  71. $condition[] = [ 'mgc.status', '=', $status ];
  72. }
  73. $condition[] = [ 'g.is_delete', '=', 0 ];
  74. $alias = 'mgc';
  75. $field = 'mgc.*, g.goods_name,g.price,g.goods_image,g.introduction';
  76. $join = [
  77. [ 'goods g', 'mgc.goods_id = g.goods_id', 'inner' ],
  78. ];
  79. $model = new MemberCardModel();
  80. $list = $model->getCardPageList($condition, $field, 'mgc.create_time desc', $page, $page_size, $alias, $join);
  81. return $this->response($list);
  82. }
  83. /**
  84. * 使用记录
  85. */
  86. public function records()
  87. {
  88. $token = $this->checkToken();
  89. if ($token[ 'code' ] < 0) return $this->response($token);
  90. $card_id = isset($this->params[ 'card_id' ]) ? $this->params[ 'card_id' ] : 0;
  91. $item_id = isset($this->params[ 'item_id' ]) ? $this->params[ 'item_id' ] : 0;
  92. if (empty($card_id) && empty($item_id)) {
  93. return $this->response($this->error([], '请传入必要参数'));
  94. }
  95. $condition = [];
  96. $condition[] = [ 'cr.site_id', '=', $this->site_id ];
  97. $condition[] = [ 'ci.member_id', '=', $this->member_id ];
  98. if (!empty($item_id)) {
  99. $condition[] = [ 'cr.card_item_id', '=', $item_id ];
  100. }
  101. if (!empty($card_id)) {
  102. $condition[] = [ 'cr.card_id', '=', $card_id ];
  103. }
  104. $alias = 'cr';
  105. $prefix = config('database.connections.mysql.prefix');
  106. $field = 'cr.*, sku.sku_name,sku.sku_image,sku.sku_images,sku.price,ci.num as item_num,
  107. IF(cr.type = \'order\', (select order_id from `' . $prefix . 'order_goods` og where og.order_goods_id = cr.relation_id), 0) as order_id';
  108. $join = [
  109. [ 'member_goods_card_item ci', 'ci.item_id = cr.card_item_id', 'left' ],
  110. [ 'goods_sku sku', 'ci.sku_id = sku.sku_id', 'left' ],
  111. ];
  112. $model = new MemberCardModel();
  113. $list = $model->getMemberCardRecordsList($condition, $field, 'cr.create_time desc', $alias, $join);
  114. return $this->response($list);
  115. }
  116. }