DonateService.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Laravel框架 [ Laravel ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 Laravel研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: wesmiler <12345678@qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Services;
  12. use App\Models\DonateModel;
  13. use App\Models\DynamicNoticeModel;
  14. use App\Models\MecryModel;
  15. use App\Models\MemberModel;
  16. use App\Models\TradeModel;
  17. /**
  18. * 捐赠物品管理-服务类
  19. * @author wesmiler
  20. * @since 2020/11/11
  21. * Class DeviceService
  22. * @package App\Services
  23. */
  24. class DonateService extends BaseService
  25. {
  26. /**
  27. * 构造函数
  28. * @author wesmiler
  29. * @since 2020/11/11
  30. * DeviceService constructor.
  31. */
  32. public function __construct()
  33. {
  34. $this->model = new DonateModel();
  35. }
  36. /**
  37. * 获取列表
  38. * @return array
  39. * @since 2020/11/11
  40. * @author wesmiler
  41. */
  42. public function getList()
  43. {
  44. $params = request()->all();
  45. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  46. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  47. $dataList = $this->model::from('donates as a')
  48. ->leftJoin('member as m', 'm.id', '=', 'a.user_id')
  49. ->where(function ($query) use ($params) {
  50. $query->where('a.mark', 1);
  51. $userId = isset($params['user_id']) ? $params['user_id'] : 0;
  52. if ($userId > 0) {
  53. $query->where('a.user_id', $userId);
  54. }
  55. $status = isset($params['status']) ? $params['status'] : 0;
  56. if ($status > 0) {
  57. $query->where('a.status', $status);
  58. } else {
  59. $query->whereIn('a.status', [1, 2]);
  60. }
  61. })
  62. ->where(function ($query) use ($params) {
  63. $keyword = isset($params['keyword']) ? trim($params['keyword']) : '';
  64. if (!empty($keyword)) {
  65. $query->where('a.title','like',"%{$keyword}%")
  66. ->orWhere('m.nickname','like',"%{$keyword}%");
  67. }
  68. })
  69. ->select(['a.id', 'a.user_id', 'm.nickname','a.stock','a.thumb', 'a.phone', 'a.title', 'a.status', 'a.create_time', 'a.update_time','a.description'])
  70. ->orderBy('a.create_time', 'desc')
  71. ->paginate($pageSize);
  72. $dataList = $dataList ? $dataList->toArray() : [];
  73. if ($dataList) {
  74. foreach ($dataList['data'] as &$item) {
  75. $item['thumb'] = $item['thumb'] ? get_image_url($item['thumb']) : '';
  76. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : '';
  77. }
  78. unset($item);
  79. }
  80. return [
  81. 'code' => 0,
  82. 'success'=> true,
  83. 'msg' => '操作成功',
  84. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  85. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  86. ];
  87. }
  88. /**
  89. * 获取列表
  90. * @return array
  91. * @since 2020/11/11
  92. * @author wesmiler
  93. */
  94. public function getDataList($params)
  95. {
  96. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  97. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  98. $dataList = $this->model::from('donates as a')
  99. ->leftJoin('member as m', 'm.id', '=', 'a.user_id')
  100. ->where(function ($query) use ($params) {
  101. $query->where(['a.mark'=>1,'a.status'=> 1]);
  102. $userId = isset($params['user_id']) ? $params['user_id'] : 0;
  103. if ($userId > 0) {
  104. $query->where('a.user_id', $userId);
  105. }
  106. $status = isset($params['status']) ? $params['status'] : 0;
  107. if ($status > 0) {
  108. $query->where('a.status', $status);
  109. }
  110. })
  111. ->where(function ($query) use ($params) {
  112. $keyword = isset($params['keyword']) ? trim($params['keyword']) : '';
  113. if (!empty($keyword)) {
  114. $query->where('a.title','like',"%{$keyword}%")
  115. ->orWhere('m.nickname','like',"%{$keyword}%");
  116. }
  117. })
  118. ->select(['a.id', 'a.user_id', 'm.nickname','a.stock','a.thumb', 'a.title', 'a.status', 'a.create_time', 'a.update_time','a.description'])
  119. ->orderBy('a.create_time', 'desc')
  120. ->paginate($pageSize);
  121. $dataList = $dataList ? $dataList->toArray() : [];
  122. if ($dataList) {
  123. foreach ($dataList['data'] as &$item) {
  124. $item['thumb'] = $item['thumb'] ? get_image_url($item['thumb']) : '';
  125. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : '';
  126. }
  127. unset($item);
  128. }
  129. return [
  130. 'code' => 0,
  131. 'success'=> true,
  132. 'msg' => '操作成功',
  133. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  134. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  135. ];
  136. }
  137. /**
  138. * 添加或编辑
  139. * @return array
  140. * @since 2020/11/11
  141. * @author wesmiler
  142. */
  143. public function edit()
  144. {
  145. $data = request()->all();
  146. $data['update_time'] = time();
  147. return parent::edit($data); // TODO: Change the autogenerated stub
  148. }
  149. /**
  150. * 发布
  151. * @param $params
  152. * @return array
  153. */
  154. public function send($params){
  155. $data = [
  156. 'id'=> isset($params['id'])? $params['id'] : 0,
  157. 'user_id'=> isset($params['user_id'])? $params['user_id'] : 0,
  158. 'phone'=> isset($params['phone'])? $params['phone'] : '',
  159. 'title'=> isset($params['title'])? $params['title'] : '',
  160. 'stock'=> isset($params['stock'])? intval($params['stock']) : 0,
  161. 'thumb'=> isset($params['thumb'])? $params['thumb'] : '',
  162. 'description'=> isset($params['description'])? $params['description'] : '',
  163. 'create_time'=> time(),
  164. 'mark'=> 1,
  165. 'status'=> 1,
  166. ];
  167. if($data['thumb']){
  168. $data['thumb'] = is_array($data['thumb'])? '' : str_replace(IMG_URL, "", $data['thumb']);
  169. }
  170. $data['update_time'] = time();
  171. return parent::edit($data); // TODO: Change the autogenerated stub
  172. }
  173. public function xingshan($userId){
  174. $type = request()->get('type', 1);
  175. $num = request()->get('num', 1);
  176. if(!in_array($type, [1,2,3])){
  177. return message('项目类型参数错误', false);
  178. }
  179. if($num <=0 || $num >1000){
  180. return message('行善券数量为1-1000', false);
  181. }
  182. $memberInfo = MemberModel::where(['id' => $userId, 'mark' => 1, 'status' => 1])
  183. ->select(['id', 'nickname','merits_num','coupon'])
  184. ->first();
  185. if (!$memberInfo) {
  186. return message('您的账号不可操作或已冻结,请联系客服', false);
  187. }
  188. if($memberInfo->coupon < $num){
  189. return message("账户花灯券不足,请先充值", false, [], 10003);
  190. }
  191. $params = request()->all();
  192. \DB::beginTransaction();
  193. $data = [
  194. 'user_id'=> $userId,
  195. 'type'=> $type,
  196. 'description'=> isset($params['description'])? $params['description']:'',
  197. 'thumb'=> isset($params['thumb'])? $params['thumb']:'',
  198. 'coupon'=> $num,
  199. 'create_time'=> time(),
  200. 'status'=> 1,
  201. ];
  202. if(!MecryModel::insertgetId($data)){
  203. return message('处理失败,请刷新后重试', false);
  204. }
  205. if (!MemberModel::where(['id' => $userId, 'mark' => 1])->decrement('coupon', $num)) {
  206. \DB::rollBack();
  207. return message("扣除花灯券账户失败", false);
  208. }
  209. $types = [1=>'日行一善,功德无量',2=>'功德三千,阿弥陀佛',3=>'打赏平台'];
  210. $data = [
  211. 'user_id' => $userId,
  212. 'source_uid' => 0,
  213. 'type' => 1,
  214. 'coin_type' => 1,
  215. 'pay_type' => 1,
  216. 'money' => $num,
  217. 'change_type' => 2,
  218. 'balance' => $memberInfo->coupon,
  219. 'create_time' => time(),
  220. 'remark' => $types[$type],
  221. 'status' => 1,
  222. ];
  223. if (!TradeModel::insertGetId($data)) {
  224. \DB::rollBack();
  225. return message("处理账户明细失败", false);
  226. }
  227. // 功德奖励
  228. $giveGd = ConfigService::make()->getConfigByCode('xingshan_give_gd');
  229. $giveGd = $giveGd>0? $giveGd : 0;
  230. if($giveGd>0){
  231. if (!MemberModel::where(['id' => $userId, 'mark' => 1])->increment('merits_num', $giveGd)) {
  232. \DB::rollBack();
  233. return message("更新功德账户失败", false);
  234. }
  235. $data = [
  236. 'user_id' => $userId,
  237. 'source_uid' => 0,
  238. 'type' => 3,
  239. 'coin_type' => 4,
  240. 'pay_type' => 4,
  241. 'money' => $giveGd,
  242. 'change_type' => 1,
  243. 'balance' => $memberInfo->merits_num,
  244. 'create_time' => time(),
  245. 'remark' => $types[$type],
  246. 'status' => 1,
  247. ];
  248. if (!TradeModel::insertGetId($data)) {
  249. \DB::rollBack();
  250. return message("处理功德奖励失败", false);
  251. }
  252. }
  253. // 动态
  254. $data = [
  255. 'type' => 5,
  256. 'user_id' => $userId,
  257. 'remark' => $types[$type],
  258. 'update_time' => time(),
  259. 'create_time' => time(),
  260. 'status' => 1
  261. ];
  262. DynamicNoticeModel::insertGetId($data);
  263. \DB::commit();
  264. // 完成修行项目
  265. PracticesService::make()->saveLog($userId, 8, $types[$type]);
  266. return message('行善成功', true);
  267. }
  268. }