This patch updates serials templates so that title tags can be more easily translated. Some templates have been updated for consistency as well: Harmonizing page title, breaddrumb navigation, and page headers; Adding "page-section" <div> where it was lacking. To test, apply the patch and confirm that the following pages have the correct title tags: - Serials home - Serials search results - Subscription details - Subscription edit - Search for vendor - Search for bibliographic record - Subscription renew - Serial collection - Create and modify routing list - Preview routing list - View routing slip - Claims - Check expiration - With a subscription which has manual history enabled, click the "Edit history" link under the "Planning" tab. - Select multiple serial search results and batch edit - New subscription - Manage frequencies: Create and edit - Manage numbering patterns: Create and edit Signed-off-by: Loïc Vassaux-Artur <loic.vassaux-artur@outlook.fr> Signed-off-by: Katrin Fischer <katrin.fischer@bsz-bw.de>
358 lines
18 KiB
Text
358 lines
18 KiB
Text
[% USE raw %]
|
|
[% USE Asset %]
|
|
[% USE AuthorisedValues %]
|
|
[% USE Branches %]
|
|
[% USE KohaDates %]
|
|
[% PROCESS 'i18n.inc' %]
|
|
[% SET footerjs = 1 %]
|
|
[% INCLUDE 'doc-head-open.inc' %]
|
|
<title>[% FILTER collapse %]
|
|
[% IF( supplierid ) %]
|
|
[% tx("Claims for {vendor}", { vendor = suppliername }) | html %] ›
|
|
[% END %]
|
|
[% t("Claims") | html %] ›
|
|
[% t("Serials") | html %] ›
|
|
[% t("Koha") | html %]
|
|
[% END %]</title>
|
|
[% INCLUDE 'doc-head-close.inc' %]
|
|
</head>
|
|
|
|
<body id="ser_claims" class="ser">
|
|
[% WRAPPER 'header.inc' %]
|
|
[% INCLUDE 'serials-search.inc' %]
|
|
[% END %]
|
|
|
|
[% WRAPPER 'sub-header.inc' %]
|
|
[% WRAPPER breadcrumbs %]
|
|
[% WRAPPER breadcrumb_item %]
|
|
<a href="/cgi-bin/koha/serials/serials-home.pl">Serials</a>
|
|
[% END %]
|
|
[% IF ( supplierid ) -%]
|
|
[% WRAPPER breadcrumb_item %]
|
|
<a href="/cgi-bin/koha/serials/claims.pl">
|
|
Claims
|
|
</a>
|
|
[% END %]
|
|
[% WRAPPER breadcrumb_item bc_active= 1 %]
|
|
<span>Claims for [% suppliername | html %]</span>
|
|
[% END %]
|
|
[% ELSE -%]
|
|
[% WRAPPER breadcrumb_item bc_active= 1 %]
|
|
<span>Claims</span>
|
|
[% END %]
|
|
[% END %]
|
|
[% END #/ WRAPPER breadcrumbs %]
|
|
[% END #/ WRAPPER sub-header.inc %]
|
|
|
|
<div class="main container-fluid">
|
|
<div class="row">
|
|
<div class="col-md-10 order-md-2 order-sm-1">
|
|
<main>
|
|
[% INCLUDE 'messages.inc' %]
|
|
|
|
<h1>Claims [% IF ( suppliername ) %] for [% suppliername | html %] [% END %]</h1>
|
|
|
|
[% IF error_claim %]
|
|
[% IF error_claim == 'no_vendor_email' %]
|
|
<div class="alert alert-warning">This vendor has no email defined for late issues.</div>
|
|
[% ELSIF error_claim == 'bad_or_missing_sender' %]
|
|
<div class="alert alert-warning">Bad or missing sender address; check your branch email address or preference KohaAdminEmailAddress.</div>
|
|
[% ELSE %]
|
|
<div class="alert alert-warning">[% error_claim | html %]</div>
|
|
[% END %]
|
|
[% END %]
|
|
[% IF info_claim %]
|
|
<div class="alert alert-info">Email has been sent.</div>
|
|
[% END %]
|
|
|
|
[% IF letters %]
|
|
[% UNLESS ( missingissues ) %]
|
|
[% IF ( supplierid ) %]
|
|
<div class="alert alert-warning">No missing issues found.</div>
|
|
[% ELSE %]
|
|
<div class="alert alert-info">Please choose a vendor.</div>
|
|
[% END %]
|
|
[% END %]
|
|
[% END %]
|
|
|
|
[% IF ( SHOWCONFIRMATION ) %]
|
|
<div class="alert alert-warning">Your notification has been sent.</div>
|
|
[% END %]
|
|
|
|
[% UNLESS letters %]
|
|
<div class="alert alert-warning">
|
|
No claims notice defined. <a href="/cgi-bin/koha/tools/letter.pl">Please define one</a>.
|
|
</div>
|
|
[% END %]
|
|
|
|
<form id="claims" name="claims" action="claims.pl" method="get">
|
|
<fieldset>
|
|
<label for="supplierid">Vendor: </label>
|
|
<select id="supplierid" name="supplierid">
|
|
[% FOREACH suploo IN suploop %]
|
|
[% IF ( suploo.selected ) %]
|
|
<option value="[% suploo.id | html %]" selected="selected" >
|
|
[% ELSE %]
|
|
<option value="[% suploo.id | html %]">
|
|
[% END %]
|
|
[% suploo.name | html %]
|
|
([% suploo.count | html %])
|
|
</option>
|
|
[% END %]
|
|
</select>
|
|
<input type="submit" class="btn btn-primary" value="OK" />
|
|
</fieldset>
|
|
</form> <!-- /#claims -->
|
|
|
|
[% IF ( missingissues ) %]
|
|
<h3>Missing issues</h3>
|
|
<form method="get" action="claims.pl" id="filter_claims_form">
|
|
<fieldset class="rows">
|
|
<legend>Filters:</legend>
|
|
<ol>
|
|
<li>
|
|
<label for="from">From:</label>
|
|
<input type="text" name="begindate" id="from" value="[% begindate | html %]" size="10" maxlength="10" class="flatpickr" data-date_to="to"/>
|
|
<label for="to" style="float:none;">To:</label>
|
|
<input type="text" name="enddate" id="to" value="[% enddate | html %]" size="10" maxlength="10" class="flatpickr" />
|
|
<span class="hint">[% INCLUDE 'date-format.inc' %]</span>
|
|
<input id="filterByDate" type="button" value="OK" />
|
|
<a href="#" id="clearfilter"><i class="fa fa-times"></i> Clear filter</a>
|
|
</li>
|
|
</ol>
|
|
</fieldset>
|
|
</form>
|
|
|
|
<fieldset>
|
|
<form action="claims.pl" method="post" id="claims_form">
|
|
[% INCLUDE 'csrf-token.inc' %]
|
|
<table id="claimst">
|
|
<thead>
|
|
<tr>
|
|
<th><input type="checkbox" id="CheckAll"></th>
|
|
<th>Vendor</th>
|
|
<th>Library</th>
|
|
<th class="anti-the">Title</th>
|
|
<th>ISSN</th>
|
|
<th>Issue number</th>
|
|
<th>Status</th>
|
|
<th>Since</th>
|
|
<th>Publication date</th>
|
|
<th>Claims count</th>
|
|
<th>Claim date</th>
|
|
[% FOR field IN additional_fields_for_subscription %]
|
|
<th>[% field.name | html %]</th>
|
|
[% END %]
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
[% FOREACH missingissue IN missingissues %]
|
|
<tr>
|
|
<td>
|
|
[% UNLESS missingissue.cannot_claim %]
|
|
<input type="checkbox" name="serialid" value="[% missingissue.serialid | html %]" />
|
|
[% END %]
|
|
</td>
|
|
<td>[% missingissue.name | html %]</td>
|
|
<td>
|
|
<span class="branch-[% missingissue.branchcode | html %]">[% Branches.GetName( missingissue.branchcode ) | html %]</span>
|
|
</td>
|
|
<td>
|
|
<a href="/cgi-bin/koha/serials/subscription-detail.pl?subscriptionid=[% missingissue.subscriptionid | uri %]">[% missingissue.title | html %]</a>
|
|
</td>
|
|
<td>[% missingissue.issn | html %]</td>
|
|
<td>[% missingissue.serialseq | html %]</td>
|
|
<td>
|
|
[% INCLUDE 'serial-status.inc' serial = missingissue %]
|
|
</td>
|
|
<td class="planneddate" data-order="[% missingissue.planneddate | html %]">
|
|
[% missingissue.planneddate | $KohaDates %]
|
|
</td>
|
|
<td class="publisheddate" data-order="[% missingissue.publisheddate | html %]">
|
|
[% missingissue.publisheddate | $KohaDates %]
|
|
</td>
|
|
<td>[% missingissue.claims_count | html %]</td>
|
|
<td data-order="[% missingissue.claimdate | html %]">
|
|
[% missingissue.claimdate | $KohaDates %]
|
|
</td>
|
|
[% INCLUDE 'additional-fields-display.inc' available=additional_fields_for_subscription values=missingissue.additional_field_values value_only=1 is_table_cell=1 %]
|
|
</tr>
|
|
[% END # /FOREACH missingissue %]
|
|
</tbody>
|
|
<tfoot>
|
|
<tr>
|
|
<td></td>
|
|
<td><input type="text" class="filter" data-column_num="1" placeholder="Search vendor" /></td>
|
|
<td><input type="text" class="filter" data-column_num="2" placeholder="Search library" /></td>
|
|
<td><input type="text" class="filter" data-column_num="3" placeholder="Search title" /></td>
|
|
<td><input type="text" class="filter" data-column_num="4" placeholder="Search ISSN" /></td>
|
|
<td><input type="text" class="filter" data-column_num="5" placeholder="Search issue number" /></td>
|
|
<td><input type="text" class="filter" data-column_num="6" placeholder="Search status" /></td>
|
|
<td><input type="text" class="filter" data-column_num="7" placeholder="Search since" /></td>
|
|
<td><input type="text" class="filter" data-column_num="8" placeholder="Search publication date" /></td>
|
|
<td><input type="text" class="filter" data-column_num="9" placeholder="Search claim count" /></td>
|
|
<td><input type="text" class="filter" data-column_num="10" placeholder="Search claim date" /></td>
|
|
[% FOR field IN additional_fields_for_subscription %]
|
|
<td><input type="text" class="filter" data-column_num="[% loop.count + 10 | html %]" placeholder="Search [% field.name | html %]" /></td>
|
|
[% END %]
|
|
</tr>
|
|
</tfoot>
|
|
</table> <!-- /#claimst -->
|
|
|
|
[% IF csv_profiles.count %]
|
|
<fieldset class="action">
|
|
<label for="csv_code">Select CSV profile:</label>
|
|
<select id="csv_profile_for_export">
|
|
[% FOR csv IN csv_profiles %]
|
|
<option value="[% csv.export_format_id | html %]">[% csv.profile | html %]</option>
|
|
[% END %]
|
|
</select>
|
|
<span class="exportSelected"><a id="ExportSelected" href="/cgi-bin/koha/serials/claims.pl">Download selected claims</a></span>
|
|
</fieldset>
|
|
[% END %]
|
|
|
|
[% IF letters %]
|
|
<fieldset class="action">
|
|
<label for="letter_code">Select notice:</label>
|
|
<select name="letter_code" id="letter_code">
|
|
[% FOREACH letter IN letters %]
|
|
<option value="[% letter.code | html %]">[% letter.name | html %]</option>
|
|
[% END %]
|
|
</select>
|
|
<input type="hidden" name="op" value="cud-send_alert" />
|
|
<input type="hidden" name="supplierid" value="[% supplierid | html %]" />
|
|
<input type="submit" name="submit" class="btn btn-primary" value="Send notification" />
|
|
</fieldset>
|
|
[% END %]
|
|
</form> <!-- /#claims_form -->
|
|
</fieldset>
|
|
[% END # /missingissues %]
|
|
|
|
</main>
|
|
</div> <!-- /.col-md-10.order-md-2 -->
|
|
|
|
<div class="col-md-2 order-sm-2 order-md-1">
|
|
<aside>
|
|
[% INCLUDE 'serials-menu.inc' %]
|
|
</aside>
|
|
</div> <!-- /.col-md-2.order-md-1 -->
|
|
</div> <!-- /.row -->
|
|
|
|
[% MACRO jsinclude BLOCK %]
|
|
[% INCLUDE 'calendar.inc' %]
|
|
[% INCLUDE 'datatables.inc' %]
|
|
<script>
|
|
var sTable;
|
|
$(document).ready(function() {
|
|
sTable = $("#claimst").dataTable($.extend(true, {}, dataTablesDefaults, {
|
|
"dom": 't',
|
|
"columnDefs": [
|
|
{ "targets": [ 0 ], "orderable": false, "searchable": false },
|
|
{ "type": "anti-the", "targets": [ 'anti-the'] }
|
|
],
|
|
"paginate": false
|
|
}));
|
|
sTable.fnAddFilters("filter", "200");
|
|
$('#supplierid').change(function() {
|
|
$('#claims').submit();
|
|
});
|
|
|
|
// Checkboxes : Select All / None
|
|
$("span.checkall").html("<input type=\"checkbox\" name=\"CheckAll\"> "+_("Check all")+"</input>");
|
|
|
|
$("#CheckAll").click(function() {
|
|
$("#claimst tr:visible :checkbox").prop('checked', $("#CheckAll").is(':checked'));
|
|
});
|
|
|
|
// Generates a dynamic link for exporting the selections data as CSV
|
|
$("#ExportSelected").click(function() {
|
|
// We need to use "input[name=serialid]:checked" instead of "input:checked". Otherwise, the "check all" box will pass the value of "on" as a serialid, which produces a SQL error.
|
|
var selected = $("input[name=serialid]:checked");
|
|
|
|
if (selected.length == 0) {
|
|
alert(_("Please select at least one item to export."));
|
|
return false;
|
|
}
|
|
|
|
// Building the url from currently checked boxes
|
|
var url = '/cgi-bin/koha/serials/lateissues-export.pl?supplierid=&op=claims';
|
|
for (var i = 0; i < selected.length; i++) {
|
|
url += '&serialid=' + selected[i].value;
|
|
}
|
|
url += '&csv_profile=' + $("#csv_profile_for_export option:selected").val();
|
|
// And redirecting to the CSV page
|
|
location.href = url;
|
|
return false;
|
|
});
|
|
$("#filterByDate").on("click",function(e){
|
|
e.preventDefault();
|
|
filterByDate();
|
|
});
|
|
$("#clearfilter").on("click",function(e){
|
|
e.preventDefault();
|
|
$("#from").flatpickr().clear();
|
|
$("#to").flatpickr().clear();
|
|
$("table#claimst tbody tr").show();
|
|
});
|
|
$("#claims_form").on("submit",function(){
|
|
return checkForm();
|
|
});
|
|
$("#filter_claims_form").on("submit",function(){
|
|
return false;
|
|
});
|
|
});
|
|
|
|
// Checks if the form can be sent (at least one checkbox must be checked)
|
|
function checkForm() {
|
|
if ($("input:checked").length == 0) {
|
|
alert(_("Please select at least one issue."));
|
|
return false;
|
|
}
|
|
}
|
|
|
|
// Filter by date
|
|
function filterByDate() {
|
|
var beginDate = new Date($("#from").val()).getTime();
|
|
var endDate = new Date($("#to").val()).getTime();
|
|
|
|
// Checks if the beginning date is valid
|
|
if (!parseInt(beginDate)) {
|
|
alert(_("The beginning date is missing or invalid."));
|
|
return false;
|
|
}
|
|
|
|
// Checks if the ending date is valid
|
|
if (!parseInt(endDate)) {
|
|
alert(_("The ending date is missing or invalid."));
|
|
return false;
|
|
}
|
|
|
|
// Checks if beginning date is before ending date
|
|
if (beginDate > endDate) {
|
|
// If not, we swap them
|
|
var tmpDate = endDate;
|
|
endDate = beginDate;
|
|
beginDate = tmpDate;
|
|
}
|
|
|
|
// We hide everything
|
|
$("table#claimst tbody tr").hide();
|
|
|
|
// For each date in the table
|
|
$(".planneddate").each(function() {
|
|
|
|
// We make a JS Date Object, according to the locale
|
|
var pdate = Date_from_syspref($(this).text()).getTime();
|
|
|
|
// And checks if the date is between the beginning and ending dates
|
|
if (pdate > beginDate &&
|
|
pdate < endDate) {
|
|
// If so, we can show the row
|
|
$(this).parent().show();
|
|
}
|
|
});
|
|
}
|
|
</script>
|
|
[% END %]
|
|
|
|
[% INCLUDE 'intranet-bottom.inc' %]
|