Adds notion of directory name for users.
[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} ({$user->fullName()})&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           {if $user->state eq 'pending'}
117           Non-inscrit
118           {else}
119           Inscrit le {$user->registration_date|date_format}
120           {/if}
121         </div>
122         <div style="float: left; text-align: left">
123           {icon name=user_gray} {$user->hruid} (uid {$user->id()})
124         </div>
125         <input type="hidden" name="uid" value="{$user->id()}" />
126       </th>
127     </tr>
128     <tr>
129       <td class="titre">Nom complet</td>
130       <td><input type="text" name="full_name" maxlength="255" value="{$user->fullName()}" /></td>
131     </tr>
132     <tr>
133       <td class="titre">Nom annuaire</td>
134       <td><input type="text" name="directory_name" maxlength="255" value="{$user->directoryName()}" /></td>
135     </tr>
136     <tr>
137       <td class="titre">Nom affiché</td>
138       <td><input type="text" name="display_name" maxlength="255" value="{$user->displayName()}" /></td>
139     </tr>
140     <tr>
141       <td class="titre">Sexe</td>
142       <td>
143         <label>femme <input type="radio" name="sex" value="female" {if $user->isFemale()}checked="checked"{/if} /></label>
144         <label><input type="radio" name="sex" value="male" {if !$user->isFemale()}checked="checked"{/if} /> homme</label>
145       </td>
146     </tr>
147     <tr class="impair">
148       <td class="titre">Mot de passe</td>
149       <td>
150         <div style="float: left">
151           <input type="text" name="newpass_clair" size="10" maxlength="256" value="********" />
152           <input type="hidden" name="hashpass" value="" />
153         </div>
154         <div style="float: left; margin-top: 5px;">
155           {checkpasswd prompt="newpass_clair" submit="dummy_none"}
156         </div>
157       </td>
158     </tr>
159     <tr class="impair">
160       <td class="titre">Mot de passe SMTP</td>
161       <td>
162         <div style="float: left">
163           <input type="password" name="weak_password" size="10" maxlength="256" value="" />
164           {if $user->weak_access}
165           <input type="submit" name="disable_weak_access" value="Supprimer" />
166           {/if}
167         </div>
168       </td>
169     </tr>
170     <tr class="impair">
171       <td class="titre">Accès RSS</td>
172       <td>
173         <label>
174           <input type="checkbox" name="token_access" {if $user->token_access}checked="checked"{/if} value="1" />
175           activer l'accès
176         </label>
177       </td>
178     </tr>
179     <tr class="impair">
180       <td class="titre">Skin</td>
181       <td>
182         <select name="skin">
183           <option value="" {if !$user->skin}selected="selected"{/if}>Aucune (défaut du système)</option>
184           {iterate from=$skins item=skin}
185           <option value="{$skin.id}" {if $user->skin eq $skin.id}selected="selected"{/if}>{$skin.name}</option>
186           {/iterate}
187         </select>
188       </td>
189     </tr>
190     <tr class="pair">
191       <td class="titre">Etat du compte</td>
192       <td>
193         <select name="state">
194           <option value="pending" {if $user->state eq 'pending'}selected="selected"{/if}>pending (Non-inscrit)</option>
195           <option value="active" {if $user->state eq 'active'}selected="selected"{/if}>active (Inscrit, peut se logguer)</option>
196           <option value="disabled" {if $user->state eq 'disabled'}selected="selected"{/if}>disabled (Inscrit, accès interdit)</option>
197         </select><br />
198         <label>
199           <input type="checkbox" name="is_admin" value="1" {if $user->is_admin}checked="checked"{/if} />
200           administrateur du site
201         </label>
202       </td>
203     </tr>
204     <tr class="pair">
205       <td class="titre">Type de compte</td>
206       <td>
207         <select name="type">
208           {iterate from=$account_types item=type}
209           <option value="{$type.type}" {if $user->type eq $type.type}selected="selected"{/if}>{$type.type} ({$type.perms})</option>
210           {/iterate}
211         </select>
212         <a href="admin/account/types">{icon name=wrench title=Gérer} gérer</a>
213       </td>
214     </tr>
215     <tr class="pair">
216       <td class="titre">
217         Surveillance
218       </td>
219       <td>
220         <label><input type="checkbox" name="watch" {if $user->watch}checked="checked"{/if} value="1" />
221         Surveiller l'activité de ce compte</label><br />
222         <span class="smaller">Cette option permet d'avoir des logs complets de l'activité
223         du compte via le logger, et d'être alerté lors des connexions de l'utilisateur.</span>
224       </td>
225     </tr>
226     <tr class="pair">
227       <td class="titre">
228         Commentaire
229       </td>
230       <td>
231         <input type="text" name="comment" size="40" maxlength="64" value="{$user->comment}" />
232       </td>
233     </tr>
234     <tr class="impair">
235       <td colspan="2" class="center">
236         {* TODO: on 'update_account', update the hashpass field before sending the form. *}
237         <input type="submit" name="update_account" value="Mettre à jour" />
238         <input type="submit" name="su_account" value="Prendre l'identité" />
239         <input type="submit" name="log_account" value="Consulter les logs" />
240       </td>
241     </tr>
242   </table>
243 </form>
244
245 <h1>Fiches associées au compte</h1>
246
247 <form id="profiles" method="post" action="admin/user/{$user->login()}#account">
248   {xsrf_token_field}
249   <table class="bicol">
250     <tr>
251       <th></th>
252       <th>Identifiant de la fiche</th>
253       <th></th>
254     </tr>
255     {iterate from=$profiles item=profile}
256     <tr>
257       <td><input type="radio" name="owner" value="{$profile.pid}" {if $profile.owner}checked="checked"{/if}
258                  onclick="this.form.submit()" /></td>
259       <td>{$profile.hrpid} (pid {$profile.pid})</td>
260       <td class="right">
261         <a href="profile/edit/{$profile.hrpid}">{icon name=user_edit}</a>
262         <a href="profile/{$profile.hrpid}" class="popup2">{icon name=user_suit}</a>
263         <a href="javascript:del_profile({$profile.pid})">{icon name=cross}</a>
264       </td>
265     </tr>
266     {/iterate}
267     <tr>
268       <td>
269         <input type="radio" name="owner" value="0" onclick="this.form.submit()" />
270       </td>
271       <td>None</td>
272       <td></td>
273     </tr>
274     <tr class="pair">
275       <td colspan="3">
276         <input type="hidden" name="del_profile" value="" />
277         <input type="text" maxlength="64" name="new_profile" />
278         <input type="submit" name="add_profile" value="Ajouter" />
279       </td>
280     </tr>
281   </table>
282 </form>
283
284 </div>
285
286 <div id="emails">
287 <h1>Gestion de l'adresse X.org</h1>
288
289 <form id="alias" method="post" action="admin/user/{$user->login()}#emails">
290   {xsrf_token_field}
291   <table class="bicol" cellpadding="2" cellspacing="0">
292     <tr>
293       <th class="alias" colspan="3">
294         Alias email de l'utilisateur
295       </th>
296     </tr>
297     {iterate from=$aliases item=a}
298     <tr class="{cycle values="impair,pair"}">
299       <td>
300         <input type="radio" name='best' {if $a.best}checked="checked"{/if} value='{$a.alias}' onclick="this.form.submit()" />
301       </td>
302       <td>
303         {if $a.for_life}<strong>{$a.alias}</strong>{else}{$a.alias}{/if}
304         {if $a.expire}<span class='erreur'>(expire le {$a.expire|date_format})</span>{/if}
305       </td>
306       {if $a.for_life}
307       <td>garanti à vie*</td>
308       {else}
309       <td class="action">
310         <a href="javascript:del_alias('{$a.alias}')">{icon name=cross}</a>
311       </td>
312       {/if}
313     </tr>
314     {/iterate}
315     <tr class="{cycle values="impair,pair"}">
316       <td colspan="2" class="detail">
317         <input type="text" name="email" size="29" maxlength="60" value="" />
318       </td>
319       <td class="action">
320         <input type="hidden" name="uid" value="{$user->id()}" />
321         <input type="hidden" name="del_alias" value="" />
322         <input type="submit" name="add_alias" value="Ajouter" />
323       </td>
324     </tr>
325     <tr class="{cycle values="impair,pair"}">
326       <td colspan="3" class="desc">
327         <strong>* à ne modifier qu'avec l'accord express de l'utilisateur !!!</strong>
328       </td>
329     </tr>
330   </table>
331 </form>
332
333 <br />
334
335 <form id="fwds" method="post" action="admin/user/{$user->login()}#emails">
336   {xsrf_token_field}
337   <table class="bicol" cellpadding="2" cellspacing="0">
338     <tr>
339       <th colspan="4">
340         Redirections
341       </th>
342     </tr>
343     {assign var=actives value=false}
344     {assign var=disabled value=false}
345     {foreach item=mail from=$emails}
346     {cycle assign=class values="impair,pair"}
347     <tr class="{$class}">
348       {if $mail->active && $mail->has_disable()}
349         {assign var=actives value=true}
350       {elseif $mail->disabled && $mail->has_disable()}
351         {assign var=disabled value=true}
352       {/if}
353       <td class="titre">
354         {if $mail->active}active{elseif $mail->disabled}suspendue{/if}
355       </td>
356       <td>
357         <span class="smaller">
358           {if !$mail->disabled}
359           <a href="javascript:act_fwd('{$mail->email}',{if $mail->active}false{else}true{/if})">
360             {if $mail->active}des{elseif $mail->broken}ré{/if}activer
361           </a>
362           {/if}
363         </span>
364       </td>
365       <td>
366         {if $mail->broken}<span style="color: #f00">{/if}
367         {if $mail->email == 'googleapps'}<a href="admin/googleapps/user/{$user->login()}">{/if}
368         {$mail->display_email}
369         {if $mail->email == 'googleapps'}</a>{/if}
370         {if $mail->broken}<em> (en panne)</em></span>{/if}
371       </td>
372       <td class="action">
373         {if $mail->is_removable()}
374         <a href="javascript:del_fwd('{$mail->email}')">{icon name=cross}</a>
375         {/if}
376       </td>
377     </tr>
378     {if $mail->panne && $mail->panne neq "0000-00-00"}
379     <tr class="{$class}">
380       <td colspan="3" class="smaller" style="color: #f00">
381         {icon name=error title="Panne"}
382         Panne de {$mail->display_email} le {$mail->panne|date_format}
383         {if $mail->panne neq $mail->last}confirmée le {$mail->last|date_format}{/if}
384       </td>
385       <td class="action">
386         <a href="javascript:clean_fwd('{$mail->email}')">effacer les pannes</a>
387       </td>
388     </tr>
389     {/if}
390     {/foreach}
391     {cycle assign=class values="impair,pair"}
392     <tr class="{$class}">
393       <td class="titre" colspan="2">
394         Ajouter une adresse
395       </td>
396       <td>
397         <input type="text" name="email" size="29" maxlength="60" value="" />
398       </td>
399       <td class="action">
400         <input type="hidden" name="uid" value="{$user->id()}" />
401         <input type="hidden" name="del_fwd" value="" />
402         <input type="hidden" name="clean_fwd" value="" />
403         <input type="hidden" name="activate_fwd" value="" />
404         <input type="hidden" name="deactivate_fwd" value="" />
405         <input type="submit" name="add_fwd" value="Ajouter" />
406       </td>
407     </tr>
408     <tr class="{$class}">
409       <td colspan="4" class="center">
410         {if $actives}
411         <input type="submit" name="disable_fwd" value="Désactiver la redirection des emails" />
412         {/if}
413         {if $disabled}
414         <input type="submit" name="enable_fwd" value="Réactiver la redirection des emails" />
415         {/if}
416       </td>
417     </tr>
418   </table>
419 </form>
420
421 {javascript name="ajax"}
422 {test_email hruid=$user->login()}
423
424 <h1>Autres adresses de l'utilisateur</h1>
425
426 <table class="bicol">
427   <tr>
428     <th>Virtual aliases auquel l'utilisateur appartient</th>
429   </tr>
430   {foreach from=$virtuals item=virtual}
431   <tr class="{cycle values="impair,pair"}">
432     <td>{$virtual}</td>
433   </tr>
434   {/foreach}
435 </table>
436 </div>
437
438 <div id="authext">
439 <h1>Gestion des autorisations d'authentification externe</h1>
440
441 <form id="openid" method="post" action="admin/user/{$user->login()}#authext">
442   {xsrf_token_field}
443   <table class="bicol">
444     <tr>
445       <th colspan="2">Sites de confiance</th>
446     </tr>
447     {iterate from=$openid item=site}
448     <tr class="{cycle values="pair,impair"}">
449       <td><a href="{$site.url}">{$site.url}</a></td>
450       <td><a href="javascript:del_openid({$site.id})">{icon name=cross}</a></td>
451     </tr>
452     {/iterate}
453   </table>
454   <div><input type="hidden" name="del_openid"/></div>
455 </form>
456 </div>
457
458 <div id="forums">
459 <h1>Gestion de l'accès au forums</h1>
460
461 <form id="bans" method="post" action="admin/user/{$user->login()}#forums">
462   {xsrf_token_field}
463   <table class="bicol">
464     <tr>
465       <th colspan="4">
466         Permissions sur les forums
467       </th>
468     </tr>
469     <tr class="impair">
470       <td class="titre">
471         Poster
472       </td>
473       <td>
474         <input type="text" name="write_perm" size="32" maxlength="255" value="{$bans.write_perm}" />
475       </td>
476       <td class="action">
477         <a href="javascript:ban_write()">Bannir</a>
478       </td>
479     </tr>
480     <tr class="pair">
481       <td class="titre">
482         Lire
483       </td>
484       <td>
485         <input type="text" name="read_perm" size="32" maxlength="255" value="{$bans.read_perm}" />
486       </td>
487       <td class="action">
488         <a href="javascript:ban_read()">Bannir</a>
489       </td>
490     </tr>
491     <tr class="impair">
492       <td class="titre">
493         Commentaire
494       </td>
495       <td colspan="2">
496         <input type="text" name="comment" size="40" maxlength="255" value="{$bans.comment}" />
497       </td>
498     </tr>
499     <tr class="center">
500       <td colspan="3">
501         <input type="hidden" name="uid" value="{$user->id()}" />
502         <input type="submit" name="b_edit" value="Modifier" />
503       </td>
504     </tr>
505   </table>
506 </form>
507 </div>
508
509 {else}
510
511 {literal}
512 <script type="text/javascript">
513 /* <![CDATA[ */
514   function add_user_to_url(f) {
515     f.action += '/' + f.login.value;
516   }
517 /* ]]> */
518 </script>
519 {/literal}
520 <form method="post" action="admin/user" onsubmit="add_user_to_url(this); return true">
521   {xsrf_token_field}
522   <table class="tinybicol" cellspacing="0" cellpadding="2">
523     <tr>
524       <th>
525         Administrer
526       </th>
527     </tr>
528     <tr class="pair">
529       <td class="center">
530         Il est possible d'entrer ici n'importe quelle adresse mail&nbsp;: redirection, melix, ou alias.
531       </td>
532     </tr>
533     <tr>
534       <td class="center">
535         <input type="text" name="login" size="40" maxlength="255" value="{$smarty.request.login|default:$user->hruid}" />
536       </td>
537     </tr>
538     <tr>
539       <td class="center">
540         <input type="submit" name="select" value=" edit " /> &nbsp;&nbsp;
541         <input type="submit" name="su_account" value=" su " />  &nbsp;&nbsp;
542         <input type="submit" name="log_account" value=" logs " />
543       </td>
544     </tr>
545   </table>
546 </form>
547 {/if}
548
549 {* vim:set et sw=2 sts=2 sws=2 enc=utf-8: *}