summaryrefslogtreecommitdiff
path: root/includes/pages/admin_active.php
blob: 553843453330ab52c3d6e7c450dae57ebb6634e1 (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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php
function admin_active() {
	global $tshirt_sizes;
	
	$msg = "";
	$search = "";
	$count = 0;
	$limit = "";
	$set_active = "";
	if (isset ($_REQUEST['search']))
		$search = strip_request_item('search');

	if (isset ($_REQUEST['set_active'])) {
		$ok = true;

		if (isset ($_REQUEST['count']) && preg_match("/^[0-9]+$/", $_REQUEST['count']))
			$count = strip_request_item('count');
		else {
			$ok = false;
			$msg .= error("Please enter a number of angels to be marked as active.", true);
		}

		if ($ok)
			$limit = " LIMIT " . $count;
		if (isset ($_REQUEST['ack'])) {
			sql_query("UPDATE `User` SET `Aktiv` = 0 WHERE `Tshirt` = 0");
			$users = sql_select("SELECT `User`.*, COUNT(`ShiftEntry`.`id`) as `shift_count`, SUM(`end`-`start`) as `shift_length` FROM `User` LEFT JOIN `ShiftEntry` ON `User`.`UID` = `ShiftEntry`.`UID` LEFT JOIN `Shifts` ON `ShiftEntry`.`SID` = `Shifts`.`SID` WHERE `User`.`Gekommen` = 1 GROUP BY `User`.`UID` ORDER BY `shift_length` DESC" . $limit);
			foreach ($users as $usr)
				sql_query("UPDATE `User` SET `Aktiv` = 1 WHERE `UID`=" . sql_escape($usr['UID']));

			$limit = "";
			$msg = success("Marked angels.", true);
		} else {
			$set_active = '<a href="' . page_link_to('admin_active') . '&amp;serach=' . $search . '">&laquo; back</a> | <a href="' . page_link_to('admin_active') . '&amp;search=' . $search . '&amp;count=' . $count . '&amp;set_active&amp;ack">apply</a>';
		}
	}

	if (isset ($_REQUEST['active']) && preg_match("/^[0-9]+$/", $_REQUEST['active'])) {
		$id = $_REQUEST['active'];
		sql_query("UPDATE `User` SET `Aktiv`=1 WHERE `UID`=" . sql_escape($id) . " LIMIT 1");
		$msg = success("Angel has been marked as active.", true);
	}
	elseif (isset ($_REQUEST['not_active']) && preg_match("/^[0-9]+$/", $_REQUEST['not_active'])) {
		$id = $_REQUEST['not_active'];
		sql_query("UPDATE `User` SET `Aktiv`=0 WHERE `UID`=" . sql_escape($id) . " LIMIT 1");
		$msg = success("Angel has been marked as not active.", true);
	}
	elseif (isset ($_REQUEST['tshirt']) && preg_match("/^[0-9]+$/", $_REQUEST['tshirt'])) {
		$id = $_REQUEST['tshirt'];
		sql_query("UPDATE `User` SET `Tshirt`=1 WHERE `UID`=" . sql_escape($id) . " LIMIT 1");
		$msg = success("Angel has got a t-shirt.", true);
	}
	elseif (isset ($_REQUEST['not_tshirt']) && preg_match("/^[0-9]+$/", $_REQUEST['not_tshirt'])) {
		$id = $_REQUEST['not_tshirt'];
		sql_query("UPDATE `User` SET `Tshirt`=0 WHERE `UID`=" . sql_escape($id) . " LIMIT 1");
		$msg = success("Angel has got no t-shirt.", true);
	}

	$users = sql_select("SELECT `User`.*, COUNT(`ShiftEntry`.`id`) as `shift_count`, SUM(`end`-`start`) as `shift_length` FROM `User` LEFT JOIN `ShiftEntry` ON `User`.`UID` = `ShiftEntry`.`UID` LEFT JOIN `Shifts` ON `ShiftEntry`.`SID` = `Shifts`.`SID` WHERE `User`.`Gekommen` = 1 GROUP BY `User`.`UID` ORDER BY `shift_length` DESC" . $limit);

	$table = "";
	if ($search == "")
		$tokens = array ();
	else
		$tokens = explode(" ", $search);
	foreach ($users as $usr) {
		if (count($tokens) > 0) {
			$match = false;
			$index = join("", $usr);
			foreach ($tokens as $t)
				if (strstr($index, trim($t))) {
					$match = true;
					break;
				}
			if (!$match)
				continue;
		}
		$table .= '<tr>';
		$table .= '<td>' . $usr['Nick'] . '</td>';
		$table .= '<td>' . $tshirt_sizes[$usr['Size']] . '</td>';
		$table .= '<td>' . $usr['shift_count'] . '</td>';

		if ($usr['shift_count'] == 0)
			$table .= '<td>-</td>';
		else
			$table .= '<td>' . round($usr['shift_length'] / 60) . ' min (' . round($usr['shift_length'] / 3600) . ' h)</td>';

		if ($usr['Aktiv'] == 1)
			$table .= '<td>yes</td>';
		else
			$table .= '<td></td>';
		if ($usr['Tshirt'] == 1)
			$table .= '<td>yes</td>';
		else
			$table .= '<td></td>';

		$actions = array ();
		if ($usr['Aktiv'] == 0)
			$actions[] = '<a href="' . page_link_to('admin_active') . '&amp;active=' . $usr['UID'] . '&amp;search=' . $search . '">set active</a>';
		if ($usr['Aktiv'] == 1 && $usr['Tshirt'] == 0) {
			$actions[] = '<a href="' . page_link_to('admin_active') . '&amp;not_active=' . $usr['UID'] . '&amp;search=' . $search . '">remove active</a>';
			$actions[] = '<a href="' . page_link_to('admin_active') . '&amp;tshirt=' . $usr['UID'] . '&amp;search=' . $search . '">got t-shirt</a>';
		}
		if ($usr['Tshirt'] == 1)
			$actions[] = '<a href="' . page_link_to('admin_active') . '&amp;not_tshirt=' . $usr['UID'] . '&amp;search=' . $search . '">remove t-shirt</a>';

		$table .= '<td>' . join(' | ', $actions) . '</td>';

		$table .= '</tr>';
	}
	return template_render('../templates/admin_active.html', array (
		'search' => $search,
		'count' => $count,
		'set_active' => $set_active,
		'table' => $table,
		'msg' => $msg,
		'link' => page_link_to('admin_active')
	));
}
?>