157 lines
6.3 KiB
Perl
Executable file
157 lines
6.3 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
#
|
|
# Copyright 2006 Katipo Communications.
|
|
# Parts Copyright 2009 Foundations Bible College.
|
|
#
|
|
# 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 vars qw($debug);
|
|
|
|
use Sys::Syslog qw(syslog);
|
|
use CGI;
|
|
use HTML::Template::Pro;
|
|
use Data::Dumper;
|
|
|
|
use C4::Auth;
|
|
use C4::Output;
|
|
use C4::Context;
|
|
use C4::Debug;
|
|
use C4::Labels::Lib 1.000000 qw(get_all_templates get_all_layouts get_all_profiles get_barcode_types get_label_types get_column_names get_table_names SELECT);
|
|
use C4::Labels::Layout 1.000000;
|
|
use C4::Labels::Template 1.000000;
|
|
use C4::Labels::Profile 1.000000;
|
|
|
|
my $cgi = new CGI;
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "labels/label-manage.tmpl",
|
|
query => $cgi,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { catalogue => 1 },
|
|
debug => 1,
|
|
}
|
|
);
|
|
|
|
my $error = 0;
|
|
my $db_rows = {};
|
|
my $column_names = [];
|
|
my $table_names = [];
|
|
|
|
my $display_columns = { layout => [ #db column => display column
|
|
{layout_id => 'Layout ID'},
|
|
{layout_name => 'Layout'},
|
|
{barcode_type => 'Barcode Type'},
|
|
{printing_type => 'Print Type'},
|
|
{format_string => 'Fields to Print'},
|
|
{select => 'Select'},
|
|
],
|
|
template => [ {template_id => 'Template ID'},
|
|
{template_code => 'Template Name'},
|
|
{template_desc => 'Description'},
|
|
{select => 'Select'},
|
|
],
|
|
profile => [ {profile_id => 'Profile ID'},
|
|
{printer_name => 'Printer Name'},
|
|
{paper_bin => 'Paper Bin'},
|
|
{_template_code => 'Template Name'}, # this display column does not have a corrisponding db column in the profile table, hence the underscore
|
|
{select => 'Select'},
|
|
],
|
|
};
|
|
|
|
my $label_element = $cgi->param('label_element') || $ARGV[0];
|
|
my $op = $cgi->param('op') || $ARGV[1] || '';
|
|
my $element_id = $cgi->param('element_id') || $ARGV[2] || '';
|
|
|
|
sub _build_table {
|
|
my $headers = shift;
|
|
my $data = shift;
|
|
my $element = shift;
|
|
my $table = [];
|
|
my $fields = [];
|
|
my @db_columns = ();
|
|
my ($row_index, $col_index) = (0,0);
|
|
my $cols = 0; # number of columns to wrap on
|
|
my $field_count = 0;
|
|
POPULATE_HEADER:
|
|
foreach my $db_column (@$headers) {
|
|
my @key = keys %$db_column;
|
|
push (@db_columns, $key[0]);
|
|
$$fields[$col_index] = {select_field => 0, field_name => ($key[0]), field_label => $db_column->{$key[0]}};
|
|
$field_count++;
|
|
$col_index++;
|
|
}
|
|
$$table[$row_index] = {header_fields => $fields};
|
|
$cols = $col_index;
|
|
$field_count *= scalar(@$data); # total fields to be displayed in the table
|
|
$col_index = 0;
|
|
$row_index++;
|
|
$fields = [];
|
|
POPULATE_TABLE:
|
|
foreach my $db_row (@$data) {
|
|
my $element_id = 0;
|
|
POPULATE_ROW:
|
|
foreach my $db_column (@db_columns) {
|
|
if ($db_column =~ m/^_((.*)_(.*$))/) {
|
|
my $table_name = get_table_names($2);
|
|
my $record_set = SELECT($1, @$table_name[0], $2 . "_id = " . $db_row->{$2 . "_id"});
|
|
$db_row->{$db_column} = $$record_set[0]{$1};
|
|
}
|
|
if (grep {$db_column eq $_} keys %$db_row) {
|
|
$element_id = $db_row->{$db_column} if $db_column =~ m/id/;
|
|
$$fields[$col_index] = {select_field => 0, field_name => ($db_column . "_tbl"), field_value => $db_row->{$db_column}};
|
|
$col_index++;
|
|
}
|
|
}
|
|
$$fields[$col_index] = {select_field => 1, field_name => 'select', field_value => $element_id};
|
|
$$table[$row_index] = {text_fields => $fields};
|
|
$col_index = 0;
|
|
$row_index++;
|
|
$fields = [];
|
|
}
|
|
return $table;
|
|
}
|
|
|
|
if ($op eq 'delete') {
|
|
$error = C4::Labels::Layout::delete(layout_id => $element_id) if $label_element eq 'layout';
|
|
$error = C4::Labels::Template::delete(template_id => $element_id) if $label_element eq 'template';
|
|
$error = C4::Labels::Profile::delete(profile_id => $element_id) if $label_element eq 'profile';
|
|
}
|
|
|
|
$table_names = get_table_names($label_element);
|
|
$column_names = get_column_names(@$table_names[0]);
|
|
$db_rows = get_all_layouts() if $label_element eq 'layout';
|
|
$db_rows = get_all_templates() if $label_element eq 'template';
|
|
$db_rows = get_all_profiles() if $label_element eq 'profile';
|
|
|
|
my $table = _build_table($display_columns->{$label_element}, $db_rows, $label_element);
|
|
|
|
$template->param(error => $error) if ($error ne 0);
|
|
$template->param(
|
|
op => $op,
|
|
element_id => $element_id,
|
|
table_loop => $table,
|
|
label_element => $label_element,
|
|
label_element_title => ($label_element eq 'layout' ? 'Layouts' :
|
|
$label_element eq 'template' ? 'Templates' :
|
|
$label_element eq 'profile' ? 'Profiles' :
|
|
''
|
|
),
|
|
);
|
|
|
|
output_html_with_http_headers $cgi, $cookie, $template->output;
|