123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785 |
- <?php
- namespace app\common\model;
- use app\common\model\Order;
- use app\common\model\Sms;
- use Firebase\JWT\JWT;
- use app\common\model\UserIntegralLog;
- use think\Model;
- use app\common\library\Common;
- use think\facade\Validate;
- use think\Request;
- use think\Db;
- use function foo\func;
- use app\common\library\WxService;
- use app\common\library\WxPay;
- use app\common\library\AliPay;
- use EasyWeChat\Factory;
- header('Access-Control-Allow-Origin: *');
- /**
- * 会员模型
- */
- class User Extends Model
- {
- // 开启自动写入时间戳字段
- protected $autoWriteTimestamp = 'TIMESTAMP';
- // 定义时间戳字段名
- protected $createTime = 'create_at';
- protected $updateTime = 'update_at';
- // 追加属性
- protected $append = [
- ];
- protected $table = 'q_user';
- /**
- * 注册
- */
- public static function register($phone,$password,$ver_code,$invite_code){
- $phone_use = self::where('phone',$phone)->find();
- if ($phone_use){
- return Common::return_error('手机号已注册!');
- }
- //获取最后的验证码
- $time = time()-90;
- $sms = Sms::where(['mobile' => $phone, 'event' => 'register'])
- ->where('createtime','>',$time)
- ->order('id', 'DESC')
- ->find();
- if (!$sms || $sms->code != $ver_code){
- return Common::return_error('短信验证码不正确!');
- }
- $data['phone'] = $phone;
- $data['fid'] = $invite_code ? $invite_code : 0;
- $data['password'] = md5($password);
- $data['ip'] = request()->ip();
- Db::startTrans();
- try {
- self::create($data);
- if ($invite_code){
- CouponUser::create([
- 'user_id'=>$invite_code,
- 'coupon_title'=>'满100可用',
- 'coupon_price'=>50,
- 'use_min_price'=>100,
- 'add_time'=>time(),
- 'end_time'=>time()+(30*24*60*60),
- ]);
- }
- Db::commit();
- return Common::return_success('注册成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('注册失败');
- }
- }
- /**
- * 登录
- */
- public static function login($phone,$password,$type,$ver_code,$come){
- $phone_use = self::where('phone',$phone)->find();
- if (!$phone_use){
- return Common::return_error('手机号未注册!');
- }
- if ($phone_use['status']!=1){
- return Common::return_error('账号已禁用!');
- }
- if ($type==1){
- if ($phone_use['password'] != md5($password)){
- return Common::return_error('密码错误!');
- }
- }elseif ($type==2){
- //获取最后的验证码
- $time = time()-90;
- $sms = Sms::where(['mobile' => $phone, 'event' => 'login'])
- ->where('createtime','>',$time)
- ->order('id', 'DESC')
- ->find();
- if (!$sms || $sms->code != $ver_code){
- return Common::return_error('短信验证码不正确!');
- }
- }
- if ($come==2){
- $info = $phone_use;
- if (!$info['skills_label']){
- $info['skills_label'] = [];
- }else{
- $info['skills_label'] = explode(',', $info['skills_label']);
- }
- if (!$info['good_type']){
- $info['good_type'] = [];
- }else{
- $info['good_type'] = explode(',', $info['good_type']);
- }
- if (!$info['good_style']){
- $info['good_style'] = [];
- }else{
- $info['good_style'] = explode(',', $info['good_style']);
- }
- if (!$info['related_certificate']){
- $info['related_certificate'] = [];
- }else{
- $info['related_certificate'] = explode(',', $info['related_certificate']);
- }
- if (!$info['works']){
- $info['works'] = [];
- }else{
- $info['works'] = explode(',', $info['works']);
- }
- $data['info'] = $phone_use;
- if ($phone_use['type']==1 && $phone_use['audit']==0){
- $data['type'] = 1;
- }elseif ($phone_use['type']==1 && $phone_use['audit']==1){
- $data['type'] = 2;
- }elseif ($phone_use['type']==1 && $phone_use['audit']==3){
- $data['type'] = 3;
- }else{
- $data['type'] = 4;
- }
- $data['token'] = "";
- if ($data['type']==4){
- self::where('id',$phone_use['id'])->update(['ip'=>request()->ip()]);
- LoginLog::create(['user_id'=>$phone_use['id'],'ip'=>request()->ip()]);
- $token = JWT::encode($phone_use,config('jwt.key'));
- $data['token'] = $token;
- }
- return Common::return_success('成功',$data);
- }
- self::where('id',$phone_use['id'])->update(['ip'=>request()->ip()]);
- LoginLog::create(['user_id'=>$phone_use['id'],'ip'=>request()->ip()]);
- $token = JWT::encode($phone_use,config('jwt.key'));
- $data['token'] = $token;
- return Common::return_success('登录成功',$data);
- }
- /**
- * 微信授权登录
- * @param $code
- */
- public static function wechatLogin($code){
- $appid = Config::get_values('wechat_appid');
- $secret = Config::get_values('wechat_appsecret');
- $url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=$appid&secret=$secret&code=$code&grant_type=authorization_code";
- $result = Common::httpcurl($url);
- if (isset($result['access_token'])){
- $access_token=$result['access_token'];
- $openid=$result['openid'];
- $urltoc = "https://api.weixin.qq.com/sns/userinfo?access_token=$access_token&openid=$openid&lang=zh_CN";
- $resinfos =Common::httpcurl($urltoc);
- //数据库是否已注册
- $user = self::where('status',1)->where('openid',$resinfos['openid'])->find();
- if ($user){
- self::where('id',$user['id'])->update(['ip'=>request()->ip()]);
- LoginLog::create(['user_id'=>$user['id'],'ip'=>request()->ip()]);
- $token = JWT::encode($user,config('jwt.key'));
- return Common::return_success('登录成功',['token'=>$token]);
- }else{
- return Common::return_error('未注册!');
- }
- }else{
- return Common::return_error('获取access_token失败');
- }
- }
- /**
- * 获取微信session_key
- */
- public static function getSessionKey($code){
- $appid = Config::get_values('small_wechat_id');
- $secret = Config::get_values('small_wechat_appsecret');
- echo $appid."<br />";
- echo $secret;
- $url = "https://api.weixin.qq.com/sns/jscode2session?appid=" . $appid . "&secret=" . $secret . "&js_code=" . $code . "&grant_type=authorization_code";
- $session_key = Common::curlRequest($url);
- print_r($session_key);die;
- return $session_key;
- }
- /**
- * 微信登录绑定手机号
- */
- public static function wechatLoginBindPhone($code,$rawData,$phone,$ver_code,$password){
- $phone_use = self::where('phone',$phone)->find();
- if ($phone_use && $phone_use['openid']!=''){
- return Common::return_error('手机号已被绑定!');
- }
- // if (!$phone_use['status']){
- // return Common::return_error('账号已禁用!');
- // }
- //获取最后的验证码
- $time = time()-90;
- $sms = Sms::where(['mobile' => $phone, 'event' => 'bindwechat'])
- ->where('createtime','>',$time)
- ->order('id', 'DESC')
- ->find();
- if (!$sms || $sms->code != $ver_code){
- return Common::return_error('短信验证码不正确!');
- }
- $appid = Config::get_values('wechat_appid');
- $secret = Config::get_values('wechat_appsecret');
- $url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=$appid&secret=$secret&code=$code&grant_type=authorization_code";
- $result = Common::httpcurl($url);
- if (isset($result['access_token'])){
- $access_token=$result['access_token'];
- $openid=$result['openid'];
- $urltoc = "https://api.weixin.qq.com/sns/userinfo?access_token=$access_token&openid=$openid&lang=zh_CN";
- $resinfos = Common::httpcurl($urltoc);
- $openid = $resinfos['openid'];
- if (!$phone_use){
- $data['phone'] = $phone;
- $data['nickname'] = $resinfos['nickname'];
- $data['headimg'] = $resinfos['headimgurl'];
- $data['openid'] = $openid;
- $data['password'] = md5($password);
- $data['ip'] = request()->ip();
- Db::startTrans();
- try {
- $user = self::create($data);
- Db::commit();
- $userId =$user->id;
- LoginLog::create(['user_id'=>$userId,'ip'=>request()->ip()]);
- $user = self::where('id',$userId)->find();
- $token = JWT::encode($user,config('jwt.key'));
- return Common::return_success('授权成功',['token'=>$token]);
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('失败');
- }
- }else{
- $da['openid'] = $openid;
- if (!$phone_use['headimg']){
- $da['headimg'] = $resinfos['headimgurl'];
- }
- if (!$phone_use['nickname']){
- $da['nickname'] = $resinfos['nickname'];
- }
- if (self::where('id',$phone_use['id'])->update($da)){
- LoginLog::create(['user_id'=>$phone_use['id'],'ip'=>request()->ip()]);
- $token = JWT::encode($phone_use,config('jwt.key'));
- return Common::return_success('绑定成功',['token'=>$token]);
- }else{
- return Common::return_error('失败');
- }
- }
- }else{
- return Common::return_error('获取access_token失败');
- }
- }
- /**
- * 商家注册第一步
- */
- public static function designer_register_one($phone,$ver_code){
- $phone_use = self::where('phone',$phone)->find();
- if ($phone_use){
- return Common::return_error('手机号已注册!');
- }
- //获取最后的验证码
- $time = time()-90;
- $sms = Sms::where(['mobile' => $phone, 'event' => 'register'])
- ->where('createtime','>',$time)
- ->order('id', 'DESC')
- ->find();
- if (!$sms || $sms->code != $ver_code){
- return Common::return_error('短信验证码不正确!');
- }
- return Common::return_success('验证成功');
- }
- /**
- * 商家注册第二步
- */
- public static function designer_register_two($data){
- $phone_use = self::where('phone',$data['phone'])->find();
- if ($phone_use && $phone_use['type']==2){
- return Common::return_error('手机号已注册!');
- }
- $data['audit'] = 1;
- Db::startTrans();
- try {
- self::where('phone',$data['phone'])->update($data);
- Db::commit();
- return Common::return_success('申请成功,等待审核');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('申请失败');
- }
- }
- /**
- * 忘记密码
- */
- public static function forgotPassword($phone,$password,$ver_code){
- $phone_use = self::where('phone',$phone)->find();
- if (!$phone_use){
- return Common::return_error('手机号未注册!');
- }
- //获取最后的验证码
- $time = time()-90;
- $sms = Sms::where(['mobile' => $phone, 'event' => 'forgetpwd'])
- ->where('createtime','>',$time)
- ->order('id', 'DESC')
- ->find();
- if (!$sms || $sms->code != $ver_code){
- return Common::return_error('短信验证码不正确!');
- }
- $phone_use->password = md5($password);
- Db::startTrans();
- try {
- $phone_use->save();
- Db::commit();
- return Common::return_success('修改成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('修改失败');
- }
- }
- /**
- * 修改密码
- */
- public static function changePassword($user_id,$password,$ver_code){
- $phone_use = self::where('id',$user_id)->find();
- //获取最后的验证码
- $time = time()-90;
- $sms = Sms::where(['mobile' => $phone_use['phone'], 'event' => 'changepwd'])
- ->where('createtime','>',$time)
- ->order('id', 'DESC')
- ->find();
- if (!$sms || $sms->code != $ver_code){
- return Common::return_error('短信验证码不正确!');
- }
- $phone_use->password = md5($password);
- Db::startTrans();
- try {
- $phone_use->save();
- Db::commit();
- return Common::return_success('修改成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('修改失败');
- }
- }
- /**
- * 我的收货地址列表
- */
- public static function MyAddress($user_id,$Nowpage,$limits){
- $list = Address::where('is_del',0)
- ->where('user_id',$user_id)
- ->page($Nowpage,$limits)
- ->order('is_default desc,id desc')
- ->select();
- $data['count'] = count($list);
- $data['list'] = $list;
- return Common::return_success('成功',$data);
- }
- /**
- * 添加,修改收货地址
- */
- public static function AddEditAddress($user_id,$data,$address_id){
- if ($address_id){
- $address = Address::where('id',$address_id)->where('user_id',$user_id)->find();
- if (!$address) return Common::return_error('地址不存在');
- //编辑
- if ($address->save($data)){
- if ($data['is_default']==1){
- Address::where('user_id',$user_id)
- ->where('is_del',0)
- ->where('id','neq',$address_id)
- ->update(['is_default'=>0]);
- }
- return Common::return_success('编辑成功');
- }else{
- return Common::return_error('编辑失败');
- }
- }else{
- $data['user_id'] = $user_id;
- $addre = Address::create($data);
- if ($addre){
- $address_id = $addre->id;
- if ($data['is_default']==1){
- Address::where('user_id',$user_id)
- ->where('is_del',0)
- ->where('id','neq',$address_id)
- ->update(['is_default'=>0]);
- }
- return Common::return_success('添加成功');
- }else{
- return Common::return_error('添加失败');
- }
- }
- }
- /**
- * 设为默认地址
- */
- public static function SetAddressDefault($user_id,$address_id){
- $address = Address::where('id',$address_id)
- ->where('user_id',$user_id)
- ->find();
- if (!$address) return Common::return_error('地址不存在');
- if ($address->save(['is_default'=>1])){
- Address::where('user_id',$user_id)
- ->where('is_del',0)
- ->where('id','neq',$address_id)
- ->update(['is_default'=>0]);
- return Common::return_success('设置成功');
- }else{
- return Common::return_error('设置失败');
- }
- }
- /**
- * 删除收货地址
- */
- public static function DelAddress($user_id,$address_id){
- $address = Address::where('id',$address_id)->where('user_id',$user_id)->find();
- if (!$address) return Common::return_error('地址不存在');
- if ($address->save(['is_del'=>time()])){
- return Common::return_success('删除成功');
- }else{
- return Common::return_error('删除失败');
- }
- }
- /**
- * 编辑用户资料
- */
- public static function EditUserInfo($user_id,$data){
- if (self::where('id',$user_id)->update($data)){
- return Common::return_success('编辑成功');
- }else{
- return Common::return_error('编辑失败');
- }
- }
- /**
- * 申请成为设计师
- */
- public static function applyDesigner($user_id,$data){
- $data['type'] = 1;
- $data['audit'] = 1;
- Db::startTrans();
- try {
- self::where('id',$user_id)->update($data);
- Db::commit();
- return Common::return_success('提交成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('提交失败');
- }
- }
- /**
- * 投诉
- */
- public static function Message($user_id,$content){
- $data['content'] = $content;
- $data['user_id'] = $user_id;
- if (Message::create($data)) return Common::return_success('提交成功');
- return Common::return_error('提交失败');
- }
- /**
- * 时间管理
- */
- public static function timeList($user_id){
- $time = time();
- //组合数据
- $date = [];
- for ($i=1; $i<=15; $i++){
- $date[$i] = date('Y-m-d' ,strtotime( $i .' days', $time));
- }
- $array = [];
- foreach ($date as &$v){
- $da = UserTime::where('user_id',$user_id)->where('time',$v)->find();
- if ($da){
- $array2['switch'] = $da['switch'];
- $array2['price'] = $da['price'];
- }else{
- $array2['switch'] = 2;
- $array2['price'] = 0;
- }
- $array2['date'] = $v;
- array_push($array,$array2);
- }
- return Common::return_success('成功',$array);
- }
- /**
- * 时间设置开关
- */
- // public static function timeSwitch($user_id,$date,$switch,$price){
- // $info = UserTime::where('user_id',$user_id)->where('time',$date)->find();
- // if ($info){
- // if (UserTime::where('id',$info['id'])->update(['switch'=>$switch,'price'=>$price])){
- // return Common::return_success('成功');
- // }else{
- // return Common::return_error('失败');
- // }
- // }else{
- // if (UserTime::create(
- // [
- // 'user_id'=>$user_id,
- // 'time'=>$date,
- // 'switch'=>$switch,
- // 'price'=>$price
- // ]
- // )){
- // return Common::return_success('成功');
- // }else{
- // return Common::return_error('失败');
- // }
- // }
- // }
- /**
- * 时间设置开关
- */
- public static function timeSwitch($user_id,$json){
- foreach ($json as &$v){
- $info = UserTime::where('user_id',$user_id)->where('time',$v['date'])->find();
- if ($info){
- UserTime::where('id',$info['id'])->update(['switch'=>$v['switch'],'price'=>$v['price']]);
- }else{
- UserTime::create(
- [
- 'user_id'=>$user_id,
- 'time'=>$v['date'],
- 'switch'=>$v['switch'],
- 'price'=>$v['price']
- ]);
- }
- }
- return Common::return_success('成功');
- }
- /**
- * 余额提现
- */
- public static function userWithdraw($user_id,$money,$withdraw_type){
- $userinfo = self::where('id',$user_id)->find();
- if ($userinfo['money']<$money)
- return Common::return_error('余额不足');
- $data['user_id'] = $user_id;
- $order_no = Common::getNewOrderId($user_id);
- $data['order_no'] = $order_no;
- $data['withdraw_type'] = $withdraw_type;
- $data['price'] = $money;
- Db::startTrans();
- try {
- UserWithdraw::create($data);
- User::money($money,$user_id,$withdraw_type=='weixin' ? '微信提现' : '支付宝提现' .$money.'元');
- Db::commit();
- return Common::return_success('提交成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('提交失败');
- }
- }
- /**
- * 消费明细
- */
- public static function moneyRecord($user_id,$Nowpage,$limits){
- //提现记录
- $withdraw = UserWithdraw::where('user_id',$user_id)->field('withdraw_type,paid,why,create_at,price')->select();
- if (count($withdraw)>0){
- $withdraw = $withdraw->toArray();
- foreach ($withdraw as &$v){
- $v['price'] = '-'.$v['price'];
- $v['project_name'] = '';
- }
- }else{
- $withdraw = [];
- }
- //收益记录
- $record = MoneyLog::where('user_id',$user_id)->where('title','订单收益')->select();
- if (count($record)>0){
- $record = $record->toArray();
- $array = [];
- foreach ($record as &$v){
- $array2['withdraw_type'] = 'sy';
- $array2['paid'] = 1;
- $array2['why'] = '';
- $array2['create_at'] = $v['create_at'];
- $array2['price'] = '+'.$v['change_money'];
- if ($v['link_id']!=0){
- $project_name = Order::where('id',$v['link_id'])->value('project_name');
- }else{
- $project_name = '';
- }
- $array2['project_name'] = $project_name;
- array_push($array,$array2);
- }
- }else{
- $array = [];
- }
- $list = array_merge($withdraw,$array);
- $data['count'] = count($list);
- array_multisort(array_column($list,'create_at'),SORT_DESC,$list);
- $list = array_slice($list,($Nowpage-1)*$limits,$limits);
- $data['list'] = $list;
- return Common::return_success('成功',$data);
- }
- /**
- * 获取首页搜索日期列表
- */
- public static function searchDateList(){
- $time = time();
- //组合数据
- $date = [];
- for ($i=1; $i<=15; $i++){
- $date[$i-1]['date'] = date('Y-m-d' ,strtotime( $i .' days', $time));
- $date[$i-1]['time'] = date('m-d' ,strtotime( $i .' days', $time));
- }
- return Common::return_success('成功',$date);
- }
- /**
- * 首页设计师列表
- */
- public static function Designer($user_id,$Nowpage,$limits,$design_classifi,$keywords,$lat,$log,$city,$distance,$price,$evaluation,$date,$price_section_start,$price_section_end){
- // self::RecentlyPrice(); //更新价格
- $count = self::designerByWhere($user_id,$design_classifi,$keywords,$city,$date,$price_section_start,$price_section_end)->count();
- if ($count){
- $field = ['id','phone','name','nickname','headimg','price','design_classifi','skills_label','good_type','good_style','evaluation','works','province','city','area','work_experience','work_year','signature'];
- if ($lat && $log){
- $field['ROUND(6378.138 * 2 * ASIN(SQRT(POW( SIN( ( ' . $lat . ' * PI( ) / 180 - wd * PI( ) / 180 ) / 2 ), 2 ) + COS( ' . $lat . ' * PI( ) / 180 ) * COS( wd * PI( ) / 180 ) * POW( SIN( ( ' . $log . ' * PI( ) / 180 - jd * PI( ) / 180 ) / 2 ), 2 ))) * 1000)'] = 'distance';
- }
- $list = self::designerByWhere($user_id,$design_classifi,$keywords,$city,$date,$price_section_start,$price_section_end)
- ->field($field)
- ->when($distance,function ($query) use ($distance,$lat,$log){
- if ($lat && $log){
- $query->order('distance '.$distance);
- }
- })
- ->when($price,function ($query) use ($price){
- $query->order('price '.$price);
- })
- ->when($evaluation,function ($query) use ($evaluation){
- $query->order('evaluation '.$evaluation);
- })
- ->page($Nowpage,$limits)
- ->select();
- $time = time();
- //组合数据
- $date = [];
- for ($i=1; $i<=15; $i++){
- $date[$i] = date('Y-m-d' ,strtotime( $i .' days', $time));
- }
- foreach ($list as &$v){
- if ($v['works']){
- $v['works'] = explode(',',$v['works']);
- }else{
- $v['works'] = [];
- }
- if ($v['skills_label']){
- $v['skills_label'] = explode(',',$v['skills_label']);
- }else{
- $v['skills_label'] = [];
- }
- if ($v['good_type']){
- $v['good_type'] = explode(',',$v['good_type']);
- }else{
- $v['good_type'] = [];
- }
- if ($v['good_style']){
- $v['good_style'] = explode(',',$v['good_style']);
- }else{
- $v['good_style'] = [];
- }
- $v['name'] = $v['nickname'];
- $datee = Works::where('user_id',$v['id'])
- ->where('is_del',1)
- ->group('date')
- ->order('id desc')
- ->column('date');
- if ($datee){
- $arr = [];
- foreach ($datee as &$a){
- $array22['date'] = $a;
- $array22['imgs'] = Works::where('user_id',$v['id'])
- ->where('date',$a)
- ->where('is_del',1)
- ->field('id,img')
- ->select();
- array_push($arr,$array22);
- }
- }else{
- $arr = [];
- }
- $v['works_list'] = $arr;
- $array = [];
- foreach ($date as &$a){
- $da = UserTime::where('user_id',$v['id'])->where('time',$a)->find();
- if ($da){
- $order = Order::where('designer_id',$v['id'])
- ->where('yy_date',$a)
- ->where('is_del',1)
- ->whereIn('status','1,2')
- ->count();
- if ($order){
- $array2['switch'] = 2;
- }else{
- $array2['switch'] = $da['switch'];
- }
- $array2['price'] = $da['price'];
- }else{
- $array2['switch'] = 2;
- $array2['price'] = 0;
- }
- $array2['date'] = $a;
- array_push($array,$array2);
- }
- $v['date_list'] = $array;
- }
- }else{
- $list = [];
- }
- return Common::return_success('成功',compact('count','list'));
- }
- /**
- * 首页设计师列表where条件
- */
- public static function designerByWhere($user_id,$design_classifi,$keywords,$city,$date,$price_section_start,$price_section_end){
- $query = self::where('status',1)
- ->when($design_classifi,function ($query) use ($design_classifi){
- $query->where('design_classifi',$design_classifi);
- })
- ->when($keywords,function ($query) use ($keywords){
- $query->whereLike('name|nickname|skills_label|design_classifi|good_type|good_style','%'.$keywords.'%');
- })
- ->when($city,function ($query) use ($city){
- //$query->where('city',$city);
- $query->whereRaw('city like "%'.$city.'%" or province like "%'.$city.'%"');
- })
- ->when($date,function ($query) use ($date){
- $ids1 = UserTime::where('time',$date)
- ->where('switch',1)
- ->column('user_id');
- $ids2 = Order::where('yy_date',$date)
- ->where('is_del',1)
- ->whereIn('status','1,2')
- ->column('designer_id');
- $ids = array_diff($ids1,$ids2); //对比两数组差异
- $query->whereIn('id',$ids);
- })
- ->when($price_section_start,function ($query) use ($price_section_start,$price_section_end){
- if ($price_section_start && $price_section_end){
- $query->where('price','>=',$price_section_start)->where('price','<=',$price_section_end);
- }
- })
- ->where('price','>',0)
- //->where('id','neq',$user_id)
- ->where('type',2);
- return $query;
- }
- /**
- * 获取设计师最近的价格显示
- */
- public static function RecentlyPrice(){
- self::where('status',1)->where('type',2)->chunk(50,function ($list){
- $time = time();
- //组合数据
- $date = [];
- for ($i=1; $i<=7; $i++){
- $date[$i] = date('Y-m-d' ,strtotime( $i .' days', $time));
- }
- foreach ($list as &$v){
- $price = UserTime::where('user_id',$v['id'])
- ->where('switch',1)
- ->order('time asc')
- ->whereBetween('time',[$date[1],$date[7]])
- ->limit(1)
- ->value('price');
- if (!$price){
- $price = 0;
- }
- self::where('id',$v['id'])->update(['price'=>$price]);
- }
- });
- }
- /**
- * 获取可使用优惠券列表
- */
- public static function getCouponList($user_id,$money){
- CouponUser::couponsTimeOut($user_id);
- $list = CouponUser::where('user_id',$user_id)
- ->where('use_min_price','<=',$money)
- ->where('end_time','>',time())
- ->where('status',0)
- ->select();
- if ($list){
- foreach ($list as &$v){
- $v['add_time'] = date('Y-m-d',$v['add_time']);
- $v['end_time'] = date('Y-m-d',$v['end_time']);
- }
- }
- return Common::return_success('成功',$list);
- }
- /**
- * 下单时间段列表
- */
- public static function periodTimeList(){
- $list = PeriodTime::where('is_del',1)->select();
- return Common::return_success('成功',$list);
- }
- /**
- * 下单
- */
- public static function PlaceOrder($user_id,$address_id,$designer_id,$yy_date,$project_name,$coupon_id,$pay_type,$period_id){
- // if ($pay_type=='weixin'){
- // return Common::return_error('暂时无法使用微信支付');
- // }
- $orde = Order::where('user_id',$user_id)->where('is_del',1)->where('overtime_pay_status',1)->find();
- if ($orde) return Common::return_error('有未支付的加班费订单,无法下单');
- $designer = self::where('id',$designer_id)
- ->where('type',2)
- ->where('status',1)
- ->find();
- if (!$designer) return Common::return_error('设计师不存在');
- $address = Address::where('id',$address_id)
- ->where('user_id',$user_id)
- ->where('is_del',0)
- ->find();
- if (!$address) return Common::return_error('地址不存在');
- $time = UserTime::where('user_id',$designer_id)
- ->where('time',$yy_date)
- //->where('switch',1)
- ->find();
- $order = Order::where('designer_id',$designer_id)
- ->where('is_del',1)
- ->whereIn('status','1,2')
- ->where('yy_date',$yy_date)
- ->find();
- $period = PeriodTime::where('id',$period_id)->find();
- if ($order) return Common::return_error('预约日期设计师已接单');
- if ($time && $time['switch']==2) return Common::return_error('预约日期设计师未开启接单');
- //价格
- $price = $designer['price'];
- $coupon_price = 0;
- $pay_price = $price;
- if ($coupon_id){
- $coupon = CouponUser::where('id',$coupon_id)
- ->where('user_id',$user_id)
- ->where('status',0)
- ->find();
- if (!$coupon) return Common::return_error('优惠券不存在');
- $coupon_price = $coupon['coupon_price'];
- $pay_price = bcsub($pay_price,$coupon_price,2);
- }else{
- $coupon_id = 0;
- }
- //订单号
- $order_no = Common::getNewOrderId($user_id);
- $data = [
- 'order_no'=>$order_no,
- 'user_id'=>$user_id,
- 'designer_id'=>$designer_id,
- 'address_id'=>$address_id,
- 'address_jd'=>$address['jd'],
- 'address_wd'=>$address['wd'],
- 'name'=>$address['name'],
- 'phone'=>$address['phone'],
- 'province'=>$address['province'],
- 'city'=>$address['city'],
- 'area'=>$address['area'],
- 'address'=>$address['address'],
- 'yy_date'=>$yy_date,
- 'servicing_time'=>$period['start'].'-'.$period['end'],
- 'project_name'=>$project_name,
- 'coupon_id'=>$coupon_id,
- 'pay_type'=>$pay_type,
- 'price'=>$price,
- 'coupon_price'=>$coupon_price,
- 'pay_price'=>$pay_price,
- ];
- Db::startTrans();
- try {
- $order = Order::create($data);
- $order_id = $order->id;
- Common::order_status($order_id,'订单生成');
- //优惠券确定
- if ($coupon_id){
- CouponUser::where('id',$coupon_id)->update(['status'=>1,'use_time'=>time()]);
- }
- //先模拟下单成功
- // $da['pay_time'] = time();
- // $da['status'] = 1;
- // Order::where('id',$order['id'])->update($da);
- // Db::commit();
- // return Common::return_success('成功');
- switch ($pay_type){
- case 'weixin':
- $wx = new WxPay();//实例化微信torganizationid支付控制器
- $body = '订单号' . $order_no;//支付说明
- $total_fee = $pay_price * 100;//支付金额(乘以100)
- $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/api/pay/pay_order';//回调地址
- $out_trade_no = $order_no;//订单号
- $config = $wx->retrunconfig();
- try{
- $app = Factory::payment($config);
- $result = $app->order->unify([
- 'body' => $body,
- 'out_trade_no' => $out_trade_no,
- 'total_fee' => $total_fee,
- 'notify_url' => $notify_url, // 支付结果通知网址,如果不设置则会使用配置里的默认地址
- 'trade_type' => 'APP', // 请对应换成你的支付方式对应的值类型
- ]);
- $jssdk = $app->jssdk;
- $order1 = $jssdk->appConfig($result['prepay_id']);
- Order::where('order_no',$order_no)->update(['wx_order'=>json_encode($order1,true)]);
- Db::commit();
- $retrun_data['order_no'] = $order_no;
- $retrun_data['pay'] = $order1;
- return Common::return_success('成功',$retrun_data);
- }catch (Exception $e){
- Db::rollback();
- return Common::return_error($order['return_msg']);
- }
- break;
- case 'zfb':
- $zfb = new AliPay();//实例化支付宝支付控制器
- $body = '设计下单支付';//支付说明
- $out_trade_no = $order_no;//订单号
- $total_fee = $pay_price;//支付金额
- $notify_url = 'http://'.$_SERVER['SERVER_NAME'].'/api/pay/alipay_order';//回调地址
- $order = $zfb->aliPay($body, $total_fee, $out_trade_no, $notify_url);//调用支付宝支付的方法
- $retrun_data['order_no'] = $order_no;
- $retrun_data['pay'] = $order;
- Db::commit();
- return Common::return_success('成功',$retrun_data);
- break;
- }
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('失败');
- }
- }
- /**
- * 用户端订单列表
- */
- public static function userOrderList($user_id,$status,$keywords,$Nowpage,$limits){
- $count = self::orderByWhere($status,$user_id,$keywords)->count();
- if ($count){
- $list = self::orderByWhere($status,$user_id,$keywords)
- ->page($Nowpage,$limits)
- ->order('id desc')
- ->select();
- }else{
- $list = [];
- }
- return Common::return_success('成功',compact('count','list'));
- }
- /**
- * 订单条件
- */
- public static function orderByWhere($status,$user_id,$keywords){
- $query = Order::where('user_id',$user_id)
- ->where('is_del',1)
- ->when($status,function ($query) use ($status){
- if ($status!='all'){
- $query->where('status',$status);
- }
- })
- ->when($keywords,function ($query) use ($keywords){
- $query->whereLike('project_name|order_no','%'.$keywords.'%');
- });
- if ($status==='0'){
- $query = $query->where('status',$status);
- }
- return $query;
- }
- /**
- * 订单支付
- */
- public static function payOrder($user_id,$order_no){
- $order = Order::where('order_no', $order_no)->where('user_id', $user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- $order = $order->toArray();
- if ($order['status'])
- return Common::return_error('订单已支付');
- $designer = self::where('id',$order['designer_id'])
- ->where('type',2)
- ->where('status',1)
- ->find();
- if (!$designer) return Common::return_error('设计师不存在');
- $time = UserTime::where('user_id',$order['designer_id'])
- ->where('time',$order['yy_date'])
- ->where('switch',1)
- ->find();
- $order2 = Order::where('designer_id',$order['designer_id'])
- ->where('is_del',1)
- ->whereIn('status','1,2')
- ->where('yy_date',$order['yy_date'])
- ->find();
- if (!$time || $order2) return Common::return_error('预约日期设计师未开启接单或已接单');
- if ($order['coupon_id']){
- $coupon = CouponUser::where('id',$order['coupon_id'])
- ->where('user_id',$user_id)
- ->where('status',0)
- ->find();
- if (!$coupon) return Common::return_error('优惠券不存在或已使用');
- }
- $pay_type = $order['pay_type'];
- $pay_price = $order['pay_price'];
- Db::startTrans();
- switch ($pay_type){
- case 'weixin':
- $wx = new WxPay();//实例化微信torganizationid支付控制器
- $body = '订单号' . $order_no;//支付说明
- $total_fee = $pay_price * 100;//支付金额(乘以100)
- $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/api/pay/pay_order';//回调地址
- $out_trade_no = $order_no;//订单号
- $config = $wx->retrunconfig();
- try{
- $app = Factory::payment($config);
- $result = $app->order->unify([
- 'body' => $body,
- 'out_trade_no' => $out_trade_no,
- 'total_fee' => $total_fee,
- 'notify_url' => $notify_url, // 支付结果通知网址,如果不设置则会使用配置里的默认地址
- 'trade_type' => 'APP', // 请对应换成你的支付方式对应的值类型
- ]);
- $jssdk = $app->jssdk;
- $order1 = $jssdk->appConfig($result['prepay_id']);
- Order::where('order_no',$order_no)->update(['wx_order'=>json_encode($order1,true)]);
- Db::commit();
- $retrun_data['order_no'] = $order_no;
- $retrun_data['pay'] = $order1;
- // Common::order_status($order['id'],'订单支付成功');
- return Common::return_success('成功',$retrun_data);
- }catch (Exception $e){
- Db::rollback();
- return Common::return_error($order['return_msg']);
- }
- break;
- case 'zfb':
- $zfb = new AliPay();//实例化支付宝支付控制器
- $body = '设计下单支付';//支付说明
- $out_trade_no = $order_no;//订单号
- $total_fee = $pay_price;//支付金额
- $notify_url = 'http://'.$_SERVER['SERVER_NAME'].'/api/pay/alipay_order';//回调地址
- $order = $zfb->aliPay($body, $total_fee, $out_trade_no, $notify_url);//调用支付宝支付的方法
- $retrun_data['order_no'] = $order_no;
- $retrun_data['pay'] = $order;
- Db::commit();
- return Common::return_success('成功',$retrun_data);
- break;
- }
- }
- /**
- * 订单支付加班费
- */
- public static function overtimePayOrder($user_id,$order_no,$pay_type){
- if ($pay_type=='weixin'){
- return Common::return_error('暂时无法使用微信支付');
- }
- $order = Order::where('order_no', $order_no)->where('user_id', $user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- $order = $order->toArray();
- if (in_array($order['overtime_pay_status'],['0','2']))
- return Common::return_error('没有加班费或加班费已支付');
- $pay_price = $order['overtime_pay'];
- Db::startTrans();
- switch ($pay_type){
- case 'weixin':
- $wx = new WxPay();//实例化微信torganizationid支付控制器
- $body = '订单号' . $order['overtime_pay_order_no'];//支付说明
- $total_fee = $pay_price * 100;//支付金额(乘以100)
- $notify_url = 'https://'.$_SERVER['SERVER_NAME'].'/api/pay/overtime_pay_order';//回调地址
- $out_trade_no = $order['overtime_pay_order_no'];//订单号
- $config = $wx->retrunconfig();
- try{
- $app = Factory::payment($config);
- $result = $app->order->unify([
- 'body' => $body,
- 'out_trade_no' => $out_trade_no,
- 'total_fee' => $total_fee,
- 'notify_url' => $notify_url, // 支付结果通知网址,如果不设置则会使用配置里的默认地址
- 'trade_type' => 'APP', // 请对应换成你的支付方式对应的值类型
- ]);
- $jssdk = $app->jssdk;
- $order1 = $jssdk->appConfig($result['prepay_id']);
- Order::where('order_no',$order_no)->update(['overtime_pay_type'=>$pay_type,'overtime_wx_order'=>json_encode($order1,true)]);
- Db::commit();
- $retrun_data['order_no'] = $out_trade_no;
- $retrun_data['pay'] = $order1;
- return Common::return_success('成功',$retrun_data);
- }catch (Exception $e){
- Db::rollback();
- return Common::return_error($order['return_msg']);
- }
- break;
- case 'zfb':
- $zfb = new AliPay();//实例化支付宝支付控制器
- $body = '设计下单支付';//支付说明
- $out_trade_no = $order['overtime_pay_order_no'];//订单号
- $total_fee = $pay_price;//支付金额
- $notify_url = 'http://'.$_SERVER['SERVER_NAME'].'/api/pay/overtime_alipay_order';//回调地址
- $order = $zfb->aliPay($body, $total_fee, $out_trade_no, $notify_url);//调用支付宝支付的方法
- $retrun_data['order_no'] = $out_trade_no;
- $retrun_data['pay'] = $order;
- Order::where('order_no',$order_no)->update(['overtime_pay_type'=>$pay_type]);
- Db::commit();
- return Common::return_success('成功',$retrun_data);
- break;
- }
- }
- /**
- * 订单详情
- */
- public static function orderDetail($order_no){
- $order = Order::where('order_no',$order_no)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- $designer =self::where('id',$order['designer_id'])->field('id,name,headimg,evaluation,works,design_classifi')->find();
- if ($designer['works']){
- $designer['works'] = explode(',',$designer['works']);
- }else{
- $designer['works'] = [];
- }
- $order['designer'] =$designer;
- $order['pay_time'] = date('Y-m-d H:i:s',$order['pay_time']);
- return Common::return_success('成功',$order);
- }
- /**
- * 取消订单
- */
- public static function cancelOrder($user_id,$order_no){
- $order = Order::where('order_no',$order_no)->where('user_id',$user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- if ($order['status'])
- return Common::return_error('订单无法取消');
- Db::startTrans();
- try {
- $order->status = 5;
- $order->remark = '用户取消订单';
- $order->save();
- if ($order->coupon_id){
- CouponUser::where('id',$order->coupon_id)->update(['status'=>0]);
- }
- Db::commit();
- Common::order_status($order->id,'订单取消成功');
- return Common::return_success('取消成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('取消失败');
- }
- }
- /**
- * 删除订单
- */
- public static function delOrder($user_id,$order_no){
- $order = Order::where('order_no',$order_no)->where('user_id',$user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- Db::startTrans();
- try {
- $order->is_del = 0;
- $order->del_time = time();
- $order->save();
- Db::commit();
- return Common::return_success('删除成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('删除失败');
- }
- }
- /**
- * 订单评价
- */
- public static function evaluationOrder($user_id,$order_no,$evaluation,$evaluation_content){
- $order = Order::where('order_no',$order_no)->where('user_id',$user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- if ($order['status']!=3)
- return Common::return_error('订单状态错误');
- Db::startTrans();
- try {
- $order->status = 4;
- $order->evaluation = $evaluation;
- $order->evaluation_time = time();
- $order->evaluation_content = $evaluation_content;
- $order->save();
- Db::commit();
- $sum = Order::where('designer_id',$order['designer_id'])->where('status',4)->sum('evaluation');
- $count = Order::where('designer_id',$order['designer_id'])->where('status',4)->count();
- $eva = ceil($sum/$count);
- User::where('id',$order['designer_id'])->update(['evaluation'=>$eva]);
- Common::order_status($order->id,'订单评价成功');
- return Common::return_success('评价成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('评价失败');
- }
- }
- /**
- * 用户端我的评价
- */
- public static function userEvaluationList($user_id,$Nowpage,$limits){
- $where = [
- 'a.user_id'=>$user_id,
- 'a.status'=>4,
- 'a.is_del'=>1
- ];
- $count = Order::where($where)
- ->alias('a')
- ->join('q_user b','a.user_id=b.id')
- ->join('q_user c','a.designer_id=c.id')
- ->count();
- if ($count){
- $list = Order::where($where)
- ->alias('a')
- ->join('q_user b','a.user_id=b.id')
- ->join('q_user c','a.designer_id=c.id')
- ->page($Nowpage,$limits)
- ->field('a.id,a.order_no,a.evaluation,a.evaluation_time,a.evaluation_content,b.name,b.nickname,b.headimg,c.name as designer_name')
- ->order('a.id desc')
- ->select();
- foreach ($list as &$v){
- $v['evaluation_time'] = date('Y-m-d',$v['evaluation_time']);
- }
- }else{
- $list = [];
- }
- return Common::return_success('成功',compact('count','list'));
- }
- /**
- * 设计师端我的评价
- */
- public static function designerEvaluationList($user_id,$Nowpage,$limits){
- $where = [
- 'a.designer_id'=>$user_id,
- 'a.status'=>4,
- 'a.is_del'=>1
- ];
- $count = Order::where($where)
- ->alias('a')
- ->join('q_user b','a.user_id=b.id')
- ->count();
- if ($count){
- $list = Order::where($where)
- ->alias('a')
- ->join('q_user b','a.user_id=b.id')
- ->page($Nowpage,$limits)
- ->field('a.id,a.order_no,a.evaluation,a.evaluation_time,a.evaluation_content,b.name,b.nickname,b.headimg')
- ->order('a.id desc')
- ->select();
- foreach ($list as &$v){
- $v['evaluation_time'] = date('Y-m-d',$v['evaluation_time']);
- }
- }else{
- $list = [];
- }
- return Common::return_success('成功',compact('count','list'));
- }
- /**
- * 设计师端添加作品
- */
- public static function addWorks($user_id,$imgs){
- $data = [
- 'user_id'=>$user_id,
- 'date'=>date('Y-m-d')
- ];
- foreach ($imgs as &$v){
- $data['img'] = $v;
- Works::create($data);
- }
- return Common::return_success('成功');
- }
- /**
- * 设计师端作品管理
- */
- public static function workList($user_id){
- $date = Works::where('user_id',$user_id)
- ->where('is_del',1)
- ->group('date')
- ->order('id desc')
- ->column('date');
- if ($date){
- $array = [];
- foreach ($date as &$v){
- $array2['date'] = $v;
- $array2['imgs'] = Works::where('user_id',$user_id)
- ->where('date',$v)
- ->where('is_del',1)
- ->field('id,img')
- ->select();
- array_push($array,$array2);
- }
- }else{
- $array = [];
- }
- return Common::return_success('成功',$array);
- }
- /**
- * 设计师端删除作品
- */
- public static function delWorks($user_id,$ids){
- if (Works::whereIn('id',$ids)->where('user_id',$user_id)->update(['is_del'=>0])){
- return Common::return_success('删除成功');
- }else{
- return Common::return_error('删除失败');
- }
- }
- /**
- * 设计师端首页
- */
- public static function designerIndex($user_id){
- $list = Order::where('designer_id',$user_id)
- ->where('is_del',1)
- ->whereIn('status','1,2')
- ->order('id desc')
- ->limit(2)
- ->select();
- return Common::return_success('成功',$list);
- }
- /**
- * 用户端订单列表
- */
- public static function designerOrderList($user_id,$status,$keywords,$Nowpage,$limits){
- $count = self::designerOrderByWhere($status,$user_id,$keywords)->count();
- if ($count){
- $list = self::designerOrderByWhere($status,$user_id,$keywords)
- ->page($Nowpage,$limits)
- ->order('id desc')
- ->select();
- }else{
- $list = [];
- }
- return Common::return_success('成功',compact('count','list'));
- }
- /**
- * 订单条件
- */
- public static function designerOrderByWhere($status,$user_id,$keywords){
- $query = Order::where('designer_id',$user_id)
- ->where('is_del',1)
- ->when($status,function ($query) use ($status){
- if (in_array($status,['1','2'])){
- $query->where('status',$status);
- }elseif ($status==3){
- $query->whereIn('status','3,4');
- }
- })
- ->when($keywords,function ($query) use ($keywords){
- $query->whereLike('project_name|order_no','%'.$keywords.'%');
- });
- if ($status===0){
- $query = $query->where('status',$status);
- }
- return $query;
- }
- /**
- * 设计师开始打卡
- */
- public static function clockInStart($user_id,$order_no,$start_address){
- $order = Order::where('order_no',$order_no)->where('designer_id',$user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- if ($order['status']!=1)
- return Common::return_error('订单状态错误');
- Db::startTrans();
- try {
- $order->status = 2;
- $order->start_time = date('Y-m-d H:i:s');
- $order->start_address = $start_address;
- $order->save();
- Db::commit();
- Common::order_status($order->id,'设计师开始打卡成功');
- return Common::return_success('打卡成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('打卡失败');
- }
- }
- /**
- * 设计师结束打卡
- */
- public static function clockInEnd($user_id,$order_no,$end_address){
- $order = Order::where('order_no',$order_no)->where('designer_id',$user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- if ($order['status']!=2)
- return Common::return_error('订单状态错误');
- Db::startTrans();
- try {
- $order->status = 3;
- $order->end_time = date('Y-m-d H:i:s');
- $order->end_address = $end_address;
- //判断是否产生加班费
- $servicing = explode('-',$order['servicing_time']);
- $end_time = strtotime($order['yy_date'].' '.$servicing[1]);
- if (time()>$end_time){
- $poor_minutes = floor((time()-$end_time)%86400/60);
- //获取加班费每分钟多钱
- $user_overtime_pay = self::where('id',$user_id)->value('overtime_pay');
- if ($user_overtime_pay>0){
- $price = $user_overtime_pay;
- }else{
- $price = $order['price'] * 0.1; //订单金额10%的加班费
- }
- $overtime_pay = sprintf("%.2f", ($price/60) * $poor_minutes); //四舍五入保留两位小数
- $order->overtime_pay = $overtime_pay;
- $order->overtime_pay_order_no = Common::getNewOrderId($order['designer_id']);
- $order->overtime_pay_status = 1;
- }
- $designer = self::where('id',$order['designer_id'])->field('earnings_ratio,margin')->find();
- //获取设计师收益金额
- $designer_money = sprintf("%.2f",$order['pay_price'] * ($designer['earnings_ratio']/100));
- $order->designer_money = $designer_money;
- if ($designer['margin']<2000){
- $designer_margin_money = 20;
- $designer_real_money = $designer_money-20;
- }else{
- $designer_margin_money = 0;
- $designer_real_money = $designer_money;
- }
- $order->designer_margin_money = $designer_margin_money;
- $order->designer_real_money = $designer_real_money;
- $order->designer_earnings_ratio = $designer['earnings_ratio'];
- $order->save();
- User::money($designer_real_money,$order['designer_id'],'订单收益',1,$order['id']);
- if ($designer_margin_money>0){
- User::margin($designer_margin_money,$order['designer_id'],'订单抵押金',1);
- }
- Common::order_status($order->id,'设计师结束打卡成功');
- Db::commit();
- return Common::return_success('打卡成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('打卡失败');
- }
- }
- /**
- * 设计师结束工作上传作品
- */
- public static function orderUploading($user_id,$order_no,$works){
- $order = Order::where('order_no',$order_no)->where('designer_id',$user_id)->find();
- if (!$order)
- return Common::return_error('订单不存在');
- // if ($order['status']!=3)
- // return Common::return_error('订单状态错误');
- Db::startTrans();
- try {
- $order->works = implode(',',$works);
- $order->save();
- Db::commit();
- Common::order_status($order->id,'设计师上传作品成功');
- return Common::return_success('上传成功');
- }catch (Exception $e) {
- Db::rollback();
- return Common::return_error('上传失败');
- }
- }
- /**
- * 优惠券列表
- */
- public static function couponList($user_id,$Nowpage,$limits){
- CouponUser::couponsTimeOut($user_id);
- $count = CouponUser::where('user_id',$user_id)
- ->where('status',0)
- ->count();
- if ($count){
- $list = CouponUser::where('user_id',$user_id)
- ->where('status',0)
- ->order('id desc')
- ->page($Nowpage,$limits)
- ->select();
- foreach ($list as &$v){
- $v['add_time'] = date('Y-m-d',$v['add_time']);
- $v['end_time'] = date('Y-m-d',$v['end_time']);
- }
- }else{
- $list = [];
- }
- return Common::return_success('成功',compact('count','list'));
- }
- /**
- * 公告列表
- */
- public static function notice(){
- $list = Notice::where('status',1)
- ->where('is_del',1)
- ->where('is_show',1)
- ->order('id desc')
- ->select();
- return Common::return_success('成功',$list);
- }
- /**
- * 根据手机号获取用户信息
- */
- public static function getByMobile($phone){
- $userinfo = self::where('phone',$phone)->find();
- return $userinfo;
- }
- /**
- * 获取用户信息
- */
- public static function getUserInfo($id){
- $info = self::where('id',$id)->field('password',true)->find();
- if (!$info['skills_label']){
- $info['skills_label'] = [];
- }else{
- $info['skills_label'] = explode(',', $info['skills_label']);
- }
- if (!$info['good_type']){
- $info['good_type'] = [];
- }else{
- $info['good_type'] = explode(',', $info['good_type']);
- }
- if (!$info['good_style']){
- $info['good_style'] = [];
- }else{
- $info['good_style'] = explode(',', $info['good_style']);
- }
- if (!$info['related_certificate']){
- $info['related_certificate'] = [];
- }else{
- $info['related_certificate'] = explode(',', $info['related_certificate']);
- }
- if (!$info['works']){
- $info['works'] = [];
- }else{
- $info['works'] = explode(',', $info['works']);
- }
- return $info;
- }
- /**
- * 变更会员余额
- * @param int $money 余额
- * @param int $user_id 会员ID
- * @param string $memo 备注
- */
- public static function money($money, $user_id, $memo, $pm = 0, $link_id = 0)
- {
- $user = self::get($user_id);
- if ($user)
- {
- $before = $user->money;
- if ($pm==1){
- $after = $user->money + $money;
- }else{
- $after = $user->money - $money;
- }
- //更新会员信息
- $user->save(['money' => $after]);
- //写入日志
- MoneyLog::create(['user_id' => $user_id,'pm' => $pm, 'change_money' => $money, 'before' => $before, 'after' => $after, 'title' => $memo,'link_id'=>$link_id]);
- }
- }
- /**
- * 变更会员余额
- * @param int $money 余额
- * @param int $user_id 会员ID
- * @param string $memo 备注
- */
- public static function margin($money, $user_id, $memo, $pm = 0)
- {
- $user = self::get($user_id);
- if ($user)
- {
- $before = $user->margin;
- if ($pm==1){
- $after = $user->margin + $money;
- }else{
- $after = $user->margin - $money;
- }
- //更新会员信息
- $user->save(['margin' => $after]);
- //写入日志
- MarginLog::create(['user_id' => $user_id,'pm' => $pm, 'change_money' => $money, 'before' => $before, 'after' => $after, 'title' => $memo]);
- }
- }
- /**
- * 十分钟未支付,取消订单
- */
- public static function systemCancelOrder(){
- Order::where('status',0)->chunk(20,function ($list){
- foreach ($list as &$v) {
- $seven = strtotime($v['create_at'])+(10*60);
- if ($seven<time()){
- Order::where('id',$v['id'])->update(
- [
- 'status'=>5,
- 'cancel_reason'=>'订单超时自动取消'
- ]
- );
- }
- }
- },'id','asc');
- }
- }
|