#===================================================================== # LedgerSMB Small Medium Business Accounting # http://www.ledgersmb.org/ # # Copyright (C) 2006 # This work contains copyrighted information from a number of sources all used # with permission. # # This file contains source code included with or based on SQL-Ledger which # is Copyright Dieter Simader and DWS Systems Inc. 2000-2005 and licensed # under the GNU General Public License version 2 or, at your option, any later # version. For a full list including contact information of contributors, # maintainers, and copyright holders, see the CONTRIBUTORS file. # # Original Copyright Notice from SQL-Ledger 2.6.17 (before the fork): # Copyright (c) 2003 # # Author: DWS Systems Inc. # Web: http://www.sql-ledger.org # # # This program 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. # # This program 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 this program; if not, write to the Free Software # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. #====================================================================== # # Batch printing # #====================================================================== use LedgerSMB::BP; use LedgerSMB::Template; 1; # end of main sub search { # $locale->text('Sales Invoices') # $locale->text('Packing Lists') # $locale->text('Pick Lists') # $locale->text('Sales Orders') # $locale->text('Work Orders') # $locale->text('Purchase Orders') # $locale->text('Bin Lists') # $locale->text('Quotations') # $locale->text('RFQs') # $locale->text('Time Cards') my %hiddens; # setup customer/vendor selection BP->get_vc( \%myconfig, \%$form ); my %name; if ( ref $form->{"all_$form->{vc}"} eq 'ARRAY' ) { $name{type} = 'select'; $name{data} = {name => $form->{vc}, options => [{text => '', value => ''}]}; for ( @{ $form->{"all_$form->{vc}"} } ) { push @{$name{data}{options}}, { text => $_->{name}, value => "$_->{name}--$_->{id}" }; } } else { $name{type} = 'input'; $name{data} = {name => $form->{vc}, size => 35}; } # $locale->text('Customer') # $locale->text('Vendor') # $locale->text('Employee') my %label = ( invoice => { title => 'Sales Invoices', name => 'Customer' }, packing_list => { title => 'Packing Lists', name => 'Customer' }, pick_list => { title => 'Pick Lists', name => 'Customer' }, sales_order => { title => 'Sales Orders', name => 'Customer' }, work_order => { title => 'Work Orders', name => 'Customer' }, purchase_order => { title => 'Purchase Orders', name => 'Vendor' }, bin_list => { title => 'Bin Lists', name => 'Vendor' }, sales_quotation => { title => 'Quotations', name => 'Customer' }, request_quotation => { title => 'RFQs', name => 'Vendor' }, timecard => { title => 'Time Cards', name => 'Employee' }, check => { title => 'Check', name => 'Vendor' }, ); $label{invoice}{invnumber} = { label => $locale->text('Invoice Number'), name => 'invnumber', }; $label{invoice}{ordnumber} = { label => $locale->text('Order Number'), name => 'ordnumber', }; $label{sales_quotation}{quonumber} = { label => $locale->text('Quotation Number'), name => 'quonumber', }; $label{packing_list}{invnumber} = $label{invoice}{invnumber}; $label{packing_list}{ordnumber} = $label{invoice}{ordnumber}; $label{pick_list}{invnumber} = $label{invoice}{invnumber}; $label{pick_list}{ordnumber} = $label{invoice}{ordnumber}; $label{sales_order}{ordnumber} = $label{invoice}{ordnumber}; $label{work_order}{ordnumber} = $label{invoice}{ordnumber}; $label{purchase_order}{ordnumber} = $label{invoice}{ordnumber}; $label{bin_list}{ordnumber} = $label{invoice}{ordnumber}; $label{request_quotation}{quonumber} = $label{sales_quotation}{quonumber}; # do one call to text $form->{title} = $locale->text("Print $label{$form->{type}}{title}"); # accounting years if ( @{ $form->{all_years} } ) { # accounting years $form->{selectaccountingyear} = { name => 'year', options => [{text => '', value => ''}] }; for ( @{ $form->{all_years} } ) { push @{$form->{selectaccountingyear}{options}}, { text => $_, value => $_ }; } $form->{selectaccountingmonth} = { name => 'month', options => [{text => '', value => ''}] }; for ( sort keys %{ $form->{all_month} } ) { push @{$form->{selectaccountingmonth}{options}}, { text => $locale->text($form->{all_month}{$_}), value => $_ }; } } $hiddens{vc} = $form->{vc}; $hiddens{type} = $form->{type}; $hiddens{title} = $form->{title}; $hiddens{sort} = 'transdate'; $hiddens{nextsub} = 'list_spool'; $hiddens{path} = $form->{path}; $hiddens{login} = $form->{login}; $hiddens{sessionid} = $form->{sessionid}; my @buttons = ({ name => 'action', value => 'list_spool', text => $locale->text('Continue'), }); my $template = LedgerSMB::Template->new_UI( user => \%myconfig, locale => $locale, template => 'bp-search', ); $template->render({ form => $form, user => \%myconfig, label => \%label, name => \%name, hiddens => \%hiddens, buttons => \@buttons, }); } sub remove { $selected = 0; for $i ( 1 .. $form->{rowcount} ) { if ( $form->{"checked_$i"} ) { $selected = 1; last; } } $form->error( $locale->text('Nothing selected!') ) unless $selected; $form->{title} = $locale->text('Confirm!'); $form->header; print qq|