Added user custom fields on user_edit.php page.
[timetracker.git] / WEB-INF / templates / user_edit.tpl
1 <script>
2 // Prepare an array of available roles. We need it for "is_client" property.
3 // It is used to selectively display client selector for client roles.
4 roles = new Array();
5 var idx = 0;
6 {foreach $active_roles as $active_role}
7 roles[idx] = new Array({$active_role.id}, '{$active_role.is_client}');
8 idx++;
9 {/foreach}
10
11 // Prepare an array of rates.
12 // Format: project_rates[0] = Array(100, '25.00'), project_rates[1] = Array(120, '30.00'), etc...
13 // First element = project_id, second element = rate for project. Quotes needed for string representation of rates.
14 project_rates = new Array();
15 var idx = 0;
16 {foreach $rates as $rate}
17 project_rates[idx] = new Array({$rate.id}, '{$rate.rate}');
18 idx++;
19 {/foreach}
20
21 // getRate - returns a rate for the project. If rate was set for user previously we'll get this old rate
22 // if project time entries for user exists. Otherwise return user default rate.
23 function getRate(project_id) {
24   var length = project_rates.length;
25   for(var i = 0; i < length; i++) {
26     if(project_rates[i][0] == project_id) {
27       return project_rates[i][1];
28     }
29   }
30   var default_rate = document.userForm.rate.value;
31   return default_rate;
32 }
33
34 // The setRate function sets / unsets user rate for a project when a corresponding checkbox is ticked.
35 function setRate(element) {
36   var default_rate = document.userForm.rate.value;
37   if (default_rate == '') {
38     // No default rate, nothing to do!
39     return;
40   }
41   // Iterate through elements of the form to find and set the project rate. 
42   for (var i = 0; i < userForm.elements.length; i++) {
43     if ((userForm.elements[i].type == 'text') && (userForm.elements[i].name == ('rate_'+element.value))) {
44       if (element.checked) {
45         userForm.elements[i].value = getRate(element.value);
46       } else {
47         userForm.elements[i].value = '';
48       }
49       break; // Element is found and set, nothing more to do, break out of the loop.
50     }
51   }
52 }
53
54 // handleClientControl - controls visibility of the client dropdown depending on the selected user role,
55 // also hides and unselects projects when "Client" user role is selected.
56 function handleClientControl() {
57   var selectedRoleId = document.getElementById("role").value;
58   var clientControl = document.getElementById("client");
59   var nonClientBlock = document.getElementById("non_client_block");
60   var projectsControl = document.getElementById("projects_control");
61
62   var len = roles.length;
63   for (var i = 0; i < len; i++) {
64     if (selectedRoleId == roles[i][0]) {
65       var isClient = roles[i][1];
66       if (isClient == 1) {
67         clientControl.style.visibility = "visible";
68         nonClientBlock.style.display = "none";
69         projectsControl.style.display = "none";
70
71         // Uncheck all project checkboxes.
72         var checkboxes = document.getElementsByName("projects[]");
73         var j;
74         for (j = 0; j < checkboxes.length; j++) {
75           checkboxes[j].checked = false;
76         }
77       } else {
78         clientControl.value = "";
79         clientControl.style.visibility = "hidden";
80         nonClientBlock.style.display = "";
81         projectsControl.style.display = "";
82       }
83       break;
84     }
85   }
86 }
87 </script>
88
89 {$forms.userForm.open}
90 <table cellspacing="4" cellpadding="7" border="0">
91   <table cellspacing="1" cellpadding="2" border="0">
92     <tr>
93       <td align="right">{$i18n.label.person_name} (*):</td>
94       <td>{$forms.userForm.name.control}</td>
95     </tr>
96     <tr>
97       <td align="right">{$i18n.label.login} (*):</td>
98       <td>{$forms.userForm.login.control}</td>
99     </tr>
100 {if !$auth_external}
101     <tr>
102       <td align="right">{$i18n.label.password} (*):</td>
103       <td>{$forms.userForm.pas1.control}</td>
104     </tr>
105     <tr>
106       <td align="right">{$i18n.label.confirm_password} (*):</td>
107       <td>{$forms.userForm.pas2.control}</td>
108     </tr>
109 {/if}
110     <tr>
111       <td align="right" nowrap>{$i18n.label.email}:</td>
112       <td>{$forms.userForm.email.control}</td>
113     </tr>
114 {if $user->id != $user_id}
115     <tr>
116       <td align="right">{$i18n.form.users.role}:</td>
117       <td>{$forms.userForm.role.control} {$forms.userForm.client.control}</td>
118     </tr>
119     <tr>
120       <td align="right">{$i18n.label.status}:</td>
121       <td>{$forms.userForm.status.control}</td>
122     </tr>
123 {/if}
124 {if $user->id == $user_id}
125       <tr>
126       <td align="right">{$i18n.form.users.role}:</td>
127       <td>{$user->role_name} {if $can_swap}<a href="swap_roles.php">{$i18n.form.user_edit.swap_roles}</a>{/if}</td>
128     </tr>
129 {/if}
130 <tbody id="non_client_block">
131 {if $show_quota}
132     <tr>
133       <td align="right">{$i18n.label.quota}&nbsp;(%):</td>
134       <td>{$forms.userForm.quota_percent.control} <a href="https://www.anuko.com/lp/tt_27.htm" target="_blank">{$i18n.label.what_is_it}</a></td>
135     </tr>
136 {/if}
137 {if $custom_fields && $custom_fields->userFields}
138   {foreach $custom_fields->userFields as $userField}
139     <tr>
140       <td align="right">{$userField['label']|escape}{if $userField['required']} (*){/if}:</td>
141       {assign var="control_name" value='user_field_'|cat:$userField['id']}
142       <td>{$forms.userForm.$control_name.control}</td>
143     </tr>
144   {/foreach}
145 {/if}
146     <tr>
147       <td align="right">{$i18n.form.users.default_rate}&nbsp;(0{$user->getDecimalMark()}00):</td>
148       <td>{$forms.userForm.rate.control}</td>
149     </tr>
150 </tbody>
151 {if $show_projects}
152 <tbody id="projects_control">
153     <tr><td>&nbsp;</td></tr>
154     <tr valign="top">
155       <td align="right">{$i18n.label.projects}:</td>
156       <td>{$forms.userForm.projects.control}</td>
157     </tr>
158 </tbody>
159 {/if}
160     <tr>
161       <td colspan="2" align="center">{$i18n.label.required_fields}</td>
162     </tr>
163     <tr>
164       <td colspan="2" align="center" height="50">{$forms.userForm.btn_submit.control}</td>
165     </tr>
166   </table>
167 </table>
168 {$forms.userForm.close}