[Koha-patches] [PATCH] Adding download for Cart and Shelf at OPAC

Henri-Damien LAURENT henridamien.laurent at biblibre.com
Mon Aug 24 23:47:19 CEST 2009


---
 koha-tmpl/opac-tmpl/prog/en/js/basket.js           |   10 +++
 .../prog/en/modules/opac-downloadcart.tmpl         |   24 ++++++
 .../prog/en/modules/opac-downloadshelf.tmpl        |   24 ++++++
 .../opac-tmpl/prog/en/modules/opac-shelves.tmpl    |    1 +
 opac/opac-downloadcart.pl                          |   80 +++++++++++++++++++
 opac/opac-downloadshelf.pl                         |   81 ++++++++++++++++++++
 6 files changed, 220 insertions(+), 0 deletions(-)
 create mode 100644 koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadcart.tmpl
 create mode 100644 koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadshelf.tmpl
 create mode 100755 opac/opac-downloadcart.pl
 create mode 100755 opac/opac-downloadshelf.pl

diff --git a/koha-tmpl/opac-tmpl/prog/en/js/basket.js b/koha-tmpl/opac-tmpl/prog/en/js/basket.js
index 70da7df..958dab3 100644
--- a/koha-tmpl/opac-tmpl/prog/en/js/basket.js
+++ b/koha-tmpl/opac-tmpl/prog/en/js/basket.js
@@ -342,6 +342,16 @@ function sendBasket() {
     var win_form = open(loc,"win_form",optWin);
 }
 
