GiftLevel.php 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. namespace app\common\model\user;
  3. use app\common\model\BaseModel;
  4. use app\common\model\store\order\StoreOrder;
  5. class GiftLevel extends BaseModel
  6. {
  7. public static function tablePk(): ?string
  8. {
  9. return 'id';
  10. }
  11. public static function tableName(): string
  12. {
  13. return 'gift_level';
  14. }
  15. //买礼包商品的时候触发 检测升级
  16. public function checkLevel($uid, $pass = [])
  17. {
  18. if (in_array($uid, $pass)) return true;
  19. $user = User::find($uid);
  20. $group_users = $this->get_group_user($uid);
  21. //Todo 获取在$group_users内所有用户的消费情况
  22. $achievement = 0;
  23. //获取该用户购买过的礼包商品的全部订单
  24. @file_put_contents('quanju2.txt', json_encode($group_users)."-礼包成员\r\n", 8);
  25. $achievement1 = StoreOrder::where('uid','in', $group_users)->where('paid', 1)->where('product_type',2)->whereNotIn('status',-1)->sum('pay_price');
  26. $achievement2 = StoreOrder::where('uid', $uid)->where('paid', 1)->where('product_type',2)->whereNotIn('status',-1)->sum('pay_price');
  27. $achievement = bcadd($achievement1, $achievement2, 2);
  28. @file_put_contents('quanju2.txt', $achievement."-礼包总业绩\r\n", 8);
  29. $old_level = self::where('id', $user['gift_level'])->find();
  30. if (!$old_level) $old_level = [
  31. 'grade' => 0,
  32. 'name' => '普通会员'
  33. ];
  34. $level = self::where('grade', '>', $old_level['grade'])->where('achievement', '<=', $achievement)
  35. ->order('grade', 'desc')->find();
  36. if ($level) {
  37. $user->gift_level = $level['id'];
  38. $res = $user->save();
  39. }
  40. $pass[] = $uid;
  41. $spread = User::where('uid', $user['spread_uid'])->find();
  42. if ($spread) return $this->checkLevel($spread['uid'], $pass);
  43. return true;
  44. }
  45. public function get_group_user($id, $init = true, $members = null){
  46. @file_put_contents('quanju3.txt',"-测试26\r\n",8);
  47. if ($init) {
  48. $us = \app\common\model\user\User::column('spread_uid', 'uid');
  49. $members = [];
  50. foreach ($us as $k => $v) {
  51. if ($v > 0)
  52. $members[$v][] = $k;
  53. }
  54. $id = [$id];
  55. }
  56. $arr = array();
  57. foreach ($id as $v) {
  58. $child = $members[$v] ?? [];
  59. $arr = array_merge($arr, $child);
  60. }
  61. if (count($arr)) {
  62. return array_merge($arr, $this->get_group_user($arr, false, $members));
  63. } else {
  64. return $arr;
  65. }
  66. }
  67. }