User.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. namespace app\controller\api;
  3. use app\extra\basic\Base;
  4. use app\middleware\WxMiddleware;
  5. use app\model\saas\SaasPrice;
  6. use app\model\saas\SaasUserOpen;
  7. use LinFly\Annotation\Route\Controller;
  8. use LinFly\Annotation\Route\Route;
  9. use LinFly\Annotation\Route\Middleware;
  10. use support\Request;
  11. use support\Response;
  12. #[Controller(prefix: "/wx_api/user"),Middleware(WxMiddleware::class)]
  13. class User extends Base
  14. {
  15. protected array $color = ["1" => "彩色", "2" => "黑白"];
  16. protected array $duplex = ["1" => "单面", "2" => "双面"];
  17. protected array $type = ["1" => "文档", "2" => "复印"];
  18. #[Route(path: "data",methods: "get")]
  19. public function getUserData(Request $request): Response
  20. {
  21. try {
  22. $param = $this->_valid([
  23. "shop.require" => trans("empty.require"),
  24. ],$request->method());
  25. if (!is_array($param)) return error($param);
  26. $user = $request->user;
  27. if (empty($user)) return errorTrans("empty.data");
  28. $member = (new SaasUserOpen)->where("openid",$user['openid'])->with(['vip' => function($query) use($param){
  29. $query->where("shop_id",$param['shop'])->field("openid,shop_id,ROUND(balance/100,2) as f_balance,ROUND(total_balance/100,2) as f_total_balance,ROUND(total_consume/100,2) as f_total_consume,card_no");
  30. }])->field("openid,headimg,nickname")->append(["coupon"])->withAttr(['coupon' => function(){
  31. return 0;
  32. }])->findOrEmpty();
  33. return success("ok",$member->toArray());
  34. } catch (\Throwable $th) {
  35. return error($th->getMessage());
  36. }
  37. }
  38. /**
  39. * 价目表
  40. */
  41. #[Route(path: "price",methods: "get")]
  42. public function getPriceData(): Response
  43. {
  44. try {
  45. $param = $this->_valid([
  46. "shop.require" => "参数错误"
  47. ]);
  48. if (!is_array($param)) return error($param);
  49. $data = (new SaasPrice)->where("shop_id",$param['shop'])->field("paper_size,source,duplex,price,color,type")->select();
  50. if ($data->isEmpty()) return error("尚未配置价目表");
  51. $resp = [];
  52. foreach ($data as $key=>$val)
  53. {
  54. $color = $this->color[$val['color']];
  55. $type = $this->type[$val['type']];
  56. $duplex = $this->duplex[$val['duplex']];
  57. $resp[$val['paper_size']]['id'] = $val['paper_size'];
  58. $resp[$val['paper_size']]['child'][$key]['name'] = $type.$color.$duplex;
  59. $resp[$val['paper_size']]['child'][$key]['price'] = $val['price'];
  60. }
  61. return success("ok",$resp);
  62. } catch (\Throwable $exception) {
  63. return error($exception->getMessage());
  64. }
  65. }
  66. }