X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fedit%2Fpart_pkg.cgi;h=93a3b24c3bf3ceb471b694d787b4ce510089d3d9;hp=a337d2272da132bac4c5a727e3a9c190eff34c6e;hb=c7bf005860b761a55ca075df987fb3b5ade8c242;hpb=2a6aa24137ddd389c1e644f5ece325c5b5dbaf3a diff --git a/httemplate/edit/part_pkg.cgi b/httemplate/edit/part_pkg.cgi index a337d2272..93a3b24c3 100755 --- a/httemplate/edit/part_pkg.cgi +++ b/httemplate/edit/part_pkg.cgi @@ -1,422 +1,842 @@ -<% include("/elements/header.html","$action Package Definition", menubar( - 'Main Menu' => popurl(2), - 'View all packages' => popurl(2). 'browse/part_pkg.cgi', -)) %> -% #), ' onLoad="visualize()"'); - -<% include('/elements/error.html') %> - -
- -<% itable('',8,1) %> - -Package information - -<% ntable("#cccccc",2) %> - - Package Definition # - - <% $hashref->{pkgpart} ? $hashref->{pkgpart} : "(NEW)" %> - - - - Package (customer-visible) - - - - - - Comment (customer-hidden) - - - - - <% include( '/elements/tr-select-pkg_class.html', - 'curr_value' => $part_pkg->classnum, - ) - %> - - Promotional code - - - - - - Disable new orders - - {disabled} eq 'Y' ? ' CHECKED' : '' %> - - - - - - - -Tax information -<% ntable("#cccccc", 2) %> - - Setup fee tax exempt - - {setuptax} eq 'Y' ? ' CHECKED' : '' %>> - - - - Recurring fee tax exempt - - {recurtax} eq 'Y' ? ' CHECKED' : '' %>> - - - -% if ( $conf->exists('enable_taxclasses') ) { - - - Tax class - - <% include('/elements/select-taxclass.html', $hashref->{taxclass} ) %> - - - -% } else { - - <% include('/elements/select-taxclass.html', $hashref->{taxclass} ) %> - -% } - - -
- -Line-item revenue recognition -<% ntable("#cccccc", 2) %> -% tie my %weight, 'Tie::IxHash', -% 'pay_weight' => 'Payment', -% 'credit_weight' => 'Credit' -% ; -% foreach my $weight (keys %weight) { - - <% $weight{$weight} %> weight - - {$weight} || 0 %>> - - -% } - - - - -% if ( $cgi->param('clone') ) { - - - -% } elsif ( scalar(@all_agent_types) == 1) { - - - -% } else { - - Reseller information - <% ntable("#cccccc", 2) %> - - <% 'Agent Types' %> - - <% include( '/elements/select-table.html', - 'element_name' => 'agent_type', - 'table' => 'agent_type', - 'name_col' => 'atype', - 'value' => \@agent_type, - 'multiple' => '1', - 'element_etc' => 'size="10"', - ) - %> - - - - -% } - - - -%my $thead = "\n\n". ntable('#cccccc', 2). -% 'Quan.'. -% 'Primary'. -% 'Service'; - -

