EquityOrderLogic.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\adminapi\logic\equity;
  15. use app\adminapi\logic\property\PropertyOrderLogic as AdminPropertyOrderLogic;
  16. use app\adminapi\logic\user\UserLogic;
  17. use app\api\logic\PropertyOrderLogic as ApiPropertyOrderLogic;
  18. use app\common\model\equity\EquityConfig;
  19. use app\common\model\equity\EquityOrder;
  20. use app\common\logic\BaseLogic;
  21. use app\common\model\equity\UserEquity;
  22. use app\common\model\property\PropertyOrder;
  23. use app\common\model\user\User;
  24. use Exception;
  25. use think\facade\Db;
  26. /**
  27. * EquityOrder逻辑
  28. * Class EquityOrderLogic
  29. * @package app\adminapi\logic
  30. */
  31. class EquityOrderLogic extends BaseLogic
  32. {
  33. /**
  34. * @notes 添加
  35. * @param array $params
  36. * @return bool
  37. * @author likeadmin
  38. * @date 2024/12/25 13:32
  39. */
  40. public static function add(array $params): bool
  41. {
  42. Db::startTrans();
  43. try {
  44. // 通过手机号查询用户是否注册 - 已注册绑定id ,未注册注册再绑定id
  45. $userId = UserLogic::getUserIdByMobile($params['mobile']);
  46. EquityOrder::create([
  47. 'user_id' => $userId,
  48. 'description' => $params['description']??'',
  49. 'price' => $params['price']??0,
  50. 'create_order_time' => $params['create_order_time']?strtotime($params['create_order_time']):0,
  51. 'service_work_id' => $params['service_work_id']??0,
  52. 'equity_id' => $params['equity_id']??0,
  53. 'status' => $params['status']??1,
  54. 'property_head_id' => $params['property_head_id']??0,
  55. 'remark' => $params['remark']??'',
  56. ]);
  57. Db::commit();
  58. return true;
  59. } catch (\Exception $e) {
  60. Db::rollback();
  61. self::setError($e->getMessage());
  62. return false;
  63. }
  64. }
  65. /**
  66. * @notes 编辑
  67. * @param array $params
  68. * @return bool
  69. * @author likeadmin
  70. * @date 2024/12/25 13:32
  71. */
  72. public static function edit(array $params): bool
  73. {
  74. Db::startTrans();
  75. try {
  76. // 通过手机号查询用户是否注册 - 已注册绑定id ,未注册注册再绑定id
  77. $userId = UserLogic::getUserIdByMobile($params['mobile']);
  78. EquityOrder::where('id', $params['id'])->update([
  79. 'user_id' => $userId,
  80. 'description' => $params['description']??'',
  81. 'price' => $params['price']??0,
  82. 'create_order_time' => $params['create_order_time']?strtotime($params['create_order_time']):0,
  83. 'service_work_id' => $params['service_work_id']??0,
  84. 'equity_id' => $params['equity_id']??0,
  85. 'status' => $params['status']??1,
  86. 'property_head_id' => $params['property_head_id']??0,
  87. 'remark' => $params['remark']??'',
  88. ]);
  89. Db::commit();
  90. return true;
  91. } catch (\Exception $e) {
  92. Db::rollback();
  93. self::setError($e->getMessage());
  94. return false;
  95. }
  96. }
  97. /**
  98. * @notes 删除
  99. * @param array $params
  100. * @return bool
  101. * @author likeadmin
  102. * @date 2024/12/25 13:32
  103. */
  104. public static function delete(array $params): bool
  105. {
  106. return EquityOrder::destroy($params['id']);
  107. }
  108. /**
  109. * @notes 获取详情
  110. * @param $params
  111. * @return array
  112. * @author likeadmin
  113. * @date 2024/12/25 13:32
  114. */
  115. public static function detail($params): array
  116. {
  117. return EquityOrder::findOrEmpty($params['id'])->toArray();
  118. }
  119. public static function addOrder($params)
  120. {
  121. Db::startTrans();
  122. try {
  123. $equityOrder = EquityOrder::findOrEmpty($params['id'])->toArray();
  124. $userInfo = User::findOrEmpty($equityOrder['user_id'])->toArray();
  125. $equityConfigInfo = EquityConfig::findOrEmpty($params['equity_id'])->toArray();
  126. $userEquity = UserEquity::where([
  127. ['equity_id','=',$params['equity_id']],['user_id','=',$equityOrder['user_id']],
  128. ['number','>',0],['end_time','>=',time()]
  129. ])->findOrEmpty();
  130. if($userEquity->isEmpty()){
  131. $userEquity = UserEquity::create([
  132. 'user_id' => $equityOrder['user_id'],
  133. 'equity_id' => $params['equity_id'],
  134. 'remark' => $params['remark']??'',
  135. 'goods_id' => $equityConfigInfo['goods_id'],
  136. 'number' => $equityConfigInfo['number'],
  137. 'end_time' => (time()+$equityConfigInfo['day_num']*86400),
  138. ]);
  139. }
  140. $order_id = ApiPropertyOrderLogic::add([
  141. 'property_head_id' => $equityOrder['property_head_id'],
  142. 'householder_name' => $userInfo['nickname'],
  143. 'householder_mobile' => $userInfo['mobile'],
  144. 'address' => $params['address']??'',
  145. 'remark' => ''
  146. ]);
  147. if (false === $order_id) {
  148. throw new Exception(ApiPropertyOrderLogic::getError());
  149. }
  150. $result = AdminPropertyOrderLogic::placeOrder([
  151. 'id' => $order_id,
  152. 'address' => $params['address'] ?? '',
  153. 'appointment_time' => $params['appointment_time'],
  154. 'goods_id' => $equityConfigInfo['goods_id'],
  155. 'pay_way' => $params['pay_way'],
  156. 'contact_number' => $params['contact_number'] ?? '',
  157. 'contact_people' => $params['contact_people'] ?? '',
  158. 'user_equity_id' => $userEquity->id
  159. ]);
  160. if (false === $result) {
  161. throw new Exception(AdminPropertyOrderLogic::getError());
  162. }
  163. $orderInfo = PropertyOrder::where('id', $order_id)->findOrEmpty()->toArray();
  164. EquityOrder::where('id', $params['id'])->update([
  165. 'service_work_id' => $orderInfo['work_id'],
  166. 'equity_id' => $params['equity_id'],
  167. 'status' => 2,
  168. ]);
  169. Db::commit();
  170. return true;
  171. } catch (\Exception $e) {
  172. Db::rollback();
  173. self::setError($e->getMessage());
  174. return false;
  175. }
  176. }
  177. }