MemberCard.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. <?php
  2. namespace addon\giftcard\model\membercard;
  3. use addon\giftcard\model\card\Card;
  4. use addon\giftcard\model\transfer\Blessing;
  5. use app\model\BaseModel;
  6. use app\model\member\Member;
  7. class MemberCard extends BaseModel
  8. {
  9. /**
  10. * 生成会员所属卡记录
  11. * @param $params
  12. */
  13. public function addMemberCard($params)
  14. {
  15. $card_id = $params[ 'card_id' ];
  16. $member_id = $params[ 'member_id' ];
  17. // $condition = array(
  18. // ['card_id', '=', $card_id],
  19. // ['member_id', '=', $member_id]
  20. // );
  21. // $member_card_info = $this->getMemberCardInfo($condition)['data'] ?? [];
  22. // if(!empty($member_card_info)){
  23. // $this->deleteMemberCard($condition);
  24. // }
  25. $data = array (
  26. 'site_id' => $params[ 'site_id' ],
  27. 'card_id' => $card_id,
  28. 'from_member_id' => $params[ 'from_member_id' ] ?? 0,
  29. 'member_id' => $member_id,
  30. // 'to_member_id' => $params['to_member_id'] ?? 0,
  31. // 'is_transfer' => $params['is_transfer'] ?? 0,
  32. 'source' => $params[ 'source' ],
  33. 'get_time' => time()
  34. );
  35. $member_card_id = model('giftcard_member_card')->add($data);
  36. return $this->success($member_card_id);
  37. }
  38. /**
  39. * 赠送后的操作
  40. * @param $params
  41. * @return array
  42. */
  43. public function memberCardTransfer($params)
  44. {
  45. $card_id = $params[ 'card_id' ];
  46. $member_id = $params[ 'member_id' ];
  47. $member_card_id = $params[ 'member_card_id' ];
  48. $condition = array (
  49. [ 'card_id', '=', $card_id ],
  50. [ 'member_id', '=', $member_id ],
  51. );
  52. $card_model = new Card();
  53. $card_info = $card_model->getCardInfo($condition)[ 'data' ] ?? [];
  54. if (empty($card_info))
  55. return $this->error([], '当前礼品卡不存在或已被领取!');
  56. $card_goods_condition = array (
  57. [ 'card_id', '=', $card_id ],
  58. );
  59. $card_goods_list = $card_model->getCardGoodsList($card_goods_condition)[ 'data' ] ?? [];
  60. $snapshot = array (
  61. 'card_info' => $card_info,
  62. 'card_goods_list' => $card_goods_list
  63. );
  64. //赠送
  65. $data = array (
  66. 'is_transfer' => 1,
  67. 'to_member_id' => $params[ 'to_member_id' ],
  68. 'transfer_time' => time(),
  69. 'snapshot' => json_encode($snapshot)
  70. );
  71. model('giftcard_member_card')->update($data, [ [ 'member_card_id', '=', $member_card_id ] ]);
  72. model('giftcard_card')->update([ 'member_id' => $data[ 'to_member_id' ] ], [ [ 'card_id', '=', $card_id ] ]);
  73. //使祝福语失效
  74. $blessing_model = new Blessing();
  75. $blessing_model->blessingToVoid([ [ 'member_card_id', '=', $member_card_id ] ]);
  76. return $this->success();
  77. }
  78. /**
  79. * 删除
  80. * @param $condition
  81. * @return array
  82. */
  83. public function deleteMemberCard($condition)
  84. {
  85. model('giftcard_member_card')->delete($condition);
  86. return $this->success();
  87. }
  88. /**
  89. * 获取会员礼品卡信息
  90. * @param $condition
  91. * @param string $field
  92. * @return array
  93. */
  94. public function getMemberCardInfo($condition, $field = '*')
  95. {
  96. $info = model('giftcard_member_card')->getInfo($condition, $field);
  97. return $this->success($info);
  98. }
  99. /**
  100. * 获取会员礼品卡列表
  101. * @param array $condition
  102. * @param string $field
  103. * @param string $order
  104. * @param null $limit
  105. * @return array
  106. */
  107. public function getMemberCardList($condition = [], $field = '*', $order = '', $limit = null, $alias = 'a', $join = [])
  108. {
  109. $list = model('giftcard_member_card')->getList($condition, $field, $order, $alias, $join, '', $limit);
  110. return $this->success($list);
  111. }
  112. /**
  113. * 获取会员礼品卡详情列表
  114. * @param array $condition
  115. * @param string $field
  116. * @param string $order
  117. * @param null $limit
  118. * @return array
  119. */
  120. public function getMemberCardDetailList($condition = [], $order = 'gmc.get_time asc', $limit = null)
  121. {
  122. $alias = 'gmc';
  123. $join = [
  124. [
  125. 'giftcard_card gc',
  126. 'gc.card_id = gmc.card_id',
  127. 'left'
  128. ],
  129. [
  130. 'member m1',
  131. 'gmc.from_member_id = m1.member_id or m1.member_id is null',
  132. 'left'
  133. ],
  134. [
  135. 'member m2',
  136. 'gmc.to_member_id = m2.member_id or m2.member_id is null',
  137. 'left'
  138. ],
  139. [
  140. 'member m3',
  141. 'gmc.member_id = m3.member_id or m3.member_id is null',
  142. 'left'
  143. ],
  144. ];
  145. $field = 'gc.*,gmc.*,m1.nickname as from_nickname, m2.nickname as to_nickname, m3.nickname as member_nickname';
  146. $list = $this->getMemberCardList($condition, $field, $order, $limit, $alias, $join)[ 'data' ] ?? [];
  147. return $this->success($list);
  148. }
  149. /**
  150. * 获取会员礼品卡分页列表
  151. * @param array $condition
  152. * @param int $page
  153. * @param int $page_size
  154. * @param string $order
  155. * @param string $field
  156. * @return array
  157. */
  158. public function getMemberCardPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = '', $field = '*', $alias = 'a', $join = [])
  159. {
  160. $list = model('giftcard_member_card')->pageList($condition, $field, $order, $page, $page_size, $alias, $join);
  161. return $this->success($list);
  162. }
  163. /**
  164. * 获取我的卡券列表
  165. * @param array $condition
  166. * @param int $page
  167. * @param int $page_size
  168. * @param string $order
  169. * @param string $field
  170. */
  171. public function getMemberCardDetailPageList($condition = [], $page = 1, $page_size = PAGE_LIST_ROWS, $order = '')
  172. {
  173. $alias = 'gmc';
  174. $join = [
  175. [
  176. 'giftcard_card gc',
  177. 'gc.card_id = gmc.card_id',
  178. 'left'
  179. ],
  180. [
  181. 'member m1',
  182. 'gmc.from_member_id = m1.member_id or m1.member_id is null',
  183. 'left'
  184. ],
  185. [
  186. 'member m2',
  187. 'gmc.to_member_id = m2.member_id or m2.member_id is null',
  188. 'left'
  189. ],
  190. [
  191. 'member m3',
  192. 'gmc.member_id = m3.member_id or m3.member_id is null',
  193. 'left'
  194. ],
  195. ];
  196. $field = 'gc.*,gmc.*,m1.nickname as from_nickname, m2.nickname as to_nickname, m3.nickname as member_nickname';
  197. $list = $this->getMemberCardPageList($condition, $page, $page_size, $order, $field, $alias, $join)[ 'data' ] ?? [];
  198. if (!empty($list[ 'list' ])) {
  199. $card_model = new Card();
  200. foreach ($list[ 'list' ] as $k => $v) {
  201. if ($v[ 'is_transfer' ] == 0) {
  202. $item_condition = array (
  203. [ 'card_id', '=', $v[ 'card_id' ] ]
  204. );
  205. $card_goods_list = $card_model->getCardGoodsList($item_condition)[ 'data' ] ?? [];
  206. } else {
  207. $snapshot = $v[ 'snapshot' ];
  208. $snapshot_array = json_decode($snapshot, true);
  209. $card_goods_list = $snapshot_array[ 'card_goods_list' ] ?? [];
  210. }
  211. $list[ 'list' ][ $k ][ 'card_goods_list' ] = $card_goods_list;
  212. }
  213. }
  214. return $this->success($list);
  215. }
  216. /**
  217. * 我的卡券详情
  218. * @param $params
  219. * @return array
  220. */
  221. public function getMemberCardDetail($params)
  222. {
  223. $site_id = $params[ 'site_id' ] ?? 0;
  224. $member_id = $params[ 'member_id' ] ?? 0;
  225. $card_id = $params[ 'card_id' ] ?? 0;
  226. $member_card_id = $params[ 'member_card_id' ];
  227. $condition = array (
  228. [ 'member_card_id', '=', $member_card_id ]
  229. );
  230. if ($site_id > 0) {
  231. $condition[] = [ 'site_id', '=', $site_id ];
  232. }
  233. if ($member_id > 0) {
  234. $condition[] = [ 'member_id', '=', $member_id ];
  235. }
  236. if ($card_id > 0) {
  237. $condition[] = [ 'card_id', '=', $card_id ];
  238. }
  239. $member_card_info = $this->getMemberCardInfo($condition)[ 'data' ] ?? [];
  240. if (empty($member_card_info))
  241. return $this->error();
  242. $card_id = $member_card_info[ 'card_id' ];
  243. if ($member_card_info[ 'is_transfer' ] == 0) {
  244. $card_model = new Card();
  245. $card_info = $card_model->getCardDetail([ 'site_id' => $site_id, 'card_id' => $card_id ])[ 'data' ] ?? [];
  246. } else {
  247. $snapshot = $member_card_info[ 'snapshot' ];
  248. $snapshot_array = json_decode($snapshot, true);
  249. $card_info = $snapshot_array[ 'card_info' ];
  250. $card_goods_list = $snapshot_array[ 'card_goods_list' ];
  251. $card_info[ 'card_goods_list' ] = $card_goods_list;
  252. }
  253. $member_model = new Member();
  254. if ($member_card_info[ 'to_member_id' ] > 0) {
  255. $to_member_info = $member_model->getMemberInfo([ [ 'member_id', '=', $member_card_info[ 'to_member_id' ] ] ], 'nickname,headimg')[ 'data' ] ?? [];
  256. $card_info[ 'to_member_nickname' ] = $to_member_info[ 'nickname' ];
  257. $card_info[ 'to_member_headimg' ] = $to_member_info[ 'headimg' ];
  258. }
  259. if ($member_card_info[ 'from_member_id' ] > 0) {
  260. $from_member_info = $member_model->getMemberInfo([ [ 'member_id', '=', $member_card_info[ 'from_member_id' ] ] ], 'nickname,headimg')[ 'data' ] ?? [];
  261. $card_info[ 'from_member_nickname' ] = $from_member_info[ 'nickname' ];
  262. $card_info[ 'from_member_headimg' ] = $from_member_info[ 'headimg' ];
  263. }
  264. if ($member_card_info[ 'member_id' ] > 0) {
  265. $member_info = $member_model->getMemberInfo([ [ 'member_id', '=', $member_card_info[ 'member_id' ] ] ], 'nickname,headimg')[ 'data' ] ?? [];
  266. $card_info[ 'member_nickname' ] = $member_info[ 'nickname' ];
  267. $card_info[ 'member_headimg' ] = $member_info[ 'headimg' ];
  268. }
  269. $info = array_merge($card_info, $member_card_info);
  270. return $this->success($info);
  271. }
  272. }