X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fview%2Fquotation.html;h=18625095eac3e11ec43ae89d594eb8610403ee09;hb=6e33e8af0974d49c1c0cf65b1963846d35f6c156;hp=461b5dfb6e2d73d4fb4440266eadc4fca376b714;hpb=8f89376bceb710bceb8d2d3b9dd7fe24e7d47cf3;p=freeside.git diff --git a/httemplate/view/quotation.html b/httemplate/view/quotation.html index 461b5dfb6..18625095e 100755 --- a/httemplate/view/quotation.html +++ b/httemplate/view/quotation.html @@ -1,51 +1,88 @@ <& /elements/header.html, mt('Quotation View'), $menubar &> -%#XXX link to order... +<& /elements/init_overlib.html &> -<%doc> + -XXX resending quotations +% unless ( $quotation->disabled eq 'Y' ) { -% if ( $curuser->access_right('Resend invoices') ) { +% if ( $curuser->access_right('Order customer package') ) { + <& /elements/order_pkg_link.html, + 'label' => emt('Add package'), + 'actionlabel' => emt('Add package'), + map { $_ => $quotation->$_ } qw( quotationnum custnum prospectnum ) + &> +% } - <% mt('Re-print this invoice') |h %> +% if ( $curuser->access_right('One-time charge') ) { + | <& /elements/one_time_charge_link.html, + map { $_ => $quotation->$_ } qw( quotationnum custnum prospectnum ) + &> +% } +

-% if ( grep { $_ ne 'POST' } $cust_bill->cust_main->invoicing_list ) { - | <% mt('Re-email this invoice') |h %> -% } +% if ( 1 ) { #if ( $curuser->access_right('Send quotations') ) -% if ( $conf->exists('hylafax') && length($cust_bill->cust_main->fax) ) { - | <% mt('Re-fax this invoice') |h %> -% } + <& /elements/popup_link.html, + 'action' => "${p}misc/email-quotation.html". + "?quotationnum=$quotationnum", + 'label' => emt('Email this quotation'), + 'actionlabel' => emt('Select recipients'), + #'width' => 540, + #'height' => 336, + &> -

+%# <% mt('Re-print this invoice') |h %> -% } +%#% if ( $conf->exists('hylafax') && length($cust_bill->cust_main->fax) ) { +%# | <% mt('Re-fax this invoice') |h %> +%#% } - +% } + +% if ( $conf->exists('quotation_latex') ) { + | <% mt('View typeset quotation PDF') |h %> +% } + +

+ +% if ( $curuser->access_right('New customer') && $quotation->quotation_pkg ) { + Place order +

+% } -% if ( $curuser->access_right('Order customer package') ) { - <& /elements/order_pkg_link.html, - 'label' => emt('Add package'), - 'actionlabel' => emt('Add package'), - map { $_ => $quotation->$_ } qw( quotationnum custnum prospectnum ) - &> % } -% if ( $conf->exists('quotation_latex') ) { - | <% mt('View typeset quotation PDF') |h %> +% if ( $curuser->access_right('Disable quotation') ) { +% if ( $quotation->disabled eq 'Y' ) { + <% emt('Enable this quotation') %> +% } else { + <% areyousure_link( + "${p}misc/disable-quotation.html?quotationnum=". $quotation->quotationnum, + emt('Are you sure you want to disable this quotation?'), + emt('Disable this quotation'), #tooltip + emt('Disable this quotation'), #link + ) %> +% }

-% } +% } + +% if ( $error ) { +
<% emt('Error calculating quotation: [_1]', $error) %>
+% } % if ( $conf->exists('quotation_html') ) { - <% join('', $quotation->print_html() ) %> + <% join('', $quotation->print_html( preref_callback=>$preref_callback )) %> % } else { % die "quotation_html config missing"; % } % #plaintext quotations?
<% join('', $quotation->print_text() ) %>
- - <& /elements/footer.html &> <%init> @@ -54,6 +91,8 @@ my $curuser = $FS::CurrentUser::CurrentUser; #die "access denied" # unless $curuser->access_right('View quotations'); +my $can_generate_quotation = $curuser->access_right('Generate quotation'); + my $quotationnum; my($query) = $cgi->keywords; if ( $query =~ /^(\d+)$/ ) { @@ -73,21 +112,37 @@ my $quotation = qsearchs({ }); die "Quotation #$quotationnum not found!" unless $quotation; -my $menubar; -if ( my $custnum = $quotation->custnum ) { - my $display_custnum = $quotation->cust_main->display_custnum; - $menubar = menubar( - emt("View this customer (#[_1])",$display_custnum) => "${p}view/cust_main.cgi?$custnum", - ); -} elsif ( my $prospectnum = $quotation->prospectnum ) { - $menubar = menubar( - emt("View this prospect (#[_1])",$prospectnum) => "${p}view/prospect_main.html?$prospectnum", - ); -} +my $error = $quotation->estimate; + +my $menubar = menubar( $quotation->cust_or_prospect_label_link($p) ); my $link = "quotationnum=$quotationnum"; #$link .= ';template='. uri_escape($template) if $template; #$link .= ';notice_name='. $notice_name if $notice_name; +my $preref_callback = sub { + my $quotation_pkg = shift; + $can_generate_quotation ? + areyousure_link("${p}misc/delete-quotation_pkg.html?". $quotation_pkg->quotationpkgnum, + emt('Are you sure you want to remove this package from the quotation?'), + emt('Remove this package'), #tooltip + qq(), #link + ) . + include('/elements/popup_link.html', + action => "${p}edit/quotation_pkg_detail.html?pkgnum=" . + $quotation_pkg->quotationpkgnum, + html_label => qq(), + title => emt('Edit quotation details'), + actionlabel => emt('Edit quotation details'), + color => '#333399', + width => 763, + ) + : ''; +}; + +sub areyousure_link { + my ($url,$msg,$title,$label) = (shift,shift,shift,shift); + ''.$label.''; +}