Subversion Repositories ALCASAR

Rev

Rev 610 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log

Rev Author Line No. Line
602 stephane 1
<?php
2
/*
3
 
4
 
5
*/
6
require_once('includes/defines.inc.php');
7
require_once(ALCASAR_ADMIN_PATH_INC.'/session.inc.php');
610 stephane 8
require_once(ALCASAR_ADMIN_PATH_LIB.'/radiusMysqlUser.class.php');
602 stephane 9
 
10
$options['fields'] = "*";
11
$users = radiusMysqlUser::find($options);
12
 
610 stephane 13
//a faire
14
$vouchers = array();
15
$models = array();
16
 
602 stephane 17
?><!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN//2.0">
18
<html>
19
<head>
20
<title>Users page</title>
703 stephane 21
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
602 stephane 22
<!-- include default CSS -->
23
<link rel="stylesheet" href="<?php echo ALCASAR_ADMIN_PATH_CSS; ?>/default/default.css" type="text/css">
24
<!-- include JQUERY UI CSS -->
25
<link type="text/css"  rel="stylesheet" href="<?php echo ALCASAR_ADMIN_PATH_CSS; ?>/default/ui-lightness/jquery-ui-1.8.10.custom.css">
26
<!-- include tablesorter CSS -->
27
<link type="text/css"  rel="stylesheet" href="<?php echo ALCASAR_ADMIN_PATH_CSS; ?>/default/tablesorter-blue/style.css">
28
 
29
<link type="text/css"  rel="stylesheet" href="<?php echo ALCASAR_ADMIN_PATH_CSS; ?>/default/datatables/css/demo_table.css">
30
<!-- include custom page CSS -->
31
<style type="text/css">
32
	div#users-contain { width: 450px; margin: 20px 0; }
33
	div#users-contain table { margin: 1em 0; border-collapse: collapse; width: 100%; }
34
	div#users-contain table td, div#users-contain table th { border: 1px solid #eee; padding: .6em 10px; text-align: left; }
35
	div#users-contain table th { ui-widget-header }
36
 
37
	.dataTables_filter {
38
    float: left;
39
    text-align: left;
40
    width: 220px;
41
}
42
</style>
43
<!-- include JQUERY -->
44
<script type="text/javascript" language="javascript" src="<?php echo ALCASAR_ADMIN_PATH_JS; ?>/jquery-1.5.min.js"></script>
45
<!-- include JQUERY UI -->
46
<script type="text/javascript" language="javascript" src="<?php echo ALCASAR_ADMIN_PATH_JS; ?>/jquery-ui-1.8.10.all.min.js"></script>
47
<script type="text/javascript" language="javascript" src="<?php echo ALCASAR_ADMIN_PATH_JS; ?>/jquery.tablesorter.min.js"></script>
48
<script type="text/javascript" language="javascript" src="<?php echo ALCASAR_ADMIN_PATH_JS; ?>/jquery.tablesorter.pager.js"></script>
49
<script type="text/javascript" language="javascript" src="<?php echo ALCASAR_ADMIN_PATH_JS; ?>/jquery.quicksearch.js"></script>
50
<script type="text/javascript" language="javascript" src="<?php echo ALCASAR_ADMIN_PATH_JS; ?>/jquery.dataTables.min.js"></script>
51
<!-- include page javascript -->
52
<script type="text/javascript">
53
	var table_data_lang = {
54
			"sProcessing": "Patientez...",
55
			"sLengthMenu": "Afficher _MENU_ enregistrements",
56
			"sZeroRecords": "Aucun enregistrement disponible.",
57
			"sInfo": "_START_ à _END_ sur _TOTAL_ enregistrements",
58
			"sInfoEmpty": "0 à 0 sur 0 enregistrement",
59
			"sInfoFiltered": "(Filtré à partir de _MAX_  enregistrements)",
60
			"sInfoPostFix": "",
61
			"sSearch": "Recherche : ",
62
			"sUrl": "",
63
			"oPaginate": {
64
				"sFirst":    "Première page",
65
				"sPrevious": "Page précédente",
66
				"sNext":     "Page suivante",
67
				"sLast":     "Dernière page"
68
			}
69
		};
70
 
