X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=labels%2Flabel-edit-template.pl;h=f367a65eca30ff8d7956d05d9b2253fc2697bb4e;hb=c6721b2fceb47f4599d092b6473323b687f9669f;hp=a645feec815f03026a7a1c8160dffb7fdb5b952a;hpb=f46abf8b909257a54c9e2c1fdd999ba30c7ac0ae;p=koha_fer diff --git a/labels/label-edit-template.pl b/labels/label-edit-template.pl index a645feec81..f367a65eca 100755 --- a/labels/label-edit-template.pl +++ b/labels/label-edit-template.pl @@ -25,8 +25,8 @@ use CGI; 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( @@ -50,29 +50,39 @@ 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=''"); + 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'), - template_desc => $cgi->param('template_desc'), - page_width => $cgi->param('page_width'), - page_height => $cgi->param('page_height'), - label_width => $cgi->param('label_width'), - label_height => $cgi->param('label_height'), - top_text_margin => $cgi->param('top_text_margin'), - left_text_margin=> $cgi->param('left_text_margin'), - top_margin => $cgi->param('top_margin'), - left_margin => $cgi->param('left_margin'), - cols => $cgi->param('cols'), - rows => $cgi->param('rows'), - col_gap => $cgi->param('col_gap'), - row_gap => $cgi->param('row_gap'), - units => $cgi->param('units'), + 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', ); - 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(); @@ -81,23 +91,18 @@ elsif ($op eq 'save') { $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')) { @@ -111,10 +116,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(field_list => 'profile_id,printer_name,paper_bin',filter => "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 {