+[% USE raw %]
+[% USE Asset %]
+[% USE AuthorisedValues %]
+[% USE Branches %]
+[% SET footerjs = 1 %]
[% INCLUDE 'doc-head-open.inc' %]
<title>Koha › Serials › Claims</title>
[% INCLUDE 'doc-head-close.inc' %]
-[% INCLUDE 'calendar.inc' %]
-<link rel="stylesheet" type="text/css" href="[% interface %]/[% theme %]/en/css/datatables.css" />
-<script type="text/javascript" src="[% interface %]/[% theme %]/en/lib/jquery/plugins/jquery.dataTables.min.js"></script>
-[% INCLUDE 'datatables-strings.inc' %]
-<script type="text/javascript" src="[% interface %]/[% theme %]/en/js/datatables.js"></script>
-<script type="text/javascript">
-//<![CDATA[
- [% IF (dateformat == 'metric') %]dt_add_type_uk_date();[% END %]
- $(document).ready(function() {
- [% UNLESS ( preview ) %]
- var sTable = $("#claimst").dataTable($.extend(true, {}, dataTablesDefaults, {
- "sDom": 't',
- "aoColumnDefs": [
- { "aTargets": [ 0,1 ], "bSortable": false, "bSearchable": false }
- ],
- "bPaginate": false
- }));
- [% END %]
- $('#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").attr('checked', $("#CheckAll").is(':checked'));
- });
-
- // Generates a dynamic link for exporting the selection's 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-excel.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;
- });
-
- $("#titlefilter").keyup( function () {
- sTable.fnFilter( this.value, 3 ); // 3 is position of title column
- } );
-
- $("#branchfilter").keyup(function() {
- sTable.fnFilter( this.value, 2 ); // 2 is the position of the author column
- });
- });
-
- // 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 item."));
- return false;
- }
- }
-
- // Filter by status
- function filterByStatus() {
- selectedStatus = $("#statusfilter").val();
- if (selectedStatus == "all") {
- clearFilters();
- } else {
- $("table#claimst tbody tr").hide();
- $("table#claimst tbody tr").each( function() {
- if ( $(this).find("span.status-" + selectedStatus).size() > 0 ) {
- $(this).show();
- }
- });
- }
- }
-
- // Filter by branch
- function filterByBranch() {
- selectedBranch = $("#branchfilter").val();
- if (selectedBranch == "all") {
- clearFilters();
- } else {
- $("table#claimst tbody tr").hide();
- $("table#claimst tbody tr:contains(" + selectedBranch + ")").show();
- }
- }
- // Filter by date
- function filterByDate() {
- var beginDate = Date_from_syspref($("#from").val()).getTime();
- var endDate = Date_from_syspref($("#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();
- }
-
- });
- }
-
- // Clears filters : shows everything
- function clearFilters() {
- $("table#claimst tbody tr").show();
- }
-
- function popup(supplierid,serialid){
- window.open('claims.pl?supplierid='+ supplierid +'&serialid='+ serialid +'&op=preview' ,'popup', 'width=600,height=400,toolbar=no,scrollbars=yes');
- }
-
-//]]>
-</script>
</head>
+
<body id="ser_claims" class="ser">
[% INCLUDE 'header.inc' %]
-[% UNLESS ( preview ) %]
[% INCLUDE 'serials-search.inc' %]
-[% END %]
<div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a> › <a href="/cgi-bin/koha/serials/serials-home.pl">Serials</a> › Claims</div>
-[% UNLESS ( preview ) %]
-
-<div id="doc3" class="yui-t2">
-
- <div id="bd">
- <div id="yui-main">
- <div class="yui-b">
+<div class="main container-fluid">
+ <div class="row">
+ <div class="col-sm-10 col-sm-push-2">
+ <main>
<h1>Claims</h1>
-[% IF ( letter ) %][% UNLESS ( missingissues ) %][% IF ( supplierid ) %] <div class="dialog alert">No missing issues found.</div>[% ELSE %]<div class="dialog message">Please choose a vendor.</div>[% END %][% END %][% END %]
+ [% IF error_claim %]
+ [% IF error_claim == 'no_vendor_email' %]
+ <div class="dialog alert">This vendor has no email defined for late issues.</div>
+ [% ELSIF error_claim == 'bad_or_missing_sender' %]
+ <div class="dialog alert">Bad or missing sender address; check your branch email address or preference KohaAdminEmailAddress.</div>
+ [% ELSE %]
+ <div class="dialog alert">[% error_claim | html %]</div>
+ [% END %]
+ [% END %]
+ [% IF info_claim %]
+ <div class="dialog message">Email has been sent.</div>
+ [% END %]
+
+[% IF letters %][% UNLESS ( missingissues ) %][% IF ( supplierid ) %] <div class="dialog alert">No missing issues found.</div>[% ELSE %]<div class="dialog message">Please choose a vendor.</div>[% END %][% END %][% END %]
[% IF ( SHOWCONFIRMATION ) %]
<div class="dialog alert">Your notification has been sent.</div>
[% END %]
-[% UNLESS ( letter ) %]<div class="dialog alert">No claims notice defined. <a href="/cgi-bin/koha/tools/letter.pl">Please define one</a>.</div>[% END %]
+[% UNLESS letters %]<div class="dialog alert">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="post">
<fieldset>
<label for="supplierid">Vendor: </label>
<select id="supplierid" name="supplierid">
[% FOREACH suploo IN suploop %]
[% IF ( suploo.selected ) %]
- <option value="[% suploo.id %]" selected="selected" >
+ <option value="[% suploo.id | html %]" selected="selected" >
[% ELSE %]
- <option value="[% suploo.id %]">
+ <option value="[% suploo.id | html %]">
[% END %]
- [% suploo.name %]
- ([% suploo.count %])
+ [% suploo.name | html %]
+ ([% suploo.count | html %])
</option>
[% END %]
</select>
<input type="submit" value="OK" />
- [% IF ( phone ) %]Phone: [% phone %][% END %]
- [% IF ( booksellerfax ) %]Fax: [% booksellerfax %][% END %]
- [% IF ( bookselleremail ) %]</p><p><a href="mailto:[% bookselleremail %]">[% bookselleremail %]</a>[% END %]
</fieldset>
</form>
[% IF ( missingissues ) %]
<h3>Missing issues</h3>
- <form action="claims.pl" onsubmit="return false;">
+ <form action="claims.pl" id="filter_claims_form">
<fieldset class="rows">
<legend>Filters :</legend>
<ol>
<li>
- <label for="statusfilter">Status : </label>
- <select id="statusfilter" onchange="filterByStatus();">
- <option value="all" selected="selected">(All)</option>
- <option value="expected">Expected</option>
- <option value="late">Late</option>
- <option value="missing">Missing</option>
- <option value="claimed">Claimed</option>
- </select>
- </li>
-
- <li>
- <label for="titlefilter">Title : </label>
- <input id="titlefilter" type="text" />
- </li>
- <li>
- <label for="branchfilter">Library: </label>
- <select id="branchfilter" onchange="filterByBranch();">
- [% FOREACH branchloo IN branchloop %]
- [% IF ( branchloo.selected ) %]
- <option value="[% branchloo.value %]" selected="selected">[% branchloo.branchname %]</option>
- [% ELSE %]
- <option value="[% branchloo.value %]">[% branchloo.branchname %]</option>
- [% END %]
- [% END %]
- </select>
- </li>
-
- <li>
<label for="from">From:</label>
- <input type="text" name="begindate" id="from" value="[% begindate %]" size="10" maxlength="10" class="datepickerfrom" />
+ <input type="text" name="begindate" id="from" value="[% begindate | html %]" size="10" maxlength="10" class="datepickerfrom" />
<label for="to" style="float:none;">To:</label>
- <input type="text" name="enddate" id="to" value="[% enddate %]" size="10" maxlength="10" class="datepickerto" />
+ <input type="text" name="enddate" id="to" value="[% enddate | html %]" size="10" maxlength="10" class="datepickerto" />
<span class="hint">[% INCLUDE 'date-format.inc' %]</span>
- <input type="button" value="OK" onclick="filterByDate();" />
- </li>
-
- <li>
- <input type="reset" value="Clear filters" onclick="clearFilters();" />
- </li>
+ <input id="filterByDate" type="button" value="OK" />
+ <a href="#" id="clearfilter"><i class="fa fa-remove"></i> Clear filter</a>
+ </li>
</ol>
</fieldset>
</form>
<fieldset>
- <form action="claims.pl" method="post" class="checkboxed" onsubmit="return checkForm()">
- <input type="hidden" name="order" value="[% order %]" />
- <table id="claimst">
- <thead><tr>
- [% IF ( letter ) %]
- <th><input type="checkbox" id="CheckAll"></th>
+ <form action="claims.pl" method="post" id="claims_form">
+ <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 class="title-string">Since</th>
+ <th>Claims count</th>
+ <th class="title-string">Claim date</th>
+ [% FOR field IN additional_fields_for_subscription %]
+ <th>[% field.name | html %]</th>
+ [% END %]
+ </tr>
+ </thead>
+ <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 claim count" /></td>
+ <td><input type="text" class="filter" data-column_num="9" placeholder="Search claim date" /></td>
+ [% FOR field IN additional_fields_for_subscription %]
+ <td><input type="text" class="filter" data-column_num="[% loop.count + 9 | html %]" placeholder="Search [% field.name | html %]" /></td>
[% END %]
- <th>Vendor</th>
- <th>Library</th>
- <th>Title</th>
- <th>Issue number</th>
- <th>Status</th>
- <th>Since</th>
- <th>Claim date</th>
- </tr></thead>
+ </tr>
+ </tfoot>
<tbody>[% FOREACH missingissue IN missingissues %]
<tr>
- [% IF ( letter ) %]
- <td>
- <input type="checkbox" name="serialid" value="[% missingissue.serialid %]" />
- </td>
- [% END %]
- <td>
- [% missingissue.name %]
- </td>
<td>
- [% missingissue.branchcode %]
+ [% UNLESS missingissue.cannot_claim %]
+ <input type="checkbox" name="serialid" value="[% missingissue.serialid | html %]" />
+ [% END %]
</td>
+ <td>[% missingissue.name | html %]</td>
<td>
- <a href="/cgi-bin/koha/serials/subscription-detail.pl?subscriptionid=[% missingissue.subscriptionid %]">[% missingissue.title |html %]</a>
+ <span class="branch-[% missingissue.branchcode | html %]">[% Branches.GetName( missingissue.branchcode ) | html %]</span>
</td>
<td>
- [% missingissue.serialseq %]
+ <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>
[% IF ( missingissue.status1 ) %]<span class="status-expected">Expected</span>[% END %]
[% IF ( missingissue.status3 ) %]<span class="status-late">Late</span>[% END %]
[% IF ( missingissue.status4 ) %]<span class="status-missing">Missing</span>[% END %]
+ [% IF ( missingissue.status41 ) %]<span class="status-missing_never_received">Missing (never received)</span>[% END %]
+ [% IF ( missingissue.status42 ) %]<span class="status-missing_sold_out">Missing (sold out)</span>[% END %]
+ [% IF ( missingissue.status43 ) %]<span class="status-missing_damaged">Missing (damaged)</span>[% END %]
+ [% IF ( missingissue.status44 ) %]<span class="status-missing_lost">Missing (lost)</span>[% END %]
[% IF ( missingissue.status7 ) %]<span class="status-claimed">Claimed</span>[% END %]
</td>
<td class="planneddate">
- [% missingissue.planneddate %]
+ [% IF ( missingissue.planneddate ) %]
+ <span title="[% missingissue.planneddateISO | html %]">[% missingissue.planneddate | html %]</span>
+ [% ELSE %]
+ <span title="0000-00-00"></span>
+ [% END %]
</td>
+ <td>[% missingissue.claims_count | html %]</td>
<td>
- [% missingissue.claimdate %]
+ [% IF ( missingissue.claimdate ) %]
+ <span title="[% missingissue.claimdateISO | html %]">[% missingissue.claimdate | html %]</span>
+ [% ELSE %]
+ <span title="0000-00-00"></span>
+ [% END %]
</td>
+ [% FOR field IN additional_fields_for_subscription %]
+ [% IF field.authorised_value_category %]
+ <td>[% AuthorisedValues.GetByCode( field.authorised_value_category, missingissue.additional_fields.${field.name} ) | html %]</td>
+ [% ELSE %]
+ <td>[% missingissue.additional_fields.${field.name} | html %]</td>
+ [% END %]
+ [% END %]
</tr>
[% END %]</tbody>
</table>
- [% IF csv_profiles %]
- <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 %]">[% csv.profile %]</option>
- [% END %]
- </select>
- <span class="exportSelected"><a id="ExportSelected" href="/cgi-bin/koha/serials/claims.pl">Download selected claims</a></span>
- [% END %]
+ [% IF csv_profiles %]
+ <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>
+ [% END %]
-[% IF ( letter ) %]
- <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 %]">[% letter.name %]</option>
- [% END %]
- </select>
- <input type="hidden" name="op" value="send_alert" /><input type="submit" name="submit" class="button" value="Send notification" /></fieldset>
+ [% 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="send_alert" />
+ <input type="hidden" name="supplierid" value="[% supplierid | html %]" />
+ <input type="submit" name="submit" class="button" value="Send notification" />
+ </fieldset>
[% END %]
</form>
</fieldset>
[% END %]
-[% ELSE %]
+ </main>
+ </div> <!-- /.col-sm-10.col-sm-push-2 -->
+
+ <div class="col-sm-2 col-sm-pull-10">
+ <aside>
+ [% INCLUDE 'serials-menu.inc' %]
+ </aside>
+ </div> <!-- /.col-sm-2.col-sm-pull-10 -->
+ </div> <!-- /.row -->
+
+[% MACRO jsinclude BLOCK %]
+ [% INCLUDE 'calendar.inc' %]
+ [% INCLUDE 'datatables.inc' %]
+ <script>
+ var sTable;
+ $(document).ready(function() {
+ sTable = $("#claimst").dataTable($.extend(true, {}, dataTablesDefaults, {
+ "sDom": 't',
+ "aoColumnDefs": [
+ { "aTargets": [ 0 ], "bSortable": false, "bSearchable": false },
+ { 'sType': "anti-the", 'aTargets' : [ 'anti-the'] },
+ { 'sType': "title-string", 'aTargets' : [ 'title-string'] }
+ ],
+ "bPaginate": false
+ }));
+ sTable.fnAddFilters("filter", "200");
+ $('#supplierid').change(function() {
+ $('#claims').submit();
+ });
-<div id="doc" class="yui-t7">
- <div id="bd">
-
-[% IF ( supplierloop ) %]
- [% FOREACH supplierloo IN supplierloop %]
- [% IF ( supplierloo.name ) %]
- <p><b>[% supplierloo.name %]</b><br />
- [% END %]
- [% IF ( supplierloo.postal ) %]
- [% supplierloo.postal %]<br />
- [% END %]
- [% IF ( supplierloo.contphone ) %]
- Ph: [% supplierloo.contphone %]<br />
- [% END %]
- [% IF ( supplierloo.contfax ) %]
- Fax: [% supplierloo.contfax %]<br />
- [% END %]
- [% IF ( supplierloo.contemail ) %]
- Email: [% supplierloo.contemail %]<br />
- [% END %]
- [% IF ( supplierloo.accountnumber ) %]
- A/C: [% supplierloo.accountnumber %]</p>
- [% END %]
- [% IF ( supplierloo.contact ) %]
- <p>Dear [% supplierloo.contact %]</p>
- [% ELSE %]
- <p>To whom it may concern</p>
- [% END %]
- <p>The following items have not been received from you and are now considered missing:</p>
- [% END %]
-[% END %]
- [% IF ( missingissues ) %]
- <h3>Missing issues</h3>
- <table>
- <tr>
- <td><b>Vendor<b></td>
- <td><b>Title</b></td>
- <td><b>Issue number</b></td>
- <td><b>Missing since</b></td>
- </tr>
- [% FOREACH missingissue IN missingissues %]
- <tr>
- <td>
- [% missingissue.name %]
- </td>
- <td>
- [% missingissue.Title |html %]
- </td>
- <td>
- [% missingissue.serialseq %]
- </td>
- <td>
- [% missingissue.planneddate %]
- </td>
- </tr>
- [% END %]
- </table>
- [% END %]
+ // Checkboxes : Select All / None
+ $("span.checkall").html("<input type=\"checkbox\" name=\"CheckAll\"> "+_("Check All")+"</input>");
-<p class="noprint"><a href="#" onclick="window.print(); return false;">Print</a> <a href="#" class="close">Close</a></p>
-[% END %]
+ $("#CheckAll").click(function() {
+ $("#claimst tr:visible :checkbox").prop('checked', $("#CheckAll").is(':checked'));
+ });
-</div>
-</div>
+ // 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,#to").val("");
+ $("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 = Date_from_syspref($("#from").val()).getTime();
+ var endDate = Date_from_syspref($("#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();
-[% UNLESS ( preview ) %]
-<div class="yui-b">
-[% INCLUDE 'serials-menu.inc' %]
-</div>
+ // 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 %]
-</div>
+
[% INCLUDE 'intranet-bottom.inc' %]