summaryrefslogtreecommitdiff
path: root/src/web/_model/apps/people.php
blob: 1bb110f65f3132871d932e498f955510f34a584c (plain)
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
<?php /* Copyright (c) 2024 Freya Murphy */
class People_model extends Model {

	private $request_model;

	function __construct($load) {
		parent::__construct($load);
		$this->request_model = $this->load->model('request');
	}

	private function get_filted_query($select) {
		$filter_username	= $this->request_model->get_str('filter_username', FALSE);
		$filter_fisrt_name	= $this->request_model->get_str('filter_first_name', FALSE);
		$filter_last_name	= $this->request_model->get_str('filter_last_name', FALSE);
		$filter_email		= $this->request_model->get_str('filter_email', FALSE);
		$max				= $this->request_model->get_int('max', FALSE);

		$query = $this->db
			->select($select)
			->from('api.user u');

		if ($filter_username) {
			$query = $query
				->where('u.username')
				->like('%' . $filter_username . '%');
		}

		if ($filter_fisrt_name) {
			$query = $query
				->where('u.first_name')
				->like('%'. $filter_fisrt_name . '%');
		}

		if ($filter_last_name) {
			$query = $query
				->where('u.last_name')
				->like('%' . $filter_last_name . '%');
		}

		if ($filter_email) {
			$query = $query
				->where('u.email')
				->like('%' . $filter_email . '%');
		}

		if ($max) {
			$query = $query
				->where('u.id')
				->le($max);
		}

		return $query;
	}

	public function get_users(): array {
		$page = $this->request_model->get_int('page', 0);
		$page_size = 24;
		$offset = $page_size * $page;

		$users = $this->get_filted_query('*')
			->order_by('u.id', 'DESC')
			->offset($offset)
			->limit($page_size)
			->rows();

		$count = $this->get_filted_query('COUNT(u.id) AS count')
			->row()['count'];

		$max = 0;

		foreach ($users as $user) {
			$max = max($max, $user['id']);
		}

		return array(
			'users' => $users,
			'count' => $count,
			'page_size' => $page_size,
			'max_id' => $max
		);
	}

	public function get_data(): ?array {
		$data = parent::get_data();
		$data['title'] = lang('title');
		return $data;
	}
}