+function downloadBasket() {
+    var nameCookie = "bib_list";
+    var valCookie = readCookie(nameCookie);
+    var strCookie = nameCookie + "=" + valCookie;
+
+    var loc = CGIBIN + "opac-downloadcart.pl?" + strCookie;
+
+    open(loc,"win_form",'dependant=yes,scrollbars=no,resizable=no,height=300,width=450,top=50,left=100');
+}
+
 function printBasket() {
     var loc = document.location + "&print=1";
     document.location = loc;
diff --git a/koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadcart.tmpl b/koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadcart.tmpl
new file mode 100644
index 0000000..aa71a3d
--- /dev/null
+++ b/koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadcart.tmpl
@@ -0,0 +1,24 @@
+<!-- TMPL_INCLUDE NAME="doc-head-open.inc" -->Download shelf<!-- TMPL_INCLUDE NAME="doc-head-close.inc" -->
+</head>
+<body>
+<!-- TMPL_IF NAME="format" -->
+    Your Download should automatically start
+<!-- TMPL_ELSE -->
+<div id="export" class="detailtagcell">    <form method="post" action="/cgi-bin/koha/opac-downloadcart.pl">
+	<label for="format">Download cart:</label>
+        <select name="format" id="format">
+	    <option value="">-- Choose Format --</option>
+	    <option value="iso2709">iso2709</option>
+	    <option value="ris">RIS</option>
+	    <option value="bibtex">BibTex</option>
+	</select>
+	<input type="hidden" name="bib_list" value="<!-- TMPL_VAR NAME="bib_list" -->" />
+	<input type="submit" name="save" value="Go" />
+    </form>
+
+    <p><a class="button" href="#" onclick="javascript:window.close()">Close this window</a></p>
+    </div>
+
+<!-- /TMPL_IF -->
+</body>
+</html>
diff --git a/koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadshelf.tmpl b/koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadshelf.tmpl
new file mode 100644
index 0000000..a36caf0
--- /dev/null
+++ b/koha-tmpl/opac-tmpl/prog/en/modules/opac-downloadshelf.tmpl
@@ -0,0 +1,24 @@
+<!-- TMPL_INCLUDE NAME="doc-head-open.inc" -->Download shelf<!-- TMPL_INCLUDE NAME="doc-head-close.inc" -->
+</head>
+<body>
+<!-- TMPL_IF NAME="format" -->
+    Your Download should automatically start
+<!-- TMPL_ELSE -->
+<div id="export" class="detailtagcell">    <form method="post" action="/cgi-bin/koha/opac-downloadshelf.pl">
+	<label for="format">Download shelf:</label>
+        <select name="format" id="format">
+	    <option value="">-- Choose Format --</option>
+	    <option value="iso2709">iso2709</option>
+	    <option value="ris">RIS</option>
+	    <option value="bibtex">BibTex</option>
+	</select>
+	<input type="hidden" name="shelfid" value="<!-- TMPL_VAR NAME="shelfid" -->" />
+	<input type="submit" name="save" value="Go" />
+    </form>
+
+    <p><a class="button" href="#" onclick="javascript:window.close()">Close this window</a></p>
+    </div>
+
+<!-- /TMPL_IF -->
+</body>
+</html>
diff --git a/koha-tmpl/opac-tmpl/prog/en/modules/opac-shelves.tmpl b/koha-tmpl/opac-tmpl/prog/en/modules/opac-shelves.tmpl
index 5458799..f40408b 100644
--- a/koha-tmpl/opac-tmpl/prog/en/modules/opac-shelves.tmpl
+++ b/koha-tmpl/opac-tmpl/prog/en/modules/opac-shelves.tmpl
@@ -184,6 +184,7 @@ $(function() {
                     <span class="clearall"></span>
                     |
 						<span class="sendlist"><a href="#" class="send tag_hides" onclick="open(CGIBIN+'opac-sendshelf.pl?shelfid=<!-- TMPL_VAR NAME="shelfnumber" -->','win_form','dependant=yes,scrollbars=no,resizable=no,height=300,width=450,top=50,left=100'); return false; ">Send List</a></span>
+                      <a href="#" class="download tag_hides" onclick="open(CGIBIN+'opac-downloadshelf.pl?shelfid=<!-- TMPL_VAR NAME="shelfnumber" -->','win_form','dependant=yes,scrollbars=no,resizable=no,height=300,width=450,top=50,left=100')">Download List</a>
                       <a class="editshelf tag_hides" href="/cgi-bin/koha/opac-shelves.pl?shelfnumber=<!-- TMPL_VAR NAME="shelfnumber" -->&amp;op=modif">Edit List</a>
                       <form method="post" action="opac-shelves.pl" class="tag_hides">
                         <input type="hidden" value="1" name="shelves"/>
diff --git a/opac/opac-downloadcart.pl b/opac/opac-downloadcart.pl
new file mode 100755
index 0000000..25fe7ce
--- /dev/null
+++ b/opac/opac-downloadcart.pl
@@ -0,0 +1,80 @@
+#!/usr/bin/perl
+
+# Copyright 2009 BibLibre
+#
+# This file is part of Koha.
+#
+# Koha is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 2 of the License, or (at your option) any later
+# version.
+#
+# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
+# Suite 330, Boston, MA  02111-1307 USA
+
+use strict;
+use warnings;
+
+use CGI;
+use Encode qw(encode);
+use Switch;
+
+use C4::Auth;
+use C4::Biblio;
+use C4::Items;
+use C4::Output;
+use C4::VirtualShelves;
+use C4::Record;
+use C4::Ris;
+use utf8;
+use open qw( :std :utf8);
+my $query = new CGI;
+
+my ( $template, $borrowernumber, $cookie ) = get_template_and_user (
+    {
+        template_name   => "opac-downloadcart.tmpl",
+        query           => $query,
+        type            => "opac",
+        authnotrequired => 1,
+        flagsrequired   => { borrow => 1 },
+    }
+);
+
+my $bib_list = $query->param('bib_list');
+my $format  = $query->param('format');
+my $dbh     = C4::Context->dbh;
+
+if ($bib_list && $format) {
+
+    my @bibs = split( /\//, $bib_list );
+
+    my $marcflavour         = C4::Context->preference('marcflavour');
+    my $output;
+
+    # retrieve biblios from shelf
+    foreach my $biblio (@bibs) {
+
+	my $record = GetMarcBiblio($biblio);
+
+	switch ($format) {
+	    case "iso2709" { $output .= $record->as_usmarc(); }
+	    case "ris"     { $output .= marc2ris($record); }
+	    case "bibtex"  { $output .= marc2bibtex($record, $biblio); }
+	}
+    }
+
+    print $query->header(
+	-type => 'application/octet-stream',
+	-'Content-Transfer-Encoding' => 'binary',
+	-attachment=>"cart.$format");
+    print $output;
+
+} else { 
+    $template->param(bib_list => $bib_list); 
+    output_html_with_http_headers $query, $cookie, $template->output;
+}
diff --git a/opac/opac-downloadshelf.pl b/opac/opac-downloadshelf.pl
new file mode 100755
index 0000000..b377109
--- /dev/null
+++ b/opac/opac-downloadshelf.pl
@@ -0,0 +1,81 @@
+#!/usr/bin/perl
+
+# Copyright 2009 BibLibre
+#
+# This file is part of Koha.
+#
+# Koha is free software; you can redistribute it and/or modify it under the
+# terms of the GNU General Public License as published by the Free Software
+# Foundation; either version 2 of the License, or (at your option) any later
+# version.
+#
+# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
+# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
+# Suite 330, Boston, MA  02111-1307 USA
+
+use strict;
+use warnings;
+
+use CGI;
+use Encode qw(encode);
+use Switch;
+
+use C4::Auth;
+use C4::Biblio;
+use C4::Items;
+use C4::Output;
+use C4::VirtualShelves;
+use C4::Record;
+use C4::Ris;
+use utf8;
+use open qw( :std :utf8);
+my $query = new CGI;
+
+my ( $template, $borrowernumber, $cookie ) = get_template_and_user (
+    {
+        template_name   => "opac-downloadshelf.tmpl",
+        query           => $query,
+        type            => "opac",
+        authnotrequired => 1,
+        flagsrequired   => { borrow => 1 },
+    }
+);
+
+my $shelfid = $query->param('shelfid');
+my $format  = $query->param('format');
+my $dbh     = C4::Context->dbh;
+
+if ($shelfid && $format) {
+
+    my @shelf               = GetShelf($shelfid);
+    my ($items, $totitems)  = GetShelfContents($shelfid);
+    my $marcflavour         = C4::Context->preference('marcflavour');
+    my $output;
+
+    # retrieve biblios from shelf
+    foreach my $biblio (@$items) {
+	my $biblionumber = $biblio->{biblionumber};
+
+	my $record = GetMarcBiblio($biblionumber);
+
+	switch ($format) {
+	    case "iso2709" { $output .= $record->as_usmarc(); }
+	    case "ris"     { $output .= marc2ris($record); }
+	    case "bibtex"  { $output .= marc2bibtex($record, $biblionumber); }
+	}
+    }
+
+    print $query->header(
+	-type => 'application/octet-stream',
+	-'Content-Transfer-Encoding' => 'binary',
+	-attachment=>"shelf.$format");
+    print $output;
+
+} else { 
+    $template->param(shelfid => $shelfid); 
+    output_html_with_http_headers $query, $cookie, $template->output;
+}
-- 
1.6.0.4




More information about the Koha-patches mailing list