| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- <?php
- namespace app\controller\api;
- use app\extra\basic\Base;
- use app\middleware\WxMiddleware;
- use app\model\saas\SaasPrice;
- use app\model\saas\SaasUser;
- use app\model\saas\SaasUserOpen;
- use LinFly\Annotation\Route\Controller;
- use LinFly\Annotation\Route\Route;
- use LinFly\Annotation\Route\Middleware;
- use support\Request;
- use support\Response;
- #[Controller(prefix: "/wx_api/user"),Middleware(WxMiddleware::class)]
- class User extends Base
- {
- protected array $color = ["1" => "彩色", "2" => "黑白"];
- protected array $duplex = ["1" => "单面", "2" => "双面"];
- protected array $type = ["1" => "文档", "2" => "复印"];
- #[Route(path: "data",methods: "get")]
- public function getUserData(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "shop.require" => trans("empty.require"),
- ],$request->method());
- if (!is_array($param)) return error($param);
- $user = $request->user;
- if (empty($user)) return errorTrans("empty.data");
- $member = (new SaasUserOpen)->where("openid",$user['openid'])->field("openid,headimg,nickname")->append(["coupon"])->withAttr(['coupon' => function(){
- return 0;
- }])->findOrEmpty();
- $memberUser = (new SaasUser)->where(['shop_id' => $param['shop'],'openid' => $user['openid']])->field("openid,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")->findOrEmpty();
- $member['vip'] = [
- "f_balance" => $memberUser['f_balance']??'0.00',
- "f_total_consume" => $memberUser['f_total_balance']??'0.00',
- ];
- return success("ok",$member->toArray());
- } catch (\Throwable $th) {
- return error($th->getMessage());
- }
- }
- /**
- * 价目表
- */
- #[Route(path: "price",methods: "get")]
- public function getPriceData(): Response
- {
- try {
- $param = $this->_valid([
- "shop.require" => "参数错误"
- ]);
- if (!is_array($param)) return error($param);
- $data = (new SaasPrice)->where("shop_id",$param['shop'])->field("paper_size,source,duplex,price,color,type")->select();
- if ($data->isEmpty()) return error("尚未配置价目表");
- $resp = [];
- foreach ($data as $key=>$val)
- {
- $color = $this->color[$val['color']];
- $type = $this->type[$val['type']];
- $duplex = $this->duplex[$val['duplex']];
- $resp[$val['paper_size']]['id'] = $val['paper_size'];
- $resp[$val['paper_size']]['child'][$key]['name'] = $type.$color.$duplex;
- $resp[$val['paper_size']]['child'][$key]['price'] = $val['price'];
- }
- return success("ok",$resp);
- } catch (\Throwable $exception) {
- return error($exception->getMessage());
- }
- }
- }
|