Merge branch 'account'
[platal.git] / templates / admin / user.tpl
1 {**************************************************************************}
2 {*                                                                        *}
3 {*  Copyright (C) 2003-2010 Polytechnique.org                             *}
4 {*  http://opensource.polytechnique.org/                                  *}
5 {*                                                                        *}
6 {*  This program is free software; you can redistribute it and/or modify  *}
7 {*  it under the terms of the GNU General Public License as published by  *}
8 {*  the Free Software Foundation; either version 2 of the License, or     *}
9 {*  (at your option) any later version.                                   *}
10 {*                                                                        *}
11 {*  This program is distributed in the hope that it will be useful,       *}
12 {*  but WITHOUT ANY WARRANTY; without even the implied warranty of        *}
13 {*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *}
14 {*  GNU General Public License for more details.                          *}
15 {*                                                                        *}
16 {*  You should have received a copy of the GNU General Public License     *}
17 {*  along with this program; if not, write to the Free Software           *}
18 {*  Foundation, Inc.,                                                     *}
19 {*  59 Temple Place, Suite 330, Boston, MA  02111-1307  USA               *}
20 {*                                                                        *}
21 {**************************************************************************}
22
23
24 {if $smarty.post.u_kill_conf}
25 <form method="post" action="admin/user">
26   {xsrf_token_field}
27   <div class="center">
28     <input type="hidden" name="uid" value="{$smarty.request.uid}" />
29     Confirmer la suppression de l'utilisateur {$smarty.request.uid} ({$mr.prenom} {$mr.nom} - X{$mr.promo})&nbsp;&nbsp;
30     <input type="submit" name="u_kill" value="continuer" />
31   </div>
32 </form>
33 {elseif $user}
34 {literal}
35
36 <script type="text/javascript">
37 //<![CDATA[
38 function doEditUser() {
39   document.forms.auth.hashpass.value = hash_encrypt(document.forms.edit.password.value);
40   document.forms.auth.password.value = "";
41   document.forms.auth.submit();
42 }
43
44 function del_alias(alias) {
45   document.forms.alias.del_alias.value = alias;
46   document.forms.alias.submit();
47 }
48
49 function del_profile(pid) {
50   document.forms.profiles.del_profile.value = pid;
51   document.forms.profiles.submit();
52 }
53
54 function del_fwd(fwd) {
55   document.forms.fwds.del_fwd.value = fwd;
56   document.forms.fwds.submit();
57 }
58
59 function del_openid(id) {
60   document.forms.openid.del_openid.value = id;
61   document.forms.openid.submit();
62 }
63
64 function act_fwd(fwd, activate) {
65   if (activate)
66     document.forms.fwds.activate_fwd.value = fwd;
67   else
68     document.forms.fwds.deactivate_fwd.value = fwd;
69   document.forms.fwds.submit();
70 }
71 function clean_fwd(fwd) {
72   document.forms.fwds.clean_fwd.value = fwd;
73   document.forms.fwds.submit();
74 }
75 function ban_write()
76 {
77     document.forms.bans.write_perm.value = "!xorg.*";
78 }
79 function ban_read()
80 {
81     document.forms.bans.read_perm.value = "!xorg.*";
82 }
83
84 $(document).ready(function() {
85   $('#tabs > ul').tabs();
86   $('.ui-tabs-nav li').width('24%')
87     .click(function() { $(this).children('a').click() });
88 });
89
90 // ]]>
91 </script>
92 {/literal}
93
94 <div id="tabs">
95   <ul style="margin-top: 0">
96     <li><a href="{$platal->pl_self()}#account"><span >Compte de {$user->login()}</span></a></li>
97     <li><a href="{$platal->pl_self()}#emails"><span>Emails</span></a></li>
98     <li><a href="{$platal->pl_self()}#authext"><span>OpenID</span></a></li>
99     <li><a href="{$platal->pl_self()}#forums"><span>Forums</span></a></li>
100   </ul>
101 </div>
102
103 <div id="account">
104 <form id="auth" method="post" action="admin/user/{$user->login()}#account">
105   {xsrf_token_field}
106   <h1>Informations sur le compte</h1>
107   <p class="smaller">
108     Dernière connexion le <strong>{$lastlogin|date_format:"%d %B %Y, %T"}</strong>
109     depuis <strong>{$host}</strong>.
110   </p>
111
112   <table class="bicol">
113     <tr>
114       <th colspan="2">
115         <div style="float: right; text-align: right">
116           Inscrit le {$user->registration_date|date_format}
117         </div>
118         <div style="float: left; text-align: left">
119           {icon name=user_gray} {$mr.hruid} (uid {$user->id()})
120         </div>
121         <input type="hidden" name="uid" value="{$user->id()}" />
122       </th>
123     </tr>
124     <tr>
125       <td class="titre">Nom complet</td>
126       <td><input type="text" name="full_name" maxlength="255" value="{$user->fullName()}" /></td>
127     </tr>
128     <tr>
129       <td class="titre">Nom affiché</td>
130       <td><input type="text" name="display_name" maxlength="255" value="{$user->displayName()}" /></td>
131     </tr>
132     <tr>
133       <td class="titre">Sexe</td>
134       <td>
135         <label>femme <input type="radio" name="sex" value="female" {if $user->isFemale()}checked="checked"{/if} /></label>
136         <label><input type="radio" name="sex" value="male" {if !$user->isFemale()}checked="checked"{/if} /> homme</label>
137       </td>
138     </tr>
139     <tr class="impair">
140       <td class="titre">Mot de passe</td>
141       <td>
142         <div style="float: left">
143           <input type="text" name="newpass_clair" size="10" maxlength="256" value="********" />
144           <input type="hidden" name="hashpass" value="" />
145         </div>
146         <div style="float: left; margin-top: 5px;">
147           {checkpasswd prompt="newpass_clair" submit="dummy_none"}
148         </div>
149       </td>
150     </tr>
151     <tr class="impair">
152       <td class="titre">Mot de passe SMTP</td>
153       <td>
154         <div style="float: left">
155           <input type="password" name="weak_password" size="10" maxlength="256" value="" />
156           {if $user->weak_access}
157           <input type="submit" name="disable_weak_access" value="Supprimer" />
158           {/if}
159         </div>
160       </td>
161     </tr>
162     <tr class="impair">
163       <td class="titre">Accès RSS</td>
164       <td>
165         <label>
166           <input type="checkbox" name="token_access" {if $user->token_access}checked="checked"{/if} value="1" />
167           activer l'accès
168         </label>
169       </td>
170     </tr>
171     <tr class="impair">
172       <td class="titre">Skin</td>
173       <td>
174         <select name="skin">
175           <option value="" {if !$user->skin}selected="selected"{/if}>Aucune (défaut du système)</option>
176           {iterate from=$skins item=skin}
177           <option value="{$skin.id}" {if $user->skin eq $skin.id}selected="selected"{/if}>{$skin.name}</option>
178           {/iterate}
179         </select>
180       </td>
181     </tr>
182     <tr class="pair">
183       <td class="titre">Etat du compte</td>
184       <td>
185         <select name="state">
186           <option value="pending" {if $user->state eq 'pending'}selected="selected"{/if}>pending (Non-inscrit)</option>
187           <option value="active" {if $user->state eq 'active'}selected="selected"{/if}>active (Inscrit, peut se logguer)</option>
188           <option value="disabled" {if $user->state eq 'disabled'}selected="selected"{/if}>disabled (Inscrit, accès interdit)</option>
189         </select><br />
190         <label>
191           <input type="checkbox" name="is_admin" value="1" {if $user->is_admin}checked="checked"{/if} />
192           administrateur du site
193         </label>
194       </td>
195     </tr>
196     <tr class="pair">
197       <td class="titre">Type de compte</td>
198       <td>
199         <select name="type">
200           {iterate from=$account_types item=type}
201           <option value="{$type.type}" {if $user->type eq $type.type}selected="selected"{/if}>{$type.type} ({$type.perms})</option>
202           {/iterate}
203         </select>
204         <a href="admin/account/types">{icon name=wrench title=Gérer} gérer</a>
205       </td>
206     </tr>
207     <tr class="pair">
208       <td class="titre">
209         Surveillance
210       </td>
211       <td>
212         <label><input type="checkbox" name="watch" {if $user->watch}checked="checked"{/if} value="1" />
213         Surveiller l'activité de ce compte</label><br />
214         <span class="smaller">Cette option permet d'avoir des logs complets de l'activité
215         du compte via le logger, et d'être alerté lors des connexions de l'utilisateur.</span>
216       </td>
217     </tr>
218     <tr class="pair">
219       <td class="titre">
220         Commentaire
221       </td>
222       <td>
223         <input type="text" name="comment" size="40" maxlength="64" value="{$user->comment}" />
224       </td>
225     </tr>
226     <tr class="impair">
227       <td colspan="2" class="center">
228         {* TODO: on 'update_account', update the hashpass field before sending the form. *}
229         <input type="submit" name="update_account" value="Mettre à jour" />
230         <input type="submit" name="su_account" value="Prendre l'identité" />
231         <input type="submit" name="log_account" value="Consulter les logs" />
232       </td>
233     </tr>
234   </table>
235 </form>
236
237 <h1>Fiches associées au compte</h1>
238
239 <form id="profiles" method="post" action="admin/user/{$user->login()}#account">
240   {xsrf_token_field}
241   <table class="bicol">
242     <tr>
243       <th></th>
244       <th>Identifiant de la fiche</th>
245       <th></th>
246     </tr>
247     {iterate from=$profiles item=profile}
248     <tr>
249       <td><input type="radio" name="owner" value="{$profile.pid}" {if $profile.owner}checked="checked"{/if}
250                  onclick="this.form.submit()" /></td>
251       <td>{$profile.hrpid}</td>
252       <td class="right">
253         <a href="profile/edit/{$profile.hrpid}">{icon name=user_edit}</a>
254         <a href="profile/{$profile.hrpid}" class="popup2">{icon name=user_suit}</a>
255         <a href="javascript:del_profile({$profile.pid})">{icon name=cross}</a>
256       </td>
257     </tr>
258     {/iterate}
259     <tr>
260       <td>
261         <input type="radio" name="owner" value="0" onclick="this.form.submit()" />
262       </td>
263       <td>None</td>
264       <td></td>
265     </tr>
266     <tr class="pair">
267       <td colspan="3">
268         <input type="hidden" name="del_profile" value="" />
269         <input type="text" maxlength="64" name="new_profile" />
270         <input type="submit" name="add_profile" value="Ajouter" />
271       </td>
272     </tr>
273   </table>
274 </form>
275
276 </div>
277
278 <div id="emails">
279 <h1>Gestion de l'adresse X.org</h1>
280
281 <form id="alias" method="post" action="admin/user/{$user->login()}#emails">
282   {xsrf_token_field}
283   <table class="bicol" cellpadding="2" cellspacing="0">
284     <tr>
285       <th class="alias" colspan="3">
286         Alias email de l'utilisateur
287       </th>
288     </tr>
289     {iterate from=$aliases item=a}
290     <tr class="{cycle values="impair,pair"}">
291       <td>
292         <input type="radio" name='best' {if $a.best}checked="checked"{/if} value='{$a.alias}' onclick="this.form.submit()" />
293       </td>
294       <td>
295         {if $a.for_life}<strong>{$a.alias}</strong>{else}{$a.alias}{/if}
296         {if $a.expire}<span class='erreur'>(expire le {$a.expire|date_format})</span>{/if}
297       </td>
298       {if $a.for_life}
299       <td>garanti à vie*</td>
300       {else}
301       <td class="action">
302         <a href="javascript:del_alias('{$a.alias}')">{icon name=cross}</a>
303       </td>
304       {/if}
305     </tr>
306     {/iterate}
307     <tr class="{cycle values="impair,pair"}">
308       <td colspan="2" class="detail">
309         <input type="text" name="email" size="29" maxlength="60" value="" />
310       </td>
311       <td class="action">
312         <input type="hidden" name="uid" value="{$mr.uid}" />
313         <input type="hidden" name="del_alias" value="" />
314         <input type="submit" name="add_alias" value="Ajouter" />
315       </td>
316     </tr>
317     <tr class="{cycle values="impair,pair"}">
318       <td colspan="3" class="desc">
319         <strong>* à ne modifier qu'avec l'accord express de l'utilisateur !!!</strong>
320       </td>
321     </tr>
322   </table>
323 </form>
324
325 <br />
326
327 <form id="fwds" method="post" action="admin/user/{$user->login()}#emails">
328   {xsrf_token_field}
329   <table class="bicol" cellpadding="2" cellspacing="0">
330     <tr>
331       <th colspan="4">
332         Redirections
333       </th>
334     </tr>
335     {assign var=actives value=false}
336     {assign var=disabled value=false}
337     {foreach item=mail from=$emails}
338     {cycle assign=class values="impair,pair"}
339     <tr class="{$class}">
340       {if $mail->active && $mail->has_disable()}
341         {assign var=actives value=true}
342       {elseif $mail->disabled && $mail->has_disable()}
343         {assign var=disabled value=true}
344       {/if}
345       <td class="titre">
346         {if $mail->active}active{elseif $mail->disabled}suspendue{/if}
347       </td>
348       <td>
349         <span class="smaller">
350           {if !$mail->disabled}
351           <a href="javascript:act_fwd('{$mail->email}',{if $mail->active}false{else}true{/if})">
352             {if $mail->active}des{elseif $mail->broken}ré{/if}activer
353           </a>
354           {/if}
355         </span>
356       </td>
357       <td>
358         {if $mail->broken}<span style="color: #f00">{/if}
359         {if $mail->email == 'googleapps'}<a href="admin/googleapps/user/{$user->login()}">{/if}
360         {$mail->display_email}
361         {if $mail->email == 'googleapps'}</a>{/if}
362         {if $mail->broken}<em> (en panne)</em></span>{/if}
363       </td>
364       <td class="action">
365         {if $mail->is_removable()}
366         <a href="javascript:del_fwd('{$mail->email}')">{icon name=cross}</a>
367         {/if}
368       </td>
369     </tr>
370     {if $mail->panne && $mail->panne neq "0000-00-00"}
371     <tr class="{$class}">
372       <td colspan="3" class="smaller" style="color: #f00">
373         {icon name=error title="Panne"}
374         Panne de {$mail->display_email} le {$mail->panne|date_format}
375         {if $mail->panne neq $mail->last}confirmée le {$mail->last|date_format}{/if}
376       </td>
377       <td class="action">
378         <a href="javascript:clean_fwd('{$mail->email}')">effacer les pannes</a>
379       </td>
380     </tr>
381     {/if}
382     {/foreach}
383     {cycle assign=class values="impair,pair"}
384     <tr class="{$class}">
385       <td class="titre" colspan="2">
386         Ajouter une adresse
387       </td>
388       <td>
389         <input type="text" name="email" size="29" maxlength="60" value="" />
390       </td>
391       <td class="action">
392         <input type="hidden" name="uid" value="{$mr.uid}" />
393         <input type="hidden" name="del_fwd" value="" />
394         <input type="hidden" name="clean_fwd" value="" />
395         <input type="hidden" name="activate_fwd" value="" />
396         <input type="hidden" name="deactivate_fwd" value="" />
397         <input type="submit" name="add_fwd" value="Ajouter" />
398       </td>
399     </tr>
400     <tr class="{$class}">
401       <td colspan="4" class="center">
402         {if $actives}
403         <input type="submit" name="disable_fwd" value="Désactiver la redirection des emails" />
404         {/if}
405         {if $disabled}
406         <input type="submit" name="enable_fwd" value="Réactiver la redirection des emails" />
407         {/if}
408       </td>
409     </tr>
410   </table>
411 </form>
412
413 {javascript name="ajax"}
414 {test_email hruid=$user->login()}
415
416 <h1>Autres adresses de l'utilisateur</h1>
417
418 <table class="bicol">
419   <tr>
420     <th>Virtual aliases auquel l'utilisateur appartient</th>
421   </tr>
422   {foreach from=$virtuals item=virtual}
423   <tr class="{cycle values="impair,pair"}">
424     <td>{$virtual}</td>
425   </tr>
426   {/foreach}
427 </table>
428 </div>
429
430 <div id="authext">
431 <h1>Gestion des autorisations d'authentification externe</h1>
432
433 <form id="openid" method="post" action="admin/user/{$user->login()}#authext">
434   {xsrf_token_field}
435   <table class="bicol">
436     <tr>
437       <th colspan="2">Sites de confiance</th>
438     </tr>
439     {iterate from=$openid item=site}
440     <tr class="{cycle values="pair,impair"}">
441       <td><a href="{$site.url}">{$site.url}</a></td>
442       <td><a href="javascript:del_openid({$site.id})">{icon name=cross}</a></td>
443     </tr>
444     {/iterate}
445   </table>
446   <div><input type="hidden" name="del_openid"/></div>
447 </form>
448 </div>
449
450 <div id="forums">
451 <h1>Gestion de l'accès au forums</h1>
452
453 <form id="bans" method="post" action="admin/user/{$user->login()}#forums">
454   {xsrf_token_field}
455   <table class="bicol">
456     <tr>
457       <th colspan="4">
458         Permissions sur les forums
459       </th>
460     </tr>
461     <tr class="impair">
462       <td class="titre">
463         Poster
464       </td>
465       <td>
466         <input type="text" name="write_perm" size="32" maxlength="255" value="{$bans.write_perm}" />
467       </td>
468       <td class="action">
469         <a href="javascript:ban_write()">Bannir</a>
470       </td>
471     </tr>
472     <tr class="pair">
473       <td class="titre">
474         Lire
475       </td>
476       <td>
477         <input type="text" name="read_perm" size="32" maxlength="255" value="{$bans.read_perm}" />
478       </td>
479       <td class="action">
480         <a href="javascript:ban_read()">Bannir</a>
481       </td>
482     </tr>
483     <tr class="impair">
484       <td class="titre">
485         Commentaire
486       </td>
487       <td colspan="2">
488         <input type="text" name="comment" size="40" maxlength="255" value="{$bans.comment}" />
489       </td>
490     </tr>
491     <tr class="center">
492       <td colspan="3">
493         <input type="hidden" name="uid" value="{$mr.uid}" />
494         <input type="submit" name="b_edit" value="Modifier" />
495       </td>
496     </tr>
497   </table>
498 </form>
499 </div>
500
501
502 {/if}
503
504 {* vim:set et sw=2 sts=2 sws=2 enc=utf-8: *}