X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fmisc%2Forder_pkg.html;h=2332f20281f208b6a766622d20bf45076a791b9d;hb=dfba562ff61f541ba7c75f2c02b32951b73aa002;hp=f911431542ad052927298a322693445c033920ba;hpb=20bddf47a41b6d064b3cfa4c41e55c157cf0c3de;p=freeside.git diff --git a/httemplate/misc/order_pkg.html b/httemplate/misc/order_pkg.html index f91143154..2332f2028 100644 --- a/httemplate/misc/order_pkg.html +++ b/httemplate/misc/order_pkg.html @@ -1,157 +1,147 @@ -<% include('/elements/header-popup.html', 'Order new package' ) %> - -<% include('/elements/xmlhttp.html', - 'url' => $p.'misc/location.cgi', - 'subs' => [ 'get_location' ], - ) -%> - - - -<% include('/elements/error.html') %> +<& /elements/header-popup.html, mt('Order new package') &> + + + + + + + + +<& /elements/error.html &>
+ +% if ( $svcpart ) { + +% } <% ntable("#cccccc", 2) %> - - Package - - <% include('/elements/select-cust-part_pkg.html', +% if ( $part_pkg ) { + + + <% mt('Package') |h %> + <% $part_pkg->pkg_comment |h %> + +% } else { + <& /elements/tr-select-cust-part_pkg.html, 'curr_value' => $pkgpart, + 'classnum' => -1, 'cust_main' => $cust_main, - 'onchange' => 'enable_order_pkg', - ) - %> + &> +% } + + + <% mt('Start date') |h %> + + <& /elements/input-date-field.html,{ + 'name' => 'start_date', + 'format' => $date_format, + 'value' => $start_date, + 'noinit' => 1, + } &> + (<% mt('leave blank to start immediately') |h %>) +% if ( $cust_main->payby =~ /^(CARD|CHEK)$/ ) { +% my $what = lc(FS::payby->shortname($cust_main->payby)); + + <% mt("Disable automatic $what charge") |h %> + + +% } + +% if ( $curuser->access_right('Discount customer package') ) { + <& /elements/tr-select-discount.html, + 'element_etc' => 'DISABLED', + 'colspan' => 7, + 'cgi' => $cgi, + &> +% } + +% if ( $curuser->access_right('Waive setup fee') ) { + + <% mt('Waive setup fee') |h %> + + +% } + % if ( $conf->exists('pkg_referral') ) { - <% include('/elements/tr-select-part_referral.html', + <& /elements/tr-select-part_referral.html, 'curr_value' => scalar( $cgi->param('refnum') ), #get rid of empty_label first# || $cust_main->refnum, 'disable_empty' => 1, 'multiple' => $conf->exists('pkg_referral-multiple'), 'colspan' => 7, - ) - %> + &> +% } + +% if ( $cgi->param('lock_locationnum') ) { + + + +% } else { + + <& /elements/tr-select-cust_location.html, + 'cgi' => $cgi, + 'cust_main' => $cust_main, + &> + % } - Service location - - + <% mt('Contract end date') |h %> + + <& /elements/input-date-field.html,{ + 'name' => 'contract_end', + 'format' => $date_format, + 'value' => '', + 'noinit' => 1, + } &> -<% include('/elements/location.html', - 'object' => $cust_location, - #'onchange' ? probably not - 'disabled' => ( $locationnum == -1 ? '' : 'DISABLED' ), - 'no_asterisks' => 1, - ) -%> - +% unless ( $cgi->param('lock_locationnum') ) { + + <& /elements/standardize_locations.html, + 'form' => "OrderPkgForm", + 'onlyship' => 1, + 'no_company' => 1, + 'callback' => 'document.OrderPkgForm.submit();', + &> + +% } +
-> +% my $onclick = $cgi->param('lock_locationnum') +% ? 'document.OrderPkgForm.submit()' +% : 'standardize_new_location()'; +" + onClick = "this.disabled=true; <% $onclick %>;" + <% $pkgpart ? '' : 'DISABLED' %> +>
-<%once> - -my @location_fields = qw( address1 address2 city county state zip country ); - - <%init> +my $curuser = $FS::CurrentUser::CurrentUser; + die "access denied" - unless $FS::CurrentUser::CurrentUser->access_right('Order customer package'); + unless $curuser->access_right('Order customer package'); my $conf = new FS::Conf; -my $countrydefault = $conf->config('countrydefault') || 'US'; -my $statedefault = $conf->config('statedefault') - || ($countrydefault eq 'US' ? 'CA' : ''); +my $date_format = $conf->config('date_format') || '%m/%d/%Y'; $cgi->param('custnum') =~ /^(\d+)$/ or die "no custnum"; my $custnum = $1; @@ -161,21 +151,25 @@ my $cust_main = qsearchs({ 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql, }); -my $pkgpart = scalar($cgi->param('pkgpart')); - -$cgi->param('locationnum') =~ /^(\d*)$/ or die "illegal locationnum"; -my $locationnum = $1; -my $cust_location; -if ( $locationnum ) { - $cust_location = qsearchs('cust_location', { 'locationnum' => $locationnum } ) - or die "unknown locationnum"; -} else { - $cust_location = new FS::cust_location; - if ( $cgi->param('error') && $locationnum == -1 ) { - $cust_location->$_( $cgi->param($_) ) foreach @location_fields; - } else { - $cust_location->$_( $cust_main->$_() ) foreach @location_fields; - } +my $part_pkg = ''; +if ( $cgi->param('lock_pkgpart') ) { + $part_pkg = qsearchs({ + 'table' => 'part_pkg', + 'hashref' => { 'pkgpart' => scalar($cgi->param('lock_pkgpart')) }, + 'extra_sql' => ' AND '. FS::part_pkg->agent_pkgs_sql( $cust_main->agent ), + }) + or die "unknown pkgpart ". $cgi->param('lock_pkgpart'); } +my $pkgpart = $part_pkg ? $part_pkg->pkgpart : scalar($cgi->param('pkgpart')); + +my $format = $date_format. ' %T %z (%Z)'; #false laziness w/REAL_cust_pkg.cgi? +my $start_date = ''; +if( ! $conf->exists('order_pkg-no_start_date') ) { + $start_date = $cust_main->next_bill_date; + $start_date = $start_date ? time2str($format, $start_date) : ''; +} + +my $svcpart = scalar($cgi->param('svcpart')); +