]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/src/templates/staff/circ/patron/t_edit.tt2
LP#1554714 Patron reg DoB via datepicker
[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 <div id="reg-alert-pane">
23
24   <div id="reg-dupe-links">
25     [%# dupe_search_encoded is uri escaped in the JS %]
26     <div class="alert alert-danger" ng-show="dupe_counts.name">
27       <a target="_blank"
28         href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
29       [% l('[_1] patron(s) with same name', '{{dupe_counts.name}}') %]
30       </a>
31     </div>
32     <div class="alert alert-danger" ng-show="dupe_counts.email">
33       <a target="_blank"
34         href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
35         [% l('[_1] patron(s) with same email', 
36         '{{dupe_counts.email}}') %]</a>
37     </div>
38     <div class="alert alert-danger" ng-show="dupe_counts.ident">
39       <a target="_blank" 
40         href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
41         [% l('[_1] patron(s) with same identification', 
42         '{{dupe_counts.ident}}') %]</a>
43     </div>
44     <div class="alert alert-danger" ng-show="dupe_counts.phone">
45       <a target="_blank" 
46         href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
47         [% l('[_1] patron(s) with same phone', 
48         '{{dupe_counts.phone}}') %]</a>
49     </div>
50     <div class="alert alert-danger" ng-show="dupe_counts.address">
51       <a target="_blank" 
52         href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}" >
53         [% l('[_1] patron(s) with same address', 
54         '{{dupe_counts.address}}') %]</a>
55     </div>
56   </div>
57
58   <!-- IDL field documentation window -->
59   <div class="alert alert-info" ng-show="selected_field_doc">
60     <fieldset id="reg-field-doc">
61       <legend>
62       {{idl_fields[selected_field_doc.fm_class()][selected_field_doc.field()].label}}
63       </legend>
64       <div>{{selected_field_doc.string()}}</div>
65     </fieldset>
66   </div>
67
68   <div class="alert alert-info" ng-show="stage_user_requestor">
69     <a target="_blank" 
70       href="/eg/staff/circ/patron/{{stage_user.reqesting_usr()}}/edit">
71       [% l('Requested by [_1]', '{{stage_user_requestor}}') %]
72     </a>
73   </div>
74 </div>
75
76 [% MACRO draw_field_label (cls, field) BLOCK %]
77   <div class="col-md-3 reg-field-label"> <!-- field label -->
78     <label>{{idl_fields.[% cls %].[% field %].label}}</label>
79     <!-- field documentation img/link -->
80     <img ng-show="field_doc.[% cls %].[% field %]" 
81       ng-click="set_selected_field_doc('[% cls %]','[% field %]')"
82       src='[% DOC_IMG %]'></img>
83   </div>
84 [% END %]
85
86
87 [% 
88 # draws a vanilla form input field for inputs that require no 
89 # special additions.
90 MACRO draw_form_input(cls, field, path, type, disable) BLOCK;
91   IF !type; type = 'text'; END;
92   base_obj = path ? 'patron.' _ path : 'patron';
93   model = base_obj _ '.' _ field;
94 %]
95   <div class="col-md-3 reg-field-input">
96     <input 
97       type="[% type %]" 
98       class="form-control" 
99       name="[% model %]"
100       ng-change="field_modified()" 
101       ng-required="field_required('[% cls %]', '[% field %]')"
102       ng-blur="handle_field_changed([% base_obj %], '[% field %]')"
103       ng-pattern="field_pattern('[% cls %]', '[% field %]')"
104       [% IF disable %]ng-disabled="[% disable %]"[% END %]
105       ng-model="[% model %]"/>
106   </div>
107 [% END %]
108
109 [% MACRO draw_example_text(cls, field) BLOCK;
110   set_str = "org_settings['ui.patron.edit." _ cls _ "." _ field _ ".example']";
111 %]
112   <span ng-if="[% set_str %]">
113     [% l('Example: [_1]', '{{' _ set_str _ '}}') %]
114   </span>
115 [% END %]
116
117 <!-- progress dialog displayed as we await all data to finish loading -->
118 <div class="row" ng-show="!page_data_loaded">
119   <div class="col-md-6 pad-vert">
120     <div class="progress progress-striped active">
121         <div class="progress-bar"  role="progressbar" aria-valuenow="100" 
122               aria-valuemin="0" aria-valuemax="100" style="width: 100%">
123             <span class="sr-only">[% l('Loading...') %]</span>
124         </div>
125     </div>
126   </div>
127 </div>
128
129 <!--  
130 MAIN FORM
131 This div wraps the entire form so we can hide it until all needed data
132 has been loaded.  Setting ng-form and a name lets us refer to fields
133 within the "form" by name for validation.
134 -->
135 <div ng-form id="patron-reg-container" 
136   name="reg_form" ng-show="page_data_loaded">
137
138 <!-- BARCODE -->
139
140 <div class="row reg-field-row" ng-show="show_field('ac.barcode')">
141   [% draw_field_label('ac', 'barcode') %]
142   <div class="col-md-3 reg-field-input"> <!-- field form input -->
143       <input type="text" 
144         name="barcode"
145         ng-model="patron.card.barcode"
146         ng-pattern="field_pattern('ac', 'barcode')"
147         ng-required="field_required('ac', 'barcode')"
148         focus-me="focus_bc"
149         ng-change="field_modified()" 
150         ng-disabled="disable_bc"
151         class="form-control" 
152         ng-blur="handle_field_changed(patron.card, 'barcode')"/>
153   </div>
154   <div class="col-md-6 patron-reg-example">
155       <button class="btn btn-default" ng-show="!patron.isnew"
156         ng-click="replace_card()">[% l('Replace Barcode') %]</button>
157       <button class="btn btn-default" 
158         ng-click="cards_dialog()">[% l('See All') %]</button>
159       <div ng-show="dupe_barcode" class="patron-reg-validation-alert">
160         <span>[% l('Barcode is already in use') %]</span>
161       </div>
162   </div>
163 </div>
164
165 <!-- USRNAME -->
166
167 <div class="row reg-field-row" ng-show="show_field('au.usrname')">
168   [% draw_field_label('au', 'usrname') %]
169   <div class="col-md-3 reg-field-input">
170     <input type="text" 
171       name='usrname'
172       ng-required="field_required('au', 'usrname')"
173       focus-me="focus_usrname"
174       ng-change="field_modified()" 
175       ng-pattern="field_pattern('au', 'usrname')"
176       ng-blur="handle_field_changed(patron, 'usrname')"
177       class="form-control" 
178       ng-model="patron.usrname"/>
179   </div>
180   <div class="col-md-6 patron-reg-example">
181     <div ng-show="dupe_username" class="patron-reg-validation-alert">
182       <span>[% l('Username is already in use') %]</span>
183     </div>
184   </div>
185 </div>
186
187 <!-- PASSWD -->
188
189 <div class="row reg-field-row" ng-show="show_field('au.passwd')">
190   [% draw_field_label('au', 'passwd') %]
191   [% draw_form_input('au', 'passwd'); %]
192   <div class="col-md-6 patron-reg-example">
193     <button class="btn btn-default" ng-click="generate_password()">
194       [% l('Generate Password') %]</button>
195   </div>
196 </div>
197
198 <!-- PREFIX -->
199
200 <div class="row reg-field-row" ng-show="show_field('au.prefix')">
201   [% draw_field_label('au', 'prefix') %]
202   [% draw_form_input('au', 'prefix'); %]
203   <div class="col-md-6 patron-reg-example">
204     [% draw_example_text('au', 'prefix') %]
205   </div>
206 </div>
207
208 <!-- FIRST_GIVEN_NAME -->
209
210 <div class="row reg-field-row" ng-show="show_field('au.first_given_name')">
211   [% draw_field_label('au', 'first_given_name') %]
212   [% draw_form_input('au', 'first_given_name'); %]
213   <div class="col-md-6 patron-reg-example">
214     [% draw_example_text('au', 'first_given_name') %]
215   </div>
216 </div>
217
218 <!-- SECOND_GIVEN_NAME -->
219
220 <div class="row reg-field-row" ng-show="show_field('au.second_given_name')">
221   [% draw_field_label('au', 'second_given_name') %]
222   [% draw_form_input('au', 'second_given_name'); %]
223   <div class="col-md-6 patron-reg-example">
224     [% draw_example_text('au', 'second_given_name') %]
225   </div>
226 </div>
227
228 <!-- FAMILY_NAME -->
229
230 <div class="row reg-field-row" ng-show="show_field('au.family_name')">
231   [% draw_field_label('au', 'family_name') %]
232   [% draw_form_input('au', 'family_name'); %]
233   <div class="col-md-6 patron-reg-example">
234     [% draw_example_text('au', 'family_name') %]
235   </div>
236 </div>
237
238 <!-- SUFFIX -->
239
240 <div class="row reg-field-row" ng-show="show_field('au.suffix')">
241   [% draw_field_label('au', 'suffix') %]
242   [% draw_form_input('au', 'suffix'); %]
243   <div class="col-md-6 patron-reg-example">
244     [% draw_example_text('au', 'suffix') %]
245   </div>
246 </div>
247
248 <!-- ALIAS -->
249
250 <div class="row reg-field-row" ng-show="show_field('au.alias')">
251   [% draw_field_label('au', 'alias') %]
252   [% draw_form_input('au', 'alias'); %]
253   <div class="col-md-6 patron-reg-example">
254     [% draw_example_text('au', 'alias') %]
255   </div>
256 </div>
257
258 <!-- DOB -->
259
260 <div class="row reg-field-row" ng-show="show_field('au.dob')">
261   [% draw_field_label('au', 'dob') %]
262   <div class="col-md-3 reg-field-input">
263     <input
264       name="dob"
265       uib-datepicker-popup="shortDate" 
266       ng-change="field_modified()" 
267       ng-required="field_required('au', 'dob')"
268       ng-blur="handle_field_changed(patron, 'dob')"
269       is-open="dob_is_open" 
270       close-text="[% l('Close') %]"/>
271       class="form-control" ng-model="patron.dob"/>
272   </div>
273   <div class="col-md-6 patron-reg-example">
274     [% draw_example_text('au', 'dob') %]
275   </div>
276 </div>
277
278 <!-- JUVENILE -->
279
280 <div class="row reg-field-row" ng-show="show_field('au.juvenile')">
281   [% draw_field_label('au', 'juvenile') %]
282   <div class="col-md-3 reg-field-input">
283     <div class='checkbox'>
284       <input 
285         ng-change="field_modified()" 
286         ng-blur="handle_field_changed(patron, 'juvenile')"
287         type='checkbox' ng-model="patron.juvenile"/>
288     </div>
289   </div>
290 </div>
291
292 <!-- ident_type -->
293
294 <div class="row reg-field-row" ng-show="show_field('au.ident_type')">
295   [% draw_field_label('au', 'ident_type') %]
296   <div class="col-md-3 reg-field-input">
297     <select 
298       class="form-control" 
299       ng-model="patron.ident_type"
300       ng-required="field_required('au', 'ident_type')"
301       ng-blur="handle_field_changed(patron, 'ident_type')"
302       ng-options="type.name() for type in ident_types track by type.id()">
303     </select>
304   </div>
305 </div>
306
307 <!-- IDENT_VALUE -->
308
309 <div class="row reg-field-row" ng-show="show_field('au.ident_value')">
310   [% draw_field_label('au', 'ident_value') %]
311   [% draw_form_input('au', 'ident_value') %]
312   <div class="col-md-6 patron-reg-example">
313     [% draw_example_text('au', 'ident_value') %]
314   </div>
315 </div>
316
317 <!-- IDENT_VALUE2 -->
318 <div class="row reg-field-row" ng-show="show_field('au.ident_value2')">
319   [% draw_field_label('au', 'ident_value2') %]
320   [% draw_form_input('au', 'ident_value2') %]
321   <div class="col-md-6 patron-reg-example">
322     [% draw_example_text('au', 'ident_value2') %]
323   </div>
324 </div>
325
326
327 <!-- EMAIL -->
328 <div class="row reg-field-row" ng-show="show_field('au.email')">
329   [% draw_field_label('au', 'email') %]
330   [% draw_form_input('au', 'email', '', 'email') %]
331   <div class="col-md-6 patron-reg-example">
332     <button ng-show="patron.email && !patron.isnew" 
333       class="btn btn-default" 
334       ng-click="invalidate_field('email')">[% l('Invalidate') %]</button>
335     <span ng-if="org_settings['ui.patron.edit.au.email.example']">
336       [% l('Example: [_1]',
337         "{{org_settings['ui.patron.edit.au.email.example']}}") %]
338     </span>
339   </div>
340 </div>
341
342 <!-- DAY_PHONE -->
343
344 <div class="row reg-field-row" ng-show="show_field('au.day_phone')">
345   [% draw_field_label('au', 'day_phone') %]
346   [% draw_form_input('au', 'day_phone') %]
347   <div class="col-md-6 patron-reg-example">
348     <button ng-show="patron.day_phone && !patron.isnew" 
349         class="btn btn-default" 
350         ng-click="invalidate_field('day_phone')">[% l('Invalidate') %]</button>
351     [% draw_example_text('au', 'day_phone') %]
352     <!-- phones have a fall-through example strings -->
353     <span ng-if="!org_settings['ui.patron.edit.au.day_phone.example'] && org_settings['ui.patron.edit.phone.example']">
354       [% l('Example: [_1]', 
355         "{{org_settings['ui.patron.edit.phone.example']}}") %]
356     </span>
357   </div>
358 </div>
359
360 <!-- EVENING_PHONE -->
361
362 <div class="row reg-field-row" ng-show="show_field('au.evening_phone')">
363   [% draw_field_label('au', 'evening_phone') %]
364   [% draw_form_input('au', 'evening_phone') %]
365   <div class="col-md-6 patron-reg-example">
366     <button ng-show="patron.evening_phone && !patron.isnew" 
367         class="btn btn-default" 
368         ng-click="invalidate_field('evening_phone')">[% l('Invalidate') %]</button>
369     [% draw_example_text('au', 'evening_phone') %]
370     <!-- phones have a fall-through example strings -->
371     <span ng-if="!org_settings['ui.patron.edit.au.evening_phone.example'] && org_settings['ui.patron.edit.phone.example']">
372       [% l('Example: [_1]', 
373         "{{org_settings['ui.patron.edit.phone.example']}}") %]
374     </span>
375   </div>
376 </div>
377
378 <!-- OTHER_PHONE -->
379
380 <div class="row reg-field-row" ng-show="show_field('au.other_phone')">
381   [% draw_field_label('au', 'other_phone') %]
382   [% draw_form_input('au', 'other_phone') %]
383   <div class="col-md-6 patron-reg-example">
384     <button ng-show="patron.other_phone && !patron.isnew" 
385         class="btn btn-default" 
386         ng-click="invalidate_field('other_phone')">[% l('Invalidate') %]</button>
387     [% draw_example_text('au', 'other_phone') %]
388     <!-- phones have a fall-through example strings -->
389     <span ng-if="!org_settings['ui.patron.edit.au.other_phone.example'] && org_settings['ui.patron.edit.phone.example']">
390       [% l('Example: [_1]', 
391         "{{org_settings['ui.patron.edit.phone.example']}}") %]
392     </span>
393   </div>
394 </div>
395
396 <!-- home org unit selector -->
397
398 <div class="row reg-field-row" ng-show="show_field('au.home_ou')">
399   [% draw_field_label('au', 'home_ou') %]
400   <div class="col-md-3 reg-field-input">
401     <eg-org-selector 
402       selected="patron.home_ou" 
403       onchange="handle_home_org_changed"
404       disable-test="disable_home_org">
405     </eg-org-selector>
406   </div>
407 </div>
408
409 <!-- profile selector -->
410
411 <div class="row reg-field-row" ng-show="show_field('au.profile')">
412   [% draw_field_label('au', 'profile') %]
413   <div class="col-md-3 reg-field-input">
414     <div class="btn-group" dropdown>
415       <button type="button" class="btn btn-default dropdown-toggle"
416           ng-class="{'ng-invalid' : invalid_profile()}">
417         <span style="padding-right: 5px;">
418           {{patron.profile.name() || "[% l('Profile Group') %]"}}
419         </span>
420         <span class="caret"></span>
421       </button>
422       <ul class="dropdown-menu">
423         <li ng-repeat="grp in edit_profiles" 
424           ng-class="{disabled : grp.usergroup() == 'f'}">
425           <a href 
426             style="padding-left: {{pgt_depth(grp) * 10 + 5}}px"
427             ng-click="set_profile(grp)">{{grp.name()}}</a>
428         </li>
429       </ul>
430     </div>
431   </div>
432   <div class="col-md-3">
433     <button class="btn btn-default" ng-disabled="!perms.CREATE_USER_GROUP_LINK"
434       ng-click="secondary_groups_dialog()">[% l('Secondary Groups') %]</button>
435   </div> 
436 </div>
437
438 <div class="row reg-field-row" ng-show="show_field('au.expire_date')">
439   [% draw_field_label('au', 'expire_date') %]
440   <div class="col-md-3 reg-field-input">
441     <input eg-date-input 
442       ng-blur="handle_field_changed(patron, 'expire_date')"
443       class="form-control" ng-model="patron.expire_date"/>
444   </div>
445   <div class="col-md-3">
446     <button class="btn btn-default" ng-click="set_expire_date()">
447       [% l('Update Expire Date') %]</button>
448   </div>
449 </div>
450
451 <!-- net_access_level -->
452
453 <div class="row reg-field-row" ng-show="show_field('au.net_access_level')">
454   [% draw_field_label('au', 'net_access_level') %]
455   <div class="col-md-3 reg-field-input">
456     <select 
457       class="form-control" 
458       ng-model="patron.net_access_level"
459       ng-required="field_required('au', 'net_access_level')"
460       ng-blur="handle_field_changed(patron, 'net_access_level')"
461       ng-options="level.name() for level in net_access_levels track by level.id()">
462     </select>
463   </div>
464 </div>
465
466 <!-- ACTIVE -->
467
468 <div class="row reg-field-row" ng-show="show_field('au.active')">
469   [% draw_field_label('au', 'active') %]
470   <div class="col-md-3 reg-field-input">
471     <div class='checkbox'>
472       <input 
473         ng-change="field_modified()" 
474         ng-blur="handle_field_changed(patron, 'active')"
475         type='checkbox' ng-model="patron.active"/>
476     </div>
477   </div>
478 </div>
479
480 <!-- BARRED -->
481
482 <div class="row reg-field-row" ng-show="show_field('au.barred')">
483   [% draw_field_label('au', 'barred') %]
484   <div class="col-md-3 reg-field-input">
485     <div class='checkbox'>
486       <input 
487         ng-change="field_modified()" 
488         ng-blur="handle_field_changed(patron, 'barred')"
489         type='checkbox' ng-model="patron.barred"/>
490     </div>
491   </div>
492 </div>
493
494 <!-- MASTER_ACCOUNT -->
495
496 <div class="row reg-field-row" ng-show="show_field('au.master_account')">
497   [% draw_field_label('au', 'master_account') %]
498   <div class="col-md-3 reg-field-input">
499     <div class='checkbox'>
500       <input 
501         ng-change="field_modified()" 
502         ng-blur="handle_field_changed(patron, 'master_account')"
503         type='checkbox' ng-model="patron.master_account"/>
504     </div>
505   </div>
506 </div>
507
508 <!-- CLAIMS_RETURNED_COUNT -->
509
510 <div class="row reg-field-row" ng-show="show_field('au.claims_returned_count')">
511   [% draw_field_label('au', 'claims_returned_count') %]
512   [% draw_form_input('au', 'claims_returned_count', 
513     '', 'number', '!perms.UPDATE_PATRON_CLAIM_RETURN_COUNT') %]
514   <div class="col-md-6 patron-reg-example">
515     [% draw_example_text('au', 'claims_returned_count') %]
516   </div>
517 </div>
518
519 <!-- CLAIMS_NEVER_CHECKED_OUT_COUNT -->
520
521 <div class="row reg-field-row" ng-show="show_field('au.claims_never_checked_out_count')">
522   [% draw_field_label('au', 'claims_never_checked_out_count') %]
523   [% draw_form_input('au', 'claims_never_checked_out_count',
524     '', 'number', '!perms.UPDATE_PATRON_CLAIM_NEVER_CHECKED_OUT_COUNT') %]
525   <div class="col-md-6 patron-reg-example">
526     [% draw_example_text('au', 'claims_never_checked_out_count') %]
527   </div>
528 </div>
529
530 <!-- ALERT_MESSAGE -->
531
532 <div class="row reg-field-row" ng-show="show_field('au.alert_message')">
533   [% draw_field_label('au', 'alert_message') %]
534   <div class="col-md-3 reg-field-input">
535     <textarea 
536       class="form-control" 
537       ng-model="patron.alert_message"
538       ng-pattern="field_pattern('au', 'alert_message')"
539       ng-change="field_modified()" 
540       ng-blur="handle_field_changed(patron, 'alert_message')">
541     </textarea>
542   </div>
543   <div class="col-md-6 patron-reg-example">
544     [% draw_example_text('au', 'alert_message') %]
545   </div>
546 </div>
547
548 <div class="alert alert-success row" role="alert">
549   <div class="col-md-6">[% l('User Settings') %]</div>
550 </div>
551
552 <div class="row reg-field-row">
553   <div class="col-md-3 reg-field-label">
554     <label>{{user_setting_types['opac.default_phone'].label()}}</label>
555   </div>
556   <div class="col-md-3 reg-field-input">
557     <input 
558       ng-change="field_modified()" 
559       type='text' ng-model="user_settings['opac.default_phone']"/>
560   </div>
561 </div>
562
563 <div class="row reg-field-row">
564   <div class="col-md-3 reg-field-label">
565     <label>{{user_setting_types['opac.default_pickup_location'].label()}}</label>
566   </div>
567   <div class="col-md-3 reg-field-input">
568     <eg-org-selector 
569       xonchange="field_modified" 
570       selected="patron.home_ou"></eg-org-selector>
571   </div>
572 </div>
573
574 <div class="row reg-field-row">
575   <div class="col-md-3 reg-field-label">
576     <label>{{user_setting_types['circ.holds_behind_desk'].label()}}</label>
577   </div>
578   <div class="col-md-3 reg-field-input">
579     <div class='checkbox'>
580       <input 
581         ng-change="field_modified()" 
582         type='checkbox' ng-model="user_settings['circ.holds_behind_desk']"/>
583     </div>
584   </div>
585 </div>
586
587 <!-- TODO: Add circ.collections.exempt to master SQL seed data -->
588 <div class="row reg-field-row" 
589   ng-if="user_setting_types['circ.collections.exempt']">
590   <div class="col-md-3 reg-field-label">
591     <label>{{user_setting_types['circ.collections.exempt'].label()}}</label>
592   </div>
593   <div class="col-md-3 reg-field-input">
594     <div class='checkbox'>
595       <input 
596         type='checkbox' 
597         ng-change="field_modified()" 
598         ng-disabled="!perms.UPDATE_PATRON_COLLECTIONS_EXEMPT"
599         ng-model="user_settings['circ.collections.exempt']"/>
600     </div>
601   </div>
602 </div>
603
604 <div class="row reg-field-row">
605   <div class="col-md-3 reg-field-label">
606     <label>[% l('Holds Notices') %]</label>
607   </div>
608   <div class="col-md-3 reg-field-input flex-row">
609     <div class='flex-cell'>
610       <input 
611         ng-change="field_modified()" 
612         type='checkbox' ng-model="hold_notify_phone"/>
613       [% l('Phone') %]
614     </div>
615     <div class='flex-cell'>
616       <input 
617         ng-change="field_modified()" 
618         type='checkbox' ng-model="hold_notify_email"/>
619       [% l('Email') %]
620     </div>
621     <div class='flex-cell' ng-if="org_settings['sms.enable']">
622       <input 
623         ng-change="field_modified()" 
624         type='checkbox' ng-model="hold_notify_sms"/>
625       [% l('SMS') %]
626     </div>
627   </div>
628 </div>
629
630 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
631   <div class="col-md-3 reg-field-label">
632     <label>[% l('Default SMS/Text Number') %]</label>
633   </div>
634   <div class="col-md-3 reg-field-input">
635     <input 
636       ng-change="field_modified()" 
637       type='text'/>
638   </div>
639 </div>
640
641 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
642   <div class="col-md-3 reg-field-label">
643     <label>[% l('Default SMS Carrier') %]</label>
644   </div>
645   <div class="col-md-3 reg-field-input">
646     <div class="btn-group" dropdown>
647       <button type="button" class="btn btn-default dropdown-toggle">
648         <span style="padding-right: 5px;"></span>
649         <span class="caret"></span>
650       </button>
651       <ul class="dropdown-menu">
652         <li ng-repeat="carrier in sms_carriers">
653           <a href 
654             ng-click="field_modified();user_settings['opac.default_sms_carrier'] = carrier">
655                 {{carrier.name()}}
656           </a>
657         </li>
658       </ul>
659     </div>
660   </div>
661 </div>
662
663 <div class="row reg-field-row" ng-repeat="type in opt_in_setting_types">
664   <div class="col-md-3 reg-field-label">
665     <label>{{type.label()}}</label>
666   </div>
667   <div class="col-md-3 reg-field-input">
668     <input 
669       ng-change="field_modified()" 
670       type='checkbox' ng-model="user_settings[type.name()]"/>
671   </div>
672 </div>
673
674 <!-- addresses -->
675
676 <div ng-repeat="addr in patron.addresses">
677   <div class="alert alert-success row" role="alert">
678       <div class="col-md-3">
679         [% l('Address') %]
680         <div ng-show="addr._linked_owner">
681           (<a target="_blank"
682             href="/eg/staff/circ/patron/{{addr._linked_owner_id}}/edit">
683             [% l('Owned by [_1]', '{{addr._linked_owner}}') %]
684           </a>)
685         </div>
686       </div>
687       <div class="col-md-3">
688           <span class='pad-all-min'>
689             [% l('Mailing') %] <input type='checkbox' 
690               ng-change="field_modified();set_addr_type(addr, 'mailing')" 
691               ng-model="addr._is_mailing"/>
692           </span>
693           <span class='pad-all-min'>
694             [% l('Physical') %] <input type='checkbox' 
695               ng-change="field_modified();set_addr_type(addr, 'billing')" 
696               ng-model="addr._is_billing"/>
697           </span>
698           <span class='pad-all-min'>
699             <button type="button" 
700               ng-click="field_modified();delete_address(addr.id)" 
701               class="btn btn-danger">[% l('X') %]</button>
702           </span>
703       </div>
704   </div>
705
706   <!-- ADDRESS_TYPE -->
707   <div class="row reg-field-row" ng-show="show_field('aua.address_type')">
708     [% draw_field_label('aua', 'address_type') %]
709     [% draw_form_input('aua', 
710       'address_type', 'addresses[$index]', '', 'addr._linked_owner') %]
711     <div class="col-md-6 patron-reg-example">
712       [% draw_example_text('aua', 'address_type') %]
713     </div>
714   </div>
715
716   <!-- POST_CODE -->
717
718   <div class="row reg-field-row" ng-show="show_field('aua.post_code')">
719     [% draw_field_label('aua', 'post_code') %]
720     [% draw_form_input('aua', 
721       'post_code', 'addresses[$index]', '', 'addr._linked_owner') %]
722     <div class="col-md-6 patron-reg-example">
723       [% draw_example_text('aua', 'post_code') %]
724     </div>
725   </div>
726
727   <!-- STREET1 -->
728
729   <div class="row reg-field-row" ng-show="show_field('aua.street1')">
730     [% draw_field_label('aua', 'street1') %]
731     [% draw_form_input('aua', 
732       'street1', 'addresses[$index]', '', 'addr._linked_owner') %]
733     <div class="col-md-6 patron-reg-example">
734       [% draw_example_text('aua', 'street1') %]
735     </div>
736   </div>
737
738   <!-- STREET2 -->
739
740   <div class="row reg-field-row" ng-show="show_field('aua.street2')">
741     [% draw_field_label('aua', 'street2') %]
742     [% draw_form_input('aua', 
743       'street2', 'addresses[$index]', '', 'addr._linked_owner') %]
744     <div class="col-md-6 patron-reg-example">
745       [% draw_example_text('aua', 'street2') %]
746     </div>
747   </div>
748
749   <!-- CITY -->
750
751   <div class="row reg-field-row" ng-show="show_field('aua.city')">
752     [% draw_field_label('aua', 'city') %]
753     [% draw_form_input('aua', 
754       'city', 'addresses[$index]', '', 'addr._linked_owner') %]
755     <div class="col-md-6 patron-reg-example">
756       [% draw_example_text('aua', 'city') %]
757     </div>
758   </div>
759
760   <!-- COUNTY -->
761
762   <div class="row reg-field-row" ng-show="show_field('aua.county')">
763     [% draw_field_label('aua', 'county') %]
764     [% draw_form_input('aua', 
765       'county', 'addresses[$index]', '', 'addr._linked_owner') %]
766     <div class="col-md-6 patron-reg-example">
767       [% draw_example_text('aua', 'county') %]
768     </div>
769   </div>
770
771   <!-- STATE -->
772
773   <div class="row reg-field-row" ng-show="show_field('aua.state')">
774     [% draw_field_label('aua', 'state') %]
775     [% draw_form_input('aua', 
776       'state', 'addresses[$index]', '', 'addr._linked_owner') %]
777     <div class="col-md-6 patron-reg-example">
778       [% draw_example_text('aua', 'state') %]
779     </div>
780   </div>
781
782   <!-- COUNTRY -->
783
784   <div class="row reg-field-row" ng-show="show_field('aua.country')">
785     [% draw_field_label('aua', 'country') %]
786     [% draw_form_input('aua', 
787       'country', 'addresses[$index]', '', 'addr._linked_owner') %]
788     <div class="col-md-6 patron-reg-example">
789       [% draw_example_text('aua', 'country') %]
790     </div>
791   </div>
792
793   <!-- VALID -->
794
795   <div class="row reg-field-row" ng-show="show_field('aua.valid')">
796     [% draw_field_label('aua', 'valid') %]
797     <div class="col-md-3 reg-field-input">
798       <div class='checkbox'>
799         <input 
800           type='checkbox' 
801           ng-change="field_modified()" 
802           ng-disabled='addr._linked_owner'
803           ng-blur="handle_field_changed(patron.addresses[$index], 'valid')"
804           ng-model="patron.addresses[$index].valid"/>
805       </div>
806     </div>
807     <div class="col-md-6 patron-reg-example">
808       [% draw_example_text('aua', 'valid') %]
809     </div>
810   </div>
811
812   <!-- WITHIN_CITY_LIMITS -->
813
814   <div class="row reg-field-row" ng-show="show_field('aua.within_city_limits')">
815     [% draw_field_label('aua', 'within_city_limits') %]
816     <div class="col-md-3 reg-field-input">
817       <div class='checkbox'>
818         <input 
819           type='checkbox' 
820           ng-change="field_modified()" 
821           ng-disabled='addr._linked_owner'
822           ng-blur="handle_field_changed(patron.addresses[$index], 'within_city_limits')"
823           ng-model="patron.addresses[$index].within_city_limits"/>
824       </div>
825     </div>
826     <div class="col-md-6 patron-reg-example">
827       [% draw_example_text('aua', 'within_city_limits') %]
828     </div>
829   </div>
830
831   <!-- pending address -->
832
833 </div> <!-- addresses -->
834
835 <div class="row">
836   <button type="button" ng-click="new_address()" 
837     class="btn btn-success">[% l('New Address') %]</button>
838 </div>
839
840 <div class="alert alert-success row" role="alert" 
841     ng-show="show_field('stat_cats')" ng-if="stat_cats.length > 0">
842     <div class="col-md-6">[% l('Statistical Categories') %]</div>
843 </div>
844
845 <div class="row reg-field-row" 
846     ng-show="show_field('stat_cats')" ng-repeat="cat in stat_cats">
847   <div class="col-md-3 reg-field-label">
848     <label>{{cat.name()}}</label>
849   </div>
850   <div class="col-md-3 reg-field-input">
851
852     <!-- Editable typeahead is not support in this version of 
853         angularjs-bootstrap.  Requires Angular 1.4 and 
854         angularjs-bootstrap version 1.1+ -->
855
856     <!-- typeahead is wonky.  Consider updating -->
857     <!--
858     <input type="text" ng-model="stat_cat_entry_maps[cat.id()]"
859       typeahead="value as entry.value() for entry in cat.entries() | filter:$viewValue | limitTo:8" 
860       class="form-control">
861     -->
862     
863     <div ng-if="cat.entries().length != 0">
864       <div class="btn-group" dropdown>
865         <button type="button" class="btn btn-default dropdown-toggle">
866           <span style="padding-right: 5px;">
867             {{stat_cat_entry_maps[cat.id()]}}</span>
868           <span class="caret"></span>
869         </button>
870         <ul class="dropdown-menu">
871           <li ng-repeat="entry in cat.entries()">
872             <a href 
873               ng-click="field_modified();stat_cat_entry_maps[cat.id()]=entry.value()"> 
874               {{entry.value()}}
875             </a>
876           </li>
877         </ul>
878       </div>
879     </div>
880   </div>
881
882   <!-- Stat cat retrieval API uses open-ils.storage under the covers
883       which represents DB bools at 1/0 instead of cstore-style t/f -->
884   <div class="col-md-3 reg-field-input" ng-if="cat.allow_freetext() == '1'">
885     <input type="text" ng-model="stat_cat_entry_maps[cat.id()]"/>
886   </div>
887 </div>
888
889 <!-- surveys -->
890
891 <div class="alert alert-success row" role="alert" 
892     ng-show="show_field('surveys')" ng-if="surveys.length > 0">
893     <div class="col-md-6">[% l('Surveys') %]</div>
894 </div>
895
896 <div class="row reg-field-row" 
897     ng-show="show_field('surveys')" ng-repeat="survey in surveys">
898   <div class="col-md-3 reg-field-label">
899     <label>{{survey.name()}}</label>
900   </div>
901   <div class="col-md-6 reg-field-input">
902     <div class="row" ng-repeat="question in survey.questions()" 
903       style="margin-bottom: 10px;">
904       <div class="col-md-6">{{question.question()}}</div>
905       <div class="col-md-6">
906         <div class="btn-group" dropdown>
907           <button type="button" class="btn btn-default dropdown-toggle">
908             <span style="padding-right: 5px;">
909               {{survey_responses[question.id()].answer()}}
910             </span>
911             <span class="caret"></span>
912           </button>
913           <ul class="dropdown-menu">
914             <li ng-repeat="answer in question.answers()">
915               <a href 
916                 ng-click="field_modified();survey_responses[question.id()] = answer"> 
917                 {{answer.answer()}} 
918               </a>
919             </li>
920           </ul>
921         </div>
922       </div>
923     </div>
924   </div>
925 </div>
926
927 </div><!-- /form wrapper -->