1 [% DOC_IMG = '/images/question-mark.png' %]
3 <!-- register banner -->
4 <div ng-if="!patron_id" ng-class='{"patron-reg-fixed-bar":!offline}'>
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>
12 <div class="flex-row" class='patron-reg-actions-bar'>
13 [% INCLUDE 'staff/circ/patron/reg_actions.tt2' %]
19 <div ng-if="patron_id"
20 class="strong-text-2">[% l('Patron Edit') %]</div>
22 <div id="reg-alert-pane">
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">
28 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.name}}&inactive=1">
29 [% l('[_1] patron(s) with same name', '{{dupe_counts.name}}') %]
32 <div class="alert alert-danger" ng-show="dupe_counts.email">
34 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.email}}">
35 [% l('[_1] patron(s) with same email',
36 '{{dupe_counts.email}}') %]</a>
38 <div class="alert alert-danger" ng-show="dupe_counts.ident">
40 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.ident}}">
41 [% l('[_1] patron(s) with same identification',
42 '{{dupe_counts.ident}}') %]</a>
44 <div class="alert alert-danger" ng-show="dupe_counts.day_phone">
46 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.day_phone}}">
47 [% l('[_1] patron(s) with same phone',
48 '{{dupe_counts.day_phone}}') %]</a>
50 <div class="alert alert-danger" ng-show="dupe_counts.evening_phone">
52 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.evening_phone}}">
53 [% l('[_1] patron(s) with same phone',
54 '{{dupe_counts.evening_phone}}') %]</a>
56 <div class="alert alert-danger" ng-show="dupe_counts.other_phone">
58 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.other_phone}}">
59 [% l('[_1] patron(s) with same phone',
60 '{{dupe_counts.other_phone}}') %]</a>
62 <div class="alert alert-danger" ng-show="dupe_counts.address">
64 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded.address}}" >
65 [% l('[_1] patron(s) with same address',
66 '{{dupe_counts.address}}') %]</a>
70 <div class="alert alert-danger" ng-show="address_alerts.length > 0">
71 <div class="strong-text-3">[% l('Address Alert') %]</div>
72 <div ng-repeat="address_alert in address_alerts">
73 {{address_alert.alert_message()}}
77 <!-- IDL field documentation window -->
78 <div class="alert alert-info" ng-show="selected_field_doc">
79 <fieldset id="reg-field-doc">
81 {{idl_fields[selected_field_doc.fm_class()][selected_field_doc.field()].label}}
83 <div>{{selected_field_doc.string()}}</div>
87 <div class="alert alert-info" ng-show="stage_user_requestor">
89 href="/eg/staff/circ/patron/{{stage_user.reqesting_usr()}}/edit">
90 [% l('Requested by [_1]', '{{stage_user_requestor}}') %]
96 # draws a label for inputs based on the idl class's field's
97 # label OR a supplied string
98 MACRO draw_field_label (cls, field, label_override) BLOCK %]
99 <div class="col-md-3 reg-field-label"> <!-- field label -->
100 [% IF label_override %]<label>[% label_override %]</label>
101 [% ELSE %]<label id="{{idl_fields.[% cls %].[% field %].name}}">{{idl_fields.[% cls %].[% field %].label}}</label>[% END %]
102 <!-- field documentation img/link -->
103 <img ng-show="field_doc.[% cls %].[% field %]"
104 ng-click="set_selected_field_doc('[% cls %]','[% field %]')"
105 src='[% DOC_IMG %]'></img>
111 # draws a vanilla form input field for inputs that require no
113 MACRO draw_form_input(cls, field, path, type, disable) BLOCK;
114 IF !type; type = 'text'; END;
115 base_obj = path ? 'patron.' _ path : 'patron';
116 model = base_obj _ '.' _ field;
118 <div class="col-md-3 reg-field-input">
120 [% IF type == "email" %]type="text" ng-required="hold_notify_type.email"
121 [% ELSE %]type="[% type %]"
125 aria-labelledby="{{idl_fields.[% cls %].[% field %].name}}"
126 ng-change="field_modified()"
127 ng-required="field_required('[% cls %]', '[% field %]')"
128 ng-blur="handle_field_changed([% base_obj %], '[% field %]')"
129 ng-pattern="field_pattern('[% cls %]', '[% field %]')"
130 [% IF disable %]ng-disabled="[% disable %]"[% END %]
131 ng-model="[% model %]"/>
135 [% MACRO draw_example_text(cls, field) BLOCK;
136 set_str = "org_settings['ui.patron.edit." _ cls _ "." _ field _ ".example']";
138 <span ng-if="[% set_str %]">
139 [% l('Example: [_1]', '{{' _ set_str _ '}}') %]
143 <!-- progress dialog displayed as we await all data to finish loading -->
144 <div class="row" ng-show="!page_data_loaded">
145 <div class="col-md-6 pad-vert">
146 <div class="progress progress-striped active">
147 <div class="progress-bar" role="progressbar" aria-valuenow="100"
148 aria-valuemin="0" aria-valuemax="100" style="width: 100%">
149 <span class="sr-only">[% l('Loading...') %]</span>
157 This div wraps the entire form so we can hide it until all needed data
158 has been loaded. Setting ng-form and a name lets us refer to fields
159 within the "form" by name for validation.
161 <div ng-form id="patron-reg-container"
162 name="reg_form" ng-show="page_data_loaded">
166 <div class="row reg-field-row" ng-show="show_field('ac.barcode')">
167 [% draw_field_label('ac', 'barcode') %]
168 <div class="col-md-3 reg-field-input"> <!-- field form input -->
171 aria-labelledby="{{idl_fields.ac.barcode.name}}"
172 ng-model="patron.card.barcode"
173 ng-pattern="field_pattern('ac', 'barcode')"
174 ng-required="field_required('ac', 'barcode')"
176 ng-change="field_modified()"
177 ng-disabled="disable_bc"
179 ng-blur="handle_field_changed(patron.card, 'barcode')"/>
181 <div class="col-md-6 patron-reg-example">
182 <button class="btn btn-default" ng-show="!patron.isnew"
183 ng-click="replace_card()">[% l('Replace Barcode') %]</button>
184 <button class="btn btn-default" ng-if="!patron.isnew"
185 ng-click="cards_dialog()">[% l('See All') %]</button>
186 <div ng-show="dupe_barcode" class="patron-reg-validation-alert">
187 <span>[% l('Barcode is already in use') %]</span>
194 <div class="row reg-field-row" ng-show="show_field('au.usrname')">
195 [% draw_field_label('au', 'usrname') %]
196 <div class="col-md-3 reg-field-input">
199 aria-labelledby="{{idl_fields.au.usrname.name}}"
200 ng-required="field_required('au', 'usrname')"
201 focus-me="focus_usrname"
202 ng-change="field_modified()"
203 ng-pattern="field_pattern('au', 'usrname')"
204 ng-blur="handle_field_changed(patron, 'usrname')"
206 ng-model="patron.usrname"/>
208 <div class="col-md-6 patron-reg-example">
209 <div ng-show="dupe_username" class="patron-reg-validation-alert">
210 <span>[% l('Username is already in use') %]</span>
217 <div class="row reg-field-row" ng-show="show_field('au.passwd')">
218 [% draw_field_label('au', 'passwd') %]
219 [% draw_form_input('au', 'passwd'); %]
220 <div class="col-md-6 patron-reg-example">
221 <button class="btn btn-default" ng-click="generate_password()">
222 [% l('Generate Password') %]</button>
223 <button class="btn btn-default" ng-show="!patron.isnew"
224 ng-click="send_password_reset_link()">
225 [% l('Send Password Reset Link') %]</button>
229 <div class="row reg-field-row">
230 <div class="col-md-6">
231 <ul class="nav nav-pills nav-pills-like-tabs">
232 <li ng-class="{active : name_tab == 'primary'}">
233 <a ng-click="name_tab='primary'" href="#">[% l('Primary Name') %]</a>
235 <li ng-class="{active : name_tab == 'preferred'}">
236 <a ng-click="name_tab='preferred'" href="#">[% l('Preferred Name') %]</a>
242 <div ng-show="name_tab == 'primary'">
246 <div class="row reg-field-row" ng-show="show_field('au.prefix')">
247 [% draw_field_label('au', 'prefix') %]
248 [% draw_form_input('au', 'prefix'); %]
249 <div class="col-md-6 patron-reg-example">
250 [% draw_example_text('au', 'prefix') %]
254 <!-- FIRST_GIVEN_NAME -->
256 <div class="row reg-field-row" ng-show="show_field('au.first_given_name')">
257 [% draw_field_label('au', 'first_given_name') %]
258 [% draw_form_input('au', 'first_given_name'); %]
259 <div class="col-md-6 patron-reg-example">
260 [% draw_example_text('au', 'first_given_name') %]
264 <!-- SECOND_GIVEN_NAME -->
266 <div class="row reg-field-row" ng-show="show_field('au.second_given_name')">
267 [% draw_field_label('au', 'second_given_name') %]
268 [% draw_form_input('au', 'second_given_name'); %]
269 <div class="col-md-6 patron-reg-example">
270 [% draw_example_text('au', 'second_given_name') %]
276 <div class="row reg-field-row" ng-show="show_field('au.family_name')">
277 [% draw_field_label('au', 'family_name') %]
278 [% draw_form_input('au', 'family_name'); %]
279 <div class="col-md-6 patron-reg-example">
280 [% draw_example_text('au', 'family_name') %]
286 <div class="row reg-field-row" ng-show="show_field('au.suffix')">
287 [% draw_field_label('au', 'suffix') %]
288 [% draw_form_input('au', 'suffix'); %]
289 <div class="col-md-6 patron-reg-example">
290 [% draw_example_text('au', 'suffix') %]
293 </div> <!-- ng-show == primary -->
295 <div ng-show="name_tab == 'preferred'" class="patron-reg-pref-names">
299 <div class="row reg-field-row" ng-show="show_field('au.pref_prefix')">
300 [% draw_field_label('au', 'pref_prefix') %]
301 [% draw_form_input('au', 'pref_prefix'); %]
302 <div class="col-md-6 patron-reg-example">
303 [% draw_example_text('au', 'pref_prefix') %]
307 <!-- FIRST_GIVEN_NAME -->
309 <div class="row reg-field-row" ng-show="show_field('au.pref_first_given_name')">
310 [% draw_field_label('au', 'pref_first_given_name') %]
311 [% draw_form_input('au', 'pref_first_given_name'); %]
312 <div class="col-md-6 patron-reg-example">
313 [% draw_example_text('au', 'pref_first_given_name') %]
317 <!-- SECOND_GIVEN_NAME -->
319 <div class="row reg-field-row" ng-show="show_field('au.pref_second_given_name')">
320 [% draw_field_label('au', 'pref_second_given_name') %]
321 [% draw_form_input('au', 'pref_second_given_name'); %]
322 <div class="col-md-6 patron-reg-example">
323 [% draw_example_text('au', 'pref_second_given_name') %]
329 <div class="row reg-field-row" ng-show="show_field('au.pref_family_name')">
330 [% draw_field_label('au', 'pref_family_name') %]
331 [% draw_form_input('au', 'pref_family_name'); %]
332 <div class="col-md-6 patron-reg-example">
333 [% draw_example_text('au', 'pref_family_name') %]
339 <div class="row reg-field-row" ng-show="show_field('au.pref_suffix')">
340 [% draw_field_label('au', 'pref_suffix') %]
341 [% draw_form_input('au', 'pref_suffix'); %]
342 <div class="col-md-6 patron-reg-example">
343 [% draw_example_text('au', 'pref_suffix') %]
346 </div> <!-- ng-show == preferred -->
348 <!-- indicate bottom of name tabs -->
349 <div class="row reg-field-row">
350 <div class="col-md-6"><hr class="patron-reg-names-separator"/></div>
353 <div class="row reg-field-row" ng-show="show_field('au.name_keywords')">
354 [% draw_field_label('au', 'name_keywords') %]
355 <div class="col-md-3 reg-field-input">
358 aria-labelledby="{{idl_fields.au.name_keywords.name}}"
359 ng-model="patron.name_keywords"
360 ng-pattern="field_pattern('au', 'name_keywords')"
361 ng-change="field_modified()"
362 ng-blur="handle_field_changed(patron, 'name_keywords')">
365 <div class="col-md-6 patron-reg-example">
366 [% draw_example_text('au', 'name_keywords') %]
372 <div class="row reg-field-row" ng-show="show_field('au.alias')">
373 [% draw_field_label('au', 'alias') %]
374 [% draw_form_input('au', 'alias'); %]
375 <div class="col-md-6 patron-reg-example">
376 [% draw_example_text('au', 'alias') %]
382 <div class="row reg-field-row" ng-show="show_field('au.dob')">
383 [% draw_field_label('au', 'dob') %]
384 <div class="col-md-3 reg-field-input">
386 date-aria="{{idl_fields.au.dob.name}}"
387 ng-required="field_required('au', 'dob')"
388 ng-model="patron.dob">
391 <div class="col-md-6 patron-reg-example">
392 [% draw_example_text('au', 'dob') %]
398 <div class="row reg-field-row" ng-show="show_field('au.juvenile')">
399 [% draw_field_label('au', 'juvenile') %]
400 <div class="col-md-3 reg-field-input">
402 aria-labelledby="{{idl_fields.au.juvenile.name}}"
403 ng-change="field_modified()"
404 ng-blur="handle_field_changed(patron, 'juvenile')"
405 type='checkbox' ng-model="patron.juvenile"/>
411 <div class="row reg-field-row" ng-show="show_field('au.guardian')">
412 [% draw_field_label('au', 'guardian') %]
413 [% draw_form_input('au', 'guardian'); %]
414 <div class="col-md-6 patron-reg-example">
415 [% draw_example_text('au', 'guardian') %]
421 <div class="row reg-field-row" ng-show="show_field('au.ident_type')">
422 [% draw_field_label('au', 'ident_type') %]
423 <div class="col-md-3 reg-field-input">
426 aria-labelledby="{{idl_fields.au.ident_type.name}}"
427 ng-model="patron.ident_type"
428 ng-required="field_required('au', 'ident_type')"
429 ng-blur="handle_field_changed(patron, 'ident_type')"
430 ng-options="type.name() for type in ident_types track by type.id()">
437 <div class="row reg-field-row" ng-show="show_field('au.ident_value')">
438 [% draw_field_label('au', 'ident_value') %]
439 [% draw_form_input('au', 'ident_value') %]
440 <div class="col-md-6 patron-reg-example">
441 [% draw_example_text('au', 'ident_value') %]
447 <div class="row reg-field-row" ng-show="show_field('au.ident_type2')">
448 [% draw_field_label('au', 'ident_type2') %]
449 <div class="col-md-3 reg-field-input">
452 aria-labelledby="{{idl_fields.au.ident_type2.name}}"
453 ng-model="patron.ident_type2"
454 ng-required="field_required('au', 'ident_type2')"
455 ng-blur="handle_field_changed(patron, 'ident_type2')"
456 ng-options="type.name() for type in ident_types track by type.id()">
461 <!-- IDENT_VALUE2 -->
462 <div class="row reg-field-row" ng-show="show_field('au.ident_value2')">
463 [% draw_field_label('au', 'ident_value2') %]
464 [% draw_form_input('au', 'ident_value2') %]
465 <div class="col-md-6 patron-reg-example">
466 [% draw_example_text('au', 'ident_value2') %]
471 <div class="row reg-field-row" ng-show="show_field('au.photo_url')">
472 [% draw_field_label('au', 'photo_url') %]
473 [% draw_form_input('au', 'photo_url', '', 'photo_url') %]
474 <div class="col-md-3 patron-reg-example">
475 <span ng-if="org_settings['ui.patron.edit.au.photo_url.example']">
476 [% l('Example: [_1]',
477 "{{org_settings['ui.patron.edit.au.photo_url.example']}}") %]
483 <div class="row reg-field-row" ng-show="show_field('au.locale')">
484 [% draw_field_label('au', 'locale') %]
485 <div class="col-md-3 reg-field-input">
488 aria-labelledby="{{idl_fields.au.locale.name}}"
489 ng-model="patron.locale"
490 ng-blur="handle_field_changed(patron, 'locale')"
491 ng-options="loc.name() for loc in locales track by loc.code()">
497 <div class="row reg-field-row" ng-show="show_field('au.email')">
498 [% draw_field_label('au', 'email') %]
499 [% draw_form_input('au', 'email', '', 'email') %]
500 <div class="col-md-3 patron-reg-example">
501 <button class="btn btn-default" ng-show="base_email && !patron.isnew"
502 ng-disabled="reg_form['patron.email'].$dirty"
503 ng-click="send_test_email()">[% l('Send Test Email') %]</button>
504 <button ng-show="patron.email && !patron.isnew"
505 class="btn btn-default"
506 ng-click="invalidate_field('email')">[% l('Invalidate') %]</button>
507 <span ng-if="org_settings['ui.patron.edit.au.email.example']">
508 [% l('Example: [_1]',
509 "{{org_settings['ui.patron.edit.au.email.example']}}") %]
514 <div class="row reg-field-row" ng-show="show_field('au.email') && opt_in_setting_types['circ.send_email_checkout_receipts']">
515 <div class="col-md-3 reg-field-label">
516 <label id="checkoutReceipts">{{opt_in_setting_types['circ.send_email_checkout_receipts'].label()}}</label>
518 <div class="col-md-3 reg-field-input">
520 aria-labelledby="checkoutReceipts"
521 ng-change="field_modified()"
522 type='checkbox' ng-model="user_settings['circ.send_email_checkout_receipts']"/>
528 <div class="row reg-field-row" ng-show="show_field('au.day_phone')">
529 [% draw_field_label('au', 'day_phone') %]
530 [% draw_form_input('au', 'day_phone') %]
531 <div class="col-md-6 patron-reg-example">
532 <button ng-show="patron.day_phone && !patron.isnew"
533 class="btn btn-default"
534 ng-click="invalidate_field('day_phone')">[% l('Invalidate') %]</button>
535 [% draw_example_text('au', 'day_phone') %]
536 <!-- phones have a fall-through example strings -->
537 <span ng-if="!org_settings['ui.patron.edit.au.day_phone.example'] && org_settings['ui.patron.edit.phone.example']">
538 [% l('Example: [_1]',
539 "{{org_settings['ui.patron.edit.phone.example']}}") %]
544 <!-- EVENING_PHONE -->
546 <div class="row reg-field-row" ng-show="show_field('au.evening_phone')">
547 [% draw_field_label('au', 'evening_phone') %]
548 [% draw_form_input('au', 'evening_phone') %]
549 <div class="col-md-6 patron-reg-example">
550 <button ng-show="patron.evening_phone && !patron.isnew"
551 class="btn btn-default"
552 ng-click="invalidate_field('evening_phone')">[% l('Invalidate') %]</button>
553 [% draw_example_text('au', 'evening_phone') %]
554 <!-- phones have a fall-through example strings -->
555 <span ng-if="!org_settings['ui.patron.edit.au.evening_phone.example'] && org_settings['ui.patron.edit.phone.example']">
556 [% l('Example: [_1]',
557 "{{org_settings['ui.patron.edit.phone.example']}}") %]
564 <div class="row reg-field-row" ng-show="show_field('au.other_phone')">
565 [% draw_field_label('au', 'other_phone') %]
566 [% draw_form_input('au', 'other_phone') %]
567 <div class="col-md-6 patron-reg-example">
568 <button ng-show="patron.other_phone && !patron.isnew"
569 class="btn btn-default"
570 ng-click="invalidate_field('other_phone')">[% l('Invalidate') %]</button>
571 [% draw_example_text('au', 'other_phone') %]
572 <!-- phones have a fall-through example strings -->
573 <span ng-if="!org_settings['ui.patron.edit.au.other_phone.example'] && org_settings['ui.patron.edit.phone.example']">
574 [% l('Example: [_1]',
575 "{{org_settings['ui.patron.edit.phone.example']}}") %]
580 <!-- home org unit selector -->
582 <div class="row reg-field-row" ng-show="show_field('au.home_ou')">
583 [% draw_field_label('au', 'home_ou') %]
584 <div class="col-md-3 reg-field-input">
586 selected="patron.home_ou"
587 onchange="handle_home_org_changed"
588 org-aria="{{idl_fields.au.home_ou.name}}"
589 disable-test="disable_home_org">
594 <!-- profile selector -->
596 <div class="row reg-field-row" ng-show="show_field('au.profile')">
597 [% draw_field_label('au', 'profile') %]
598 <div class="col-md-3 reg-field-input">
599 <div class="btn-group" uib-dropdown>
600 <button type="button" class="btn btn-default" uib-dropdown-toggle
601 aria-labelledby="{{idl_fields.au.profile.name}}"
602 ng-class="{'ng-invalid' : invalid_profile()}">
603 <span style="padding-right: 5px;">
604 {{patron.profile.name() || "[% l('Profile Group') %]"}}
606 <span class="caret"></span>
608 <ul class="scrollable-menu" uib-dropdown-menu>
609 <li ng-repeat="entry in edit_profile_entries" ng-if="edit_profile_entries.length"
610 ng-class="{disabled : entry.grp().usergroup() == 'f'}">
612 style="padding-left: {{pgtde_depth(entry) * 10 + 5}}px"
613 ng-click="set_profile(entry.grp())">{{entry.grp().name()}}</a>
615 <li ng-repeat="grp in edit_profiles" ng-if="!edit_profile_entries.length"
616 ng-class="{disabled : grp.usergroup() == 'f'}">
618 style="padding-left: {{pgt_depth(grp) * 10 + 5}}px"
619 ng-click="set_profile(grp)">{{grp.name()}}</a>
624 <div class="col-md-3">
625 <button class="btn btn-default" ng-if="!offline" ng-disabled="!perms.CREATE_USER_GROUP_LINK"
626 ng-click="secondary_groups_dialog()">[% l('Secondary Groups') %]</button>
630 <div class="row reg-field-row" ng-show="show_field('au.expire_date')">
631 [% draw_field_label('au', 'expire_date') %]
632 <div class="col-md-3 reg-field-input">
634 date-aria="{{idl_fields.au.expire_date.name}}"
635 ng-model="patron.expire_date">
638 <div class="col-md-3">
639 <button class="btn btn-default" ng-click="set_expire_date()">
640 [% l('Update Expire Date') %]</button>
644 <!-- net_access_level -->
646 <div class="row reg-field-row" ng-show="show_field('au.net_access_level')">
647 [% draw_field_label('au', 'net_access_level') %]
648 <div class="col-md-3 reg-field-input">
651 aria-labelledby="{{idl_fields.au.net_access_level.name}}"
652 ng-model="patron.net_access_level"
653 ng-required="field_required('au', 'net_access_level')"
654 ng-blur="handle_field_changed(patron, 'net_access_level')"
655 ng-options="level.name() for level in net_access_levels track by level.id()">
662 <div class="row reg-field-row" ng-show="show_field('au.active')">
663 [% draw_field_label('au', 'active') %]
664 <div class="col-md-3 reg-field-input">
666 aria-labelledby="{{idl_fields.au.active.name}}"
667 ng-change="field_modified()"
668 ng-blur="handle_field_changed(patron, 'active')"
669 type='checkbox' ng-model="patron.active"/>
675 <div class="row reg-field-row" ng-show="show_field('au.barred')">
676 [% draw_field_label('au', 'barred') %]
677 <div class="col-md-3 reg-field-input">
679 aria-labelledby="{{idl_fields.au.barred.name}}"
680 ng-change="field_modified()"
681 ng-blur="handle_field_changed(patron, 'barred')"
682 type='checkbox' ng-model="patron.barred"/>
686 <!-- MASTER_ACCOUNT -->
688 <div class="row reg-field-row" ng-show="show_field('au.master_account')">
689 [% draw_field_label('au', 'master_account') %]
690 <div class="col-md-3 reg-field-input">
692 aria-labelledby="{{idl_fields.au.master_account.name}}"
693 ng-change="field_modified()"
694 ng-blur="handle_field_changed(patron, 'master_account')"
695 type='checkbox' ng-model="patron.master_account"/>
699 <!-- CLAIMS_RETURNED_COUNT -->
701 <div class="row reg-field-row" ng-show="show_field('au.claims_returned_count')">
702 [% draw_field_label('au', 'claims_returned_count') %]
703 [% draw_form_input('au', 'claims_returned_count',
704 '', 'number', '!perms.UPDATE_PATRON_CLAIM_RETURN_COUNT') %]
705 <div class="col-md-6 patron-reg-example">
706 [% draw_example_text('au', 'claims_returned_count') %]
710 <!-- CLAIMS_NEVER_CHECKED_OUT_COUNT -->
712 <div class="row reg-field-row" ng-show="show_field('au.claims_never_checked_out_count')">
713 [% draw_field_label('au', 'claims_never_checked_out_count') %]
714 [% draw_form_input('au', 'claims_never_checked_out_count',
715 '', 'number', '!perms.UPDATE_PATRON_CLAIM_NEVER_CHECKED_OUT_COUNT') %]
716 <div class="col-md-6 patron-reg-example">
717 [% draw_example_text('au', 'claims_never_checked_out_count') %]
721 <div ng-if="!offline">
723 <div class="alert alert-success row" role="alert">
724 <div class="col-md-6">[% l('User Settings') %]</div>
727 <div class="row reg-field-row">
728 <div class="col-md-3 reg-field-label">
729 <label id="defaultPhone">{{user_setting_types['opac.default_phone'].label()}}</label>
731 <div class="col-md-3 reg-field-input">
732 <input ng-required="hold_notify_type.phone"
733 aria-labelledby="defaultPhone"
734 ng-change="field_modified()"
735 ng-blur="handle_field_changed(user_settings, 'opac.default_phone')"
736 type='text' ng-model="user_settings['opac.default_phone']"/>
740 <div class="row reg-field-row">
741 <div class="col-md-3 reg-field-label">
742 <label id="defaultPickupLoc">
743 {{user_setting_types['opac.default_pickup_location'].label()}}
746 <div class="col-md-3 reg-field-input">
747 <eg-org-selector nodefault
748 org-aria="defaultPickupLoc"
749 disable-test="disable_pulib"
750 selected="patron._pickup_lib"
751 onchange="handle_pulib_changed">
754 <div class="col-md-3">
755 <button class="btn btn-default" ng-click="clear_pulib()" type="button"
756 ng-disabled="!patron._pickup_lib">
757 [% l('Clear Default Pickup Location') %]</button>
761 <div class="row reg-field-row"
762 ng-if="org_settings['circ.holds.behind_desk_pickup_supported']">
763 <div class="col-md-3 reg-field-label">
764 <label id="holdsBehindDesk">
765 {{user_setting_types['circ.holds_behind_desk'].label()}}
768 <div class="col-md-3 reg-field-input">
770 aria-labelledby="holdsBehindDesk"
771 ng-change="field_modified()"
772 type='checkbox' ng-model="user_settings['circ.holds_behind_desk']"/>
776 <div class="row reg-field-row"
777 ng-if="user_setting_types['circ.collections.exempt']">
778 <div class="col-md-3 reg-field-label">
780 {{user_setting_types['circ.collections.exempt'].label()}}
783 <div class="col-md-3 reg-field-input">
786 aria-labelledby="exempt"
787 ng-change="field_modified()"
788 ng-disabled="!perms.UPDATE_PATRON_COLLECTIONS_EXEMPT"
789 ng-model="user_settings['circ.collections.exempt']"/>
793 <div class="row reg-field-row">
794 <div class="col-md-3 reg-field-label">
795 <label id="holdsNotices">[% l('Holds Notices') %]</label>
797 <div class="col-md-4 reg-field-input flex-row">
798 <div class='flex-cell'>
800 aria-labelledby="holdsNotices holdsPhone"
801 ng-change="field_modified()"
802 type='checkbox' ng-model="hold_notify_type.phone"/>
803 <label id="holdsPhone">
807 <div class='flex-cell'>
809 aria-labelledby="holdsNotices holdsEmail"
810 ng-change="field_modified()"
811 type='checkbox' ng-model="hold_notify_type.email"/>
812 <label id="holdsEmail">
816 <div class='flex-cell' ng-if="org_settings['sms.enable']">
818 aria-labelledby="holdsNotices holdsSms"
819 ng-change="field_modified()"
820 type='checkbox' ng-model="hold_notify_type.sms"/>
821 <label id="holdsSms">
828 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
829 <div class="col-md-3 reg-field-label">
830 <label id="defaultSmsNum">[% l('Default SMS/Text Number') %]</label>
832 <div class="col-md-3 reg-field-input">
834 name="default_sms_text_number"
835 aria-labelledby="defaultSmsNum"
836 ng-required="hold_notify_type.sms"
837 ng-change="field_modified()" ng-model="user_settings['opac.default_sms_notify']"
838 ng-blur="handle_field_changed(user_settings, 'opac.default_sms_notify')"
841 <div class="col-md-3" ng-if="base_default_sms && !patron.isnew">
842 <button class="btn btn-default"
843 ng-disabled="reg_form['default_sms_text_number'].$dirty || reg_form['default_sms_text_carrier'].$dirty"
844 ng-click="send_test_sms()">[% l('Send Test Text') %]</button>
848 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
849 <div class="col-md-3 reg-field-label">
850 <label id="defaultSmsCarrier">
851 [% l('Default SMS Carrier') %]
854 <div class="col-md-3 reg-field-input">
855 <span class="nullable">
858 aria-labelledby="defaultSmsCarrier"
859 name="default_sms_text_carrier"
860 ng-model="user_settings['opac.default_sms_carrier']"
861 ng-required="user_settings['opac.default_sms_notify']"
862 ng-options="c.id() as c.name() + ' (' + c.region() + ')' for c in sms_carriers | orderBy:'name()'"
863 ng-blur="handle_field_changed(user_settings, 'opac.default_sms_carrier')">
864 <option value="">Select a Carrier</option>
870 <div class="row reg-field-row" ng-repeat="type in opt_in_setting_types">
871 <div class="col-md-3 reg-field-label" ng-if="type.name() != 'circ.send_email_checkout_receipts'">
872 <label id="settingTypes">{{type.label()}}</label>
874 <div class="col-md-3 reg-field-input" ng-if="type.name() != 'circ.send_email_checkout_receipts'">
876 aria-labelledby="settingTypes"
877 ng-change="field_modified()"
878 type='checkbox' ng-model="user_settings[type.name()]"/>
882 <div class="row reg-field-row" ng-if="org_settings['circ.privacy_waiver']">
883 <div class="col-md-3 reg-field-label">
884 <label id="privacyWaiver">[% l('Allow others to use my account') %]</label>
886 <div class="col-md-4 reg-field-input">
887 <div class="row" ng-repeat="waiver_entry in patron.waiver_entries" ng-hide="waiver_entry.isdeleted">
888 <div class="row flex-row">
889 <div class="flex-cell">
890 <label id="waiverName" ng-hide="true">
893 <input ng-change="field_modified()"
894 aria-labelledby="privacyWaiver waiverName"
895 type='text' ng-model="waiver_entry.name"/>
897 <div class="flex-cell">
898 <button type="button"
899 aria-label="[% l('Delete Person Allowed to Use My Account') %]"
900 ng-click="field_modified();delete_waiver_entry(waiver_entry)"
901 class="btn btn-danger">[% l('X') %]</button>
904 <div class="row flex-row reg-field-input">
905 <div class="flex-cell">
906 <label id="waiverPlace"><input ng-change="field_modified()"
907 aria-labelledby="privacyWaiver waiverPlace"
908 type='checkbox' ng-model="waiver_entry.place_holds"/>
909 [% l('Place Holds?') %]</label>
911 <div class="flex-cell">
912 <label id="waiverPickup"><input ng-change="field_modified()"
913 aria-labelledby="privacyWaiver waiverPickup"
914 type='checkbox' ng-model="waiver_entry.pickup_holds"/>
915 [% l('Pick Up Holds?') %]</label>
917 <div class="flex-cell">
918 <label id="waiverHistory"><input ng-change="field_modified()"
919 aria-labelledby="privacyWaiver waiverHistory"
920 type='checkbox' ng-model="waiver_entry.view_history"/>
921 [% l('View Borrowing History?') %]</label>
923 <div class="flex-cell">
924 <label id="waiverCheckOut"><input ng-change="field_modified()"
925 aria-labelledby="privacyWaiver waiverCheckOut"
926 type='checkbox' ng-model="waiver_entry.checkout_items"/>
927 [% l('Check Out Items?') %]</label>
929 </div> <!-- end checkboxes -->
930 </div> <!-- end ng-repeat waiver_entry -->
932 <div class="col-md-3 reg-field-input">
933 <button type="button"
934 ng-click="new_waiver_entry()"
935 class="btn btn-success">[% l('Add Person') %]</button>
938 </div> <!-- end waiver entries input -->
939 </div> <!-- end waiver entries row -->
941 </div> <!-- end offline test -->
945 <div ng-repeat="addr in patron.addresses">
946 <div class="alert alert-success row" role="alert">
947 <div class="col-md-3">
948 <label id="address{{addr.id}}">
951 <div ng-show="addr._linked_owner">
953 href="/eg/staff/circ/patron/{{addr._linked_owner_id}}/edit">
954 [% l('Owned by [_1]', '{{addr._linked_owner}}') %]
958 <div class="col-md-3">
959 <span class='pad-all-min'>
960 <label id="mailing{{addr.id}}">
963 <input type='checkbox'
964 aria-labelledby="address{{addr.id}} mailing{{addr.id}}"
965 ng-change="field_modified();set_addr_type(addr, 'mailing')"
966 ng-model="addr._is_mailing"/>
968 <span class='pad-all-min'>
969 <label id="physical{{addr.id}}">
972 <input type='checkbox'
973 aria-labelledby="address{{addr.id}} physical{{addr.id}}"
974 ng-change="field_modified();set_addr_type(addr, 'billing')"
975 ng-model="addr._is_billing"/>
977 <span class='pad-all-min'>
978 <button type="button"
979 aria-label="[% l('Delete this address') %]"
980 ng-click="field_modified();delete_address(addr.id)"
981 class="btn btn-danger">[% l('X') %]</button>
986 <div ng-if="addr.pending" class="row">
987 <div class="col-md-6 patron-reg-pending-address">
989 <div class="col-md-6">
990 [% l('This is a pending address') %]
992 <div class="col-md-6">
993 <button class="btn btn-success"
994 ng-click="approve_pending_address(addr)">[% l('Approve') %]</button>
997 <div class="row" ng-if="addr._replaces">
998 <div class="col-md-6">
1000 '{{addr._replaces.street1}}',
1001 '{{addr._replaces.street2}}',
1003 '{{addr._replaces.city}}',
1004 '{{addr._replaces.state}}',
1005 '{{addr._replaces.post_code}}') %]
1006 Replaces: [_1] [_2] [_3] [_4], [_5] [_6]
1011 <!-- make sure we occupy the entire row -->
1012 <div class="col-md-6"> </div>
1015 <!-- ADDRESS_TYPE -->
1016 <div class="row reg-field-row" ng-show="show_field('aua.address_type')">
1017 [% draw_field_label('aua', 'address_type') %]
1018 [% draw_form_input('aua',
1019 'address_type', 'addresses[$index]', '', 'addr._linked_owner') %]
1020 <div class="col-md-6 patron-reg-example">
1021 [% draw_example_text('aua', 'address_type') %]
1027 <div class="row reg-field-row" ng-show="show_field('aua.post_code')">
1028 [% draw_field_label('aua', 'post_code') %]
1029 [% draw_form_input('aua',
1030 'post_code', 'addresses[$index]', '', 'addr._linked_owner') %]
1031 <div class="col-md-6 patron-reg-example">
1032 [% draw_example_text('aua', 'post_code') %]
1038 <div class="row reg-field-row" ng-show="show_field('aua.street1')">
1039 [% draw_field_label('aua', 'street1') %]
1040 [% draw_form_input('aua',
1041 'street1', 'addresses[$index]', '', 'addr._linked_owner') %]
1042 <div class="col-md-6 patron-reg-example">
1043 [% draw_example_text('aua', 'street1') %]
1049 <div class="row reg-field-row" ng-show="show_field('aua.street2')">
1050 [% draw_field_label('aua', 'street2') %]
1051 [% draw_form_input('aua',
1052 'street2', 'addresses[$index]', '', 'addr._linked_owner') %]
1053 <div class="col-md-6 patron-reg-example">
1054 [% draw_example_text('aua', 'street2') %]
1060 <div class="row reg-field-row" ng-show="show_field('aua.city')">
1061 [% draw_field_label('aua', 'city') %]
1062 [% draw_form_input('aua',
1063 'city', 'addresses[$index]', '', 'addr._linked_owner') %]
1064 <div class="col-md-6 patron-reg-example">
1065 [% draw_example_text('aua', 'city') %]
1071 <div class="row reg-field-row" ng-show="show_field('aua.county')">
1072 [% draw_field_label('aua', 'county') %]
1073 [% draw_form_input('aua',
1074 'county', 'addresses[$index]', '', 'addr._linked_owner') %]
1075 <div class="col-md-6 patron-reg-example">
1076 [% draw_example_text('aua', 'county') %]
1082 <div class="row reg-field-row" ng-show="show_field('aua.state')">
1083 [% draw_field_label('aua', 'state') %]
1084 [% draw_form_input('aua',
1085 'state', 'addresses[$index]', '', 'addr._linked_owner') %]
1086 <div class="col-md-6 patron-reg-example">
1087 [% draw_example_text('aua', 'state') %]
1093 <div class="row reg-field-row" ng-show="show_field('aua.country')">
1094 [% draw_field_label('aua', 'country') %]
1095 [% draw_form_input('aua',
1096 'country', 'addresses[$index]', '', 'addr._linked_owner') %]
1097 <div class="col-md-6 patron-reg-example">
1098 [% draw_example_text('aua', 'country') %]
1104 <div class="row reg-field-row" ng-show="show_field('aua.valid')">
1105 [% draw_field_label('aua', 'valid') %]
1106 <div class="col-md-3 reg-field-input">
1108 aria-labelledby="{{idl_fields.aua.valid.name}}"
1110 ng-change="field_modified()"
1111 ng-disabled='addr._linked_owner'
1112 ng-blur="handle_field_changed(patron.addresses[$index], 'valid')"
1113 ng-model="patron.addresses[$index].valid"/>
1115 <div class="col-md-6 patron-reg-example">
1116 [% draw_example_text('aua', 'valid') %]
1120 <!-- WITHIN_CITY_LIMITS -->
1122 <div class="row reg-field-row" ng-show="show_field('aua.within_city_limits')">
1123 [% draw_field_label('aua', 'within_city_limits') %]
1124 <div class="col-md-3 reg-field-input">
1127 aria-labelledby="{{idl_fields.aua.within_city_limits.name}}"
1128 ng-change="field_modified()"
1129 ng-disabled='addr._linked_owner'
1130 ng-blur="handle_field_changed(patron.addresses[$index], 'within_city_limits')"
1131 ng-model="patron.addresses[$index].within_city_limits"/>
1133 <div class="col-md-6 patron-reg-example">
1134 [% draw_example_text('aua', 'within_city_limits') %]
1138 <!-- pending address -->
1140 </div> <!-- addresses -->
1143 <button type="button" ng-click="new_address()"
1144 class="btn btn-success">[% l('New Address') %]</button>
1147 <div ng-if="!offline">
1148 <div class="alert alert-success row" role="alert"
1149 ng-show="show_field('stat_cats') || hasRequiredStatCat" ng-if="stat_cats.length > 0">
1150 <div class="col-md-6">[% l('Statistical Categories') %]</div>
1153 <div class="row reg-field-row"
1154 ng-show="show_field('stat_cats') || hasRequiredStatCat" ng-repeat="cat in stat_cats">
1155 <!-- Display this stat cat when displaying all stat cats
1156 or when this stat cat is required. Wrap the body of
1157 stat cat display in a div for easy show/hide. -->
1158 <div ng-if="show_field('stat_cats') || cat.required() == 1">
1160 <div class="col-md-3 reg-field-label">
1161 <label id="statcat{{cat.id()}}">{{cat.name()}}</label>
1163 <div class="col-md-3 reg-field-input">
1164 <div ng-if="cat.entries().length != 0">
1165 <div class="btn-group" uib-dropdown>
1166 <button type="button" class="btn btn-default"
1167 aria-labelledby="statcat{{cat.id()}}"
1168 ng-class="{'ng-invalid': cat.required() == 1 && !stat_cat_entry_maps[cat.id()] }"
1169 uib-dropdown-toggle>
1170 <span style="padding-right: 5px;">
1171 {{stat_cat_entry_maps[cat.id()]}}</span>
1172 <span class="caret"></span>
1174 <ul uib-dropdown-menu>
1175 <li ng-repeat="entry in cat.entries()">
1177 ng-click="field_modified();stat_cat_entry_maps[cat.id()]=entry.value()">
1186 <!-- Stat cat retrieval API uses open-ils.storage under the covers
1187 which represents DB bools at 1/0 instead of cstore-style t/f -->
1188 <div class="col-md-3 reg-field-input"
1189 ng-show="show_field('stat_cats') || hasRequiredStatCat"
1190 ng-if="cat.allow_freetext() == '1'">
1192 aria-labelledby="statcat{{cat.id()}}"
1193 ng-model="stat_cat_entry_maps[cat.id()]"
1194 class="form-control" ng-required="cat.required() == 1"/>
1197 </div><!-- show/hide wrapper -->
1203 <div class="alert alert-success row" role="alert"
1204 ng-show="show_field('surveys')" ng-if="surveys.length > 0">
1205 <div class="col-md-6">[% l('Surveys') %]</div>
1208 <div class="row reg-field-row"
1209 ng-show="show_field('surveys')" ng-repeat="survey in surveys">
1210 <div class="col-md-3 reg-field-label">
1211 <label>{{survey.name()}}</label>
1213 <div class="col-md-6 reg-field-input">
1214 <div class="row" ng-repeat="question in survey.questions()"
1215 style="margin-bottom: 10px;">
1216 <div class="col-md-6">{{question.question()}}</div>
1217 <div class="col-md-6">
1218 <div class="btn-group" uib-dropdown>
1219 <button type="button" class="btn btn-default" uib-dropdown-toggle>
1220 <span style="padding-right: 5px;">
1221 {{survey_responses[question.id()].answer()}}
1223 <span class="caret"></span>
1225 <ul uib-dropdown-menu>
1226 <li ng-repeat="answer in question.answers()">
1228 ng-click="field_modified();survey_responses[question.id()] = answer">
1239 </div><!-- /form wrapper -->