Services included -<% itable('', 4, 1) %> -<% $thead %> -% -% -%my $where = "WHERE disabled IS NULL OR disabled = ''"; -%if ( $pkgpart ) { -% $where .= " OR 0 < ( SELECT quantity FROM pkg_svc -% WHERE pkg_svc.svcpart = part_svc.svcpart -% AND pkgpart = $pkgpart -% )"; -%} -%my @part_svc = qsearch('part_svc', {}, '', $where); -%my $q_part_pkg = $clone_part_pkg || $part_pkg; -%my %pkg_svc = map { $_->svcpart => $_ } $q_part_pkg->pkg_svc; -% -%my @fixups = (); -%my $count = 0; -%my $columns = 3; -%foreach my $part_svc ( @part_svc ) { -% my $svcpart = $part_svc->svcpart; -% my $pkg_svc = $pkg_svc{$svcpart} -% || new FS::pkg_svc ( { -% 'pkgpart' => $pkgpart, -% 'svcpart' => $svcpart, -% 'quantity' => 0, -% 'primary_svc' => '', -% } ); -% if ( $cgi->param('error') ) { -% my $primary_svc = ( $pkg_svc->primary_svc =~ /^Y/i ); -% my $pkg_svc_primary = scalar($cgi->param('pkg_svc_primary')); -% $pkg_svc->primary_svc('') -% if $primary_svc && $pkg_svc_primary != $svcpart; -% $pkg_svc->primary_svc('Y') -% if ! $primary_svc && $pkg_svc_primary == $svcpart; -% } -% -% push @fixups, "pkg_svc$svcpart"; -% -% my $quan = 0; -% if ( $cgi->param("pkg_svc$svcpart") =~ /^\s*(\d+)\s*$/ ) { -% $quan = $1; -% } elsif ( $pkg_svc->quantity ) { -% $quan = $pkg_svc->quantity; -% } - - - - - - - - - primary_svc =~ /^Y/i ? ' CHECKED' : '' %>> - - - - <% $part_svc->svc %> <% $part_svc->disabled =~ /^Y/i ? ' (DISABLED' : '' %> - - -% foreach ( 1 .. $columns-1 ) { -% if ( $count == int( $_ * scalar(@part_svc) / $columns ) ) { -% - - <% $thead %> -% } -% } -% $count++; -% -% } - - - -% foreach my $f ( qw( clone pkgnum ) ) { #safe, these were untained in %init - -% } - - -% -% -%# prolly should be in database -%tie my %plans, 'Tie::IxHash', %{ FS::part_pkg::plan_info() }; -% -%my %plandata = map { /^(\w+)=(.*)$/; ( $1 => $2 ); } -% split("\n", ($clone_part_pkg||$part_pkg)->plandata ); -%#warn join("\n", map { "$_: $plandata{$_}" } keys %plandata ). "\n"; -% -%tie my %options, 'Tie::IxHash', map { $_=>$plans{$_}->{'name'} } keys %plans; -% -%#my @form_select = ('classnum'); -%#if ( $conf->exists('enable_taxclasses') ) { -%# push @form_select, 'taxclass'; -%#} else { -%# push @fixups, 'taxclass'; #hidden -%#} -%my @form_elements = ( 'classnum', 'taxclass', 'agent_type' ); -% -%my @form_radio = ( 'pkg_svc_primary' ); -% -%tie my %freq, 'Tie::IxHash', %{FS::part_pkg->freqs_href()}; -%if ( $part_pkg->dbdef_table->column('freq')->type =~ /(int)/i ) { -% delete $freq{$_} foreach grep { ! /^\d+$/ } keys %freq; -%} -% -%my $widget = new HTML::Widgets::SelectLayers( -% 'selected_layer' => $part_pkg->plan, -% 'options' => \%options, -% 'form_name' => 'dummy', -% 'form_action' => 'process/part_pkg.cgi', -% 'form_elements' => \@form_elements, -% 'form_text' => [ qw(pkg comment promo_code clone pkgnum pkgpart), -% qw(pay_weight credit_weight), #keys(%weight), -% @fixups, -% ], -% 'form_checkbox' => [ qw(setuptax recurtax disabled) ], -% 'form_radio' => \@form_radio, -% 'layer_callback' => sub { -% my $layer = shift; -% my $html = qq!!. -% ntable("#cccccc",2); -% $html .= ' -% -% Recurring fee frequency -% '; -% -% my $href = $plans{$layer}->{'fields'}; -% foreach my $field ( exists($plans{$layer}->{'fieldorder'}) -% ? @{$plans{$layer}->{'fieldorder'}} -% : keys %{ $href } -% ) { -% -% $html .= ''. $href->{$field}{'name'}. ''; -% -% my $format = sub { shift }; -% $format = $href->{$field}{'format'} if exists($href->{$field}{'format'}); -% if ( ! exists($href->{$field}{'type'}) ) { -% $html .= qq!!; -% } elsif ( $href->{$field}{'type'} eq 'checkbox' ) { -% $html .= qq!'; -% } elsif ( $href->{$field}{'type'} =~ /^select/ ) { -% $html .= '{$field}{'type'} eq 'select_multiple'; -% $html .= qq! NAME="$field" onChange="fchanged(this)">!; -% -% if ( $href->{$field}{'select_table'} ) { -% foreach my $record ( -% qsearch( $href->{$field}{'select_table'}, -% $href->{$field}{'select_hash'} ) -% ) { -% my $value = $record->getfield($href->{$field}{'select_key'}); -% $html .= qq!