X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fedit%2Fpart_pkg.cgi;h=e5edcdedcc683c57a24a1c23de7a974994d40b04;hp=185d66ac772fb8879763cd8dcf4bdb40c8a1b857;hb=077bb34b3467c3320440c49b76064f664c0eee98;hpb=3ce7691203a7737406bf2d4442f7fd84b81f847e diff --git a/httemplate/edit/part_pkg.cgi b/httemplate/edit/part_pkg.cgi index 185d66ac7..e5edcdedc 100755 --- a/httemplate/edit/part_pkg.cgi +++ b/httemplate/edit/part_pkg.cgi @@ -1,356 +1,869 @@ -% -% -%if ( $cgi->param('clone') && $cgi->param('clone') =~ /^(\d+)$/ ) { -% $cgi->param('clone', $1); -%} else { -% $cgi->param('clone', ''); -%} -%if ( $cgi->param('pkgnum') && $cgi->param('pkgnum') =~ /^(\d+)$/ ) { -% $cgi->param('pkgnum', $1); -%} else { -% $cgi->param('pkgnum', ''); -%} -% -%my ($query) = $cgi->keywords; -% -%my $part_pkg = ''; -%if ( $cgi->param('error') ) { -% $part_pkg = new FS::part_pkg ( { -% map { $_, scalar($cgi->param($_)) } fields('part_pkg') -% } ); -%} -% -%my $action = ''; -%my $clone_part_pkg = ''; -%my $pkgpart = ''; -%if ( $cgi->param('clone') ) { -% $pkgpart = $cgi->param('clone'); -% $action = 'Custom Pricing'; -% $clone_part_pkg= qsearchs('part_pkg', { 'pkgpart' => $cgi->param('clone') } ); -% $part_pkg ||= $clone_part_pkg->clone; -% $part_pkg->disabled('Y'); #isn't sticky on errors -%} elsif ( $query && $query =~ /^(\d+)$/ ) { -% $part_pkg ||= qsearchs('part_pkg',{'pkgpart'=>$1}); -% $pkgpart = $part_pkg->pkgpart; -%} else { -% unless ( $part_pkg ) { -% $part_pkg = new FS::part_pkg {}; -% $part_pkg->plan('flat'); -% } -%} -%unless ( $part_pkg->plan ) { #backwards-compat -% $part_pkg->plan('flat'); -% $part_pkg->plandata("setup_fee=". $part_pkg->setup. "\n". -% "recur_fee=". $part_pkg->recur. "\n"); -%} -%$action ||= $part_pkg->pkgpart ? 'Edit' : 'Add'; -%my $hashref = $part_pkg->hashref; -% -% - - -<% include("/elements/header.html","$action Package Definition", menubar( - 'Main Menu' => popurl(2), - 'View all packages' => popurl(2). 'browse/part_pkg.cgi', -)) %> -% #), ' onLoad="visualize()"'); -% if ( $cgi->param('error') ) { - - Error: <% $cgi->param('error') %> -% } - - -
- -<% 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', $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' : '' %>> - - -% my $conf = new FS::Conf; -% if ( $conf->exists('enable_taxclasses') ) { - - - - Tax class - - <% include('/elements/select-taxclass.html', $hashref->{taxclass} ) %> - - -% } else { - - - <% include('/elements/select-taxclass.html', $hashref->{taxclass} ) %> -% } - - - - - -% -% -%my $thead = "\n\n". ntable('#cccccc', 2). -% 'Quan.'; -%$thead .= 'Primary' -% if dbdef->table('pkg_svc')->column('primary_svc'); -%$thead .= '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' => '', -% } ); -% -% push @fixups, "pkg_svc$svcpart"; -% -% - - - - - quantity || 0 %>"> - - - - 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 ) ) { - - -% } - - -% -% -%# 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_radio = (); -%if ( dbdef->table('pkg_svc')->column('primary_svc') ) { -% push @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_text' => [ qw(pkg comment promo_code clone pkgnum pkgpart), -% @fixups -% ], -% 'form_checkbox' => [ qw(setuptax recurtax disabled) ], -% 'form_radio' => \@form_radio, -% 'form_select' => \@form_select, -% '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'}. ''; -% -% 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!