X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/kivitendo-erp.git/blobdiff_plain/4c23c4787a182219447ec7aa1206b7b6288eb26a..b12e8d1411cb7af3a1a9b6f7637692f0758b4741:/bin/mozilla/am.pl diff --git a/bin/mozilla/am.pl b/bin/mozilla/am.pl index 0ce8c2ee6..e34957f94 100644 --- a/bin/mozilla/am.pl +++ b/bin/mozilla/am.pl @@ -47,10 +47,32 @@ require "$form->{path}/common.pl"; # end of main sub add { &{"add_$form->{type}"} } -sub edit { &{"edit_$form->{type}"} } -sub save { &{"save_$form->{type}"} } sub delete { &{"delete_$form->{type}"} } +sub display { + if ($form->{display_nextsub}) { + &{ $form->{display_nextsub} }(); + } else { + &{ $form->{nextsub} }(); + } +} + +sub save { + if ($form->{save_nextsub}) { + &{ $form->{save_nextsub} }(); + } else { + &{ $form->{nextsub} }(); + } +} + +sub edit { + if ($form->{edit_nextsub}) { + &{ $form->{edit_nextsub} }(); + } else { + &{ "edit_$form->{type}" }(); + } +} + sub add_account { $lxdebug->enter_sub(); @@ -2412,97 +2434,218 @@ sub swap_payment_terms { $lxdebug->leave_sub(); } -sub display_stylesheet { +sub display_template { $lxdebug->enter_sub(); - $form->{file} = "css/$myconfig{stylesheet}"; - &display_form; + $form->{edit} = 0; + display_template_form(); $lxdebug->leave_sub(); } -sub display_form { +sub edit_template { $lxdebug->enter_sub(); - $form->{file} =~ s/^(.:)*?\/|\.\.\///g; - $form->{file} =~ s/^\/*//g; - $form->{file} =~ s/$userspath//; + $form->{edit} = 1; + display_template_form(); - $form->error("$!: $form->{file}") unless -f $form->{file}; + $lxdebug->leave_sub(); +} - AM->load_template(\%$form); +sub save_template { + $lxdebug->enter_sub(); - $form->{title} = $form->{file}; + $form->isblank("formname", $locale->text("You're not editing a file.")) unless ($form->{type} eq "stylesheet"); - # if it is anything but html - if ($form->{file} !~ /\.html$/) { - $form->{body} = "
\n$form->{body}\n
"; + my ($filename) = AM->prepare_template_filename(\%myconfig, $form); + if (my $error = AM->save_template($filename, $form->{content})) { + $form->error(sprintf($locale->text("Saving the file '%s' failed. OS error message: %s"), $filename, $error)); } - $form->header; + $form->{edit} = 0; + display_template_form(); - print qq| - + $lxdebug->leave_sub(); +} + +sub display_template_form { + $lxdebug->enter_sub(); -$form->{body} + $form->{formname} =~ s|.*/||; + my $format = $form->{format} eq "html" ? "html" : "tex"; -
{script}> + my $title = $form->{type} eq "stylesheet" ? $locale->text("Edit the stylesheet") : $locale->text("Edit templates"); + $form->{title} = $title; -{file}> - + my $edit_options; -{path}> -{login}> -{password}> + my @hidden = qw(login path password type format); - + if (($form->{type} ne "stylesheet") && !$form->{edit}) { + $edit_options = "

"; -

+ my %formname_setup = + ( + "balance_sheet" => { "translation" => $locale->text('Balance Sheet'), "html" => 1 }, + "bin_list" => $locale->text('Bin List'), + "bwa" => { "translation" => $locale->text('BWA'), "html" => 1 }, + "check" => { "translation" => $locale->text('Check'), "html" => 1 }, + "credit_note" => $locale->text('Credit Note'), + "income_statement" => { "translation" => $locale->text('Income Statement'), "html" => 1 }, + "invoice" => $locale->text('Invoice'), + "packing_list" => $locale->text('Packing List'), + "pick_list" => $locale->text('Pick List'), + "proforma" => $locale->text('Proforma Invoice'), + "purchase_order" => $locale->text('Purchase Order'), + "receipt" => { "translation" => $locale->text('Receipt'), "tex" => 1 }, + "request_quotation" => $locale->text('RFQ'), + "sales_order" => $locale->text('Confirmation'), + "sales_quotation" => $locale->text('Quotation'), + "statement" => $locale->text('Statement'), + "storno_invoice" => $locale->text('Storno Invoice'), + "storno_packing_list" => $locale->text('Storno Packing List'), + "ustva-2004" => { "translation" => $locale->text("USTVA 2004"), "tex" => 1 }, + "ustva-2005" => { "translation" => $locale->text("USTVA 2005"), "tex" => 1 }, + "ustva-2006" => { "translation" => $locale->text("USTVA 2006"), "tex" => 1 }, + "ustva-2007" => { "translation" => $locale->text("USTVA 2007"), "tex" => 1 }, + "ustva" => $locale->text("USTVA"), + "zahlungserinnerung" => $locale->text('Payment Reminder'), + ); - - + my (@values, %labels, $file, $setup); + + while (($file, $setup) = each(%formname_setup)) { + next unless (!ref($setup) || $setup->{$format}); + + push(@values, $file); + $labels{$file} = ref($setup) ? $setup->{translation} : $setup; + } + @values = sort({ $labels{$a} cmp $labels{$b} } @values); + + $edit_options .= + $locale->text("Template") . " " . + NTI($cgi->popup_menu("-name" => "formname", "-default" => $form->{formname}, + "-values" => \@values, "-labels" => \%labels)); + + $form->get_lists("printers" => "ALL_PRINTERS", + "languages" => "ALL_LANGUAGES"); + + @values = (""); + %labels = (); + + foreach my $item (@{ $form->{ALL_LANGUAGES} }) { + next unless ($item->{template_code}); + my $key = "$item->{id}--$item->{template_code}"; + push(@values, $key); + $labels{$key} = $item->{description}; + } + + if (1 != scalar(@values)) { + $edit_options .= + " " . $locale->text("Language") . " " . + NTI($cgi->popup_menu("-name" => "language", "-default" => $form->{language}, + "-values" => \@values, "-labels" => \%labels)); + } + + @values = (""); + %labels = (); + + foreach my $item (@{ $form->{ALL_PRINTERS} }) { + next unless ($item->{template_code}); + my $key = "$item->{id}--$item->{template_code}"; + push(@values, $key); + $labels{$key} = $item->{printer_description}; + } + + if (1 != scalar(@values)) { + $edit_options .= + " " . $locale->text("Printer") . " " . + NTI($cgi->popup_menu("-name" => "printer", "-default" => $form->{printer}, + "-values" => \@values, "-labels" => \%labels)); + } + + $edit_options .= qq| + + + + + +

+ +
|; - $lxdebug->leave_sub(); -} + } else { + push(@hidden, qw(formname language printer)); + } -sub edit_template { - $lxdebug->enter_sub(); + if ($form->{formname} || ($form->{type} eq "stylesheet")) { + my ($filename, $display_filename) = AM->prepare_template_filename(\%myconfig, $form); + my ($content, $lines) = AM->load_template($filename); - AM->load_template(\%$form); + $body = qq| +|; + + if ($form->{edit}) { + $form->{fokus} = "Form.content"; + $body = qq|\n

| . $locale->text('Edit file') . " '" . H($display_filename) . qq|'

\n

| + . NTI($cgi->textarea("-name" => "content", + "-id" => "content", + "-default" => $content, + "-columns" => 100, + "-rows" => 25)) + . qq|

+ +

+ + + +

+|; + + } else { + $content = "\n\n" unless ($content); + + $body = qq| +

| . $locale->text('Display file') . " '" . H($display_filename) . qq|'

- $form->{title} = $locale->text('Edit Template'); + - # convert   to   - $form->{body} =~ s/ / /gi; +

+ +

+

| . H($content) . qq|
+

+|; + + if ($lines > 25) { + $body .= qq| + +|; + } + } + } $form->header; print qq| -
{script}> - -{file}> - - -{path}> -{login}> -{password}> +
$title
- + - +|; + $form->hide_form(@hidden); -
- + print qq| +$edit_options -
+$body + @@ -2511,15 +2654,6 @@ $form->{body} $lxdebug->leave_sub(); } -sub save_template { - $lxdebug->enter_sub(); - - AM->save_template(\%$form); - $form->redirect($locale->text('Template saved!')); - - $lxdebug->leave_sub(); -} - sub config { $lxdebug->enter_sub();