|
|
<?php namespace App\Http\Model; use DB; use Log;
class UserAddress extends BaseModel { //用户收货地址
protected $table = 'user_address'; public $timestamps = false; protected $hidden = array(); protected $guarded = array(); //$guarded包含你不想被赋值的字段数组。
const IS_DEFAULT = 1; //是默认地址
public function getDb() { return DB::table($this->table); } /** * 列表 * @param array $where 查询条件 * @param string $order 排序 * @param string $field 字段 * @param int $offset 偏移量 * @param int $limit 取多少条 * @return array */ public function getList($where = array(), $order = '', $field = '*', $offset = 0, $limit = 10) { $model = $this->getDb(); if($where){$model = $model->where($where);} $res['count'] = $model->count(); $res['list'] = array(); if($res['count'] > 0) { if($field){if(is_array($field)){$model = $model->select($field);}else{$model = $model->select(\DB::raw($field));}} if($order){$model = parent::getOrderByData($model, $order);} if($offset){}else{$offset = 0;} if($limit){}else{$limit = 10;} $res['list'] = $model->skip($offset)->take($limit)->get(); } return $res; } /** * 分页,用于前端html输出 * @param array $where 查询条件 * @param string $order 排序 * @param string $field 字段 * @param int $limit 每页几条 * @param int $page 当前第几页 * @return array */ public function getPaginate($where = array(), $order = '', $field = '*', $limit = 10) { $res = $this->getDb(); if($where){$res = $res->where($where);} if($field){if(is_array($field)){$res = $res->select($field);}else{$res = $res->select(\DB::raw($field));}} if($order){$res = parent::getOrderByData($res, $order);} if($limit){}else{$limit = 10;} return $res->paginate($limit); } /** * 查询全部 * @param array $where 查询条件 * @param string $order 排序 * @param string $field 字段 * @param int $limit 取多少条 * @return array */ public function getAll($where = array(), $order = '', $field = '*', $limit = '', $offset = '') { $res = $this->getDb(); if($where){$res = $res->where($where);} if($field){if(is_array($field)){$res = $res->select($field);}else{$res = $res->select(\DB::raw($field));}} if($order){$res = parent::getOrderByData($res, $order);} if($offset){$res = $res->skip($offset);} if($limit){$res = $res->take($limit);} $res = $res->get(); return $res; } /** * 获取一条 * @param array $where 条件 * @param string $field 字段 * @return array */ public function getOne($where, $field = '*') { $res = $this->getDb(); if($where){$res = $res->where($where);} if($field){if(is_array($field)){$res = $res->select($field);}else{$res = $res->select(\DB::raw($field));}} $res = $res->first(); return $res; } /** * 添加 * @param array $data 数据 * @return int */ public function add(array $data,$type = 0) { if($type==0) { // 新增单条数据并返回主键值
return self::insertGetId(parent::filterTableColumn($data,$this->table)); } elseif($type==1) { /** * 添加单条数据 * $data = ['foo' => 'bar', 'bar' => 'foo']; * 添加多条数据 * $data = [ * ['foo' => 'bar', 'bar' => 'foo'], * ['foo' => 'bar1', 'bar' => 'foo1'], * ['foo' => 'bar2', 'bar' => 'foo2'] * ]; */ return self::insert($data); } } /** * 修改 * @param array $data 数据 * @param array $where 条件 * @return bool */ public function edit($data, $where = array()) { $res = $this->getDb(); $res = $res->where($where)->update(parent::filterTableColumn($data, $this->table)); if ($res === false) { return false; } return true; } /** * 删除 * @param array $where 条件 * @return bool */ public function del($where) { $res = $this->getDb(); $res = $res->where($where)->delete(); return $res; } /* //获取列表
public static function getList(array $param) { extract($param); //参数:limit,offset
$limit = isset($limit) ? $limit : 10; $offset = isset($offset) ? $offset : 0; $model = self::where(array('user_id'=>$user_id)); $res['count'] = $model->count(); $res['list'] = array(); if($res['count']>0) { $res['list'] = $model->skip($offset)->take($limit)->get(); if($res['list']) { foreach($res['list'] as $k=>$v) { $res['list'][$k]['country_name'] = Region::getRegionName($v['country']); $res['list'][$k]['province_name'] = Region::getRegionName($v['province']); $res['list'][$k]['city_name'] = Region::getRegionName($v['city']); $res['list'][$k]['district_name'] = Region::getRegionName($v['district']); } } } else { return false; } return $res; } //获取一条记录,不传address_id表示获取默认地址
public static function getOne($user_id,$address_id='') { $arr = ''; if ($address_id) { $arr = self::where(array('id'=>$address_id,'user_id'=>$user_id))->first(); return $arr; } if ($user_id > 0) { // 取默认地址
$arr = self::join('user','user_address.id', '=', 'user.address_id') ->where('user.id',$user_id)->select('user_address.id','user_address.name','country','province','city','district','address','user_address.mobile','zipcode') ->first(); } if($arr) { $arr->country_name = Region::getRegionName($arr->country); $arr->province_name = Region::getRegionName($arr->province); $arr->city_name = Region::getRegionName($arr->city); $arr->district_name = Region::getRegionName($arr->district); } return $arr; } public static function add(array $param) { extract($param); if(UserAddress::where('user_id', $user_id)->count() >= 10) { return ReturnData::create(ReturnData::PARAMS_ERROR,null,'最多10个收货地址'); } $model = new UserAddress; $model->user_id = $user_id; $model->name = $name; $model->address = $address; $model->mobile = $mobile; $model->is_default = isset($is_default) ? $is_default : 0; if(isset($country)){$model->country = isset($country) ? $country : 0;} if(isset($province)){$model->province = isset($province) ? $province : 0;} if(isset($city)){$model->city = isset($city) ? $city : 0;} if(isset($district)){$model->district = isset($district) ? $district : 0;} if(isset($telphone)){$model->telphone = isset($telphone) ? $telphone : '';} if(isset($zipcode)){$model->zipcode = isset($zipcode) ? $zipcode : '';} if ($model->save()) { $user = User::where('id', $user_id)->first();
if (!UserAddress::where('id', $user->address_id)->first() || $model->is_default!=0) { self::setDefault($model->id,$user_id); } return ReturnData::create(ReturnData::SUCCESS,$model); }
return ReturnData::create(ReturnData::SYSTEM_FAIL); } public static function modify(array $param) { extract($param); if ($model = UserAddress::where('id', $id)->where('user_id', $user_id)->first()) { $model->user_id = $user_id; $model->is_default = isset($is_default) ? $is_default : 0; if(isset($name)){$model->name = $name;} if(isset($country)){$model->country = $country;} if(isset($province)){$model->province = $province;} if(isset($city)){$model->city = $city;} if(isset($district)){$model->district = $district;} if(isset($address)){$model->address = $address;} if(isset($mobile)){$model->mobile = $mobile;} if(isset($telphone)){$model->telphone = $telphone;} if(isset($zipcode)){$model->zipcode = $zipcode;} if ($model->save()) { if ($model->is_default!=0) { self::setDefault($model->id,$user_id); } return $model->toArray(); } } return false; } //删除一条记录
public static function remove($id,$user_id) { if (UserAddress::where('id', $id)->where('user_id', $user_id)->delete()) { if ($address = UserAddress::where('user_id', $user_id)->first()) { $user = User::where('id', $user_id)->first(); if($user->address_id == $id) { $user->address_id = $address->id; $user->save(); self::where('id',$address->id)->update(array('is_default' => 1)); } } } return true; } //设为默认地址
public static function setDefault($address_id,$user_id) { if ($user_address = UserAddress::where('id', $address_id)->where('user_id', $user_id)->first()) { $user_address->is_default = 1; $user_address->save(); UserAddress::where('user_id', $user_id)->where('id', '<>', $address_id)->update(['is_default'=>0]); if($user = User::where('id', $user_id)->first()) { $user->address_id = $address_id; $user->save(); return true; } }
return false; } // 获取默认地址
public static function userDefaultAddress($user_id) { $arr = ''; $arr = self::where(array('user_id'=>$user_id,'is_default'=>self::IS_DEFAULT))->first(); if (!$arr) { $arr = self::where(array('user_id'=>$user_id))->first(); } if($arr) { $arr->country_name = Region::getRegionName($arr->country); $arr->province_name = Region::getRegionName($arr->province); $arr->city_name = Region::getRegionName($arr->city); $arr->district_name = Region::getRegionName($arr->district); } return $arr; } */ }
|