-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathUser.php
69 lines (59 loc) · 1.9 KB
/
User.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
//use Authenticatable, Authorizable, CanResetPassword;
/**
* The database table used by the model.
*
* @var string
*/
protected $table = 'users';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = ['username', 'email', 'password'];
/**
* The attributes excluded from the model's JSON form.
*
* @var array
*/
protected $hidden = ['password', 'remember_token'];
protected $primaryKey = 'uid';
public function info()
{
return $this->hasOne('App\Userinfo', 'uid');
}
/**
* @function getUserInPage
* @input $user_per_page, $page_id, $gid, $search_username
*
* @return array $data
* @description Get user information of one page by page_id, gid, search_username
*/
public static function getUserInPage($user_per_page, $page_id, $gid, $search_username)
{
$data = [];
$data['users'] = [];
if($search_username == "" && $gid == 0 )
$userObj = User::all();
else if($search_username != "" && $gid != 0)
$userObj = User::where('gid', $gid)->where('username', 'like', '%'.$search_username.'%')->get();
else if($search_username != "")
$userObj = User::where('username', 'like', '%'.$search_username.'%')->get();
else if($gid != 0)
$userObj = User::where('gid', $gid)->get();
$usernum = $userObj->count();
for($count = 0, $i = ($page_id - 1) * $user_per_page; $i < $usernum && $count < $user_per_page; $i++, $count++)
{
$data['users'][$count] = $userObj[$i];
}
$data['page_num'] = ceil($usernum / $user_per_page);
$data['page_id'] = $page_id;
$data['page_user'] = $user_per_page;
return $data;
}
}