1e7cc716144351d8eaaeac18e37293e39044e9c3
[Evergreen.git] / Open-ILS / src / templates / staff / circ / patron / t_edit.tt2
1 [% DOC_IMG = '/images/question-mark.png' %]
2
3 <!-- register banner -->
4 <div ng-if="!patron_id" class='patron-reg-fixed-bar'>
5
6   <div class="container-fluid" style="text-align:center">
7     <div class="alert alert-info alert-less-pad strong-text-2">
8       <span >[% l('Register Patron') %]</span>
9     </div>
10   </div>
11
12   <div class="flex-row" class='patron-reg-actions-bar'>
13     [% INCLUDE 'staff/circ/patron/reg_actions.tt2' %]
14   </div>
15 </div>
16
17
18 <!-- edit banner -->
19 <div ng-if="patron_id"
20     class="strong-text-2">[% l('Patron Edit') %]</div>
21
22 <!-- IDL field documentation window -->
23 <fieldset id="reg-field-doc" ng-show="selected_field_doc">
24   <legend>
25   {{idl_fields[selected_field_doc.fm_class()][selected_field_doc.field()].label}}
26   </legend>
27   <div>{{selected_field_doc.string()}}</div>
28 </fieldset>
29
30 [% MACRO formfield(cls, field, path, input_type) BLOCK;
31
32   # input field generator for common text/number/checkbox fields
33
34   IF NOT input_type; input_type = 'text'; END %] 
35
36 <div class="row reg-field-row" 
37   ng-show="show_field('[% cls _ '.' _ field %]')">
38
39   <div class="col-md-3 reg-field-label"> <!-- field label -->
40
41     <label>{{idl_fields.[% cls %].[% field %].label}}</label>
42
43     <!-- field documentation img/link -->
44     <img ng-show="field_doc.[% cls %].[% field %]" 
45       ng-click="selected_field_doc=field_doc.[% cls %].[% field %]"
46       src='[% DOC_IMG %]'></img>
47   </div>
48
49   <div class="col-md-3 reg-field-input"> <!-- field form input -->
50
51   [% model = path ? 'patron.' _ path _ '.' _ field : 'patron.' _ field %]
52
53   [% IF input_type == 'checkbox' %]
54
55     <div class='checkbox'>
56       <input type='checkbox' ng-model='[% model %]'/>
57     </div>
58
59   [% ELSE %]
60     <!-- text / number input -->
61
62     [% IF field == 'alert_message' %]
63       <textarea class="form-control" ng-model="[% model %]"/>
64     [% ELSIF field == 'post_code' %]
65       <input type="text" ng-blur="post_code_changed(patron.[% path %])"
66         class="form-control" ng-model="[% model %]"/>
67     [% ELSIF field == 'barcode' %]
68       <input type="text" ng-blur="barcode_changed(patron.card.barcode)"
69         class="form-control" ng-model="[% model %]"/>
70     [% ELSE %]
71       <input type="[% input_type %]" 
72         class="form-control" ng-model="[% model %]"/>
73     [% END %]
74   [% END %]
75
76   </div>
77
78   <!-- supplemental actions and example text -->
79   <div class="col-md-6 patron-reg-example">
80
81     [% IF field == 'barcode' %]
82
83       <button class="btn btn-default"
84         ng-click="replace_card()">[% l('Replace Barcode') %]</button>
85       <button class="btn btn-default" 
86         ng-click="cards_dialog()">[% l('See All') %]</button>
87
88     [% ELSIF field == 'passwd' %]
89
90       <button class="btn btn-default" ng-click="generate_password()">
91         [% l('Generate Password') %]</button>
92
93     [% ELSE %]
94
95       <!-- invalidate buttons -->
96
97       [% IF field.match('phone') OR field.match('email') %]
98         <button ng-show="patron.[% field %]" class="btn btn-default"
99           ng-click="">[% l('Invalidate') %]</button>
100       [% END %]
101
102       <!-- example strings -->
103
104       [% set_str = "org_settings['ui.patron.edit." _ 
105           cls _ "." _ field _ ".example']"; %]
106
107       <span ng-if="[% set_str %]">
108         [% l('Example: [_1]', "{{" _ set_str _ "}}") %]
109       </span>
110
111       <!-- phones have a fall-through example strings -->
112       [% IF field.match('phone') %]
113         <span ng-if="![% set_str %] && org_settings['ui.patron.edit.phone.example']">
114           [% l('Example: [_1]', 
115           "{{org_settings['ui.patron.edit.phone.example']}}") %]
116         </span>
117       [% END %]
118     [% END %]
119   </div>
120 </div>
121 [% END %]
122
123 [% formfield('ac', 'barcode', 'card') %]
124 [% formfield('au', 'usrname') %]
125 [% formfield('au', 'passwd') %]
126 [% formfield('au', 'prefix') %]
127 [% formfield('au', 'first_given_name') %]
128 [% formfield('au', 'second_given_name') %]
129 [% formfield('au', 'family_name') %]
130 [% formfield('au', 'suffix') %]
131 [% formfield('au', 'alias') %]
132
133 <div class="row reg-field-row" ng-show="show_field('au.dob')">
134   <div class="col-md-3 reg-field-label">
135     <label>{{idl_fields.au.dob.label}}</label>
136     <img ng-show="field_doc.au.dob" 
137       ng-click="selected_field_doc=field_doc.au.dob"
138       src='[% DOC_IMG %]'></img>
139   </div>
140   <div class="col-md-3 reg-field-input">
141     <input eg-date-input 
142       class="form-control" ng-model="patron.dob"/>
143   </div>
144 </div>
145
146 [% formfield('au', 'juvenile', '', 'checkbox') %]
147
148 <!-- ident_type -->
149
150 <div class="row reg-field-row" ng-show="show_field('au.ident_type')">
151   <div class="col-md-3 reg-field-label">
152     <label>{{idl_fields.au.ident_type.label}}</label>
153     <img ng-show="field_doc.au.ident_type" 
154       ng-click="selected_field_doc=field_doc.au.ident_type"
155       src='[% DOC_IMG %]'></img>
156   </div>
157   <div class="col-md-3 reg-field-input">
158     <div class="btn-group" dropdown>
159       <button type="button" class="btn btn-default dropdown-toggle">
160         <span style="padding-right: 5px;">
161           {{patron.ident_type.name() || "[% l('Primary Ident Type') %]"}}
162         </span>
163         <span class="caret"></span>
164       </button>
165       <ul class="dropdown-menu">
166         <li ng-repeat="type in ident_types">
167           <a href ng-click="patron.ident_type = type">{{type.name()}}</a>
168         </li>
169       </ul>
170     </div>
171   </div>
172 </div>
173
174
175 [% formfield('au', 'ident_value') %]
176 [% formfield('au', 'ident_value2') %]
177 [% formfield('au', 'email', '', 'email') %]
178 [% formfield('au', 'day_phone') %]
179 [% formfield('au', 'evening_phone') %]
180 [% formfield('au', 'other_phone') %]
181
182 <!-- home org unit selector -->
183
184 <div class="row reg-field-row" ng-show="show_field('au.home_ou')">
185   <div class="col-md-3 reg-field-label">
186     <label>{{idl_fields.au.home_ou.label}}</label>
187     <img ng-show="field_doc.au.home_ou" 
188       ng-click="selected_field_doc=field_doc.au.home_ou"
189       src='[% DOC_IMG %]'></img>
190     </div>
191     <div class="col-md-3 reg-field-input">
192       <eg-org-selector selected="patron.home_ou" onchange="">
193       </eg-org-selector>
194   </div>
195 </div>
196
197 <!-- profile selector -->
198
199 <div class="row reg-field-row" ng-show="show_field('au.profile')">
200   <div class="col-md-3 reg-field-label">
201     <label>{{idl_fields.au.profile.label}}</label>
202     <img ng-show="field_doc.au.profile" 
203       ng-click="selected_field_doc=field_doc.au.profile"
204       src='[% DOC_IMG %]'></img>
205   </div>
206   <div class="col-md-3 reg-field-input">
207     <div class="btn-group" dropdown>
208       <button type="button" class="btn btn-default dropdown-toggle">
209         <span style="padding-right: 5px;">
210           {{patron.profile.name() || "[% l('Profile Group') %]"}}
211         </span>
212         <span class="caret"></span>
213       </button>
214       <ul class="dropdown-menu">
215         <li ng-repeat="grp in profiles">
216           <a href 
217             style="padding-left: {{pgt_depth(grp) * 10 + 5}}px"
218             ng-click="set_profile(grp)">{{grp.name()}}</a>
219         </li>
220       </ul>
221     </div>
222   </div>
223   <div class="col-md-3">
224     <button class="btn btn-default">[% l('Secondary Groups') %]</button>
225   </div> 
226 </div>
227
228 <div class="row reg-field-row" ng-show="show_field('au.expire_date')">
229   <div class="col-md-3 reg-field-label">
230   <label>{{idl_fields.au.expire_date.label}}</label>
231     <img ng-show="field_doc.au.expire_date" 
232     ng-click="selected_field_doc=field_doc.au.expire_date"
233     src='[% DOC_IMG %]'></img>
234   </div>
235   <div class="col-md-3 reg-field-input">
236     <input eg-date-input 
237       class="form-control" ng-model="patron.expire_date"/>
238   </div>
239   <div class="col-md-3">
240     <button class="btn btn-default" ng-click="set_expire_date()">
241       [% l('Update Expire Date') %]</button>
242   </div>
243 </div>
244
245 <!-- net_access_level -->
246
247 <div class="row reg-field-row" ng-show="show_field('au.net_access_level')">
248   <div class="col-md-3 reg-field-label">
249     <label>{{idl_fields.au.net_access_level.label}}</label>
250     <img ng-show="field_doc.au.net_access_level" 
251       ng-click="selected_field_doc=field_doc.au.net_access_level"
252       src='[% DOC_IMG %]'></img>
253   </div>
254   <div class="col-md-3 reg-field-input">
255     <div class="btn-group" dropdown>
256       <button type="button" class="btn btn-default dropdown-toggle">
257         <span style="padding-right: 5px;">
258           {{patron.net_access_level.name() || "[% l('Net Access Level') %]"}}
259         </span>
260         <span class="caret"></span>
261       </button>
262       <ul class="dropdown-menu">
263         <li ng-repeat="level in net_access_levels">
264           <a href 
265             ng-click="patron.net_access_level = level">{{level.name()}}</a>
266         </li>
267       </ul>
268     </div>
269   </div>
270 </div>
271
272 [% formfield('au', 'active', '', 'checkbox') %]
273 [% formfield('au', 'barred', '', 'checkbox') %]
274 [% formfield('au', 'master_account', '', 'checkbox') %]
275 [% formfield('au', 'claims_returned_count', '', 'number') %]
276 [% formfield('au', 'claims_never_checked_out_count', '', 'number') %]
277 [% formfield('au', 'alert_message') %]
278
279 <div class="alert alert-success row" role="alert">
280   <div class="col-md-6">[% l('User Settings') %]</div>
281 </div>
282
283 <div class="row reg-field-row">
284   <div class="col-md-3 reg-field-label">
285     <label>{{user_setting_types['opac.default_phone'].label()}}</label>
286   </div>
287   <div class="col-md-3 reg-field-input">
288     <input type='text' ng-model="user_settings['opac.default_phone']"/>
289   </div>
290 </div>
291
292 <div class="row reg-field-row">
293   <div class="col-md-3 reg-field-label">
294     <label>{{user_setting_types['opac.default_pickup_location'].label()}}</label>
295   </div>
296   <div class="col-md-3 reg-field-input">
297     <eg-org-selector selected="patron.home_ou" onchange=""></eg-org-selector>
298   </div>
299 </div>
300
301 <div class="row reg-field-row">
302   <div class="col-md-3 reg-field-label">
303     <label>{{user_setting_types['circ.holds_behind_desk'].label()}}</label>
304   </div>
305   <div class="col-md-3 reg-field-input">
306     <div class='checkbox'>
307       <input type='checkbox' ng-model="user_settings['circ.holds_behind_desk']"/>
308     </div>
309   </div>
310 </div>
311
312 <div class="row reg-field-row">
313   <div class="col-md-3 reg-field-label">
314     <label>[% l('Holds Notices') %]</label>
315   </div>
316   <div class="col-md-3 reg-field-input flex-row">
317     <div class='flex-cell'>
318       <input type='checkbox' ng-model="hold_notify_phone"/>
319       [% l('Phone') %]
320     </div>
321     <div class='flex-cell'>
322       <input type='checkbox' ng-model="hold_notify_email"/>
323       [% l('Email') %]
324     </div>
325     <div class='flex-cell' ng-if="org_settings['sms.enable']">
326       <input type='checkbox' ng-model="hold_notify_sms"/>
327       [% l('SMS') %]
328     </div>
329   </div>
330 </div>
331
332 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
333   <div class="col-md-3 reg-field-label">
334     <label>[% l('Default SMS/Text Number') %]</label>
335   </div>
336   <div class="col-md-3 reg-field-input">
337     <input type='text'/>
338   </div>
339 </div>
340
341 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
342   <div class="col-md-3 reg-field-label">
343     <label>[% l('Default SMS Carrier') %]</label>
344   </div>
345   <div class="col-md-3 reg-field-input">
346     <div class="btn-group" dropdown>
347       <button type="button" class="btn btn-default dropdown-toggle">
348         <span style="padding-right: 5px;"></span>
349         <span class="caret"></span>
350       </button>
351       <ul class="dropdown-menu">
352         <li ng-repeat="carrier in sms_carriers">
353           <a href 
354             ng-click="user_settings['opac.default_sms_carrier'] = carrier">
355                 {{carrier.name()}}
356           </a>
357         </li>
358       </ul>
359     </div>
360   </div>
361 </div>
362
363
364 <!-- addresses -->
365
366
367 <div ng-repeat="addr in patron.addresses">
368   <div class="alert alert-success row" role="alert">
369       <div class="col-md-3">[% l('Address') %]</div>
370       <div class="col-md-3">
371           <span class='pad-all-min'>
372             [% l('Mailing') %] <input type='checkbox' 
373               ng-change="set_addr_type(addr, 'mailing')" 
374               ng-model="addr._is_mailing"/>
375           </span>
376           <span class='pad-all-min'>
377             [% l('Physical') %] <input type='checkbox' 
378               ng-change="set_addr_type(addr, 'billing')" 
379               ng-model="addr._is_billing"/>
380           </span>
381           <span class='pad-all-min'>
382             <button type="button" ng-click="delete_address(addr.id)" 
383               class="btn btn-danger">[% l('X') %]</button>
384           </span>
385       </div>
386   </div>
387
388   [% formfield('aua', 'address_type', 'addresses[$index]') %]
389   [% formfield('aua', 'post_code', 'addresses[$index]') %]
390   [% formfield('aua', 'street1', 'addresses[$index]') %]
391   [% formfield('aua', 'street2', 'addresses[$index]') %]
392   [% formfield('aua', 'city', 'addresses[$index]') %]
393   [% formfield('aua', 'county', 'addresses[$index]') %]
394   [% formfield('aua', 'state', 'addresses[$index]') %]
395   [% formfield('aua', 'country', 'addresses[$index]') %]
396   [% formfield('aua', 'valid', 'addresses[$index]', 'checkbox') %]
397   [% formfield('aua', 'within_city_limits', 'addresses[$index]', 'checkbox') %]
398
399   <div class="row" ng-if="$last">
400     <button type="button" ng-click="new_address()" 
401       class="btn btn-success">[% l('New Address') %]</button>
402   </div>
403
404   <!-- pending address -->
405
406 </div> <!-- addresses -->
407
408 <div class="alert alert-success row" role="alert" 
409     ng-show="show_field('stat_cats')" ng-if="stat_cats.length > 0">
410     <div class="col-md-6">[% l('Statistical Categories') %]</div>
411 </div>
412
413 <div class="row reg-field-row" 
414     ng-show="show_field('stat_cats')" ng-repeat="cat in stat_cats">
415   <div class="col-md-3 reg-field-label">
416     <label>{{cat.name()}}</label>
417   </div>
418   <div class="col-md-3 reg-field-input">
419     <div ng-if="cat.entries().length == 0">
420       <input type="text" class="form-control"/>
421     </div>
422     <div ng-if="cat.entries().length != 0">
423       <div class="btn-group" dropdown>
424         <button type="button" class="btn btn-default dropdown-toggle">
425           <span style="padding-right: 5px;"></span>
426           <span class="caret"></span>
427         </button>
428         <ul class="dropdown-menu">
429           <li ng-repeat="entry in cat.entries()">
430             <a href ng-click=""> {{entry.value()}} </a>
431           </li>
432         </ul>
433       </div>
434     </div>
435   </div>
436 </div>
437
438 <!-- surveys -->
439
440 <div class="alert alert-success row" role="alert" 
441     ng-show="show_field('surveys')" ng-if="surveys.length > 0">
442     <div class="col-md-6">[% l('Surveys') %]</div>
443 </div>
444
445 <div class="row reg-field-row" 
446     ng-show="show_field('surveys')" ng-repeat="survey in surveys">
447   <div class="col-md-3 reg-field-label">
448     <label>{{survey.name()}}</label>
449   </div>
450   <div class="col-md-3 reg-field-input">
451     <div class="btn-group" dropdown>
452       <button type="button" class="btn btn-default dropdown-toggle">
453         <span style="padding-right: 5px;"></span>
454         <span class="caret"></span>
455       </button>
456       <ul class="dropdown-menu">
457         <li ng-repeat="question in survey.questions()">
458           <a href ng-click=""> {{question.question()}} </a>
459         </li>
460       </ul>
461     </div>
462   </div>
463 </div>
464
465
466