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