RechargeService.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. <?php
  2. namespace app\admin\service\notify;
  3. use app\model\Goods;
  4. use app\model\MemberAccount;
  5. use app\model\MemberQuota;
  6. use app\model\MemberRole;
  7. use app\model\Order;
  8. use app\model\OrderSheet;
  9. use app\model\RuleAdded;
  10. use app\model\RuleAddedComponent;
  11. use support\exception\BusinessException;
  12. class RechargeService
  13. {
  14. /**
  15. * @Desc
  16. * @Author Gorden
  17. * @Date 2024/5/28 16:50
  18. *
  19. * @param $orderId
  20. * @return mixed
  21. * @throws BusinessException
  22. */
  23. public static function disposeOrder($orderId)
  24. {
  25. $orderSheet = OrderSheet::where('join_sheet_order_id', $orderId)->first();
  26. if (!$orderSheet) {
  27. throw new BusinessException('订单数据异常');
  28. }
  29. $goods = Goods::find($orderSheet->join_sheet_goods_id);
  30. if (empty($goods->goods_attribute_json)) {
  31. throw new BusinessException('产品数据异常');
  32. }
  33. $attributeJson = json_decode($goods->goods_attribute_json, true);
  34. if (!isset($attributeJson['added'])) {
  35. throw new BusinessException('产品数据异常');
  36. }
  37. return $attributeJson['added']['nbr'];
  38. }
  39. /**
  40. * @Desc
  41. * @Author Gorden
  42. * @Date 2024/5/28 17:23
  43. *
  44. * @param $memberId
  45. * @return mixed|void
  46. */
  47. public static function disposeRole($memberId, $payAmount)
  48. {
  49. $memberAccount = MemberAccount::where('member_account_classify', 'CASH')
  50. ->where('join_account_member_id', $memberId)
  51. ->first();
  52. $income = floatval($memberAccount->member_account_income);
  53. $expend = floatval($memberAccount->member_account_expen);
  54. $money = max($income,$expend);
  55. $memberRoles = MemberRole::where('member_role_status', 'ACTIVED')->get()->toArray();
  56. foreach ($memberRoles as $role) {
  57. if ($money >= floatval($role['member_role_range_begin']) && $money < floatval($role['member_role_range_end'])) {
  58. return $role['member_role_id'];
  59. }
  60. }
  61. return false;
  62. }
  63. /**
  64. * @Desc
  65. * @Author Gorden
  66. * @Date 2024/5/28 18:03
  67. *
  68. * @param $roleId
  69. * @param $memberId
  70. * @return void
  71. * @throws BusinessException
  72. */
  73. public static function disposeAdded($roleId, $memberId)
  74. {
  75. $role = MemberRole::find($roleId);
  76. if (empty($role->member_role_rule_json)) {
  77. throw new BusinessException('增值套包数据异常');
  78. }
  79. $ruleJson = json_decode($role->member_role_rule_json, true);
  80. if (!isset($ruleJson['added'])) {
  81. throw new BusinessException('增值套包数据异常');
  82. }
  83. $addedId = $ruleJson['added'];
  84. $added = RuleAdded::find($addedId);
  85. if (!$added){
  86. throw new BusinessException('增值套包数据异常');
  87. }
  88. $diff = $added->rule_added_goods_diff;
  89. $components = RuleAddedComponent::where('join_component_rule_added_id', $addedId)->get()->toArray();
  90. switch ($diff) {
  91. case "SUM":
  92. self::diffSum($memberId, $components);
  93. break;
  94. case "REPLACE":
  95. self::diffReplace($memberId, $components);
  96. break;
  97. case "NONE":
  98. self::diffNone($memberId, $components);
  99. }
  100. }
  101. /**
  102. * @Desc
  103. * @Author Gorden
  104. * @Date 2024/5/28 18:03
  105. *
  106. * @param $memberId
  107. * @param $components
  108. * @return void
  109. */
  110. public static function diffSum($memberId, $components)
  111. {
  112. foreach ($components as $component) {
  113. self::saveMemberQuota($memberId, $component);
  114. }
  115. }
  116. /**
  117. * @Desc
  118. * @Author Gorden
  119. * @Date 2024/5/28 18:02
  120. *
  121. * @param $memberId
  122. * @param $components
  123. * @return void
  124. */
  125. public static function diffReplace($memberId, $components)
  126. {
  127. foreach ($components as $component) {
  128. if (MemberQuota::where('join_quota_member_id', $memberId)->where('join_member_rule_added_component_id', $component['rule_added_component_id'])->exists()) {
  129. MemberQuota::where('join_quota_member_id', $memberId)
  130. ->where('join_member_rule_added_component_id', $component['rule_added_component_id'])
  131. ->where('member_quota_status', 'PENDING')
  132. ->delete();
  133. }
  134. self::saveMemberQuota($memberId, $component);
  135. }
  136. }
  137. /**
  138. * @Desc
  139. * @Author Gorden
  140. * @Date 2024/5/28 18:02
  141. *
  142. * @param $memberId
  143. * @param $components
  144. * @return void
  145. */
  146. public static function diffNone($memberId, $components)
  147. {
  148. foreach ($components as $component) {
  149. if (MemberQuota::where('join_quota_member_id', $memberId)->where('join_member_rule_added_component_id', $component['rule_added_component_id'])->exists()) {
  150. continue;
  151. }
  152. self::saveMemberQuota($memberId, $component);
  153. }
  154. }
  155. /**
  156. * @Desc
  157. * @Author Gorden
  158. * @Date 2024/5/28 18:02
  159. *
  160. * @param $memberId
  161. * @param $component
  162. * @return void
  163. */
  164. private static function saveMemberQuota($memberId, $component)
  165. {
  166. for ($i = 0; $i < floatval($component['rule_added_component_goods_nbr']); $i++) {
  167. $model = new MemberQuota();
  168. $model->member_quota_id = 'MQ' . date('YmdHis') . random_string(6, 'up');
  169. $model->join_quota_member_id = $memberId;
  170. $model->join_member_rule_added_component_id = $component['rule_added_component_id'];
  171. $model->member_quota_status = 'PENDING';
  172. $model->member_quota_category = $component['rule_added_component_category'];
  173. $model->member_quota_name = $component['rule_added_component_name'];
  174. $model->member_quota_nbr = $component['rule_added_component_goods_nbr'];
  175. $model->member_quota_json = $component['rule_added_component_goods_json'];
  176. $model->member_quota_addtimes = time();
  177. $model->save();
  178. }
  179. }
  180. }