User.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | [ WE CAN DO IT MORE SIMPLE ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2018-2020 rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Author: TABLE ME
  8. // +----------------------------------------------------------------------
  9. // | Date: 2020-08-25 17:23
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\api\controller;
  13. use app\BaseController;
  14. use app\model\api\User as UserModel;
  15. use app\model\api\ServiceType as ServiceTypeModel;
  16. use app\model\api\InfoAudit;
  17. use app\model\api\TypeAudit;
  18. use app\model\api\UserAudit;
  19. use app\model\api\ServiceType;
  20. use app\model\api\ServiceTimeType;
  21. use app\model\api\City as CityModel;
  22. use app\model\api\Sys as SysModel;
  23. use app\model\api\ShowTemplate;
  24. use app\model\api\ShowTemplateOrder;
  25. use app\model\api\UserShowTemplate;
  26. use app\model\api\PayTradeModel;
  27. use app\Request;
  28. use library\services\UtilService;
  29. use library\utils\QRcodeComm;
  30. use library\utils\WxpayV2 as wxpayApi;
  31. use think\db\exception\DbException;
  32. use library\lib\weixina;
  33. use think\facade\Db;
  34. use think\Image;
  35. use think\Route;
  36. class User extends BaseController
  37. {
  38. /**
  39. * 获取用户详情
  40. * @param Request $request
  41. */
  42. public function userInfo(Request $request){
  43. //资料审核信息
  44. $infoAuditData = (new InfoAudit)->where("uid",$request->user["uid"])->order("id desc")->find();
  45. $userAuditData = (new UserAudit)->where("uid",$request->user["uid"])->order("id desc")->find();
  46. $typeAuditData = (new TypeAudit)->where("uid",$request->user["uid"])->order("id desc")->find();
  47. $data = [];
  48. $data['nickname'] = $request->user['nickname'];
  49. $data['avatar'] = $request->user['avatar'];
  50. $data['name'] = $request->user['name'];
  51. $data['info_audit_status'] = empty($infoAuditData)?-2:$infoAuditData["status"];
  52. $data['user_audit_status'] = empty($userAuditData)?-2:$userAuditData["status"];
  53. $data['type_audit_status'] = empty($typeAuditData)?-2:$typeAuditData["status"];
  54. return app('json')->success($data);
  55. }
  56. /**
  57. * 设置用户信息
  58. * @param Request $request
  59. */
  60. public function setUserInfo(Request $request){
  61. $post = UtilService::getMore([
  62. ['avatar',''],
  63. ['nickname',''],
  64. ['name',''],
  65. ['mobile',''],
  66. ['sex', ''],
  67. ],$request);
  68. $save=[];
  69. if(!empty($post["avatar"])){
  70. $save["avatar"] = $post["avatar"];
  71. }
  72. if(!empty($post["nickname"])){
  73. $save["nickname"] = $post["nickname"];
  74. }
  75. if(!empty($post["name"])){
  76. $save["name"] = $post["name"];
  77. }
  78. if(!empty($post["mobile"])){
  79. if(is_mobile($post["mobile"])){
  80. return app("json")->fail("请输入正确的手机号码");
  81. }
  82. $save["mobile"] = $post["mobile"];
  83. }
  84. if(in_array((string)$post["sex"],["0","1","2"])){
  85. $save["sex"] = (int)$post["sex"];
  86. }
  87. if(empty($save)){
  88. return app("json")->fail("提交数据为空");
  89. }
  90. //是否需要审核
  91. $isInfoAudit = 0;
  92. if($isInfoAudit==0){
  93. $r = (new UserModel)->where("uid",$request->user["uid"])->update($save);
  94. if(!$r){
  95. return app("json")->fail("提交数据为空");
  96. }
  97. }else{
  98. $data = (new UserAudit)->where("uid",$request->user["uid"])->order("id desc")->find();
  99. if(!empty($data) && $data["status"]==0){
  100. return app('json')->fail("资料审核中,请勿重复提交");
  101. }
  102. $save["uid"] = $request->user["uid"];
  103. $save["status"] = 0;
  104. $r = (new UserAudit)->insert($save);
  105. if(!$r){
  106. return app("json")->fail("提交数据为空");
  107. }
  108. }
  109. return app("json")->success("提交成功");
  110. }
  111. /**
  112. * 提交资料审核
  113. * @param Request $request
  114. */
  115. public function subInfoAudit(Request $request){
  116. $data = (new InfoAudit)->where("uid",$request->user["uid"])->order("id desc")->find();
  117. if(!empty($data) && $data["status"]==0){
  118. return app('json')->fail("资料审核中,请勿重复提交");
  119. }
  120. $post = UtilService::getMore([
  121. ['avatar',''],
  122. ['name','','empty','请输入真实姓名'],
  123. ['mobile','','is_moblie','请输入正确的手机号码'],
  124. ['idcard','','empty','请输入正确的身份证号码'],
  125. ['birthday',''],
  126. ['service_type',''],
  127. ['service_price',''],
  128. ['service_area',[]],
  129. ['service_project',[]],
  130. ['service_intro_content',''],
  131. ['service_intro_imgs',[]],
  132. ['service_audit_imgs',[]],
  133. ],$request);
  134. $save=[];
  135. $save["avatar"] = empty($post["avatar"]) ? "" : $post["avatar"];
  136. $save["name"] = empty($post["name"]) ? "" : $post["name"];
  137. $save["mobile"] = empty($post["mobile"]) ? "" : $post["mobile"];
  138. $save["idcard"] = empty($post["idcard"]) ? "" : $post["idcard"];
  139. $save["birthday"] = empty($post["birthday"])? 0 : strtotime($post["birthday"]);
  140. //服务类型
  141. if(!empty($post["service_type"])){
  142. $timeTypeData = (new ServiceTimeType)->where("code",$post["service_type"])->where("status",1)->select();
  143. if(empty($timeTypeData)){
  144. return app('json')->fail("服务时长类型不存在");
  145. }
  146. $save["service_type"] = $post["service_type"];
  147. }
  148. //服务价格区间
  149. $save["service_price"] = empty($post["service_price"]) ? "" : $post["service_price"];
  150. //服务区域
  151. $cityModel = new CityModel();
  152. if(!empty($post["service_area"]) && is_array($post["service_area"])){
  153. $saveAre=[];
  154. foreach($post["service_area"] as $k=>$v){
  155. if(empty(trim($v))){
  156. continue;
  157. }
  158. $itemData = $cityModel->where("name",trim($v))->where("level",2)->find();
  159. if(!empty($itemData)){
  160. $saveAre[]=$itemData["id"];
  161. }
  162. }
  163. if(!empty($saveAre)){
  164. $save["service_area"] = implode(",", $saveAre);
  165. }
  166. }
  167. //服务内容
  168. $serviceTypeModel = new ServiceTypeModel();
  169. if(!empty($post["service_project"]) && is_array($post["service_project"])){
  170. $saveCon=[];
  171. foreach($post["service_project"] as $k=>$v){
  172. if(empty(trim($v))){
  173. continue;
  174. }
  175. $itemData = $serviceTypeModel->where("id",(int)$v)->where("status",1)->find();
  176. if(!empty($itemData)){
  177. $saveCon[]=$itemData["id"];
  178. }
  179. }
  180. if(!empty($saveCon)){
  181. $save["service_project"] = implode(",", $saveCon);
  182. }
  183. }
  184. $save["service_intro_content"] = empty($post["service_intro_content"])?"": $post["service_intro_content"];
  185. $save["service_intro_imgs"] = empty($post["service_intro_imgs"]) ?"": implode(",", $post["service_intro_imgs"]);
  186. $save["service_audit_imgs"] = empty($post["service_audit_imgs"]) ?"": implode(",", $post["service_audit_imgs"]);
  187. $save["status"] = 0;
  188. $save["time"] = time();
  189. $save["uid"] = $request->user["uid"];
  190. $r = (new InfoAudit)->insert($save);
  191. if(!$r){
  192. return app('json')->fail("系统错误");
  193. }
  194. return app('json')->success("提交成功,请耐心等待审核");
  195. }
  196. /**
  197. * 提交资料审核2
  198. * @param Request $request
  199. */
  200. public function subTypeAudit(Request $request){
  201. $data = (new TypeAudit)->where("uid",$request->user["uid"])->order("id desc")->find();
  202. if(!empty($data) && $data["status"]==0){
  203. return app('json')->fail("资料审核中,请勿重复提交");
  204. }
  205. $post = UtilService::getMore([
  206. ['avatar',''],
  207. ['name','','empty','请输入真实姓名'],
  208. ['mobile','','is_moblie','请输入正确的手机号码'],
  209. ['idcard','','empty','请输入正确的身份证号码'],
  210. ['birthday',''],
  211. ['service_type',''],
  212. ['service_price',''],
  213. ['service_area',[]],
  214. ['service_project',[]],
  215. ['service_intro_content',''],
  216. ['service_intro_imgs',[]],
  217. ['service_audit_imgs',[]],
  218. ],$request);
  219. $save=[];
  220. $save["avatar"] = empty($post["avatar"]) ? "" : $post["avatar"];
  221. $save["name"] = empty($post["name"]) ? "" : $post["name"];
  222. $save["mobile"] = empty($post["mobile"]) ? "" : $post["mobile"];
  223. $save["idcard"] = empty($post["idcard"]) ? "" : $post["idcard"];
  224. $save["birthday"] = empty($post["birthday"])? 0 : strtotime($post["birthday"]);
  225. //服务类型
  226. if(!empty($post["service_type"])){
  227. $timeTypeData = (new ServiceTimeType)->where("code",$post["service_type"])->where("status",1)->select();
  228. if(empty($timeTypeData)){
  229. return app('json')->fail("服务时长类型不存在");
  230. }
  231. $save["service_type"] = $post["service_type"];
  232. }
  233. //服务价格区间
  234. $save["service_price"] = empty($post["service_price"]) ? "" : $post["service_price"];
  235. //服务区域
  236. $cityModel = new CityModel();
  237. if(!empty($post["service_area"]) && is_array($post["service_area"])){
  238. $saveAre=[];
  239. foreach($post["service_area"] as $k=>$v){
  240. if(empty(trim($v))){
  241. continue;
  242. }
  243. $itemData = $cityModel->where("name",trim($v))->where("level",2)->find();
  244. if(!empty($itemData)){
  245. $saveAre[]=$itemData["id"];
  246. }
  247. }
  248. if(!empty($saveAre)){
  249. $save["service_area"] = implode(",", $saveAre);
  250. }
  251. }
  252. //服务内容
  253. $serviceTypeModel = new ServiceTypeModel();
  254. if(!empty($post["service_project"]) && is_array($post["service_project"])){
  255. $saveCon=[];
  256. foreach($post["service_project"] as $k=>$v){
  257. if(empty(trim($v))){
  258. continue;
  259. }
  260. $itemData = $serviceTypeModel->where("id",(int)$v)->where("status",1)->find();
  261. if(!empty($itemData)){
  262. $saveCon[]=$itemData["id"];
  263. }
  264. }
  265. if(!empty($saveCon)){
  266. $save["service_project"] = implode(",", $saveCon);
  267. }
  268. }
  269. $save["service_intro_content"] = empty($post["service_intro_content"])?"": $post["service_intro_content"];
  270. $save["service_intro_imgs"] = empty($post["service_intro_imgs"]) ?"": implode(",", $post["service_intro_imgs"]);
  271. $save["service_audit_imgs"] = empty($post["service_audit_imgs"]) ?"": implode(",", $post["service_audit_imgs"]);
  272. $save["status"] = 0;
  273. $save["time"] = time();
  274. $save["uid"] = $request->user["uid"];
  275. $r = (new TypeAudit)->insert($save);
  276. if(!$r){
  277. return app('json')->fail("系统错误");
  278. }
  279. return app('json')->success("提交成功,请耐心等待审核");
  280. }
  281. /**
  282. * 模板订单提交[第一步]
  283. * @param Request $request
  284. */
  285. public function subShowTemplateOrder(Request $request){
  286. [$id,$pay_type] = UtilService::getMore([
  287. ['id','','empty','参数错误'],
  288. ['pay_type','','empty','请选择支付方式'],
  289. ],$request,true);
  290. if(!in_array($pay_type,["wxpay","balance"])){
  291. return app('json')->fail('不支持该支付方式!');
  292. }
  293. //缓存
  294. $redis = \think\facade\Cache::store('redis');
  295. $key = 'show_template_order_sub_' . $request->user['uid'];
  296. $bool = $redis->handler()->exists($key);
  297. if ($bool) {
  298. return app('json')->fail('请务重复操作,请稍等在重试!');
  299. }
  300. $redis->set($key,1,5);//5秒缓存
  301. $proData = (new ShowTemplate)->where("id",$id)->where("status",1)->find();
  302. if(empty($proData)){
  303. return app('json')->fail("当前模板已下架");
  304. }
  305. $proData = $proData->toArray();
  306. $count = (new UserShowTemplate)->where("uid",$request->user['uid'])->where("show_template_id",$id)->count();
  307. if($count>0){
  308. return app('json')->fail("您已购买过当前模板");
  309. }
  310. $orderCount = (new ShowTemplateOrder)->where("uid",$request->user['uid'])->where("show_template_id",$id)->where("status",">",-1)->count();
  311. if($orderCount>0){
  312. return app('json')->fail("您已下单该模板,请勿重复下单");
  313. }
  314. $price = floatval($proData["price"]);
  315. // if($price<0.01){
  316. // return app('json')->fail("模板信息错误");
  317. // }
  318. $allMoney = $price;//订单商品费用
  319. $total_money = $allMoney;//订单总费用
  320. $payMoney = $total_money;//订单需支付费用
  321. $payMoney = $payMoney <= 0 ? 0 : $payMoney;
  322. $nowTime = time();
  323. //主订单数据
  324. $save=[];
  325. $save['uid'] = $request->user['uid'];
  326. $save['order_id'] = makeOrderId($request->user['uid'],"A");
  327. $save['pay_type'] = $pay_type;//目前只支持微信支付
  328. $save['total_money'] = $total_money;//订单总金额
  329. $save['all_money'] = $allMoney;//商品中金额
  330. $save['pay_money'] = $payMoney;//实际支付金额
  331. $save['balance'] = 0;//余额支付了多少(目前没有余额支付)
  332. $save['status'] = $payMoney <= 0 ? 1 : 0;
  333. $save['pay_time'] = $payMoney <= 0 ? time() : 0;
  334. $save['time'] = $nowTime;
  335. $save['show_template_id'] = $proData["id"];
  336. $save['show_template_title'] = $proData["title"];;
  337. $save['show_template_price'] = $proData["price"];
  338. $save['show_template_img'] = empty($proData["imgs"]) ? "" : explode(",", $proData["imgs"])[0];
  339. $save['show_template_code'] = $proData["code"];
  340. try{
  341. Db::startTrans();
  342. $o_id = (new ShowTemplateOrder)->insertGetId($save);
  343. if(empty($o_id)){
  344. return app('json')->fail("订单提交失败");
  345. }
  346. //不需要支付
  347. if($save['status']==1){
  348. Db::commit();
  349. return app("json")->success(["order_id"=>$save['order_id'],"money"=>$payMoney,"status"=>$save['status']]);
  350. }
  351. if(empty($request->user['openid'])){
  352. Db::rollback();
  353. return app('json')->fail('用户还未绑定微信!');
  354. }
  355. //清理之前支付凭证 || 防止重复购买
  356. $payTrade = (new PayTradeModel)
  357. ->where("uid",$request->user["uid"])
  358. ->where("o_id",$o_id)
  359. ->where("type","temp")
  360. ->where("status",0)
  361. ->where("time","<",time() - 7*24*60*60)
  362. ->select()
  363. ->toArray();
  364. $wxpay = new wxpayApi();
  365. foreach ($payTrade as $v) {
  366. // if($v['pay_type'] == 'wxpay') {
  367. // $result = $wxpay->closeOrder($v['pay_no']);
  368. // }
  369. (new PayTradeModel)->where("id",$v['id'])->where("status",0)->delete();
  370. }
  371. $mtime = microtime(true)*10000;
  372. $payOn = "A".date("Ymd").$mtime .rand(1000,9000) . $request->user['uid'];
  373. $out_trade_no="";
  374. $payType = $save["pay_type"];
  375. //添加交易记录
  376. $trade = [
  377. 'uid' => $request->user['uid'],
  378. 'o_id' => $o_id,
  379. 'order_id' =>$save["order_id"],
  380. 'pay_no' => $payOn,
  381. 'out_trade_no' => empty($out_trade_no) ? $payOn : $out_trade_no,
  382. 'pay_type' => $payType,
  383. 'money' => $payMoney,
  384. 'type' => 'temp',
  385. 'd_json' => serialize(['orderId'=>$save["order_id"],"give_score"=>0]),
  386. 'time' => time(),
  387. 'status' => 0,
  388. ];
  389. $r=(new PayTradeModel)->insert($trade);
  390. if(!$r){
  391. Db::rollback();
  392. return app('json')->fail('支付信息获取失败!');
  393. }
  394. $clictip = get_client_ip();
  395. if(empty($clictip)){
  396. $clictip = $request->ip();
  397. }
  398. $payData = $wxpay->wxmpPay([
  399. 'body' => "微信小程序购买模板",
  400. 'out_trade_no' => $payOn,
  401. 'total' => $payMoney,
  402. 'openid' => $request->user['openid'],
  403. 'payer_client_ip' => $clictip,
  404. ]);
  405. if(empty($payData)){
  406. Db::rollback();
  407. return app('json')->fail($wxpay->errorMsg);
  408. }
  409. Db::commit();
  410. $redis->delete($key);
  411. return app('json')->success([
  412. 'jsApiParameters'=> $payData,
  413. 'pay_no' => $payOn,
  414. 'order_id' => $save["order_id"],
  415. "status" => $save['status'],
  416. "money" => $payMoney,
  417. ]);
  418. } catch (DbException $db){
  419. Db::rollback();
  420. return app('json')->fail("订单生成失败");
  421. }
  422. }
  423. /**
  424. * 获取模板购买订单详情
  425. * @param Request $request
  426. */
  427. public function payShowTemplateOrderInfo(Request $request){
  428. [$order_id] = UtilService::getMore([
  429. ['order_id','','empty','参数错误'],
  430. ],$request,true);
  431. $data = (new ShowTemplateOrder)
  432. ->field("order_id,total_money,all_money,pay_money,status,time")
  433. ->where("order_id",$order_id)
  434. ->where("uid",$request->user["uid"])
  435. ->find();
  436. if(empty($data)){
  437. return app('json')->fail('信息不存在!');
  438. }
  439. $data=$data->toArray();
  440. if($data["status"]==0 && $data["time"]<time() - 30*60){
  441. (new ShowTemplateOrder)->where("id",$data["id"])->where("uid",$request->user["uid"])->update(["status"=>-1]);
  442. $data["status"]==-1;
  443. }
  444. $data["time"] = date("Y-m-d H:i:s",$data["time"]);
  445. return app('json')->success($data);
  446. }
  447. /**
  448. * 发布圈子
  449. * @param Request $request
  450. */
  451. public function upCircle(Request $request){
  452. $post = UtilService::getMore([
  453. ['id',''],
  454. ['title',''],
  455. ['content','','empty','请输入动态内容'],
  456. ['imgs',[]],
  457. ['video',''],
  458. ['video_img',''],
  459. ['video_time',0],
  460. ['pro_id',''],
  461. ],$request);
  462. $post["status"]=0;
  463. $post["imgs"] = empty($post["imgs"]) ? "" : $post["imgs"];
  464. $post["update_time"] = time();
  465. if(empty($post["imgs"]) && empty($post["video"])){
  466. return app('json')->fail("请至少上传一张主图");
  467. }
  468. if(!empty($post["imgs"])){
  469. $post["video"]="";
  470. $post["video_img"]="";
  471. $post["video_time"]=0;
  472. }
  473. if(!empty($post["video"])){
  474. $post["imgs"]="";
  475. if(empty($post["video_img"])){
  476. return app('json')->fail("视频封面错误");
  477. }
  478. if(empty($post["video_time"]) || (int)$post["video_time"]<=0){
  479. return app('json')->fail("视频时长错误");
  480. }
  481. }
  482. if(!empty($post["pro_id"])){
  483. $proData = (new Goods)->where("id",$post["pro_id"])->where("status",1)->find();
  484. if(empty($proData)){
  485. return app('json')->fail("当前商品不可选中");
  486. }
  487. }else{
  488. $post["pro_id"]=0;
  489. }
  490. $id = $post["id"];
  491. unset($post["id"]);
  492. $r=0;
  493. if(empty($id) || $id=="0"){
  494. $post["time"] = time();
  495. $post["uid"] = $request->user["uid"];
  496. $r = (new UserCircle)->insert($post);
  497. }else{
  498. $r = (new UserCircle)->where("id",$id)->update($post);
  499. }
  500. if($r){
  501. return app('json')->success("发布成功,等待客服审核。");
  502. }else{
  503. return app('json')->fail("数据保存失败");
  504. }
  505. }
  506. /**
  507. * 图片上传
  508. * @param Request $request
  509. * @return type
  510. */
  511. public function upload(Request $request){
  512. $sysData = (new SysModel())->where("id",1)->find();
  513. $file = $request->file('file');
  514. $code = $request->post("code","image");
  515. if(empty($file)) {
  516. return app('json')->fail("未上传文件");
  517. }
  518. if(!in_array($code, ["avatar","video","image","circle","advert","goods","activity"])){
  519. return app('json')->fail("上传路径错误");
  520. }
  521. $ext = $file->extension();
  522. if(!in_array($ext, array("png","jpeg","gif","jpg"))){
  523. return app('json')->fail("图片类型错误");
  524. }
  525. $upPath = \think\facade\Filesystem::disk('resource')->putFile( $code, $file);
  526. if(!$upPath){
  527. return app('json')->fail("上传失败01");
  528. }
  529. $savePath = $sysData['file_url'].'/resource/' . $upPath;
  530. $imgUrl = str_replace("\\", "/", $savePath);
  531. return app('json')->success(['img'=>$imgUrl]);
  532. }
  533. /**
  534. * 视频上传
  535. * @param Request $request
  536. * @return type
  537. */
  538. public function uploadVideo(Request $request){
  539. $sysData = (new SysModel())->where("id",1)->find();
  540. $file = $request->file('file');
  541. $code = $request->post("code","video");
  542. if(empty($file)) {
  543. return app('json')->fail("未上传文件");
  544. }
  545. if(!in_array($code, ["video"])){
  546. return app('json')->fail("上传路径错误");
  547. }
  548. $ext = $file->extension();
  549. if(!in_array($ext, array("mp4","megp4"))){
  550. return app('json')->fail("视频类型错误");
  551. }
  552. $upPath = \think\facade\Filesystem::disk('resource')->putFile( $code, $file);
  553. if(!$upPath){
  554. return app('json')->fail("上传失败01");
  555. }
  556. $savePath = $sysData['system_url'].'/resource/' . $upPath;
  557. $imgUrl = str_replace("\\", "/", $savePath);
  558. return app('json')->success(['video'=>$imgUrl]);
  559. }
  560. /**
  561. * 钻币明细
  562. * @param Request $request
  563. */
  564. public function scoreList(Request $request)
  565. {
  566. $pageSize = 10;
  567. [$page, $type, $monthTime]
  568. = UtilService::getMore([
  569. ['page', 1],
  570. ['type',0],
  571. ['monthTime', ''],
  572. ], $request, true);
  573. $data = (new UserScoreDetail)
  574. ->where("uid", $request->user['uid'])
  575. ->when($type!=0, function ($query) use ($type) {
  576. if($type==1){
  577. $query->where("type", 1);
  578. }
  579. if($type==-1){
  580. $query->where("type", -1);
  581. }
  582. })
  583. ->when(!empty($monthTime), function ($query) use ($monthTime) {
  584. $query->whereMonth("time", $monthTime);
  585. })
  586. ->order("id", "desc")
  587. ->page((int)$page, $pageSize)
  588. ->select();
  589. $tAr = UtilService::getParam([
  590. 'id',
  591. 'title',
  592. 'content',
  593. 'type',
  594. ['into','v',function($item){
  595. return floatval($item);
  596. }],
  597. ['time', 'time', 'date("Y-m-d H:i:s",$1)'],
  598. ], $data);
  599. return app('json')->success(['list' => $tAr, 'pageSize' => $pageSize]);
  600. }
  601. }