<title>Koha › Tools › Batch patron modification</title>
[% INCLUDE 'doc-head-close.inc' %]
[% INCLUDE 'calendar.inc' %]
-<script type="text/javascript" src="[% themelang %]/lib/jquery/plugins/jquery.tablesorter.min.js"></script>
-<script type="text/JavaScript">
+<link rel="stylesheet" type="text/css" href="[% themelang %]/css/datatables.css" />
+[% INCLUDE 'datatables.inc' %]
+<script type="text/javascript">
//<![CDATA[
var patron_attributes_lib = new Array();
var patron_attributes_values = new Array();
$(document).ready(function() {
- $("#borrowerst").tablesorter({
- [% IF ( op == 'show' ) %]headers: { 0: { sorter: false}},[% END %]
- widgets : ['zebra'],
- sortList: [[1,0]]
- });
-
- $("#selectallbutton").click(function() {
- $("#borrowerst").find("input:checkbox").each(function() {
- $(this).attr("checked", true);
+ [% IF borrowers %]
+ $("#borrowerst").dataTable($.extend(true, {}, dataTablesDefaults, {
+ "sDom": 't',
+ [% IF ( op == 'show_results' ) %]
+ "aoColumnDefs": [
+ { 'sType': "title-string", 'aTargets' : [ 'title-string'] }
+ ],
+ [% ELSE %]
+ "aoColumnDefs": [
+ { "aTargets": [ 0 ], "bSortable": false, "bSearchable": false },
+ { 'sType': "title-string", 'aTargets' : [ 'title-string'] }
+ ],
+ [% END %]
+ "bPaginate": false
+ }));
+ $("#selectallbutton").click(function() {
+ $("#borrowerst").find("input:checkbox").each(function() {
+ $(this).attr("checked", true);
+ });
+ return false;
});
- return false;
- });
- $("#clearallbutton").click(function() {
- $("#borrowerst").find("input:checkbox").each(function() {
- $(this).attr("checked", false);
+ $("#clearallbutton").click(function() {
+ $("#borrowerst").find("input:checkbox").each(function() {
+ $(this).attr("checked", false);
+ });
+ return false;
});
- return false;
- });
+ [% END %]
var values = new Array();
var lib = new Array();
var information_category_node = $(select_attr).parent().parent().find('span.information_category');
information_category_node.html("");
if ( category.length > 0 ) {
- information_category_node.html(_("This attribute will be only applied to the patron\'s category") +' "' + category + '"');
+ information_category_node.html(_("This attribute will be only applied to the patron's category %s").format(category));
}
if ( type == 'select' ) {
var options = '<option value = ""></option>';
//]]>
</script>
</head>
-<body>
+<body id="tools_modborrowers" class="tools">
[% INCLUDE 'header.inc' %]
[% INCLUDE 'cat-search.inc' %]
<h1>Batch patron modification</h1>
<form method="post" enctype="multipart/form-data" action="/cgi-bin/koha/tools/modborrowers.pl">
<fieldset class="rows">
- <legend>Use a file</legend>
- <ol>
- <li><label for="uploadfile">File: </label> <input type="file" id="uploadfile" name="uploadfile" /></li>
- </ol>
+ <legend>Use a file</legend>
+ <ol>
+ <li><label for="uploadfile">File: </label> <input type="file" id="uploadfile" name="uploadfile" /></li>
+ </ol>
</fieldset>
+
+ [% IF patron_lists %]
+ <fieldset class="rows">
+ <legend>Or use a patron list</legend>
+ <ol>
+ <li>
+ <label for="patron_list_id">Patron list: </label>
+ <select id="patron_list_id" name="patron_list_id">
+ <option value=""></option>
+ [% FOREACH pl IN patron_lists %]
+ <option value="[% pl.patron_list_id %]">[% pl.name %]</option>
+ [% END %]
+ </select>
+ </li>
+ </ol>
+ </fieldset>
+ [% END %]
+
<fieldset class="rows">
<legend>Or list cardnumbers one by one</legend>
<ol>
[% IF ( op == 'show_results' ) %]
[% IF ( errors ) %]
<div class="dialog alert">
- <h4>Errors occured:</h4>
+ <h4>Errors occurred:</h4>
<ul class="warnings">
[% FOREACH error IN errors %]
[% IF ( error.error == 'can_not_update' ) %]
- <li>Can not update patron with borrowernumber [% error.borrowernumber %]</li>
+ <li>Can not update patron.
+ [% IF ( error.cardnumber ) %] Cardnumber: [% error.cardnumber %] [% END %]
+ (Borrowernumber: [% error.borrowernumber %])
+ </li>
[% ELSE %]
<li>[% error.error %]</li>
[% END %]
<form name="f" action="modborrowers.pl" method="post">
<input type="hidden" name="op" value="do" />
[% IF ( borrowers ) %]
- <div id="toolbar"><a id="selectallbutton" href="#">Select All</a> | <a id="clearallbutton" href="#">Clear All</a></div>
+ <div id="toolbar"><a id="selectallbutton" href="#">Select all</a> | <a id="clearallbutton" href="#">Clear all</a></div>
[% END %]
[% END %]
+ [% IF borrowers %]
<div id="cataloguing_additem_itemlist">
<div style="overflow:auto">
<table id="borrowerst">
[% END %]
<th>Card number</th>
<th>Surname</th>
- <th>Firstname</th>
+ <th>First name</th>
<th>Library</th>
<th>Category</th>
- <th>Registration date</th>
- <th>Expiry date</th>
- <th>Restricted</th>
+ <th>City</th>
+ <th>State</th>
+ <th>Zip/Postal code</th>
+ <th>Country</th>
+ <th class="title-string">Registration date</th>
+ <th class="title-string">Expiry date</th>
[% FOREACH attrh IN attributes_header %]
<th>[% attrh.attribute %]</th>
[% END %]
<td>[% borrower.firstname %]</td>
<td>[% borrower.branchname %]</td>
<td>[% borrower.categorycode %]</td>
- <td>[% borrower.dateenrolled | $KohaDates %]</td>
- <td>[% borrower.dateexpiry | $KohaDates %]</td>
- <td>[% borrower.debarred | $KohaDates %]</td>
+ <td>[% borrower.city %]</td>
+ <td>[% borrower.state %]</td>
+ <td>[% borrower.zipcode %]</td>
+ <td>[% borrower.country %]</td>
+ <td><span title="[% borrower.dateenrolled %]">[% borrower.dateenrolled | $KohaDates %]</span></td>
+ <td><span title="[% borrower.dateexpiry %]">[% borrower.dateexpiry | $KohaDates %]</span></td>
[% FOREACH pa IN borrower.patron_attributes %]
[% IF ( pa.code ) %]
<td>[% pa.code %]=[% pa.value %]</td>
[% IF ( op == 'show' ) %]
<div id="cataloguing_additem_newitem">
- <h2>Edit Patrons</h2>
- <div class="hint">Checking the box right next the label will disable the entry and delete the values of that field on all selected patrons</div>
+ <h2>Edit patrons</h2>
+ <div class="hint">Checking the box right next to the label will disable the entry and delete the values of that field on all selected patrons</div>
<fieldset class="rows" id="fields_list">
<ol>
[% FOREACH field IN fields %]
Library:
[% CASE 'categorycode' %]
Category
+ [% CASE 'city' %]
+ City
+ [% CASE 'state' %]
+ State
+ [% CASE 'zipcode' %]
+ Zip/Postal code
+ [% CASE 'country' %]
+ Country
[% CASE 'sort1' %]
Sort 1:
[% CASE 'sort2' %]
Registration date:
[% CASE 'dateexpiry' %]
Expiry date:
- [% CASE 'debarred' %]
- Restricted:
- [% CASE 'debarredcomment' %]
- Restriction comment:
[% CASE 'borrowernotes' %]
Circulation note:
[% END %]
[% IF ( field.type == 'date' ) %]
<input type="text" name="[% field.name %]" id="[% field.name %]" value="" size="10" maxlength="10" readonly="readonly" class="datepicker" />
<a href="#" class="clear-field" onclick="clearDate('[% field.name %]');return false;">Clear</a>
- [% END %]
+ [% END %]
+ [% IF field.mandatory %]
+ <span class="required">Required fields cannot be cleared</span>
+ [% END %]
</li>
[% END %]
[% IF ( patron_attributes_codes ) %]
</div>
</form>
[% END %]
+ [% END %]
[% END %]
[% IF ( op == 'show_results' ) %]
<p>
[% INCLUDE 'tools-menu.inc' %]
</div>
</div>
- </div>
-</div>
-</body>
-</html>
+[% INCLUDE 'intranet-bottom.inc' %]