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