71
	$(document).ready(function(){
72
		// Tabs
73
		$('#tabs-users').tabs();
74
		// buttons
75
		$( "button, input:submit, input:button, input:reset").button();
76
		// Users table		
77
		$('#users_table').dataTable(
78
		{
79
			// fonction suivante permet d'avoir une colone numérotée dynamiquement (non triable)
80
			"fnDrawCallback": function ( oSettings ) {
81
				/* Need to redo the counters if filtered or sorted */
82
				if ( oSettings.bSorted || oSettings.bFiltered )
83
				{
84
					for ( var i=0, iLen=oSettings.aiDisplay.length ; i<iLen ; i++ )
85
					{
86
						$('td:eq(0)', oSettings.aoData[ oSettings.aiDisplay[i] ].nTr ).html( i+1 );
87
					}
88
				}
89
			},
90
			"aoColumnDefs": [
91
				{ "bSortable": false, "aTargets": [ 0 ] }
92
			],
93
			"aaSorting": [[ 1, 'asc' ]]
94
			//fin 			
95
			,"oLanguage": table_data_lang
96
		});
97
 
98
		$('#users_table_filter').after('<div style="float:left"><a href="javascript:alert(\'Fonction prochainement dispobible.\');" title="Recherche avancée">Avancée</a></div>');
99
 
100
 
101
		$('#vouchers_table').dataTable({
102
 
103
		// fonction suivante permet d'avoir une colone numérotée dynamiquement (non triable)
104
		"fnDrawCallback": function ( oSettings ) {
105
			/* Need to redo the counters if filtered or sorted */
106
			if ( oSettings.bSorted || oSettings.bFiltered )
107
			{
108
				for ( var i=0, iLen=oSettings.aiDisplay.length ; i<iLen ; i++ )
109
				{
110
					$('td:eq(0)', oSettings.aoData[ oSettings.aiDisplay[i] ].nTr ).html( i+1 );
111
				}
112
			}
113
		},
114
		"aoColumnDefs": [
115
			{ "bSortable": false, "aTargets": [ 0 ] }
116
		],
117
		"aaSorting": [[ 1, 'asc' ]]
118
		//fin
119
		,"oLanguage": table_data_lang
120
		});
121
		$('#vouchers_table_filter').after('<div style="float:left"><a href="javascript:alert(\'Fonction prochainement dispobible.\');" title="Recherche avancée">Avancée</a></div>');
610 stephane 122
 
123
 
124
		$('#models_table').dataTable({
125
 
126
		// fonction suivante permet d'avoir une colone numérotée dynamiquement (non triable)
127
		"fnDrawCallback": function ( oSettings ) {
128
			/* Need to redo the counters if filtered or sorted */
129
			if ( oSettings.bSorted || oSettings.bFiltered )
130
			{
131
				for ( var i=0, iLen=oSettings.aiDisplay.length ; i<iLen ; i++ )
132
				{
133
					$('td:eq(0)', oSettings.aoData[ oSettings.aiDisplay[i] ].nTr ).html( i+1 );
134
				}
135
			}
136
		},
137
		"aoColumnDefs": [
138
			{ "bSortable": false, "aTargets": [ 0 ] }
139
		],
140
		"aaSorting": [[ 1, 'asc' ]]
141
		//fin
142
		,"oLanguage": table_data_lang
143
		});
602 stephane 144
	});
145
</script>
146
</head>
147
<body>
148
<div class="ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix">
149
	<span class="ui-dialog-title" id="ui-dialog-title-dialog">Gestion des usagers</span>
150
</div>
151
<br />
152
<div id="tabs-users">
153
	<ul>
154
		<li><a href="#tabs1">Usagers</a></li>
703 stephane 155
		<!--li><a href="#tabs2">Vouchers</a></li-->
610 stephane 156
		<li><a href="#tabs3">Modèles</a></li>
602 stephane 157
	</ul>
158
	<div id="tabs1">
159
		<div>
160
			Un usager est un utilisateur standard de votre réseau de consultation.<br>
161
			<font color="red">ATTENTION POUR DEMONSTRATION DES OPTIONS A UTILISER. Données du serveur RADIUS traitées (tri, pagination) par la page dans l'exemple , gérées par le serveur (AJAX) en production</font>
162
		</div>
163
		<br>
164
		<div style="float:right;">
165
			<form name="newUserform">
166
				<input type="button" value="Nouvel usager">
167
			</form>
168
		</div>
169
		<br>
170
		<table id="users_table" cellspacing="1" class="tablesorter" border="0" width="100%">
171
		<thead>
172
			<tr>
173
				<th width="20">#</th><th width="200">Usagers</th><th>Nom, prénom</th><th width="100">Date validitée</th>
