+[% USE raw %]
+[% USE Asset %]
[% USE Branches %]
[% USE Koha %]
[% USE KohaDates %]
+[% SET footerjs = 1 %]
+[% USE AuthorisedValues %]
+[% USE ColumnsSettings %]
+[% USE Price %]
[% INCLUDE 'doc-head-open.inc' %]
-<title>Koha › ILL requests ›</title>
+<title>Koha › ILL requests</title>
[% INCLUDE 'doc-head-close.inc' %]
-<script type="text/javascript" src="[% interface %]/lib/jquery/plugins/jquery.checkboxes.min.js"></script>
-<link rel="stylesheet" type="text/css" href="[% interface %]/[% theme %]/css/datatables.css">
-[% INCLUDE 'datatables.inc' %]
-<script type="text/javascript">
- //<![CDATA[
- $(document).ready(function() {
-
- // Illview Datatable setup
-
- // Fields we don't want to display
- var ignore = [
- 'accessurl',
- 'backend',
- 'completed',
- 'branch',
- 'capabilities',
- 'cost',
- 'medium',
- 'notesopac',
- 'notesstaff',
- 'placed',
- 'replied'
- ];
-
- // Fields we need to expand (flatten)
- var expand = [
- 'metadata',
- 'patron'
- ];
-
- // Expanded fields
- // This is auto populated
- var expanded = {};
-
- // The core fields that should be displayed first
- var core = [
- 'metadata_Author',
- 'metadata_Title',
- 'borrowername',
- 'biblio_id',
- 'branchcode',
- 'status',
- 'updated',
- 'illrequest_id',
- 'action'
- ];
-
- // Extra fields that we need to tack on to the end
- var extra = [ 'action' ];
-
- // Remove any fields we're ignoring
- var removeIgnore = function(dataObj) {
- dataObj.forEach(function(thisRow) {
- ignore.forEach(function(thisIgnore) {
- if (thisRow.hasOwnProperty(thisIgnore)) {
- delete thisRow[thisIgnore];
- }
- });
- });
- };
-
- // Expand any fields we're expanding
- var expandExpand = function(row) {
- expand.forEach(function(thisExpand) {
- if (row.hasOwnProperty(thisExpand)) {
- if (!expanded.hasOwnProperty(thisExpand)) {
- expanded[thisExpand] = [];
- }
- var expandObj = row[thisExpand];
- Object.keys(expandObj).forEach(
- function(thisExpandCol) {
- var expColName = thisExpand + '_' + thisExpandCol;
- // Keep a list of fields that have been expanded
- // so we can create toggle links for them
- if (expanded[thisExpand].indexOf(expColName) == -1) {
- expanded[thisExpand].push(expColName);
- }
- expandObj[expColName] =
- expandObj[thisExpandCol];
- delete expandObj[thisExpandCol];
- }
- );
- $.extend(true, row, expandObj);
- delete row[thisExpand];
- }
- });
- };
-
- // Build a de-duped list of all column names
- var allCols = {};
- core.map(function(thisCore) {
- allCols[thisCore] = 1;
- });
- var unionColumns = function(row) {
- Object.keys(row).forEach(function(col) {
- if (ignore.indexOf(col) == -1) {
- allCols[col] = 1;
- }
- });
- };
-
- // Some rows may not have fields that other rows have,
- // so make sure all rows have the same fields
- var fillMissing = function(row) {
- Object.keys(allCols).forEach(function(thisCol) {
- row[thisCol] = (!row.hasOwnProperty(thisCol)) ?
- null :
- row[thisCol];
- });
- };
-
- // Strip the expand prefix if it exists, we do this for display
- var stripPrefix = function(value) {
- expand.forEach(function(thisExpand) {
- var regex = new RegExp(thisExpand + '_', 'g');
- value = value.replace(regex, '');
- });
- return value;
- };
-
- // Our 'render' function for borrowerlink
- var createPatronLink = function(data, type, row) {
- return '<a title="View borrower details" ' +
- 'href="/cgi-bin/koha/members/moremember.pl?' +
- 'borrowernumber='+row.borrowernumber+'">' +
- row.patron_firstname + ' ' + row.patron_surname +
- '</a>';
- };
-
- // Render function for request ID
- var createRequestId = function(data, type, row) {
- return row.id_prefix + row.illrequest_id;
- };
-
- // Render function for request status
- var createStatus = function(data, type, row, meta) {
- var origData = meta.settings.oInit.originalData;
- if (origData.length > 0) {
- return meta.settings.oInit.originalData[0].capabilities[
- row.status
- ].name;
- } else {
- return '';
- }
- };
-
- // Render function for creating a row's action link
- var createActionLink = function(data, type, row) {
- return '<a class="btn btn-default btn-sm" ' +
- 'href="/cgi-bin/koha/ill/ill-requests.pl?' +
- 'method=illview&illrequest_id=' +
- row.illrequest_id +
- '">Manage request</a>' +
- '</div>';
- };
-
- // Columns that require special treatment
- var specialCols = {
- action: {
- name: '',
- func: createActionLink
- },
- borrowername: {
- name: 'Patron',
- func: createPatronLink
- },
- illrequest_id: {
- name: 'Request number',
- func: createRequestId
- },
- status: {
- name: 'Status',
- func: createStatus
- },
- biblio_id: {
- name: 'Biblio ID'
- },
- branchcode: {
- name: 'Library'
- }
- };
-
- // Helper for handling prefilter column names
- function toColumnName(myVal) {
- return myVal
- .replace(/^filter/, '')
- .replace(/([A-Z])/g, "_$1")
- .replace(/^_/,'').toLowerCase();
- }
-
- // Toggle request attributes in Illview
- $('#toggle_requestattributes').on('click', function(e) {
- e.preventDefault();
- $('#requestattributes').toggleClass('content_hidden');
- });
-
- // Filter partner list
- $('#partner_filter').keyup(function() {
- var needle = $('#partner_filter').val();
- $('#partners > option').each(function() {
- var regex = new RegExp(needle, 'i');
- if (
- needle.length == 0 ||
- $(this).is(':selected') ||
- $(this).text().match(regex)
- ) {
- $(this).show();
- } else {
- $(this).hide();
- }
- });
- });
-
- // Get our data from the API and process it prior to passing
- // it to datatables
- var ajax = $.ajax(
- '/api/v1/illrequests?embed=metadata,patron,capabilities,branch'
- ).done(function() {
- var data = JSON.parse(ajax.responseText);
- // Make a copy, we'll be removing columns next and need
- // to be able to refer to data that has been removed
- var dataCopy = $.extend(true, [], data);
- // Remove all columns we're not interested in
- removeIgnore(dataCopy);
- // Expand columns that need it and create an array
- // of all column names
- $.each(dataCopy, function(k, row) {
- expandExpand(row);
- unionColumns(row);
- });
- // Append any extra columns we need to tag on
- if (extra.length > 0) {
- extra.forEach(function(thisExtra) {
- allCols[thisExtra] = 1;
- });
- }
- // Different requests will have different columns,
- // make sure they all have the same
- $.each(dataCopy, function(k, row) {
- fillMissing(row);
- });
-
- // Assemble an array of column definitions for passing
- // to datatables
- var colData = [];
- Object.keys(allCols).forEach(function(thisCol) {
- // We may have defined a pretty name for this column
- var colName = (
- specialCols.hasOwnProperty(thisCol) &&
- specialCols[thisCol].hasOwnProperty('name')
- ) ?
- specialCols[thisCol].name :
- thisCol;
- // Create the table header for this column
- var str = '<th>' + stripPrefix(colName) + '</th>';
- $(str).appendTo('#illview-header');
- // Create the base column object
- var colObj = {
- name: thisCol,
- className: thisCol
- };
- // We may need to process the data going in this
- // column, so do it if necessary
- if (
- specialCols.hasOwnProperty(thisCol) &&
- specialCols[thisCol].hasOwnProperty('func')
- ) {
- colObj.render = specialCols[thisCol].func;
- } else {
- colObj.data = thisCol;
- }
- colData.push(colObj);
- });
-
- // Create the toggle links for all metadata fields
- var links = [];
- expanded.metadata.forEach(function(thisExpanded) {
- if (core.indexOf(thisExpanded) == -1) {
- links.push(
- '<a href="#" class="toggle-vis" data-column="' +
- thisExpanded + '">' + stripPrefix(thisExpanded) +
- '</a>'
- );
- }
- });
- $('#column-toggle').append(links.join(' | '));
-
- // Initialise the datatable
- var myTable = $('#ill-requests').DataTable($.extend(true, {}, dataTablesDefaults, {
- aoColumnDefs: [ // Last column shouldn't be sortable or searchable
- {
- aTargets: [ 'action' ],
- bSortable: false,
- bSearchable: false
- },
- ],
- aaSorting: [[ 6, 'desc' ]], // Default sort, updated descending
- processing: true, // Display a message when manipulating
- language: {
- loadingRecords: "Please wait - loading requests...",
- zeroRecords: "No requests were found"
- },
- iDisplayLength: 10, // 10 results per page
- sPaginationType: "full_numbers", // Pagination display
- deferRender: true, // Improve performance on big datasets
- data: dataCopy,
- columns: colData,
- originalData: data // Enable render functions to access
- // our original data
- }));
-
- // Reset columns to default
- var resetColumns = function() {
- Object.keys(allCols).forEach(function(thisCol) {
- myTable.column(thisCol + ':name').visible(core.indexOf(thisCol) != -1);
- });
- myTable.columns.adjust().draw(false);
- };
-
- // Handle the click event on a toggle link
- $('a.toggle-vis').on('click', function(e) {
- e.preventDefault();
- var column = myTable.column(
- $(this).data('column') + ':name'
- );
- column.visible(!column.visible());
- });
-
- // Reset column toggling
- $('#reset-toggle').click(function() {
- resetColumns();
- });
-
- // Handle a prefilter request and do the prefiltering
- var filters = $('#ill-requests').data();
- if (typeof filters !== 'undefined') {
- var filterNames = Object.keys(filters).filter(
- function(thisData) {
- return thisData.match(/^filter/);
- }
- );
- filterNames.forEach(function(thisFilter) {
- var filterName = toColumnName(thisFilter) + ':name';
- var regex = '^'+filters[thisFilter]+'$';
- myTable.columns(filterName).search(regex, true, false);
- });
- myTable.draw();
- }
-
- // Initialise column hiding
- resetColumns();
-
- }
- );
-
- });
- //]]>
-</script>
</head>
<body id="illrequests" class="ill">
[% END %]
</div>
-<div id="doc3" class="yui-t2">
- <div id="bd">
- <div id="yui-main">
- <div id="interlibraryloans" class="yui-b">
- [% IF !backends_available %]
+<div class="main container-fluid">
+ <div class="row">
+
+ [% IF query_type == 'illlist' %]
+ <div class="col-sm-2">
+ <aside>
+ <form method="get" id="illfilter_form">
+ <fieldset class="brief">
+ <h3>Filters</h3>
+ <ol>
+ <li>
+ <label for="illfilter_status">Status:</label>
+ <select name="illfilter_status" id="illfilter_status">
+ <option value=""></option>
+ </select>
+ </li>
+ <li>
+ <label for="illfilter_dateplaced_start">Date placed between:</label>
+ <input type="text" name="illfilter_dateplaced_start" id="illfilter_dateplaced_start" class="datepicker" />
+ </li>
+ <li>
+ <label for="illfilter_dateplaced_end">and:</label>
+ <input type="text" name="illfilter_dateplaced_end" id="illfilter_dateplaced_end" class="datepicker" />
+ </li>
+ <li>
+ <label for="illfilter_datemodified_start">Updated between:</label>
+ <input type="text" name="illfilter_datemodified_start" id="illfilter_datemodified_start" class="datepicker" />
+ </li>
+ <li>
+ <label for="illfilter_datemodified_end">and:</label>
+ <input type="text" name="illfilter_datemodified_end" id="illfilter_datemodified_end" class="datepicker" />
+ </li>
+ <li>
+ <label for="illfilter_branchname">Library:</label>
+ <select name="illfilter_branchname" id="illfilter_branchname">
+ <option value=""></option>
+ </select>
+ </li>
+ <li>
+ <label for="illfilter_patron">Patron:</label>
+ <input type="text" name="illfilter_patron" id="illfilter_patron" />
+ </li>
+ </ol>
+ <fieldset class="action">
+ <input type="submit" value="Search" />
+ <input type="button" value="Clear" id="clear_search" />
+ </fieldset>
+ </fieldset>
+ </form> <!-- /#illfilter_form -->
+ </aside>
+ </div> <!-- /.col-sm-2 -->
+ <div class="col-sm-10">
+ <main>
+ [% ELSE %]
+ <div class="col-sm-10 col-sm-offset-2">
+ <main>
+ [% END %]
+ <div id="interlibraryloans">
+ [% IF !backends_available || !has_branch %]
<div class="dialog message">ILL module configuration problem. Take a look at the <a href="/cgi-bin/koha/about.pl#sysinfo">about page</a></div>
[% ELSE %]
[% INCLUDE 'ill-toolbar.inc' %]
<!-- Dispatch on Status -->
<p>We encountered an error:</p>
<p>
- <pre>[% whole.message %] ([% whole.status %])</pre>
+ <pre>[% whole.message | html %] ([% whole.status | html %])</pre>
</p>
[% END %]
[% IF query_type == 'create' %]
<h1>New ILL request</h1>
- [% IF whole.stage == 'copyrightclearance' %]
- <div>
- <p>
- [% Koha.Preference('ILLModuleCopyrightClearance') %]
- </p>
- <a href="?method=create&stage=copyrightclearance&backend=[% whole.value.backend %]"
- class="btn btn-sm btn-default btn-group"><i class="fa fa-check">Yes</i></a>
- <a href="/cgi-bin/koha/ill/ill-requests.pl"
- class="btn btn-sm btn-default btn-group"><i class="fa fa-times">No</i></a>
- </div>
- [% ELSE %]
- [% PROCESS $whole.template %]
- [% END %]
+ [% PROCESS $whole.template %]
[% ELSIF query_type == 'confirm' %]
<h1>Confirm ILL request</h1>
<h1>Cancel a confirmed request</h1>
[% PROCESS $whole.template %]
+ [% ELSIF query_type == 'check_out' and !whole.error %]
+ [% IF !whole.stage || whole.stage == 'form' %]
+ <h1 id="ill-issue-title">Issue requested item to [% INCLUDE 'patron-title.inc' patron = request.patron %]</h1>
+ [% IF !request.biblio_id || request.biblio_id.length == 0 %]
+ <div class="alert">This item cannot be issued as it has no biblio record associated with it</div>
+ [% END %]
+ [% IF whole.value.errors.itemcount %]
+ <div class="alert">The bibliographic record for this request has multiple items, it should only have one. Please fix this then try again.</div>
+ [% END %]
+ [% IF whole.value.errors.item_creation %]
+ <div class="alert">An unknown error occurred while trying to add an item</div>
+ [% END %]
+ [% IF whole.value.errors.item_check_out %]
+ <div class="alert">An unknown error occurred while trying to check out the item</div>
+ [% END %]
+ [% IF whole.value.check_out_errors %]
+ [% IF whole.value.check_out_errors.error.STATS %]
+ <div class="alert">
+ Local use recorded
+ </div>
+ [% ELSE %]
+ <div class="alert">
+ There was a problem checking this item out, please check for problems with the <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% whole.value.patron.borrowernumber | uri %]">patron's account</a>
+ </div>
+ [% END %]
+ [% END %]
+ [% IF request.biblio_id && request.biblio_id.length > 0 && !whole.value.check_out_errors.error.STATS %]
+ <form method="POST" action="/cgi-bin/koha/ill/ill-requests.pl">
+ <fieldset class="rows">
+ <legend>Check out details</legend>
+ [% items = whole.value.biblio.items.unblessed %]
+ [% IF items.size == 1 %]
+ <p>The bibliographic record for this request already has an item attached to it, you are about to check it out</p>
+ [% ELSE %]
+ <p>A bibliographic record for this request exists, but no item. You are about to create an item and check it out</p>
+ [% END %]
+ <ol>
+ <li class="ill_checkout_inhouse">
+ <label for="inhouse" class="ill_checkout_inhouse_label">Statistical patron:</label>
+ <select id="ill_checkout_inhouse_select" name="inhouse" class="ill_checkout_inhouse_select">
+ <option value=""></option>
+ [% FOREACH stat IN whole.value.statistical %]
+ [% IF stat.borrowernumber == params.inhouse %]
+ <option value="[% stat.cardnumber | html %]" selected>[% INCLUDE 'patron-title.inc' patron = stat %]</option>
+ [% ELSE %]
+ <option value="[% stat.cardnumber | html %]">[% INCLUDE 'patron-title.inc' patron = stat %]</option>
+ [% END %]
+ [% END %]
+ </select>
+ [% IF whole.value.errors.inhouse %]
+ <span class="required">You must choose a valid patron</span>
+ [% END %]
+ <div class="hint">If you do not wish to check out the item to [% INCLUDE 'patron-title.inc' patron = request.patron %] and would rather issue it to an in-house statistical patron, choose the patron here</div>
+ </li>
+ <li class="ill_checkout_item_type">
+ <label for="item_type" class="ill_checkout_item_type_label required">Item type:</label>
+ [% IF items.size != 1 %]
+ <select id="ill_checkout_item_type_select" name="item_type" required>
+ [% FOREACH type IN whole.value.itemtypes %]
+ [% IF type.itemtype == params.item_type %]
+ <option value="[% type.itemtype | html %]" selected>
+ [% ELSE %]
+ <option value="[% type.itemtype | html %]">
+ [% END %]
+ [% type.description | html %]
+ </option>
+ [% END %]
+ </select>
+ [% ELSE %]
+ [% FOREACH type IN whole.value.itemtypes %]
+ [% IF type.itemtype == items.0.itype %]
+ [% type.description | html %]
+ [% END %]
+ [% END %]
+ [% END %]
+ [% IF whole.value.errors.item_type %]
+ <span class="required">You must choose an item type</span>
+ [% END %]
+ </li>
+ [% IF items.size == 1 %]
+ <li>
+ <label for="barcode" class="ill_checkout_barcode_label">Item barcode:</label>
+ [% items.0.barcode | html %]
+ </li>
+ [% END %]
+ <li class="ill_checkout_branchcode">
+ <label for="branchcode" class="ill_checkout_branchcode_label required">Library:</label>
+ [% branchcode = items.size == 1 ? items.0.homebranch : params.branchcode ? params.branchcode : request.branchcode %]
+ [% IF items.size != 1 %]
+ <select name="branchcode" id="ill_checkout_branchcode_select" required>
+ [% PROCESS options_for_libraries libraries => Branches.all( selected => branchcode ) %]
+ </select>
+ [% ELSE %]
+ [% FOREACH branch IN whole.value.libraries.unblessed %]
+ [% IF branch.branchcode == branchcode %]
+ [% branch.branchname | html %]
+ [% END %]
+ [% END %]
+ [% END %]
+ [% IF whole.value.errors.branchcode %]
+ <span class="required">You must choose a branch</span>
+ [% END %]
+ </li>
+ <li class="ill_checkout_due_date">
+ <label for="duedate" class="ill_checkout_duedate_label">Due date:</label>
+ <input name="duedate" id="ill_checkout_duedate_input" type="text" value="[% params.duedate | html %]"> [% INCLUDE 'date-format.inc' %]
+ <div class="hint">If you do not specify a due date, it will be set according to circulation rules</p>
+ </li>
+ </ol>
+ </fieldset>
+ <fieldset class="action">
+ <input type="hidden" value="check_out" name="method">
+ <input type="hidden" value="form" name="stage">
+ [% IF items.size == 1 %]
+ <input name="branchcode" type="hidden" value="[% branchcode | html %]">
+ <input name="item_type" type="hidden" value="[% items.0.itype | html %]">
+ [% END %]
+ <input type="hidden" value="[% request.illrequest_id | html %]" name="illrequest_id">
+ <input type="submit" value="Submit">
+ <a class="cancel" href="/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=[% request.id | html %]">Cancel</a>
+ </fieldset>
+ </form>
+ [% END %]
+ [% IF whole.value.check_out_errors.error.STATS %]
+ <a class="cancel" href="/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=[% request.id | html %]">Return to request</a>
+ [% END %]
+ [% ELSIF whole.stage == 'done_check_out' %]
+ <h1>Item checked out</h1>
+ <fieldset class="rows">
+ <legend>Check out details</legend>
+ <ol>
+ <li>
+ <label>Checked out to:</label>
+ [% INCLUDE 'patron-title.inc' patron = whole.value.patron %]
+ </li>
+ <li>
+ <label>Due date:</label>
+ [% whole.value.check_out.date_due | $KohaDates with_hours => 1 %]
+ </li>
+ </ol>
+ </fieldset>
+ <fieldset class="action">
+ <a class="cancel" href="/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=[% request.id | html %]">Return to request</a>
+ </fieldset>
+ [% END %]
+
[% ELSIF query_type == 'generic_confirm' %]
<h1>Place request with partner libraries</h1>
[% IF error %]
- <div class="alert">
[% IF error == 'no_target_email' %]
- No target email addresses found. Either select at least
- one partner or check your ILL partner library records.
+ <div class="alert">
+ No target email addresses found. Either select at least
+ one partner or check your ILL partner library records.
+ </div>
[% ELSIF error == 'no_library_email' %]
- Your library has no usable email address. Please set it.
+ <div class="alert">
+ Your library has no usable email address. Please set it.
+ </div>
[% ELSIF error == 'unkown_error' %]
- Unknown error processing your request. Contact your administrator.
+ <div class="alert">
+ Unknown error processing your request. Contact your administrator.
+ </div>
[% END %]
- </div>
[% END %]
<!-- Start of GENERIC_EMAIL case -->
[% IF whole.value.partners %]
- [% ill_url = here_link _ "?method=illview&illrequest_id=" _ request.illrequest_id %]
- <form method="POST" action=[% here_link %]>
+ [% ill_url = "/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=" _ request.illrequest_id %]
+ <form method="POST" action="/cgi-bin/koha/ill/ill-requests.pl">
<fieldset class="rows">
<legend>Interlibrary loan request details</legend>
<ol>
<li>
<label for="partner_filter">Filter partner libraries:</label>
- <input type="text" id="partner_filter">
+ <input type="text" id="partner_filter" />
</li>
<li>
- <label for="partners">Select partner libraries:</label>
- <select size="5" multiple="true" id="partners"
- name="partners">
+ <label for="partners" class="required">Select partner libraries:</label>
+ <select size="5" multiple="true" id="partners" name="partners" required="required">
[% FOREACH partner IN whole.value.partners %]
- <option value=[% partner.email %]>
+ <option value=[% partner.email | html %]>
[% partner.branchcode _ " - " _ partner.surname %]
</option>
[% END %]
</li>
<li>
- <label for="subject">Subject Line</label>
- <input type="text" name="subject"
- id="subject" type="text"
- value="[% whole.value.draft.subject %]"/>
+ <label for="subject" class="required">Subject line:</label>
+ <input type="text" name="subject" id="subject" type="text" value="[% whole.value.draft.subject | html %]" required="required" />
</li>
<li>
- <label for="body">Email text:</label>
- <textarea name="body" id="body" rows="20" cols="80">[% whole.value.draft.body %]</textarea>
+ <label for="body" class="required">Email text:</label>
+ <textarea name="body" id="body" rows="20" cols="80" required="required">[% whole.value.draft.body | html %]</textarea>
</li>
</ol>
<input type="hidden" value="generic_confirm" name="method">
<input type="hidden" value="draft" name="stage">
- <input type="hidden" value="[% request.illrequest_id %]" name="illrequest_id">
+ <input type="hidden" value="[% request.illrequest_id | html %]" name="illrequest_id">
</fieldset>
<fieldset class="action">
<input type="submit" class="btn btn-default" value="Send email"/>
- <span><a href="[% ill_url %]" title="Return to request details">Cancel</a></span>
+ <span><a href="[% ill_url | url %]" title="Return to request details">Cancel</a></span>
</fieldset>
</form>
[% ELSE %]
<legend>Interlibrary loan request details</legend>
<p>No partners have been defined yet. Please create appropriate patron records (by default ILLLIBS category).</p>
<p>Be sure to provide email addresses for these patrons.</p>
- <p><span><a href="[% ill_url %]" title="Return to request details">Cancel</a></span></p>
+ <p><span><a href="[% ill_url | url %]" title="Return to request details">Cancel</a></span></p>
</fieldset>
[% END %]
<!-- generic_confirm ends here -->
[% ELSIF query_type == 'edit_action' %]
- <form method="POST" action=[% here_link %]>
+ <form method="POST" action="/cgi-bin/koha/ill/ill-requests.pl">
<fieldset class="rows">
<legend>Request details</legend>
<ol>
+ [% type = request.get_type %]
<li class="borrowernumber">
<label for="borrowernumber">Patron ID:</label>
- <input name="borrowernumber" id="borrowernumber" type="text" value="[% request.borrowernumber %]">
+ [% request.borrowernumber | html %]
</li>
<li class="biblio_id">
- <label for="biblio_id" class="biblio_id">Biblio ID:</label>
- <input name="biblio_id" id="biblio_id" type="text" value="[% request.biblio_id %]">
+ <label for="biblio_id" class="biblio_id">Bibliographic record ID:</label>
+ <input name="biblio_id" id="biblio_id" type="text" value="[% request.biblio_id | html %]">
</li>
<li class="branchcode">
- <label for="branchcode" class="branchcode">Library:</label>
- <select name="branchcode" id="branch">
- [% FOREACH branch IN branches %]
- [% IF ( branch.branchcode == request.branchcode ) %]
- <option value="[% branch.branchcode %]" selected="selected">
- [% branch.branchname %]
- </option>
- [% ELSE %]
- <option value="[% branch.branchcode %]">
- [% branch.branchname %]
- </option>
- [% END %]
- [% END %]
+ <label for="library" class="branchcode">Library:</label>
+ <select name="branchcode" id="library">
+ [% PROCESS options_for_libraries libraries => Branches.all( selected => request.branchcode ) %]
</select>
</li>
<li class="status">
<label class="status">Status:</label>
[% stat = request.status %]
- [% request.capabilities.$stat.name %]
+ [% current_alias = request.status_alias %]
+ <select id="status_alias" name="status_alias">
+ [% IF !current_alias %]
+ <option value="" selected>
+ [% ELSE %]
+ <option value="">
+ [% END %]
+ [% request.capabilities.$stat.name | html %]
+ </option>
+ [% FOREACH alias IN AuthorisedValues.Get('ILLSTATUS') %]
+ [% IF alias.authorised_value == current_alias %]
+ <option value="[% alias.authorised_value | html %]" selected>
+ [% ELSE %]
+ <option value="[% alias.authorised_value | html %]">
+ [% END %]
+ [% alias.lib | html %]
+ </option>
+ [% END %]
+ </select>
</li>
<li class="updated">
<label class="updated">Last updated:</label>
- [% request.updated | $KohaDates with_hours => 1 %]
+ [% request.updated | $KohaDates with_hours => 1 %]
</li>
<li class="medium">
<label class="medium">Request type:</label>
- [% request.medium %]
+ [% IF type %][% type | html %][% ELSE %]<span>N/A</span>[% END %]
</li>
<li class="cost">
<label class="cost">Cost:</label>
- [% request.cost || 'N/A' %]
+ [% IF request.cost %][% request.cost | $Price %][% ELSE %]<span>N/A</span>[% END %]
+ </li>
+ <li class="price_paid">
+ <label class="price_paid">Price paid:</label>
+ <input name="price_paid" id="price_paid" type="text" value="[% request.price_paid | html %]">
</li>
<li class="req_id">
<label class="req_id">Request number:</label>
- [% request.id_prefix _ request.illrequest_id %]
+ [% request.id_prefix _ request.illrequest_id | html %]
</li>
<li class="notesstaff">
<label for="notesstaff" class="notesstaff">Staff notes:</label>
- <textarea name="notesstaff" id="notesstaff" rows="5">[% request.notesstaff %]</textarea>
+ <textarea name="notesstaff" id="notesstaff" rows="5">[% request.notesstaff | html %]</textarea>
</li>
<li class="notesopac">
<label for="notesopac" class="notesopac">Opac notes:</label>
- <textarea name="notesopac" id="notesopac" rows="5">[% request.notesopac %]</textarea>
+ <textarea name="notesopac" id="notesopac" rows="5">[% request.notesopac | html %]</textarea>
</li>
</ol>
</fieldset>
<fieldset class="action">
<input type="hidden" value="edit_action" name="method">
<input type="hidden" value="form" name="stage">
- <input type="hidden" value="[% request.illrequest_id %]" name="illrequest_id">
+ <input type="hidden" value="[% request.illrequest_id | html %]" name="illrequest_id">
+ <input type="hidden" value="[% request.borrowernumber | html %]" name="borrowernumber">
<input type="submit" value="Submit">
- <a class="cancel" href="/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=[% request.id %]">Cancel</a>
+ <a class="cancel" href="/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=[% request.id | html %]">Cancel</a>
</fieldset>
</form>
<div class="dialog alert">
<h3>Are you sure you wish to delete this request?</h3>
- <p>
- <a class="btn btn-default btn-sm approve" href="?method=delete&illrequest_id=[% request.id %]&confirmed=1"><i class="fa fa-fw fa-check"></i>Yes</a>
- <a class="btn btn-default btn-sm deny" href="?method=illview&illrequest_id=[% request.id %]"><i class="fa fa-fw fa-remove"></i>No</a>
- </p>
+ <form action="/cgi-bin/koha/ill/ill-requests.pl" method="post">
+ <input type="hidden" name="method" value="delete" />
+ <input type="hidden" name="confirmed" value="1" />
+ <input type="hidden" name="illrequest_id" value="[% request.id | html %]" />
+ <button type="submit" class="btn btn-default approve"><i class="fa fa-fw fa-check"></i> Yes, delete</button>
+ </form>
+ <a class="btn btn-default deny" href="/cgi-bin/koha/ill/ill-requests.pl?method=illview&illrequest_id=[% request.id | html %]"><i class="fa fa-fw fa-remove"></i>No, do not delete</a>
</div>
-
[% ELSIF query_type == 'illview' %]
- [% actions = request.available_actions %]
- [% capabilities = request.capabilities %]
[% req_status = request.status %]
+
+ [% IF error %]
+ [% IF error == 'migrate_target' %]
+ <div class="alert">
+ The backend you tried to migrate to does not yet support migrations, please try again with an alternative target.
+ </div>
+ [% END %]
+ [% END %]
+
<h1>Manage ILL request</h1>
- <div id="toolbar" class="btn-toolbar">
- <a title="Edit request" id="ill-toolbar-btn-edit-action" class="btn btn-sm btn-default" href="/cgi-bin/koha/ill/ill-requests.pl?method=edit_action&illrequest_id=[% request.illrequest_id %]">
+ <div id="request-toolbar" class="btn-toolbar">
+ <a title="Edit request" id="ill-toolbar-btn-edit-action" class="btn btn-default" href="/cgi-bin/koha/ill/ill-requests.pl?method=edit_action&illrequest_id=[% request.illrequest_id | html %]">
<span class="fa fa-pencil"></span>
Edit request
</a>
- [% FOREACH action IN actions %]
- [% IF action.method != 0 %]
- <a title="[% action.ui_method_name %]" id="ill-toolbar-btn-[% action.id | lower %]" class="btn btn-sm btn-default" href="/cgi-bin/koha/ill/ill-requests.pl?method=[% action.method %]&illrequest_id=[% request.illrequest_id %]">
- <span class="fa [% action.ui_method_icon %]"></span>
- [% action.ui_method_name %]
+ [% FOREACH action IN request.available_actions %]
+ [% needs_prefs = action.needs_prefs.size ? action.needs_prefs : [] %]
+ [% needs_perms = action.needs_perms.size ? action.needs_perms : [] %]
+ [% needs_all = action.needs_all.size ? action.needs_all : [] %]
+ [% has_prefs_count = 0 %]
+ [% has_perms_count = 0 %]
+ [% has_all_count = 0 %]
+ [% FOREACH pref IN needs_prefs %]
+ [% IF Koha.Preference(pref) %]
+ [% has_prefs_count = has_prefs_count + 1 %]
+ [% END %]
+ [% END %]
+ [% FOREACH perm IN needs_perms %]
+ [% perm_name = 'CAN_' _ perm %]
+ [% IF ($perm_name) %]
+ [% has_perms_count = has_perms_count + 1 %]
+ [% END %]
+ [% END %]
+ [% FOREACH func IN needs_all %]
+ [% IF func(request) %]
+ [% has_all_count = has_all_count + 1 %]
+ [% END %]
+ [% END %]
+ [% NEXT IF has_prefs_count < needs_prefs.size || has_perms_count < needs_perms.size || has_all_count < needs_all.size %]
+ [% IF action.method == 'migrate' %]
+ [% IF backends.size > 2 %]
+ <div class="dropdown btn-group">
+ <button class="btn btn-default dropdown-toggle" type="button" id="ill-migrate-dropdown" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">
+ <i class="fa [% action.ui_method_icon | html %]"></i> [% action.ui_method_name | html %] <span class="caret"></span>
+ </button>
+ <ul class="dropdown-menu" aria-labelledby="ill-migrate-dropdown">
+ [% FOREACH backend IN backends %]
+ [% IF backend != request.backend %]
+ <li><a href="/cgi-bin/koha/ill/ill-requests.pl?method=[% action.method | uri %]&illrequest_id=[% request.illrequest_id | uri %]&backend=[% backend | uri %]">[% backend | html %]</a></li>
+ [% END %]
+ [% END %]
+ </ul>
+ </div>
+ [% ELSIF backends.size == 2 %]
+ [% FOREACH backend IN backends %]
+ [% IF backend != request.backend %]
+ <a title="[% action.ui_method_name | html %]" id="ill-toolbar-btn-[% action.id | lower | html %]" class="btn btn-default" href="/cgi-bin/koha/ill/ill-requests.pl?method=[% action.method | uri %]&illrequest_id=[% request.illrequest_id | uri %]&backend=[% backend | uri %]">
+ <span class="fa [% action.ui_method_icon | html %]"></span>
+ [% action.ui_method_name | html %]
+ </a>
+ [% END %]
+ [% END %]
+ [% END %]
+ [% ELSIF action.method != 0 %]
+ <a title="[% action.ui_method_name | html %]" id="ill-toolbar-btn-[% action.id | lower | html %]" class="btn btn-default" href="/cgi-bin/koha/ill/ill-requests.pl?method=[% action.method | uri %]&illrequest_id=[% request.illrequest_id | uri %]">
+ <span class="fa [% action.ui_method_icon | html %]"></span>
+ [% action.ui_method_name | html %]
</a>
[% END %]
[% END %]
+ <a title="Display supplier metadata" id="ill-request-display-metadata" class="btn btn-default pull-right" href="#">
+ <span class="fa fa-eye"></span>
+ Display supplier metadata
+ </a>
+ <a title="ILL request log" id="ill-request-display-log" class="btn btn-default pull-right" href="#">
+ <span class="fa fa-calendar"></span>
+ ILL request log
+ </a>
</div>
- <div id="ill-view-panel" class="panel panel-default">
+ <div class="ill-view-panel panel panel-default">
<div class="panel-heading">
<h3>Request details</h3>
</div>
<div class="panel-body">
<h4>Details from library</h4>
<div class="rows">
- <div class="orderid">
- <span class="label orderid">Order ID:</span>
- [% request.orderid || "N/A" %]
- </div>
- <div class="borrowernumber">
- <span class="label borrowernumber">Patron:</span>
- [% borrowerlink = "/cgi-bin/koha/members/moremember.pl" _ "?borrowernumber=" _ request.patron.borrowernumber %]
- <a href="[% borrowerlink %]" title="View borrower details">
- [% request.patron.firstname _ " " _ request.patron.surname _ " [" _ request.patron.cardnumber _ "]" %]
- </a>
- </div>
+ <ol>
+ <li class="orderid">
+ <span class="label orderid">Order ID:</span>
+ [% IF request.orderid %][% request.orderid | html %][% ELSE %]<span>N/A</span>[% END %]
+ </li>
+ <li class="borrowernumber">
+ <span class="label borrowernumber">Patron:</span>
+ [% borrowerlink = "/cgi-bin/koha/members/moremember.pl" _ "?borrowernumber=" _ request.patron.borrowernumber %]
+ <a href="[% borrowerlink | url %]" title="View borrower details">
+ [% request.patron.firstname _ " " _ request.patron.surname _ " [" _ request.patron.cardnumber _ "]" | html %]
+ </a>
+ </li>
- <div class="biblio_id">
- <span class="label biblio_id">Biblio ID:</span>
- [% request.biblio_id || "N/A" %]
- </div>
- <div class="branchcode">
- <span class="label branchcode">Library:</span>
- [% Branches.GetName(request.branchcode) %]
- </div>
- <div class="status">
- <span class="label status">Status:</span>
- [% capabilities.$req_status.name %]
- </div>
- <div class="updated">
- <span class="label updated">Last updated:</span>
- [% request.updated | $KohaDates with_hours => 1 %]
+ <li class="biblio_id">
+ <span class="label biblio_id">Bibliographic record ID:</span>
+ [% IF request.biblio_id %]
+ <a href="/cgi-bin/koha/catalogue/detail.pl?biblionumber=[% request.biblio_id | uri %]">[% request.biblio_id | html %]</a>
+ [% ELSE %]
+ <span>N/A</span>
+ [% END %]
+ </li>
+ <li class="branchcode">
+ <span class="label branchcode">Library:</span>
+ [% Branches.GetName(request.branchcode) | html %]
+ </li>
+ <li class="status">
+ <span class="label status">Status:</span>
+ [% IF request.statusalias %]
+ [% request.statusalias.lib | html %]
+ [% ELSE %]
+ [% request.capabilities.$req_status.name | html%]
+ [% IF request.requested_partners.length > 0 %]
+ ([% request.requested_partners | html %])
+ [% END %]
+ [% END %]
+ </li>
+ <li class="updated">
+ <span class="label updated">Last updated:</span>
+ [% request.updated | $KohaDates with_hours => 1 %]
+ </li>
+ <li class="medium">
+ <span class="label medium">Request type:</span>
+ [% type = request.get_type %]
+ [% IF type %][% type | html %][% ELSE %]<span>N/A</span>[% END %]
+ </li>
+ <li class="cost">
+ <span class="label cost">Cost:</span>
+ [% IF request.cost %][% request.cost | $Price %][% ELSE %]<span>N/A</span>[% END %]
+ </li>
+ <li class="price_paid">
+ <span class="label price_paid">Price paid:</span>
+ [% IF request.price_paid %][% request.price_paid | $Price %][% ELSE %]<span>N/A</span>[% END %]
+ </li>
+ <li class="req_id">
+ <span class="label req_id">Request number:</span>
+ [% request.id_prefix _ request.illrequest_id | html %]
+ </li>
+ <li class="notesstaff">
+ <span class="label notes_staff">Staff notes:</span>
+ <p>[% request.notesstaff | html %]</p>
+ </li>
+ <li class="notesopac">
+ <span class="label notes_opac">Notes:</span>
+ <p>[% request.notesopac | html %]</p>
+ </li>
+ </ol>
+ </div>
+ <div class="rows">
+ <h4>Details from supplier ([% request.backend | html %])</h4>
+ <ol>
+ [% FOREACH meta IN request.metadata %]
+ <li class="requestmeta-[% meta.key.replace('\s','_') | html %]">
+ <span class="label">[% meta.key | html %]:</span>
+ [% meta.value | html %]
+ </li>
+ [% END %]
+ </ol>
+ </div>
+ </div>
+ </div>
+
+ <div id="dataPreview" class="modal fade" tabindex="-1" role="dialog" aria-labelledby="dataPreviewLabel" aria-hidden="true">
+ <div class="modal-dialog">
+ <div class="modal-content">
+ <div class="modal-header">
+ <button type="button" class="closebtn" data-dismiss="modal" aria-hidden="true">×</button>
+ <h3 id="dataPreviewLabel"> Supplier metadata</h3>
</div>
- <div class="medium">
- <span class="label medium">Request type:</span>
- [% request.medium %]
+ <div class="modal-body">
+ <div id="requestattributes">
+ [% FOREACH attr IN request.illrequestattributes %]
+ <div class="requestattr-[% attr.type | html %]">
+ <span class="label">[% attr.type | html %]:</span>
+ [% attr.value | html %]
+ </div>
+ [% END %]
+ </div>
</div>
- <div class="cost">
- <span class="label cost">Cost:</span>
- [% request.cost || "N/A" %]
+ <div class="modal-footer">
+ <button class="btn btn-default" data-dismiss="modal" aria-hidden="true">Close</button>
</div>
- <div class="req_id">
- <span class="label req_id">Request number:</span>
- [% request.id_prefix _ request.illrequest_id %]
+ </div>
+ </div>
+ </div>
+
+ <div id="requestLog" class="modal fade" tabindex="-1" role="dialog" aria-labelledby="dataPreviewLabel" aria-hidden="true">
+ <div class="modal-dialog">
+ <div class="modal-content">
+ <div class="modal-header">
+ <button type="button" class="closebtn" data-dismiss="modal" aria-hidden="true">×</button>
+ <h3 id="requestLogLabel"> Request log</h3>
</div>
- <div class="notesstaff">
- <span class="label notes_staff">Staff notes:</span>
- <pre>[% request.notesstaff %]</pre>
+ <div class="modal-body">
+ [% IF request.logs.size > 0 %]
+ [% FOREACH log IN request.logs %]
+ [% tpl = log.template %]
+ [% INCLUDE $tpl log=log %]
+ [% END %]
+ [% ELSE %]
+ There are no recorded logs for this request
+ [% END %]
</div>
- <div class="notesopac">
- <span class="label notes_opac">Notes:</span>
- <pre>[% request.notesopac %]</pre>
+ <div class="modal-footer">
+ <button class="btn btn-default" data-dismiss="modal" aria-hidden="true">Close</button>
</div>
</div>
- <div class="rows">
- <h4>Details from supplier ([% request.backend %])</h4>
- [% FOREACH meta IN request.metadata %]
- <div class="requestmeta-[% meta.key %]">
- <span class="label">[% meta.key %]:</span>
- [% meta.value %]
+ </div>
+ </div>
+
+ <div class="ill-view-panel panel panel-default">
+ <div class="panel-heading">
+ <h3>[% request.illcomments.count | html %] comments</h3>
+ </div>
+ <div class="panel-body">
+ [% IF request.illcomments.count && request.illcomments.count > 0 %]
+ [% FOREACH comment IN request.illcomments %]
+ <div class="rows comment_[% comment.patron.categorycode | html %]">
+ <h5>Comment by:
+ <a href="[% borrowerlink | url %]" title="View borrower details">
+ [% comment.patron.firstname _ " " _ comment.patron.surname _ " [" _ comment.patron.cardnumber _ "]" | html %]</a>
+ [% comment.timestamp | $KohaDates with_hours => 1 %]</h5>
+ <p>[% comment.comment | html %]</p>
</div>
[% END %]
- </div>
- <div class="rows">
- <h3><a id="toggle_requestattributes" href="#">Toggle full supplier metadata</a></h3>
- <div id="requestattributes" class="content_hidden">
- [% FOREACH attr IN request.illrequestattributes %]
- <div class="requestattr-[% attr.type %]">
- <span class="label">[% attr.type %]:</span>
- [% attr.value %]
- </div>
- [% END %]
+ [% END %]
+ <div class="rows">
+ <h3><a id="toggle_addcomment" href="#">Add comment</a></h3>
+ <div id="addcomment" class="content_hidden">
+ <form class="validated" method="post" action="/cgi-bin/koha/ill/ill-requests.pl">
+ <input type="hidden" value="save_comment" name="method">
+ <input type="hidden" value="[% csrf_token | html %]" name="csrf_token">
+ <input type="hidden" value="[% request.illrequest_id | html %]" name="illrequest_id">
+ <fieldset class="rows">
+ <ol>
+ <li>
+ <label class="required" for="comment">Comment: </label>
+ <textarea class="required" required="required" cols="80" rows="10" id="comment" name="comment"></textarea>
+ <span class="required">Required</span>
+ </li>
+ </ol>
+ </fieldset>
+ <fieldset class="action">
+ <input type="submit" value="Submit">
+ </fieldset>
+ </form>
+ </div>
</div>
-
- </div>
</div>
</div>
<h1>View ILL requests</h1>
<div id="results">
<h3>Details for all requests</h3>
+ [% INCLUDE 'ill-list-table.inc' %]
- <div id="column-toggle">
- Toggle additional columns:
- </div>
- <div id="reset-toggle"><a href="#">Reset toggled columns</a></div>
-
- <table
- [% FOREACH filter IN prefilters %]
- data-filter-[% filter.name %]="[% filter.value %]"
- [% END %]
- id="ill-requests">
- <thead>
- <tr id="illview-header"></tr>
- </thead>
- <tbody id="illview-body">
- </tbody>
- </table>
- </div>
+ </div> <!-- /#results -->
[% ELSE %]
<!-- Custom Backend Action -->
- [% INCLUDE $whole.template %]
+ [% PROCESS $whole.template %]
[% END %]
[% END %]
- </div>
- </div>
- </div>
-</div>
+ </div> <!-- /#interlibraryloans -->
+ </main>
+ </div> <!-- /.col-sm-10 -->
+ </div> <!-- /.row -->
+
+
+[% MACRO jsinclude BLOCK %]
+ [% INCLUDE 'datatables.inc' %]
+ [% INCLUDE 'columns_settings.inc' %]
+ [% INCLUDE 'calendar.inc' %]
+ [% Asset.js("lib/jquery/plugins/jquery-ui-timepicker-addon.min.js") | $raw %]
+ [% Asset.js("lib/jquery/plugins/jquery.checkboxes.min.js") | $raw %]
+ <script>
+ var prefilters = '[% prefilters | $raw %]';
+ // Set column settings
+ var columns_settings = [% ColumnsSettings.GetColumns( 'illrequests', 'ill-requests', 'ill-requests', 'json' ) %];
+ $("#ill_checkout_duedate_input").datetimepicker({
+ hour: 23,
+ minute: 59
+ }).on("change", function(e, value) {
+ if ( ! is_valid_date( $(this).val() ) ) {$(this).val("");}
+ });
+ </script>
+ <script>
+ $('#ill_checkout_inhouse_select').on('change', function() {
+ if ($(this).val().length > 0) {
+ $('.ill_checkout_due_date').hide();
+ } else {
+ $('.ill_checkout_due_date').show();
+ }
+ });
+ </script>
+ [% INCLUDE 'ill-list-table-strings.inc' %]
+ [% Asset.js("js/ill-list-table.js") | $raw %]
+[% END %]
[% TRY %]
[% PROCESS backend_jsinclude %]