YigongService.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  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\MemberModel;
  13. use App\Models\SiyuanModel;
  14. use App\Models\YigongModel;
  15. /**
  16. * 义工管理-服务类
  17. * @author wesmiler
  18. * @since 2020/11/11
  19. * Class YigongService
  20. * @package App\Services
  21. */
  22. class YigongService extends BaseService
  23. {
  24. /**
  25. * 构造函数
  26. * @author wesmiler
  27. * @since 2020/11/11
  28. * YigongService constructor.
  29. */
  30. public function __construct()
  31. {
  32. $this->model = new YigongModel();
  33. }
  34. /**
  35. * 获取列表
  36. * @return array
  37. * @since 2020/11/11
  38. * @author wesmiler
  39. */
  40. public function getList()
  41. {
  42. $params = request()->all();
  43. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  44. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  45. $dataList = $this->model::from('yigong as y')
  46. ->leftJoin('member as m', 'm.id', '=', 'y.user_id')
  47. ->leftJoin('siyuan as s', 's.id', '=', 'y.siyuan_id')
  48. ->where(function ($query) use ($params) {
  49. $query->where('y.mark', 1);
  50. $realname = isset($params['realname']) ? trim($params['realname']) : '';
  51. if (!empty($realname)) {
  52. $query->where('y.realname', 'like', "%{$realname}%");
  53. }
  54. $onSiyuan = isset($params['on_siyuan']) ? intval($params['on_siyuan']) : 0;
  55. if ($onSiyuan > 0) {
  56. $query->where('a.on_siyuan', $onSiyuan);
  57. }
  58. $status = isset($params['status']) ? $params['status'] : 0;
  59. if ($status > 0) {
  60. $query->where('y.status', $status);
  61. } else {
  62. $query->whereIn('y.status', [1, 2]);
  63. }
  64. })
  65. ->select(['y.id', 'y.siyuan_id','y.user_id','s.title as siyuan', 'm.nickname','m.salary', 'y.realname', 'y.on_siyuan', 'm.avatar', 'y.status', 'y.create_time', 'y.update_time','y.reason', 'y.description', 'y.sort'])
  66. ->orderBy('y.update_time', 'desc')
  67. ->paginate($pageSize);
  68. $dataList = $dataList ? $dataList->toArray() : [];
  69. if ($dataList) {
  70. foreach ($dataList['data'] as &$item) {
  71. $item['avatar'] = $item['avatar'] ? get_image_url($item['avatar']) : '';
  72. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : '';
  73. }
  74. unset($item);
  75. }
  76. return [
  77. 'code' => 0,
  78. 'success'=> true,
  79. 'msg' => '操作成功',
  80. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  81. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  82. ];
  83. }
  84. /**
  85. * 添加或编辑
  86. * @return array
  87. * @since 2020/11/11
  88. * @author wesmiler
  89. */
  90. public function edit()
  91. {
  92. $data = request()->all();
  93. $data['update_time'] = time();
  94. $data['publish_at'] = isset($data['publish_at']) && $data['publish_at']? $data['publish_at'] : date('Y-m-d H:i:s');
  95. return parent::edit($data); // TODO: Change the autogenerated stub
  96. }
  97. /**
  98. * 申请成为义工
  99. * @param $userId
  100. * @return array
  101. */
  102. public function apply($userId){
  103. $params = request()->all();
  104. $siyuanId = isset($params['siyuan_id'])? $params['siyuan_id'] : 0;
  105. $siyuanInfo = SiyuanModel::where(['id'=> $siyuanId,'mark'=> 1,'status'=> 1])
  106. ->select(['id','title','status'])
  107. ->first();
  108. if(!$siyuanInfo){
  109. return message('所选寺院不存在', false);
  110. }
  111. // 验证账户
  112. $memberInfo = MemberModel::where(['id'=> $userId,'mark'=> 1,'status'=> 1])
  113. ->select(['id','nickname','status'])
  114. ->first();
  115. if(!$memberInfo){
  116. return message('当前账号无权操作或已冻结,请联系客服', false);
  117. }
  118. // 验证是否已申请
  119. $info = $this->model::where(['user_id'=> $userId])
  120. ->select(['id','user_id','mark','status'])
  121. ->first();
  122. if($info && $info->mark==1 && $info->status == 1){
  123. return message('您已提交过申请,请耐心等候审核', false);
  124. }else if($info && $info->mark==1 && $info->status == 2){
  125. return message('您的申请已通过,请不要重复提交', false);
  126. }
  127. if($info){
  128. $info->realname = isset($params['realname'])? trim($params['realname']) : '';
  129. $info->phone = isset($params['phone'])? trim($params['phone']) : '';
  130. $info->idcard = isset($params['idcard'])? trim($params['idcard']) : '';
  131. $info->description = isset($params['description'])? trim($params['description']) : '';
  132. $info->reason = '';
  133. $info->create_time = time();
  134. $info->mark = 1;
  135. $info->status = 1;
  136. if($info->save()){
  137. return message('您的申请已重新提交,请耐心等候审核', true);
  138. }
  139. }else{
  140. $data = [
  141. 'siyuan_id'=> $siyuanId,
  142. 'user_id'=> $userId,
  143. 'realname'=> isset($params['realname'])? trim($params['realname']) : '',
  144. 'phone'=> isset($params['phone'])? trim($params['phone']) : '',
  145. 'idcard'=> isset($params['idcard'])? trim($params['idcard']) : '',
  146. 'description'=> isset($params['description'])? trim($params['description']) : '',
  147. 'create_time'=> time(),
  148. 'status'=> 1,
  149. ];
  150. if($this->model::insertGetId($data)){
  151. return message('您的申请已提交,请耐心等候审核', true);
  152. }
  153. }
  154. return message('操作失败,请刷新页面后重试', false);
  155. }
  156. /**
  157. * 获取申请信息
  158. * @param $userId
  159. * @return mixed
  160. */
  161. public function applyInfo($userId){
  162. $params = request()->all();
  163. $siyuanId = isset($params['siyuan_id'])? $params['siyuan_id'] : 0;
  164. $info = $this->model::from('yigong as y')
  165. ->leftJoin('siyuan as s','s.id','=','y.siyuan_id')
  166. ->where(['y.siyuan_id'=> $siyuanId,'user_id'=> $userId, 'y.mark'=> 1])
  167. ->select(['y.id','y.user_id','y.siyuan_id','y.realname','y.phone','y.idcard','y.description','y.reason','y.create_time','y.status','s.title as siyuan_text'])
  168. ->orderBy('y.create_time','desc')
  169. ->first();
  170. return message(1005, true, $info? $info : []);
  171. }
  172. }