7 use C4::Interface::CGI::Output;
11 my $dbh = C4::Context->dbh;
13 my $op = $query->param('op');
14 my $barcodetype = $query->param('barcodetype');
15 my $title = $query->param('title');
16 my $isbn = $query->param('isbn');
17 my $itemtype = $query->param('itemtype');
18 my $bcn = $query->param('bcn');
19 my $dcn = $query->param('dcn');
20 my $classif = $query->param('classif');
21 my $author = $query->param('author');
22 my $papertype = $query->param('papertype');
23 my $itemnumber = $query->param('itemnumber');
24 my $summary = $query->param('summary');
25 my $startrow = $query->param('startrow');
27 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
29 template_name => "barcodes/label-manager.tmpl",
33 flagsrequired => { catalogue => 1 },
38 if ( $op eq 'save_conf' ) {
39 my $query2 = "DELETE FROM labels_conf";
40 my $sth2 = $dbh->prepare($query2);
43 my $query2 = "INSERT INTO labels_conf
44 ( barcodetype, title, isbn, itemtype, barcode,
45 dewey, class, author, papertype, startrow)
46 values ( ?, ?, ?, ?, ?, ?, ?, ?, ?, ? )";
47 my $sth2 = $dbh->prepare($query2);
49 $barcodetype, $title, $isbn, $itemtype, $bcn,
50 $dcn, $classif, $author, $papertype, $startrow
55 elsif ( $op eq 'add' ) {
56 my $query2 = "INSERT INTO labels ( itemnumber ) values ( ? )";
57 my $sth2 = $dbh->prepare($query2);
58 $sth2->execute($itemnumber);
61 elsif ( $op eq 'deleteall' ) {
62 my $query2 = "DELETE FROM labels";
63 my $sth2 = $dbh->prepare($query2);
67 elsif ( $op eq 'delete' ) {
68 my $query2 = "DELETE FROM labels where itemnumber = ?";
69 my $sth2 = $dbh->prepare($query2);
70 $sth2->execute($itemnumber);
74 # first lets do a read of the labels table , to get the a list of the
75 # currently entered items to be prinited
80 my $query3 = "Select * from labels";
81 my $sth = $dbh->prepare($query3);
86 while ( my $data = $sth->fetchrow_hashref ) {
88 # lets get some summary info from each item
90 select * from biblio,biblioitems,items where itemnumber=? and
91 items.biblioitemnumber=biblioitems.biblioitemnumber and
92 biblioitems.biblionumber=biblio.biblionumber";
94 my $sth1 = $dbh->prepare($query1);
95 $sth1->execute( $data->{'itemnumber'} );
96 my $data1 = $sth1->fetchrow_hashref();
98 $data1->{'labelno'} = $i1;
100 "$data1->{'barcode'}, $data1->{'title'}, $data1->{'isbn'}";
102 push( @resultsloop, $data1 );
109 # this script can be run from the side nav, and is not passed a value for $startrow
110 # so lets get it from the DB
113 my $dbh = C4::Context->dbh;
114 my $query2 = "SELECT * FROM labels_conf LIMIT 1";
115 my $sth = $dbh->prepare($query2);
118 my $data = $sth->fetchrow_hashref;
119 $startrow = $data->{'startrow'};
123 #calc-ing number of sheets
124 my $number_of_results = scalar @resultsloop;
125 my $sheets_needed = ( ( --$number_of_results + $startrow ) / 8 );
126 $sheets_needed = ceil($sheets_needed); # rounding up int's
128 my $tot_labels = ($sheets_needed * 8);
129 my $start_results = ($number_of_results + $startrow);
130 my $labels_remaining = ($tot_labels - $start_results);
133 resultsloop => \@resultsloop,
134 startrow => $startrow,
135 sheets => $sheets_needed,
136 labels_remaining => $labels_remaining,
138 intranetcolorstylesheet =>
139 C4::Context->preference("intranetcolorstylesheet"),
140 intranetstylesheet => C4::Context->preference("intranetstylesheet"),
141 IntranetNav => C4::Context->preference("IntranetNav"),
143 output_html_with_http_headers $query, $cookie, $template->output;