174
			</tr>
175
		</thead>
176
		<tfoot>
177
			<tr>
178
				<th width="20">#</th><th width="200">Usagers</th><th>Nom, prénom</th><th width="100">Date validitée</th>
179
			</tr>
180
		</tfoot>
181
		<tbody>
182
		<?php 
183
		foreach ($users as $user){
184
			echo "<tr><td></td><td><a href='user.php?username=".$user['username']."' title='Edit User'>".$user['username']."</a></td><td>".$user['Name']."</td><td><font color=red>ND</font></td></tr>";
185
		}
186
		?>
187
		</tbody>
188
		</table>
189
 
190
		<br><br><br>
191
	</div>
703 stephane 192
	<!--div id="tabs2">
602 stephane 193
		<div>
194
		Un "Voucher" est un compte d'accès de type "pré-payé" qui dépend d'une durée d'utilisation ou d'un délai dans le temps.<br>
195
		<font color="red">PROCHAINEMENT DISPONIBLE</font>
196
		</div>
197
		<br>
198
		<div style="float:right;">
199
			<form name="newVoucherform">
200
				<input type="button" value="Nouveau voucher">
201
			</form>
202
		</div>
203
		<br>
204
		<table id="vouchers_table" cellspacing="1" class="tablesorter" border="0" width="100%">
205
		<thead>
206
			<tr>
207
				<th width="20">#</th>
208
				<th>Vouchers</th>
209
				<th>Description</th>
210
				<th>Nom complet (identifier la personne)</th>
610 stephane 211
				<th width="100">Date validitée</th>
602 stephane 212
			</tr>
213
		</thead>
214
		<tfoot>
215
			<tr>
216
				<th width="20">#</th>
217
				<th>Vouchers</th>
218
				<th>Description</th>
219
				<th>Nom complet (identifier la personne)</th>
610 stephane 220
				<th width="100">Date validitée</th>
602 stephane 221
			</tr>
222
		</tfoot>
223
		<tbody>
610 stephane 224
		<?php 
225
		foreach ($vouchers as $voucher){
226
			echo "<tr><td></td><td>".$voucher['name']."</td><td>".$voucher['description']."</td><td>".$voucher['user']."</td><td>".$voucher['validity']."</td></tr>";
227
		}
228
		?>
602 stephane 229
		</tbody>
230
		</table>
703 stephane 231
	</div-->
602 stephane 232
	<div id="tabs3">
233
		<div>
610 stephane 234
		Afin de gagner du temps dans la création des comptes usagers et vouchers, vous avez la possibilité de prédéfinir des modèles de création de compte.<br>
602 stephane 235
		<font color="red">PROCHAINEMENT DISPONIBLE</font>
236
		</div>
237
		<br>
610 stephane 238
		<div style="float:right;">
239
			<form name="newModelform">
240
				<input type="button" value="Nouveau modèle">
241
			</form>
242
		</div>
243
		<br>
244
		<table id="models_table" cellspacing="1" class="tablesorter" border="0" width="100%">
245
		<thead>
246
			<tr>
247
				<th width="20px">#</th>
248
				<th>Modèle</th>
249
				<th>Description</th>
250
			</tr>
251
		</thead>
252
		<tfoot>
253
			<tr>
254
				<th width="20px">#</th>
255
				<th>Modèle</th>
256
				<th>Description</th>
257
			</tr>
258
		</tfoot>
259
		<tbody>
703 stephane 260
			<tr>
261
				<td width="20px">#</td>
262
				<td>Défaut</td>
263
				<td>Modèle par défaut non modifiable. Aucune caractéristique particulière</td>
264
			</tr>
265
			<tr>
266
				<td width="20px">#</td>
267
				<td>Ticket 1 jour</td>
268
				<td>Modèle d'utilisateur, connexion valide 1 journée</td>
269
			</tr>
270
			<tr>
271
				<td width="20px">#</td>
272
				<td>Ticket 1 semaine</td>
273
				<td>Modèle d'utilisateur, connexion valide 1 semaine</td>
274
			</tr>
610 stephane 275
		<?php
276
		foreach ($models as $model){
277
			echo "<tr><td></td><td>".$model['name']."</td><td>".$model['description']."</td></tr>";
278
		}
279
		?>
280
		</tbody>
281
		</table>
602 stephane 282
	</div>
283
</div>
284
</body>
285
</html>