1 [% DOC_IMG = '/images/question-mark.png' %]
3 <!-- register banner -->
4 <div ng-if="!patron_id" class='patron-reg-fixed-bar'>
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>
23 <div id="reg-alert-pane">
25 <div id="reg-dupe-links">
26 [%# dupe_search_encoded is uri escaped in the JS %]
27 <div class="alert alert-danger" ng-show="dupe_counts.name">
29 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
30 [% l('[_1] patron(s) with same name', '{{dupe_counts.name}}') %]
33 <div class="alert alert-danger" ng-show="dupe_counts.email">
35 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
36 [% l('[_1] patron(s) with same email',
37 '{{dupe_counts.email}}') %]</a>
39 <div class="alert alert-danger" ng-show="dupe_counts.ident">
41 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
42 [% l('[_1] patron(s) with same identification',
43 '{{dupe_counts.ident}}') %]</a>
45 <div class="alert alert-danger" ng-show="dupe_counts.phone">
47 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}">
48 [% l('[_1] patron(s) with same phone',
49 '{{dupe_counts.phone}}') %]</a>
51 <div class="alert alert-danger" ng-show="dupe_counts.address">
53 href="/eg/staff/circ/patron/search?search={{dupe_search_encoded}}" >
54 [% l('[_1] patron(s) with same address',
55 '{{dupe_counts.address}}') %]</a>
59 <!-- IDL field documentation window -->
60 <div class="alert alert-info" ng-show="selected_field_doc">
61 <fieldset id="reg-field-doc">
63 {{idl_fields[selected_field_doc.fm_class()][selected_field_doc.field()].label}}
65 <div>{{selected_field_doc.string()}}</div>
69 <div class="alert alert-info" ng-show="stage_user_requestor">
71 href="/eg/staff/circ/patron/{{stage_user.reqesting_usr()}}/edit">
72 [% l('Requested by [_1]', '{{stage_user_requestor}}') %]
78 [% MACRO formfield(cls, field, path, input_type) BLOCK;
80 # input field generator for common text/number/checkbox fields
82 IF NOT input_type; input_type = 'text'; END %]
84 <div class="row reg-field-row"
85 ng-show="show_field('[% cls _ '.' _ field %]')">
87 <div class="col-md-3 reg-field-label"> <!-- field label -->
89 <label>{{idl_fields.[% cls %].[% field %].label}}</label>
91 <!-- field documentation img/link -->
92 <img ng-show="field_doc.[% cls %].[% field %]"
93 ng-click="set_selected_field_doc('[% cls %]','[% field %]')"
94 src='[% DOC_IMG %]'></img>
97 <div class="col-md-3 reg-field-input"> <!-- field form input -->
99 [% model = path ? 'patron.' _ path _ '.' _ field : 'patron.' _ field %]
101 [% IF input_type == 'checkbox' %]
103 <div class='checkbox'>
104 <input type='checkbox' ng-model='[% model %]'/>
108 <!-- text / number input -->
110 [% IF field == 'alert_message' %]
111 <textarea ng-change="field_modified()"
112 class="form-control" ng-model="[% model %]"/>
113 [% ELSIF field == 'post_code' %]
114 <input type="text" ng-change="field_modified()"
115 ng-blur="post_code_changed(patron.[% path %])"
116 class="form-control" ng-model="[% model %]"/>
117 [% ELSIF field == 'barcode' %]
120 ng-change="field_modified()"
121 ng-disabled="disable_bc"
122 ng-blur="barcode_changed(patron.card.barcode)"
123 class="form-control" ng-model="[% model %]"/>
124 [% ELSIF field == 'usrname' %]
126 focus-me="focus_usrname"
127 ng-change="field_modified()"
128 ng-blur="usrname_changed(patron.usrname)"
129 class="form-control" ng-model="[% model %]"/>
130 [% ELSIF field == 'day_phone' %]
132 ng-blur="day_phone_changed(patron.day_phone)"
133 ng-change="field_modified()"
134 class="form-control" ng-model="[% model %]"/>
135 [% ELSIF field.match('phone') %]
137 ng-change="field_modified()"
138 ng-blur="dupe_value_changed('phone', patron.[% field %])"
139 class="form-control" ng-model="[% model %]"/>
140 [% ELSIF field.match('ident_value') %]
142 ng-change="field_modified()"
143 ng-blur="dupe_value_changed('ident', patron.[% field %])"
144 class="form-control" ng-model="[% model %]"/>
145 [% ELSIF field == 'first_given_name' OR field == 'family_name' %]
147 ng-change="field_modified()"
148 ng-blur="dupe_value_changed('name', patron.[% field %])"
149 class="form-control" ng-model="[% model %]"/>
150 [% ELSIF field == 'email' %]
151 <input type="[% input_type %]"
152 ng-change="field_modified()"
153 ng-blur="dupe_value_changed('email', patron.email)"
154 class="form-control" ng-model="[% model %]"/>
155 [% ELSIF field.match('street') OR field == 'city' %]
156 <!-- note: passing address object to dupe_value_changed -->
157 <input type="[% input_type %]"
158 ng-change="field_modified()"
159 ng-blur="dupe_value_changed('address', patron.[% path %])"
160 class="form-control" ng-model="[% model %]"/>
162 <input type="[% input_type %]"
163 ng-change="field_modified()"
164 class="form-control" ng-model="[% model %]"/>
170 <!-- supplemental actions and example text -->
171 <div class="col-md-6 patron-reg-example">
173 [% IF field == 'barcode' %]
175 <button class="btn btn-default" ng-show="!patron.isnew"
176 ng-click="replace_card()">[% l('Replace Barcode') %]</button>
177 <button class="btn btn-default"
178 ng-click="cards_dialog()">[% l('See All') %]</button>
180 [% ELSIF field == 'passwd' %]
182 <button class="btn btn-default" ng-click="generate_password()">
183 [% l('Generate Password') %]</button>
187 <!-- invalidate buttons -->
189 [% IF field.match('phone') OR field.match('email') %]
190 <button ng-show="patron.[% field %] && !patron.isnew"
191 class="btn btn-default"
192 ng-click="invalidate_field('[% field %]')">
193 [% l('Invalidate') %]
197 <!-- example strings -->
199 [% set_str = "org_settings['ui.patron.edit." _
200 cls _ "." _ field _ ".example']"; %]
202 <span ng-if="[% set_str %]">
203 [% l('Example: [_1]', "{{" _ set_str _ "}}") %]
206 <!-- phones have a fall-through example strings -->
207 [% IF field.match('phone') %]
208 <span ng-if="![% set_str %] && org_settings['ui.patron.edit.phone.example']">
209 [% l('Example: [_1]',
210 "{{org_settings['ui.patron.edit.phone.example']}}") %]
218 <!-- progress dialog displayed as we await all data to finish loading -->
219 <div class="row" ng-show="!page_data_loaded">
220 <div class="col-md-6 pad-vert">
221 <div class="progress progress-striped active">
222 <div class="progress-bar" role="progressbar" aria-valuenow="100"
223 aria-valuemin="0" aria-valuemax="100" style="width: 100%">
224 <span class="sr-only">[% l('Loading...') %]</span>
230 <!-- this div wraps the entire form so we can hide it
231 until all needed data has been loaded -->
232 <div ng-show="page_data_loaded"><!-- form wrapper -->
234 [% formfield('ac', 'barcode', 'card') %]
235 [% formfield('au', 'usrname') %]
236 [% formfield('au', 'passwd') %]
237 [% formfield('au', 'prefix') %]
238 [% formfield('au', 'first_given_name') %]
239 [% formfield('au', 'second_given_name') %]
240 [% formfield('au', 'family_name') %]
241 [% formfield('au', 'suffix') %]
242 [% formfield('au', 'alias') %]
244 <div class="row reg-field-row" ng-show="show_field('au.dob')">
245 <div class="col-md-3 reg-field-label">
246 <label>{{idl_fields.au.dob.label}}</label>
247 <img ng-show="field_doc.au.dob"
248 ng-click="selected_field_doc=field_doc.au.dob"
249 src='[% DOC_IMG %]'></img>
251 <div class="col-md-3 reg-field-input">
253 ng-change="field_modified()"
254 class="form-control" ng-model="patron.dob"/>
258 [% formfield('au', 'juvenile', '', 'checkbox') %]
262 <div class="row reg-field-row" ng-show="show_field('au.ident_type')">
263 <div class="col-md-3 reg-field-label">
264 <label>{{idl_fields.au.ident_type.label}}</label>
265 <img ng-show="field_doc.au.ident_type"
266 ng-click="selected_field_doc=field_doc.au.ident_type"
267 src='[% DOC_IMG %]'></img>
269 <div class="col-md-3 reg-field-input">
270 <div class="btn-group" dropdown>
271 <button type="button" class="btn btn-default dropdown-toggle">
272 <span style="padding-right: 5px;">
273 {{patron.ident_type.name() || "[% l('Primary Ident Type') %]"}}
275 <span class="caret"></span>
277 <ul class="dropdown-menu">
278 <li ng-repeat="type in ident_types">
279 <a href ng-click="patron.ident_type = type; field_modified()">
289 [% formfield('au', 'ident_value') %]
290 [% formfield('au', 'ident_value2') %]
291 [% formfield('au', 'email', '', 'email') %]
292 [% formfield('au', 'day_phone') %]
293 [% formfield('au', 'evening_phone') %]
294 [% formfield('au', 'other_phone') %]
296 <!-- home org unit selector -->
298 <div class="row reg-field-row" ng-show="show_field('au.home_ou')">
299 <div class="col-md-3 reg-field-label">
300 <label>{{idl_fields.au.home_ou.label}}</label>
301 <img ng-show="field_doc.au.home_ou"
302 ng-click="selected_field_doc=field_doc.au.home_ou"
303 src='[% DOC_IMG %]'></img>
305 <div class="col-md-3 reg-field-input">
306 <eg-org-selector selected="patron.home_ou" onchange="field_modified">
311 <!-- profile selector -->
313 <div class="row reg-field-row" ng-show="show_field('au.profile')">
314 <div class="col-md-3 reg-field-label">
315 <label>{{idl_fields.au.profile.label}}</label>
316 <img ng-show="field_doc.au.profile"
317 ng-click="selected_field_doc=field_doc.au.profile"
318 src='[% DOC_IMG %]'></img>
320 <div class="col-md-3 reg-field-input">
321 <div class="btn-group" dropdown>
322 <button type="button" class="btn btn-default dropdown-toggle">
323 <span style="padding-right: 5px;">
324 {{patron.profile.name() || "[% l('Profile Group') %]"}}
326 <span class="caret"></span>
328 <ul class="dropdown-menu">
329 <li ng-repeat="grp in edit_profiles">
331 style="padding-left: {{pgt_depth(grp) * 10 + 5}}px"
332 ng-click="set_profile(grp)">{{grp.name()}}</a>
337 <div class="col-md-3">
338 <button class="btn btn-default" ng-disabled="!has_group_link_perm"
339 ng-click="secondary_groups_dialog()">[% l('Secondary Groups') %]</button>
343 <div class="row reg-field-row" ng-show="show_field('au.expire_date')">
344 <div class="col-md-3 reg-field-label">
345 <label>{{idl_fields.au.expire_date.label}}</label>
346 <img ng-show="field_doc.au.expire_date"
347 ng-click="selected_field_doc=field_doc.au.expire_date"
348 src='[% DOC_IMG %]'></img>
350 <div class="col-md-3 reg-field-input">
352 ng-change="field_modified()"
353 class="form-control" ng-model="patron.expire_date"/>
355 <div class="col-md-3">
356 <button class="btn btn-default" ng-click="set_expire_date()">
357 [% l('Update Expire Date') %]</button>
361 <!-- net_access_level -->
363 <div class="row reg-field-row" ng-show="show_field('au.net_access_level')">
364 <div class="col-md-3 reg-field-label">
365 <label>{{idl_fields.au.net_access_level.label}}</label>
366 <img ng-show="field_doc.au.net_access_level"
367 ng-click="selected_field_doc=field_doc.au.net_access_level"
368 src='[% DOC_IMG %]'></img>
370 <div class="col-md-3 reg-field-input">
371 <div class="btn-group" dropdown>
372 <button type="button" class="btn btn-default dropdown-toggle">
373 <span style="padding-right: 5px;">
374 {{patron.net_access_level.name() || "[% l('Net Access Level') %]"}}
376 <span class="caret"></span>
378 <ul class="dropdown-menu">
379 <li ng-repeat="level in net_access_levels">
381 ng-click="patron.net_access_level = level">{{level.name()}}</a>
388 [% formfield('au', 'active', '', 'checkbox') %]
389 [% formfield('au', 'barred', '', 'checkbox') %]
390 [% formfield('au', 'master_account', '', 'checkbox') %]
391 [% formfield('au', 'claims_returned_count', '', 'number') %]
392 [% formfield('au', 'claims_never_checked_out_count', '', 'number') %]
393 [% formfield('au', 'alert_message') %]
395 <div class="alert alert-success row" role="alert">
396 <div class="col-md-6">[% l('User Settings') %]</div>
399 <div class="row reg-field-row">
400 <div class="col-md-3 reg-field-label">
401 <label>{{user_setting_types['opac.default_phone'].label()}}</label>
403 <div class="col-md-3 reg-field-input">
405 ng-change="field_modified()"
406 type='text' ng-model="user_settings['opac.default_phone']"/>
410 <div class="row reg-field-row">
411 <div class="col-md-3 reg-field-label">
412 <label>{{user_setting_types['opac.default_pickup_location'].label()}}</label>
414 <div class="col-md-3 reg-field-input">
416 xonchange="field_modified"
417 selected="patron.home_ou"></eg-org-selector>
421 <div class="row reg-field-row">
422 <div class="col-md-3 reg-field-label">
423 <label>{{user_setting_types['circ.holds_behind_desk'].label()}}</label>
425 <div class="col-md-3 reg-field-input">
426 <div class='checkbox'>
428 ng-change="field_modified()"
429 type='checkbox' ng-model="user_settings['circ.holds_behind_desk']"/>
434 <div class="row reg-field-row">
435 <div class="col-md-3 reg-field-label">
436 <label>[% l('Holds Notices') %]</label>
438 <div class="col-md-3 reg-field-input flex-row">
439 <div class='flex-cell'>
441 ng-change="field_modified()"
442 type='checkbox' ng-model="hold_notify_phone"/>
445 <div class='flex-cell'>
447 ng-change="field_modified()"
448 type='checkbox' ng-model="hold_notify_email"/>
451 <div class='flex-cell' ng-if="org_settings['sms.enable']">
453 ng-change="field_modified()"
454 type='checkbox' ng-model="hold_notify_sms"/>
460 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
461 <div class="col-md-3 reg-field-label">
462 <label>[% l('Default SMS/Text Number') %]</label>
464 <div class="col-md-3 reg-field-input">
466 ng-change="field_modified()"
471 <div class="row reg-field-row" ng-if="org_settings['sms.enable']">
472 <div class="col-md-3 reg-field-label">
473 <label>[% l('Default SMS Carrier') %]</label>
475 <div class="col-md-3 reg-field-input">
476 <div class="btn-group" dropdown>
477 <button type="button" class="btn btn-default dropdown-toggle">
478 <span style="padding-right: 5px;"></span>
479 <span class="caret"></span>
481 <ul class="dropdown-menu">
482 <li ng-repeat="carrier in sms_carriers">
484 ng-click="field_modified();user_settings['opac.default_sms_carrier'] = carrier">
493 <div class="row reg-field-row" ng-repeat="type in opt_in_setting_types">
494 <div class="col-md-3 reg-field-label">
495 <label>{{type.label()}}</label>
497 <div class="col-md-3 reg-field-input">
499 ng-change="field_modified()"
500 type='checkbox' ng-model="user_settings[type.name()]"/>
506 <div ng-repeat="addr in patron.addresses">
507 <div class="alert alert-success row" role="alert">
508 <div class="col-md-3">
510 <div ng-show="addr._linked_owner">
512 href="/eg/staff/circ/patron/{{addr._linked_owner_id}}/edit">
513 [% l('Owned by [_1]', '{{addr._linked_owner}}') %]
517 <div class="col-md-3">
518 <span class='pad-all-min'>
519 [% l('Mailing') %] <input type='checkbox'
520 ng-change="field_modified();set_addr_type(addr, 'mailing')"
521 ng-model="addr._is_mailing"/>
523 <span class='pad-all-min'>
524 [% l('Physical') %] <input type='checkbox'
525 ng-change="field_modified();set_addr_type(addr, 'billing')"
526 ng-model="addr._is_billing"/>
528 <span class='pad-all-min'>
529 <button type="button"
530 ng-click="field_modified();delete_address(addr.id)"
531 class="btn btn-danger">[% l('X') %]</button>
536 [% formfield('aua', 'address_type', 'addresses[$index]') %]
537 [% formfield('aua', 'post_code', 'addresses[$index]') %]
538 [% formfield('aua', 'street1', 'addresses[$index]') %]
539 [% formfield('aua', 'street2', 'addresses[$index]') %]
540 [% formfield('aua', 'city', 'addresses[$index]') %]
541 [% formfield('aua', 'county', 'addresses[$index]') %]
542 [% formfield('aua', 'state', 'addresses[$index]') %]
543 [% formfield('aua', 'country', 'addresses[$index]') %]
544 [% formfield('aua', 'valid', 'addresses[$index]', 'checkbox') %]
545 [% formfield('aua', 'within_city_limits', 'addresses[$index]', 'checkbox') %]
547 <div class="row" ng-if="$last">
548 <button type="button" ng-click="new_address()"
549 class="btn btn-success">[% l('New Address') %]</button>
552 <!-- pending address -->
554 </div> <!-- addresses -->
556 <div class="alert alert-success row" role="alert"
557 ng-show="show_field('stat_cats')" ng-if="stat_cats.length > 0">
558 <div class="col-md-6">[% l('Statistical Categories') %]</div>
561 <div class="row reg-field-row"
562 ng-show="show_field('stat_cats')" ng-repeat="cat in stat_cats">
563 <div class="col-md-3 reg-field-label">
564 <label>{{cat.name()}}</label>
566 <div class="col-md-3 reg-field-input">
568 <!-- Editable typeahead is not support in this version of
569 angularjs-bootstrap. Requires Angular 1.4 and
570 angularjs-bootstrap version 1.1+ -->
572 <!-- typeahead is wonky. Consider updating -->
574 <input type="text" ng-model="stat_cat_entry_maps[cat.id()]"
575 typeahead="value as entry.value() for entry in cat.entries() | filter:$viewValue | limitTo:8"
576 class="form-control">
579 <div ng-if="cat.entries().length != 0">
580 <div class="btn-group" dropdown>
581 <button type="button" class="btn btn-default dropdown-toggle">
582 <span style="padding-right: 5px;">
583 {{stat_cat_entry_maps[cat.id()]}}</span>
584 <span class="caret"></span>
586 <ul class="dropdown-menu">
587 <li ng-repeat="entry in cat.entries()">
589 ng-click="field_modified();stat_cat_entry_maps[cat.id()]=entry.value()">
598 <!-- Stat cat retrieval API uses open-ils.storage under the covers
599 which represents DB bools at 1/0 instead of cstore-style t/f -->
600 <div class="col-md-3 reg-field-input" ng-if="cat.allow_freetext() == '1'">
601 <input type="text" ng-model="stat_cat_entry_maps[cat.id()]"/>
607 <div class="alert alert-success row" role="alert"
608 ng-show="show_field('surveys')" ng-if="surveys.length > 0">
609 <div class="col-md-6">[% l('Surveys') %]</div>
612 <div class="row reg-field-row"
613 ng-show="show_field('surveys')" ng-repeat="survey in surveys">
614 <div class="col-md-3 reg-field-label">
615 <label>{{survey.name()}}</label>
617 <div class="col-md-6 reg-field-input">
618 <div class="row" ng-repeat="question in survey.questions()"
619 style="margin-bottom: 10px;">
620 <div class="col-md-6">{{question.question()}}</div>
621 <div class="col-md-6">
622 <div class="btn-group" dropdown>
623 <button type="button" class="btn btn-default dropdown-toggle">
624 <span style="padding-right: 5px;">
625 {{survey_responses[question.id()].answer()}}
627 <span class="caret"></span>
629 <ul class="dropdown-menu">
630 <li ng-repeat="answer in question.answers()">
632 ng-click="field_modified();survey_responses[question.id()] = answer">
643 </div><!-- /form wrapper -->