InfoController.php 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. <?php
  2. /**
  3. * 用户表
  4. * @author system
  5. * @version 1.0
  6. * @date 2017-05-30 12:16:56
  7. *
  8. */
  9. namespace App\Http\Controllers\Admin\User;
  10. use App\Http\Controllers\Admin\Controller;
  11. use App\Models\AccountLog;
  12. use App\Models\BaseAttachmentModel;
  13. use App\Models\MeetInfoModel;
  14. use App\Models\SearchInfoModel;
  15. use App\Models\SuggestInfoModel;
  16. use App\Models\SupportDreamModel;
  17. use App\Models\SystemInfoModel;
  18. use App\Models\UserBanksModel;
  19. use App\Models\UserCareDream;
  20. use App\Models\UserCashOut;
  21. use App\Models\UserInfoModel;
  22. use Illuminate\Http\Request;
  23. use App\Repositories\Base\Criteria\OrderBy;
  24. use App\Repositories\User\Criteria\MultiWhere;
  25. use App\Repositories\User\InfoRepository;
  26. class InfoController extends Controller
  27. {
  28. private $repository;
  29. public function __construct(InfoRepository $repository) {
  30. if(!$this->repository) $this->repository = $repository;
  31. }
  32. function index(Request $reqeust) {
  33. $search['keyword'] = $reqeust->input('keyword');
  34. $query = $this->repository->pushCriteria(new MultiWhere($search));
  35. $request = $reqeust->all();
  36. if(isset($request['sort_field']) && $request['sort_field'] && isset($request['sort_field_by'])) {
  37. $query = $query->pushCriteria(new OrderBy($request['sort_field'],$request['sort_field_by']));
  38. }
  39. $list = $query->paginate();
  40. foreach ($list as $item) {
  41. $dream_number = count($item->dreams);
  42. $score_array = SupportDreamModel::where('user_id',$item->id)->select('score')->get()->toArray();
  43. $coin_array = $item->dreams->toArray();
  44. if (count($coin_array) > 0) {
  45. $coin_list = array_column($coin_array,'get_coin');
  46. $get_coin = array_sum($coin_list);
  47. }else{
  48. $get_coin = 0;
  49. }
  50. if (count($score_array) > 0) {
  51. $score_list = array_column($score_array,'score');
  52. $sup_score = array_sum($score_list);
  53. }else{
  54. $sup_score = 0;
  55. }
  56. $item->dream_number = $dream_number; //梦想数量
  57. $item->sup_score = $sup_score; //捐赠分数
  58. $item->get_coin = $get_coin; //收到的梦想币
  59. }
  60. return view('admin.user.info.index',compact('list'));
  61. }
  62. function check(Request $reqeust) {
  63. $request = $reqeust->all();
  64. $search['keyword'] = $reqeust->input('keyword');
  65. $orderby = array();
  66. if(isset($request['sort_field']) && $request['sort_field'] && isset($request['sort_field_by'])) {
  67. $orderby[$request['sort_field']] = $request['sort_field_by'];
  68. }
  69. $list = $this->repository->search($search,$orderby);
  70. return view('admin.user.info.check',compact('list'));
  71. }
  72. /**
  73. * 添加
  74. *
  75. */
  76. public function create(Request $reqeust)
  77. {
  78. if($reqeust->method() == 'POST') {
  79. $validator = \Validator::make($reqeust->all(),
  80. [
  81. 'data.address' => 'required',
  82. 'data.phone' => 'required|unique:user_info,phone',
  83. 'data.sex' => 'required',
  84. 'data.emotion' => 'required',
  85. // 'avatar' => 'dimensions:width=100,height=100'
  86. ],
  87. [
  88. 'data.address.required' => '请选择省市区地址',
  89. 'data.sex.required' => '请选择性别',
  90. 'data.phone.unique' => '电话号码唯一',
  91. 'data.emotion.required' => '请选择情感状态',
  92. ]
  93. );
  94. if($validator->fails()){
  95. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  96. return $this->showWarning($validator->messages()->all(),$url);
  97. }
  98. $avatar = request('avatar');
  99. $data = (array) request('data');
  100. $data['avatar'] = getenv('APP_URL').$avatar;
  101. $id = $this->repository->create($data);
  102. if($id) {
  103. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  104. $url[] = array('url'=>U( 'User/Info/create'),'title'=>'继续添加');
  105. $this->showMessage('添加成功',$url);
  106. }else{
  107. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  108. return $this->showWarning('添加失败',$url);
  109. }
  110. }
  111. return view('admin.user.info.edit');
  112. }
  113. /**
  114. * 保存修改
  115. */
  116. private function _createSave(){
  117. $avatar = request('avatar');
  118. $data = (array) request('data');
  119. $data['avatar'] = getenv('APP_URL').$avatar;
  120. $id = $this->repository->create($data);
  121. if($id) {
  122. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  123. $url[] = array('url'=>U( 'User/Info/create'),'title'=>'继续添加');
  124. $this->showMessage('添加成功',$url);
  125. }else{
  126. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  127. return $this->showWarning('添加失败',$url);
  128. }
  129. }
  130. /**
  131. *
  132. * 修改
  133. *
  134. *
  135. */
  136. public function update(Request $reqeust) {
  137. if($reqeust->method() == 'POST') {
  138. return $this->_updateSave();
  139. }
  140. $data = $this->repository->find($reqeust->get('id'));
  141. return view('admin.user.info.edit',compact('data'));
  142. }
  143. /**
  144. * 保存修改
  145. */
  146. private function _updateSave() {
  147. $old_avatar = $this->repository->find(request('id'))->avatar;
  148. $data = (array) request('data');
  149. if (!empty(request('avatar'))) {
  150. if (is_file('.'.str_replace(getenv('APP_URL'),'',$old_avatar))) {
  151. unlink('.'.str_replace(getenv('APP_URL'),'',$old_avatar));
  152. }
  153. BaseAttachmentModel::where('url',$old_avatar)->delete();
  154. $data['avatar'] = getenv('APP_URL').request('avatar');
  155. }
  156. $ok = $this->repository->update(request('id'),$data);
  157. if($ok) {
  158. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  159. return $this->showMessage('操作成功',urldecode(request('_referer')));
  160. }else{
  161. $url[] = array('url'=>U( 'User/Info/index'),'title'=>'返回列表');
  162. return $this->showWarning('操作失败',$url);
  163. }
  164. }
  165. public function view(Request $reqeust) {
  166. $data = $this->repository->find(request('id'));
  167. return view('admin.user.info.view',compact('data'));
  168. }
  169. /**
  170. *
  171. * 状态改变
  172. *
  173. */
  174. public function status(Request $reqeust) {
  175. $ok = $this->repository->updateStatus(request('id'),request('status'));
  176. if($ok) {
  177. return $this->showMessage('操作成功');
  178. }else{
  179. return $this->showWarning('操作失败');
  180. }
  181. }
  182. /**
  183. * 删除
  184. */
  185. public function destroy(Request $reqeust) {
  186. $user_id = $reqeust->get('id');
  187. // 关联模型删除
  188. $user = UserInfoModel::find($user_id);
  189. $allImgs = $user->allImgs();
  190. if(count($allImgs) > 0) $allImgs->delete();
  191. $allInteraction = $user->allInteraction();
  192. if(count($allInteraction) > 0) $allInteraction->delete();
  193. $dreams = $user->dreams();
  194. if(count($dreams) > 0) $dreams->delete();
  195. $bool = $this->repository->destroy($reqeust->get('id'));
  196. if($bool) {
  197. // 删除用户后跟用户相关的数据全部删除
  198. UserCashOut::where('user_id',$user_id)->delete();
  199. UserCareDream::where('user_id',$user_id)->delete();
  200. UserBanksModel::where('user_id',$user_id)->delete();
  201. SystemInfoModel::where('user_id',$user_id)->delete();
  202. SupportDreamModel::where('user_id',$user_id)->delete();
  203. SuggestInfoModel::where('user_id',$user_id)->delete();
  204. SearchInfoModel::where('user_id',$user_id)->delete();
  205. MeetInfoModel::where('user_id',$user_id)->delete();
  206. return $this->showMessage('操作成功');
  207. }else{
  208. return $this->showWarning("操作失败");
  209. }
  210. }
  211. /**
  212. 加减币
  213. */
  214. public function editCoin(Request $request)
  215. {
  216. $status = $request->input('status');
  217. $user_id = request('id');
  218. $user = UserInfoModel::find($user_id);
  219. if ($request->isMethod('POST')) {
  220. $data = ($request->data);
  221. if (empty($status)) {
  222. return $this->showWarning("请选择交易类型");
  223. }
  224. $data['from_type']='梦想币';
  225. $data['from_id']=0; //设置初始值
  226. $data['from_amount']=$data['to_amount'];
  227. $data['from_type']='梦想币';
  228. $data['to_id']=$user_id;
  229. $data['channel']='后台';
  230. $data['transaction_id']=date('YmdHis') . mt_rand(1000, 9999);
  231. if (($status)==2) { //2减
  232. if ($user->coin<$data['to_amount']) {
  233. return $this->showWarning("交易数额不合法,请填写不大于{$user->coin}的金额");
  234. }
  235. $user->coin -= $data['to_amount'];
  236. $data['from_id']=$user_id;
  237. $data['avatar']=env('APP_URL').'/base/img/jianhao.png';
  238. }else{//1加
  239. $user->coin += $data['to_amount'];
  240. $data['avatar']=env('APP_URL').'/base/img/jiahao.png';
  241. }
  242. $user->save();
  243. $ok = AccountLog::create($data);
  244. if (!$ok) {
  245. return $this->showWarning("操作失败");
  246. }else{
  247. return $this->showMessage('操作成功');
  248. }
  249. }
  250. return view('admin.user.info.editcoin');
  251. }
  252. }