]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/src/templates/staff/circ/patron/index.tt2
LP2045292 Color contrast for AngularJS patron bills
[Evergreen.git] / Open-ILS / src / templates / staff / circ / patron / index.tt2
1 [%
2   WRAPPER "staff/base.tt2";
3   ctx.page_title = l("Patron"); 
4   ctx.page_app = "egPatronApp";
5   ctx.page_ctrl = "PatronCtrl";
6 %]
7
8 [% BLOCK APP_JS %]
9 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/grid.js"></script>
10 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/ui.js"></script>
11 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/user.js"></script>
12 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/eframe.js"></script>
13 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/date.js"></script>
14 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/user-bucket.js"></script>
15 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/services/patrons.js"></script>
16 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/services/billing.js"></script>
17 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/services/circ.js"></script>
18 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/services/item.js"></script>
19 [% INCLUDE 'staff/circ/share/circ_strings.tt2' %]
20 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/services/holds.js"></script>
21 [% INCLUDE 'staff/circ/share/hold_strings.tt2' %]
22 <script src="[% ctx.media_prefix %]/js/ui/default/staff/cat/services/record.js"></script>
23 <script src="[% ctx.media_prefix %]/js/ui/default/staff/services/patron_search.js"></script>
24 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/patron/app.js"></script>
25 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/patron/regctl.js"></script>
26
27 <!-- load the rest on demand? -->
28
29 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/patron/checkout.js"></script>
30 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/patron/items_out.js"></script>
31 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/patron/holds.js"></script>
32 <script src="[% ctx.media_prefix %]/js/ui/default/staff/circ/patron/bills.js"></script>
33
34 <!-- TODO: APP_JS should really be called APP_ADDONS or some such.
35     It just means "load these things, too, and load them last" -->
36 <link rel="stylesheet" href="[% ctx.base_path %]/staff/css/circ.css" />
37
38 <script>
39 angular.module('egCoreMod').run(['egStrings', function(s) {
40   s.ANNOTATE_PAYMENT_MSG = "[% l('Please annotate this payment') %]";
41   s.CONFIRM_ADJUST_TO_ZERO = 
42     "[% |l('{{xactIds}}') -%]Are you sure you would like to adjust to zero the balance on bills [_1]?[% END %]";
43   s.CONFIRM_VOID_BILLINGS = 
44     "[% l('Are you sure you would like to void $[_1] for these line-item billings? [_2]','{{amount|number:2}}','{{billIds}}') %]";
45   s.CONFIRM_REFUND_PAYMENT = 
46     "[% |l('{{xactIds}}') -%]Are you sure you would like to refund excess payment on bills [_1]?  This action will simply put the amount in the Payment Pending column as a negative value.  You must still select Apply Payment!  Certain types of payments may not be refunded.  The refund may be applied to checked transactions that follow the refunded transaction.[% END %]";
47   s.EDIT_BILL_PAY_NOTE = "[% l('Enter new note for #[_1]:','{{ids}}') %]";
48   s.GROUP_ADD_USER = "[% l('Enter the patron barcode') %]";
49   s.RENEW_ITEMS = "[% l('Renew Items?') %]";
50   s.RENEW_ALL_ITEMS = "[% l('Renew All Items?') %]";
51   s.CHECK_IN_CONFIRM = "[% l('Check In Items?') %]";
52   s.REG_INVALID_FIELDS = 
53     "[% l('Please enter valid values for all required fields.') %]"
54   s.PAYMENT_WARN_AMOUNT = "[% l('Are you sure you want to apply a payment of $[_1]?', '{{payment_amount}}') %]";
55   s.PAYMENT_WARN_AMOUNT_TITLE = "[% l('Verify Payment Amount') %]";
56   s.PAYMENT_OVER_MAX = "[% l('Payments over $[_1] are denied by policy.', '{{max_amount}}') %]";
57   s.PATRON_NOTE_DELETE_CONFIRM_TITLE = "[% l('Delete Note?') %]";
58   s.PATRON_NOTE_DELETE_CONFIRM = "[% l('Delete the note titled \"[_1]\" created on [_2]?', '{{note_title}}', '{{create_date | date}}') %]";
59   s.PATRON_PURGE_CONFIRM_TITLE = "[% l('Completely Purge Patron Account?') %]";
60   s.PATRON_PURGE_CONFIRM = "[% l('Completely OBLITERATE this patron account, including bills, payments, bookbags, etc? This is IRREVERSIBLE.') %]";
61   s.PATRON_PURGE_LAST_CHANCE = "[% l('Last chance, are you sure you want to completely delete this account?') %]";
62   s.PATRON_PURGE_STAFF_PROMPT = "[% l('The account you are attempting to delete has STAFF_LOGIN privileges. Please enter the barcode for a destination account to receive miscellaneous staff artifacts (reports, etc.) from the account to be deleted.') %]";
63   s.PATRON_PURGE_STAFF_BAD_BARCODE = "[% l('Could not retrieve a destination account with the barcode provided. Aborting the purge...') %]";
64   s.PATRON_PURGE_OVERRIDE_PROMPT = "[% l('The account has open transactions (circulations and/or unpaid bills). Purge anyway?') %]";
65   s.PATRON_EDIT_COLLISION = "[% l('Patron record was modified by another user while you were editing it. Your changes were not saved; please reapply them.') %]";
66   s.OPT_IN_DIALOG_TITLE = "[% l('Verify Permission to Share Personal Information') %]";
67   s.OPT_IN_DIALOG = "[% l('Does patron [_1], [_2] from [_3] ([_4]) consent to having their personal information shared with your library?', '{{family_name}}', '{{first_given_name}}', '{{org_name}}', '{{org_shortname}}') %]";
68   s.BUCKET_ADD_SUCCESS = "[% l('Successfully added [_1] users to bucket [_2].', '{{count}}', '{{name}}') %]";
69   s.BUCKET_ADD_FAIL = "[% l('Failed to add [_1] users to bucket [_2].', '{{count}}', '{{name}}') %]";
70   s.PAGE_TITLE_PATRON_SEARCH = "[% l('Patron Search') %]";
71   s.PAGE_TITLE_PATRON_NAME = "[% l('[_1], [_2] [_3]', '{{lname}}','{{fname}}','{{mname}}') %]";
72   s.PAGE_TITLE_PATRON_CHECKOUT = "[% l('Checkout') %]";
73   s.PAGE_TITLE_PATRON_MESSAGES = "[% l('Messages') %]";
74   /* TODO: The "Other" page title could be smarter.. */
75   s.PAGE_TITLE_PATRON_OTHER = "[% l('Other') %]";
76   s.PAGE_TITLE_PATRON_BILLS = "[% l('Bills') %]";
77   s.PAGE_TITLE_PATRON_HOLDS = "[% l('Holds') %]";
78   s.PAGE_TITLE_PATRON_ITEMS_OUT = "[% l('Items Out') %]";
79   s.PAGE_TITLE_PATRON_EDIT = "[% l('Edit') %]";
80   s.MERGE_SELF_NOT_ALLOWED = "[% l('Logged in account cannot be merged') %]";
81   s.TEST_NOTIFY_SUCCESS = "[% l('Test Notification sent') %]";
82   s.TEST_NOTIFY_FAIL = "[% l('Test Notification failed to send') %]"
83 }]);
84 </script>
85
86 <!-- add room for the fixed navigation elements -->
87 <style ng-if="is_patron_edit">
88   #top-content-container { padding-top: 120px; }
89 </style>
90 <style ng-if="!is_patron_edit">
91   #top-content-container { padding-top: 80px; }
92 </style>
93
94 [% END %]
95
96 <div class="row" id="patron-fixed-tabs">
97   <div class="col-md-3 patron-name-header">
98     <div ng-show="patron()">
99       <h4 title="{{patron().id()}}">
100         <div class="flex-row">
101           <div class="flex-cell"
102           ng-class="{'patron-summary-alert' : hasAlerts()}">
103             [% l('[_1] [_2], [_3] [_4] [_5]', 
104                 '{{patron().prefix()}}',
105                 '{{patron().family_name()}}',
106                 '{{patron().first_given_name()}}',
107                 '{{patron().second_given_name()}}',
108                 '{{patron().suffix()}}') %]
109                <span ng-if="patron().name_keywords()"> <a title="[% l('Name keywords: ') %]{{patron().name_keywords()}}" class="glyphicon glyphicon-tags"></a>
110           </div>
111
112           <p ng-show="patron().notes().length > 0"><a class='patron-summary-has-notes' href="./circ/patron/{{patron().id()}}/notes"><span class="label label-warning">Notes &nbsp;{{patron().notes().length}}</span></a></p>
113           <div ng-show="tab != 'search'">
114             <a href ng-click="toggle_expand_summary()"
115               title="[% l('Collapse Patron Summary Display') %]"
116               ng-hide="collapse_summary()">
117               <span class="glyphicon glyphicon-resize-small"></span>
118             </a>
119             <a href ng-click="toggle_expand_summary()"
120               title="[% l('Expand Patron Summary Display') %]"
121               ng-show="collapse_summary()">
122               <span class="glyphicon glyphicon-resize-full"></span>
123             </a>
124           </div>
125         </div>
126       </h4>
127     </div>
128   </div>
129
130   <div class="col-md-9">
131     <ul class="nav nav-pills nav-pills-like-tabs">
132       <li ng-class="{active : tab == 'checkout', disabled : !patron()}">
133         <a a-disabled="!patron()" href="./circ/patron/{{patron().id()}}/checkout">[% l('Check Out') %]</a>
134       </li>
135       <li ng-class="{active : tab == 'items_out', disabled : !patron()}">
136         <a a-disabled="!patron()" href="./circ/patron/{{patron().id()}}/items_out">
137           [% l('Items Out') %] 
138           <span ng-if="patron()"><!-- lack of space / newline below intentional -->
139           (<span ng-class="{'patron-summary-alert-small' : patron_stats().checkouts.overdue}">{{patron_stats().checkouts.total_out}}</span>)
140           </span>
141         </a>
142       </li>
143       <li ng-class="{active : tab == 'holds', disabled : !patron()}">
144         <a a-disabled="!patron()" href="./circ/patron/{{patron().id()}}/holds">
145           [% l('Holds') %]
146           <span ng-if="patron()">
147             (<span>{{patron_stats().holds.ready}} / {{patron_stats().holds.total}}</span>)
148           </span>
149         </a>
150       </li>
151       <li ng-class="{active : tab == 'bills', disabled : !patron()}">
152         <a a-disabled="!patron()" href="./circ/patron/{{patron().id()}}/bills">
153           [% l('Bills') %]
154           <span ng-if="patron()">
155             (<span ng-class="{'patron-summary-alert-small' : patron_stats().fines.balance_owed}">{{patron_stats().fines.balance_owed | currency}}</span>)
156           </span>
157         </a>
158       </li>
159       <li ng-class="{active : tab == 'messages', disabled : !patron()}">
160         <a a-disabled="!patron()" href="./circ/patron/{{patron().id()}}/messages">[% l('Messages') %]</a>
161       </li>
162       <li ng-class="{active : tab == 'edit', disabled : !patron()}">
163         <a href="./circ/patron/{{patron().id()}}/edit">[% l('Edit') %]</a>
164       </li>
165       <li uib-dropdown ng-class="{active : tab == 'other', disabled : !patron()}">
166         <a a-disabled="!patron()" href uib-dropdown-toggle>
167             [% l('Other') %]
168             <b class="caret"></b>
169         </a>
170         <ul uib-dropdown-menu>
171           <li>
172             <a href="./circ/patron/{{patron().id()}}/alerts">
173               [% l('Display Alert and Messages') %]
174             </a>
175           </li>
176           <li>
177             <a href="./circ/patron/{{patron().id()}}/notes">
178               [% l('Notes') %]
179             </a>
180           </li>
181           <li>
182             <a href="./circ/patron/{{patron().id()}}/triggered_events">
183               [% l('Triggered Events / Notifications') %]
184             </a>
185           </li>
186           <li>
187             <a href="./circ/patron/{{patron().id()}}/message_center">
188               [% l('Message Center') %]
189             </a>
190           </li>
191           <li>
192             <a href="./circ/patron/{{patron().id()}}/stat_cats">
193               [% l('Statistical Categories') %]
194             </a>
195           </li>
196           <li>
197             <a href="./circ/patron/{{patron().id()}}/surveys">
198               [% l('Surveys') %]
199             </a>
200           </li>
201           <li>
202             <a href="./circ/patron/{{patron().id()}}/group">
203               [% l('Group Member Details') %]
204             </a>
205           </li>
206           <li>
207             <a href="./circ/patron/{{patron().id()}}/edit_perms">
208               [% l('User Permission Editor') %]
209             </a>
210           </li>
211           <li>
212             <a href="./circ/patron/{{patron().id()}}/credentials">
213               [% l('Test Password') %]
214             </a>
215           </li>
216           <li>
217             <a href="./acq/requests/user/{{patron().id()}}" target="_top">
218               [% l('Acquisition Patron Requests') %]
219             </a>
220           </li>
221           <li>
222             <a href="/eg2/staff/booking/manage_reservations/by_patron/{{patron().id()}}" target="_top">
223               [% l('Booking: Manage Reservations') %]
224             </a>
225           </li>
226           <li>
227             <a href="/eg2/staff/booking/create_reservation/for_patron/{{patron().id()}}" target="_top">
228               [% l('Booking: Create Reservation') %]
229             </a>
230           </li>
231           <li>
232             <a href="/eg2/staff/booking/pickup/by_patron/{{patron().id()}}" target="_top">
233               [% l('Booking: Pick Up Reservations') %]
234             </a>
235           </li>
236           <li>
237             <a href="/eg2/staff/booking/return/by_patron/{{patron().id()}}" target="_top">
238               [% l('Booking: Return Reservations') %]
239             </a>
240           </li>
241           <li>
242             <a href ng-click="purge_account()" a-disabled="patron().super_user() == 't' || patron().id() == auth_user_id">
243               [% l('Completely Purge Account') %]
244             </a>
245           </li>
246        </ul>
247       </li>
248       <li ng-class="{active : tab == 'search'}" class="pull-right">
249         <a href="./circ/patron/search">[% l('Patron Search') %]</a>
250       </li>
251     </ul>
252     <div class="flex-row patron-reg-actions-bar" ng-if="is_patron_edit()">
253       [% INCLUDE 'staff/circ/patron/reg_actions.tt2' %]
254     </div>
255
256   </div><!-- col -->
257 </div><!-- row -->
258
259 <div class="row">
260   <div class="col-md-3" ng-hide="collapse_summary()">
261     [% INCLUDE 'staff/circ/patron/t_summary.tt2' %]
262   </div>
263   <div ng-class="{'col-md-12' : collapse_summary(),'col-md-9' : !collapse_summary()}">
264     <div class="tab-content">
265       <div class="tab-pane active">
266         <div ng-view></div>
267       </div>
268     </div>
269   </div><!-- col -->
270 </div><!-- row -->
271
272 [% END %]