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