4 [% USE TablesSettings %]
8 [% PROCESS 'patronfields.inc' %]
9 [% SET libraries = Branches.all %]
10 [% SET categories = Categories.all.unblessed %]
11 [% SET columns = ['cardnumber', 'name-address', 'dateofbirth', 'branch', 'category', 'dateexpiry', 'checkouts', 'account_balance', 'borrowernotes', 'action'] %]
12 [% PROCESS 'patron-search.inc' %]
13 [% INCLUDE 'doc-head-open.inc' %]
14 <title>Patrons[% IF ( searching ) %] › Search results[% END %] › Koha</title>
15 [% INCLUDE 'doc-head-close.inc' %]
18 <body id="pat_member" class="pat">
19 [% INCLUDE 'header.inc' %]
20 [% INCLUDE 'patron-search-header.inc' %]
22 <nav id="breadcrumbs" aria-label="Breadcrumb" class="breadcrumb">
25 <a href="/cgi-bin/koha/mainpage.pl">Home</a>
27 [% IF ( searching ) %]
29 <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
32 <a href="#" aria-current="page">
38 <a href="#" aria-current="page">
46 <div class="main container-fluid">
48 <div class="col-sm-10 col-sm-push-2">
51 [% IF CAN_user_tools_manage_patron_lists %]
52 <div id="patron_list_dialog" class="dialog message">
53 Added <span class="patrons-length"></span> patrons to <a></a>.
57 [% INCLUDE 'patron-toolbar.inc' %]
58 [% INCLUDE 'noadd-warnings.inc' %]
60 [% IF CAN_user_borrowers_edit_borrowers && pending_borrower_modifications %]
61 <div class="pending-info" id="patron_updates_pending">
62 <a href="/cgi-bin/koha/members/members-update.pl">Patrons requesting modifications</a>:
63 <span class="number_box"><a href="/cgi-bin/koha/members/members-update.pl">[% pending_borrower_modifications | html %]</a></span>
67 <div id="searchresults">
68 [% IF CAN_user_tools_manage_patron_lists || CAN_user_borrowers_edit_borrowers %]
69 <div class="searchheader fh-fixedHeader" id="searchheader" style="display:none;">
71 <a href="#" class="btn btn-link" id="select_all"><i class="fa fa-check"></i> Select all</a>
73 <a href="#" class="btn btn-link" id="clear_all"><i class="fa fa-remove"></i> Clear all</a>
74 [% IF CAN_user_tools_manage_patron_lists %]
78 [% IF CAN_user_tools_manage_patron_lists %]
79 <div id="patronlist-dropdown" class="btn-group">
80 <button id="patronlist-menu" type="button" class="btn btn-sm btn-default dropdown-toggle patron-edits disabled" disabled="disabled" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
81 Add to patron list <span class="caret"></span>
83 <ul class="dropdown-menu">
85 [% FOREACH pl IN patron_lists %]
86 <li><a href="#" class="patron-list-add" data-listid="[% pl.patron_list_id | html %]">[% pl.name | html %]</a></li>
89 <li role="separator" class="divider"></li>
90 <li><a href="#" class="patron-list-add" data-listid="new">New list</a></li>
95 [% IF CAN_user_borrowers_edit_borrowers %]
96 <button id="merge-patrons" class="btn btn-sm btn-default disabled" disabled="disabled" type="submit"><i class="fa fa-compress" aria-hidden="true"></i> Merge selected patrons</button>
98 <div id="patron_search_selected" class="btn-group" style="display:none;">
100 <a href="#" id="clear-patron-selection"><i class="fa fa-remove"></i> Clear</a>
106 [% IF CAN_user_borrowers_edit_borrowers || CAN_user_tools_manage_patron_lists %]
107 [% columns.unshift('checkbox') | html %]
109 [% PROCESS patron_search_table table_id => 'memberresultst' columns => columns %]
113 </div> <!-- /.col-sm-10.col-sm-push-2 -->
115 <div class="col-sm-2 col-sm-pull-10">
117 [% PROCESS patron_search_filters categories => categories, libraries => libraries, filters => ['search_field', 'search_type', 'category', 'branch'], search_filter => searchmember %]
119 </div> <!-- /.col-sm-2.col-sm-pull-10 -->
120 </div> <!-- /.row -->
122 <!-- New Patron List Modal -->
123 <div class="modal" id="new-patron-list" tabindex="-1" role="dialog" aria-labelledby="new-patron-listLabel">
124 <div class="modal-dialog" role="document">
125 <div class="modal-content">
126 <div class="modal-header">
127 <button type="button" class="closebtn" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
128 <h4 class="modal-title" id="new-patron-listLabel">Add patrons to a new patron list</h4>
130 <form id="new-patron-list_form">
131 <div class="modal-body">
132 <div class="form-group">
133 <label for="new_patron_list" class="required">Patron list name: </label>
134 <input class="form-control required" type="text" name="new_patron_list" id="new_patron_list" required="required" />
135 <input type="hidden" name="add_to_patron_list" id="add_to_patron_list" />
136 <span class="required">Required</span>
138 </div> <!-- /.modal-body -->
139 <div class="modal-footer">
140 <button type="submit" id="add_to_patron_list_submit" class="btn btn-default approve">Submit</button>
141 <button type="button" class="btn btn-default deny" data-dismiss="modal">Cancel</button>
142 </div> <!-- /.modal-footer -->
143 </form> <!-- /#new-patron-list_form -->
144 </div> <!-- /.modal-content -->
145 </div> <!-- /.modal-dialog -->
146 </div> <!-- /#new-patron-list -->
148 [% MACRO jsinclude BLOCK %]
149 [% INCLUDE 'datatables.inc' %]
150 [% INCLUDE 'columns_settings.inc' %]
151 [% INCLUDE 'str/members-menu.inc' %]
152 [% Asset.js("js/members-menu.js") | $raw %]
154 function showPatronSelections( number ){
155 $("#patron_search_selected").show().find("span").text(_("Patrons selected: " + number ) );
158 $(document).ready(function() {
159 $('#merge-patrons').prop('disabled', true);
160 $('#memberresultst').on('change', 'input.selection', function() {
161 var patron_search_selections = JSON.parse( localStorage.getItem("patron_search_selections") ) || [];
162 var borrowernumber = $(this).val();
163 if( $(this).prop("checked") ){
164 patron_search_selections.push( $(this).val() );
165 localStorage.setItem('patron_search_selections', JSON.stringify( patron_search_selections ));
166 showPatronSelections( patron_search_selections.length );
168 var filtered = patron_search_selections.filter(function( value ){
169 return value !== borrowernumber;
171 if( filtered.length > 0 ){
172 localStorage.setItem('patron_search_selections', JSON.stringify( filtered ));
173 patron_search_selections = filtered;
174 showPatronSelections( filtered.length );
176 patron_search_selections = [];
177 localStorage.removeItem('patron_search_selections');
178 $("#patron_search_selected").hide();
181 if ( patron_search_selections.length > 1 ) {
182 /* More than one checkbox has been checked */
183 $('#merge-patrons').prop('disabled', false).removeClass("disabled");
184 $("#patronlist-menu").removeClass("disabled").prop("disabled", false);
185 } else if ( patron_search_selections.length == 1 ) {
186 /* At least one checkbox has been checked */
187 $('#merge-patrons').prop('disabled', true).addClass("disabled");
188 $("#patronlist-menu").removeClass("disabled").prop("disabled", false);
190 /* No checkbox has been checked */
191 $('#merge-patrons').prop('disabled', true).addClass("disabled");
192 $("#patronlist-menu").addClass("disabled").prop("disabled", true);
196 $('#merge-patrons').on('click', function() {
197 var patron_search_selections = JSON.parse( localStorage.getItem("patron_search_selections") ) || [];
198 var merge_patrons_url = 'merge-patrons.pl?id=' + patron_search_selections.join("&id=");
199 window.location.href = merge_patrons_url;
202 $("#clear-patron-selection").on("click", function(e){
204 $(".selection").prop("checked", false).change();
205 localStorage.removeItem("patron_search_selections");
206 $("#patron_search_selected").hide();
207 $('#merge-patrons').prop('disabled', true).addClass("disabled");
208 $("#patronlist-menu").addClass("disabled").prop("disabled", true);
211 $("#patronlist-dropdown").on("click", ".patron-list-add", function(e){
213 var patron_search_selections = JSON.parse( localStorage.getItem("patron_search_selections") ) || [];
214 if ( patron_search_selections.length == 0 ) {
215 alert( _("You have not selected any patrons to add to a list!") );
216 $(".btn-group").removeClass("open"); /* Close button menu */
220 var listid = $(this).data("listid");
221 $("#add_to_patron_list").val( listid );
222 if( listid == "new" ){
223 /* #add_to_patron_list value "new" in the modal form will tell API to create a new list */
224 $("#new-patron-list").modal("show");
226 /* Ajax submit the patrons to list */
232 /* Submit selected patrons to a list via AJAX */
233 $("#new-patron-list_form").on('submit', function(e){
235 /* Upon submitting modal patron list add form... */
236 if ( $('#new_patron_list').val() ) {
237 $(".patron-list-add").each(function() {
238 /* Check each list name in the menu of patron lists */
239 /* If submitted list name matches... */
240 if ( $(this).text() == $('#new_patron_list').val() ) {
241 alert( _("You already have a list with that name!") );
246 alert( _("You must give your new patron list a name!") );
249 $("#new-patron-list").modal("hide");
253 $("#select_all").on("click",function(e){
255 $(".selection").prop("checked", true).change();
257 $("#clear_all").on("click",function(e){
259 $(".selection").prop("checked", false).change();
262 [% IF searchmember %]
263 $("#searchmember_filter").val("[% searchmember | html %]");
265 [% IF searchfieldstype %]
266 $("searchfieldstype_filter").val("[% searchfieldstype | html %]");
269 $("#searchtype_filter").val("[% searchtype | html %]");
271 [% IF categorycode %]
272 $("#categorycode_filter").val("[% categorycode_filter | html %]");
275 $("#branchcode_filter").val("[% branchcode_filter | html %]");
278 $("#searchheader").hide();
279 $("#patron_search_form").on('submit', function(){$("#searchheader").show();});
280 $("#clear_search").on("click",function(e){$("#searchheader").hide();});
283 function patronListAdd(){
284 var borrowernumbers = JSON.parse( localStorage.getItem("patron_search_selections") ) || [];
285 if ( borrowernumbers.length > 0 ){
287 add_to_patron_list: $("#add_to_patron_list").val(),
288 new_patron_list: $("#new_patron_list").val(),
289 borrowernumbers: borrowernumbers
294 url: '/cgi-bin/koha/svc/members/add_to_list',
295 success: function(data) {
296 $("#patron_list_dialog").show();
297 $("#patron_list_dialog > span.patrons-length").html(data.patrons_added_to_list);
298 $("#patron_list_dialog > a").attr("href", "/cgi-bin/koha/patron_lists/list.pl?patron_list_id=" + data.patron_list.patron_list_id);
299 $("#patron_list_dialog > a").html(data.patron_list.name);
301 if ( $('#add_to_patron_list').val() == 'new' ) {
302 /* Add a new entry to the menu */
303 $("#patronlist-dropdown .divider").before('<li><a class="patron-list-add" href="#" data-listid="' + data.patron_list.patron_list_id + '">' + data.patron_list.name + '</li>');
307 alert( _("An error occurred. Patron list could not be updated.") );
312 alert( _("You have not selected any patrons to add to a list!") );
317 function prepSelections(){
318 var selected_patrons = JSON.parse( localStorage.getItem("patron_search_selections") );
319 if( selected_patrons && selected_patrons.length > 0 ){
320 showPatronSelections( selected_patrons.length );
322 $('#merge-patrons').prop('disabled', true);
323 $("input.selection").each(function(){
324 var cardnumber = $(this).val();
325 if( selected_patrons.indexOf( cardnumber ) >= 0 ){
326 $(this).prop("checked", true );
330 if( selected_patrons.length > 1 ){
331 $('#merge-patrons').removeClass("disabled").prop('disabled', false);
332 $('#patronlist-menu').removeClass("disabled").prop('disabled', false);
337 $('#memberresultst tbody').on('click','td',function(e){
338 var $checkbox = $(this).find("input[type=checkbox]");
339 if (e.target.type != "checkbox") {
340 $checkbox.prop('checked', !$checkbox.prop("checked"));
348 // Apply DataTables on the results table
349 var table_settings = [% TablesSettings.GetTableSettings( 'members', 'member', 'memberresultst', 'json' ) | $raw %];
350 [% UNLESS CAN_user_borrowers_edit_borrowers OR CAN_user_tools_manage_patron_lists %]
351 [%# Remove the first column if we do not display the checkbox %]
352 table_settings['columns'].splice(0, 1);
356 [% IF circsearch == 1 %]
357 [% SET redirect_url = '/cgi-bin/koha/circ/circulation.pl' %]
359 [% SET redirect_url = '/cgi-bin/koha/members/moremember.pl' %]
361 [% PROCESS patron_search_js table_id => 'memberresultst', categories => categories, libraries => libraries, extended_attribute_types => attribute_type_codes, columns => columns,actions => ['edit', 'checkout'], redirect_if_one_result => 1, redirect_url => redirect_url, sticky_header => "searchheader", sticky_to => "searchresults", default_sort_column => 'name-address', display_search_description => 1, remember_selections => 1 %]
365 [% INCLUDE 'intranet-bottom.inc' %]