# This file is part of Koha.
#
+# Copyright 2004 Biblibre
# Parts copyright 2011 Catalyst IT Ltd.
#
-# 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 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 3 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.
+# 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
-
+# You should have received a copy of the GNU General Public License
+# along with Koha; if not, see <http://www.gnu.org/licenses>.
=head1 NAME
=cut
-use strict;
-#use warnings; FIXME - Bug 2505
-use CGI;
+use Modern::Perl;
+use CGI qw ( -utf8 );
use C4::Auth; # get_template_and_user
use C4::Output;
use C4::Acquisition;
-use C4::Dates;
use C4::Debug;
+use C4::Koha;
+use Koha::DateUtils;
my $input = new CGI;
-my $title = $input->param( 'title');
-my $author = $input->param('author');
-my $isbn = $input->param('isbn');
-my $name = $input->param( 'name' );
-my $basket = $input->param( 'basket' );
-my $booksellerinvoicenumber = $input->param( 'booksellerinvoicenumber' );
-my $from_placed_on = $input->param('from');
-$from_placed_on = C4::Dates->new($from_placed_on) if $from_placed_on;
-my $to_placed_on = $input->param('to');
-$to_placed_on = C4::Dates->new($to_placed_on) if $to_placed_on;
+my $do_search = $input->param('do_search') || 0;
my $dbh = C4::Context->dbh;
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
{
- template_name => "acqui/histsearch.tmpl",
+ template_name => "acqui/histsearch.tt",
query => $input,
type => "intranet",
authnotrequired => 0,
- flagsrequired => { acquisition => 1 },
+ flagsrequired => { acquisition => '*' },
debug => 1,
}
);
-my ( $from_iso, $to_iso, $d );
-if ( $d = $input->param('from') ) {
- $from_iso = C4::Dates->new($d)->output('iso');
-}
-if ( $d = $input->param('iso') ) {
- $to_iso = C4::Dates->new($d)->output('iso');
+my $filters = {
+ basket => scalar $input->param('basket'),
+ title => scalar $input->param('title'),
+ author => scalar $input->param('author'),
+ isbn => scalar $input->param('isbn'),
+ name => scalar $input->param('name'),
+ ean => scalar $input->param('ean'),
+ basketgroupname => scalar $input->param('basketgroupname'),
+ budget => scalar $input->param('budget'),
+ booksellerinvoicenumber => scalar $input->param('booksellerinvoicenumber'),
+ budget => scalar $input->param('budget'),
+ orderstatus => scalar $input->param('orderstatus'),
+ ordernumber => scalar $input->param('ordernumber'),
+ search_children_too => scalar $input->param('search_children_too'),
+ created_by => scalar $input->multi_param('created_by'),
+};
+my $from_placed_on = eval { dt_from_string( scalar $input->param('from') ) } || dt_from_string;
+my $to_placed_on = eval { dt_from_string( scalar $input->param('to') ) } || dt_from_string;
+unless ( $input->param('from') ) {
+ # Fill the form with year-1
+ $from_placed_on->subtract( years => 1 );
}
+$filters->{from_placed_on} = output_pref( { dt => $from_placed_on, dateformat => 'iso', dateonly => 1 } ),
+$filters->{to_placed_on} = output_pref( { dt => $to_placed_on, dateformat => 'iso', dateonly => 1 } ),
-my ( $order_loop, $total_qty, $total_price, $total_qtyreceived );
+my $order_loop;
# If we're supplied any value then we do a search. Otherwise we don't.
-my $do_search = $title || $author || $isbn || $name || $basket || $booksellerinvoicenumber ||
- $from_placed_on || $to_placed_on;
if ($do_search) {
- ( $order_loop, $total_qty, $total_price, $total_qtyreceived ) = GetHistory(
- title => $title,
- author => $author,
- isbn => $isbn,
- name => $name,
- from_placed_on => $from_iso,
- to_placed_on => $to_iso,
- basket => $basket,
- booksellerinvoicenumber => $booksellerinvoicenumber,
- );
+ $order_loop = GetHistory(%$filters);
}
-my $from_date = $from_placed_on ? $from_placed_on->output('syspref') : undef;
-my $to_date = $to_placed_on ? $to_placed_on->output('syspref') : undef;
+my $budgetperiods = C4::Budgets::GetBudgetPeriods;
+my $bp_loop = $budgetperiods;
+for my $bp ( @{$budgetperiods} ) {
+ my $hierarchy = C4::Budgets::GetBudgetHierarchy( $$bp{budget_period_id} );
+ for my $budget ( @{$hierarchy} ) {
+ $$budget{budget_display_name} = sprintf("%s", ">" x $$budget{depth} . $$budget{budget_name});
+ }
+ $$bp{hierarchy} = $hierarchy;
+}
$template->param(
- suggestions_loop => $order_loop,
- total_qty => $total_qty,
- total_qtyreceived => $total_qtyreceived,
- total_price => sprintf( "%.2f", $total_price ),
- numresults => $order_loop ? scalar(@$order_loop) : undef,
- title => $title,
- author => $author,
- isbn => $isbn,
- name => $name,
- basket => $basket,
- booksellerinvoicenumber => $booksellerinvoicenumber,
- from_placed_on => $from_date,
- to_placed_on => $to_date,
- DHTMLcalendar_dateformat=> C4::Dates->DHTMLcalendar(),
- dateformat => C4::Dates->new()->format(),
- debug => $debug || $input->param('debug') || 0,
+ order_loop => $order_loop,
+ filters => $filters,
+ bp_loop => $bp_loop,
+ search_done => $do_search,
);
output_html_with_http_headers $input, $cookie, $template->output;