X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=labels%2Flabel-edit-template.pl;h=d4afc5eede7a494608fbedd0809f4bdc0196cba0;hb=refs%2Fheads%2Fkoha_ffzg;hp=f0a6ab077352c1c60722a0647810eecbbc0ad55b;hpb=1705820ed4eed06b2c2a02ff04b92a0630355384;p=koha.git diff --git a/labels/label-edit-template.pl b/labels/label-edit-template.pl index f0a6ab0773..d4afc5eede 100755 --- a/labels/label-edit-template.pl +++ b/labels/label-edit-template.pl @@ -5,33 +5,32 @@ # # 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 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., -# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +# You should have received a copy of the GNU General Public License +# along with Koha; if not, see . -use strict; -use warnings; +use Modern::Perl; -use CGI; +use CGI qw ( -utf8 ); use C4::Auth qw(get_template_and_user); use C4::Output qw(output_html_with_http_headers); -use C4::Creators 1.000000; -use C4::Labels 1.000000; +use C4::Creators; +use C4::Labels; my $cgi = new CGI; my ( $template, $loggedinuser, $cookie ) = get_template_and_user( { - template_name => "labels/label-edit-template.tmpl", + template_name => "labels/label-edit-template.tt", query => $cgi, type => "intranet", authnotrequired => 0, @@ -49,59 +48,64 @@ my $units = get_unit_values(); if ($op eq 'edit') { $label_template = C4::Labels::Template->retrieve(template_id => $template_id); - $profile_list = get_all_profiles(field_list => 'profile_id,printer_name,paper_bin',filter => "template_id=$template_id OR template_id=''"); + $profile_list = get_all_profiles({ fields => [ qw( profile_id printer_name paper_bin ) ], filters => { template_id => [ $template_id, '' ] } } ); + push @$profile_list, {paper_bin => 'N/A', profile_id => 0, printer_name => 'No Profile'}; + foreach my $profile (@$profile_list) { + if ($profile->{'profile_id'} == $label_template->get_attr('profile_id')) { + $profile->{'selected'} = 1; + } + else { + $profile->{'selected'} = 0; + } + } } elsif ($op eq 'save') { - my @params = ( profile_id => $cgi->param('profile_id') || '', - template_code => $cgi->param('template_code') || 'DEFAULT_TEMPLATE', - template_desc => $cgi->param('template_desc') || 'Default description', - page_width => $cgi->param('page_width') || 0, - page_height => $cgi->param('page_height') || 0, - label_width => $cgi->param('label_width') || 0, - label_height => $cgi->param('label_height') || 0, - top_text_margin => $cgi->param('top_text_margin') || 0, - left_text_margin=> $cgi->param('left_text_margin') || 0, - top_margin => $cgi->param('top_margin') || 0, - left_margin => $cgi->param('left_margin') || 0, - cols => $cgi->param('cols') || 0, - rows => $cgi->param('rows') || 0, - col_gap => $cgi->param('col_gap') || 0, - row_gap => $cgi->param('row_gap') || 0, - units => $cgi->param('units') || 'POINT', + my @params = ( profile_id => scalar $cgi->param('profile_id'), + template_code => scalar $cgi->param('template_code') || 'DEFAULT_TEMPLATE', + template_desc => scalar $cgi->param('template_desc') || 'Default description', + page_width => scalar $cgi->param('page_width') || 0, + page_height => scalar $cgi->param('page_height') || 0, + label_width => scalar $cgi->param('label_width') || 0, + label_height => scalar $cgi->param('label_height') || 0, + top_text_margin => scalar $cgi->param('top_text_margin') || 0, + left_text_margin=> scalar $cgi->param('left_text_margin') || 0, + top_margin => scalar $cgi->param('top_margin') || 0, + left_margin => scalar $cgi->param('left_margin') || 0, + cols => scalar $cgi->param('cols') || 0, + rows => scalar $cgi->param('rows') || 0, + col_gap => scalar $cgi->param('col_gap') || 0, + row_gap => scalar $cgi->param('row_gap') || 0, + units => scalar $cgi->param('units') || 'POINT', ); - if ($template_id) { # if a label_id was passed in, this is an update to an existing layout + if ($template_id) { # if a template_id was passed in, this is an update to an existing template $label_template = C4::Labels::Template->retrieve(template_id => $template_id); if ($cgi->param('profile_id') && ($label_template->get_attr('template_id') != $cgi->param('profile_id'))) { - if ($label_template->get_attr('profile_id') > 0) { # no need to get the old one if there was no profile associated + # Release the old profile if one is currently associated + if ($label_template->get_attr('profile_id') > 0) { my $old_profile = C4::Labels::Profile->retrieve(profile_id => $label_template->get_attr('profile_id')); $old_profile->set_attr(template_id => 0); $old_profile->save(); } - my $new_profile = C4::Labels::Profile->retrieve(profile_id => $cgi->param('profile_id')); + my $new_profile = C4::Labels::Profile->retrieve(profile_id => scalar $cgi->param('profile_id')); $new_profile->set_attr(template_id => $label_template->get_attr('template_id')); $new_profile->save(); } + elsif ($cgi->param('profile_id') == 0) { # Disassociate any printer profile from the template + if ($label_template->get_attr('profile_id') > 0) { + my $old_profile = C4::Labels::Profile->retrieve(profile_id => $label_template->get_attr('profile_id')); + $old_profile->set_attr(template_id => 0); + $old_profile->save(); + } + } -# if ($cgi->param('profile_id')) { -# my $old_profile = ($label_template->get_attr('profile_id') ? C4::Labels::Profile->retrieve(profile_id => $label_template->get_attr('profile_id')) : undef); -# my $new_profile = C4::Labels::Profile->retrieve(profile_id => $cgi->param('profile_id')); -# if ($label_template->get_attr('template_id') != $new_profile->get_attr('template_id')) { -# $new_profile->set_attr(template_id => $label_template->get_attr('template_id')); -# $new_profile->save(); -# if ($old_profile) { -# $old_profile->set_attr(template_id => 0); -# $old_profile->save(); -# } -# } -# } $label_template->set_attr(@params); $label_template->save(); } - else { # if no label_id, this is a new layout so insert it + else { # if no template_id, this is a new template so insert it $label_template = C4::Labels::Template->new(@params); my $template_id = $label_template->save(); if ($cgi->param('profile_id')) { - my $profile = C4::Labels::Profile->retrieve(profile_id => $cgi->param('profile_id')); + my $profile = C4::Labels::Profile->retrieve(profile_id => scalar $cgi->param('profile_id')); $profile->set_attr(template_id => $template_id) if $template_id != $profile->get_attr('template_id'); $profile->save(); } @@ -111,10 +115,10 @@ elsif ($op eq 'save') { } else { # if we get here, this is a new layout $label_template = C4::Labels::Template->new(); -} -if ($template_id) { + $profile_list = get_all_profiles({ fields => [ qw( profile_id printer_name paper_bin ) ], filters => { template_id => [''] } }); + push @$profile_list, {paper_bin => 'N/A', profile_id => 0, printer_name => 'No Profile'}; foreach my $profile (@$profile_list) { - if ($profile->{'profile_id'} == $label_template->get_attr('profile_id')) { + if ($profile->{'profile_id'} == 0) { $profile->{'selected'} = 1; } else {