diff options
Diffstat (limited to 'httemplate')
| -rw-r--r-- | httemplate/edit/credit-cust_bill_pkg.html | 4 | ||||
| -rwxr-xr-x | httemplate/edit/cust_credit.cgi | 2 | ||||
| -rw-r--r-- | httemplate/edit/process/credit-cust_bill_pkg.html | 26 | ||||
| -rwxr-xr-x | httemplate/edit/process/cust_credit.cgi | 17 | ||||
| -rwxr-xr-x | httemplate/elements/tr-select-reason.html | 232 | ||||
| -rw-r--r-- | httemplate/misc/cancel_cust.html | 2 | ||||
| -rwxr-xr-x | httemplate/misc/cancel_pkg.html | 6 | ||||
| -rwxr-xr-x | httemplate/misc/cust_main-cancel.cgi | 30 | ||||
| -rwxr-xr-x | httemplate/misc/cust_main-suspend.cgi | 37 | ||||
| -rwxr-xr-x | httemplate/misc/process/cancel_pkg.html | 19 | ||||
| -rw-r--r-- | httemplate/misc/process/elements/reason | 17 | ||||
| -rw-r--r-- | httemplate/misc/suspend_cust.html | 2 | ||||
| -rwxr-xr-x | httemplate/view/cust_main.cgi | 6 | ||||
| -rw-r--r-- | httemplate/view/cust_main/packages/status.html | 2 | 
14 files changed, 194 insertions, 208 deletions
| diff --git a/httemplate/edit/credit-cust_bill_pkg.html b/httemplate/edit/credit-cust_bill_pkg.html index 40faddc46..85f794317 100644 --- a/httemplate/edit/credit-cust_bill_pkg.html +++ b/httemplate/edit/credit-cust_bill_pkg.html @@ -80,9 +80,9 @@  <& /elements/tr-select-reason.html,                'field'          => 'reasonnum',                'reason_class'   => 'R', -              #XXX reconcile both this and show_taxes wanteding to enable this +              #XXX reconcile both this and show_taxes wanting to enable this                'id'             => 'select_reason', -              'control_button' => "document.getElementById('credit_button')", +              'control_button' => 'credit_button',                'cgi'            => $cgi,  &> diff --git a/httemplate/edit/cust_credit.cgi b/httemplate/edit/cust_credit.cgi index 4bf140a74..e6eb97dbc 100755 --- a/httemplate/edit/cust_credit.cgi +++ b/httemplate/edit/cust_credit.cgi @@ -25,7 +25,7 @@  <& /elements/tr-select-reason.html,                'field'          => 'reasonnum',                'reason_class'   => 'R', -              'control_button' => "document.getElementById('confirm_credit_button')", +              'control_button' => 'confirm_credit_button',                'cgi'            => $cgi,  &> diff --git a/httemplate/edit/process/credit-cust_bill_pkg.html b/httemplate/edit/process/credit-cust_bill_pkg.html index 8e66368d4..75900bde5 100644 --- a/httemplate/edit/process/credit-cust_bill_pkg.html +++ b/httemplate/edit/process/credit-cust_bill_pkg.html @@ -27,19 +27,35 @@ foreach my $billpkgnum_setuprecur (@billpkgnum_setuprecurs) {    push @amounts,     $amount;  } -my $error = FS::cust_credit->credit_lineitems( +my $reasonnum = $cgi->param('reasonnum'); +$reasonnum =~ /^(-?\d+)$/ or die "Illegal reasonnum"; +$reasonnum = $1; + +my $error; +if ($reasonnum == -1) { +  my $new_reason = FS::reason->new({ +    map { $_ => scalar( $cgi->param("select_reason_new_$_") ) } +    qw( reason_type reason ) +  }); +  $error = $new_reason->insert; +  $reasonnum = $new_reason->reasonnum; +} + +if ( !$reasonnum ) { +  $error ||= 'Reason required' +} + +$error ||= FS::cust_credit->credit_lineitems(    #the lineitems to credit    'billpkgnums'       => \@billpkgnums,    'setuprecurs'       => \@setuprecurs,    'amounts'           => \@amounts,    'apply'             => ( $cgi->param('apply') eq 'yes' ), +  'reasonnum'         => $reasonnum, -  #the credit -  'newreasonnum'      => scalar($cgi->param('newreasonnum')), -  'newreasonnum_type' => scalar($cgi->param('newreasonnumT')),    map { $_ => scalar($cgi->param($_)) }      #fields('cust_credit')   -    qw( custnum _date amount reason reasonnum addlinfo ), #pkgnum eventnum +    qw( custnum _date amount addlinfo ), #pkgnum eventnum  );  </%init> diff --git a/httemplate/edit/process/cust_credit.cgi b/httemplate/edit/process/cust_credit.cgi index 245f31af7..e442d7fa6 100755 --- a/httemplate/edit/process/cust_credit.cgi +++ b/httemplate/edit/process/cust_credit.cgi @@ -1,5 +1,4 @@  %if ( $error ) { -%  $cgi->param('reasonnum', $reasonnum);  %  $cgi->param('error', $error);  %  $dbh->rollback if $oldAutoCommit;  %   @@ -37,19 +36,11 @@ my $oldAutoCommit = $FS::UID::AutoCommit;  local $FS::UID::AutoCommit = 0;  my $dbh = dbh; -my $error = ''; -if ($reasonnum == -1) { - -  $error = 'Enter a new reason (or select an existing one)' -    unless $cgi->param('newreasonnum') !~ /^\s*$/; -  my $reason = new FS::reason { -                 'reason_type' => scalar($cgi->param('newreasonnumT')), -                 'reason'      => scalar($cgi->param('newreasonnum')), -               }; -  $error ||= $reason->insert; -  $cgi->param('reasonnum', $reason->reasonnum) -    unless $error; +my ($reasonnum, $error) = $m->comp('/misc/process/elements/reason'); +if (!$reasonnum) { +  $error ||= 'Reason required'  } +$cgi->param('reasonnum', $reasonnum) unless $error;  unless ($error) {    my $new = new FS::cust_credit ( { diff --git a/httemplate/elements/tr-select-reason.html b/httemplate/elements/tr-select-reason.html index 9a670a26b..9b402b0eb 100755 --- a/httemplate/elements/tr-select-reason.html +++ b/httemplate/elements/tr-select-reason.html @@ -29,109 +29,119 @@ Example:  </%doc> +% # note style improvements. +% # - no more conditionally included code here +% # - callers are not expected to pass javascript fragments +% # - no redundant checking of ACLs or parameters +% # - form fields are grouped for easy management +% # - use the standard select-table widget instead of ad hoc crap  <SCRIPT TYPE="text/javascript"> -  function sh_add<% $func_suffix %>() -  { -    var hints = <% encode_json(\@hints) %>; +  function <% $id %>_changed() { +    var hints = <% encode_json(\%all_hints) %>;      var select_reason = document.getElementById('<% $id %>'); -% if ( $class eq 'S' ) {          document.getElementById('<% $id %>_hint').innerHTML = -      hints[select_reason.selectedIndex]; -% } +      hints[select_reason.value] || ''; -    if (select_reason.selectedIndex == 0){ -      <% $controlledbutton ? $controlledbutton.'.disabled = true;' : ';' %> -    }else{ -      <% $controlledbutton ? $controlledbutton.'.disabled = false;' : ';' %> +    // toggle submit button state +    var submit_button = document.getElementById(<% $opt{control_button} |js_string %>); +    if (submit_button) { +      submit_button.disabled = ( select_reason.value == 0 );      } -%if ($curuser->access_right($add_access_right)){ - -    if (select_reason.selectedIndex ==  -         (select_reason.length - 1)) { -      document.getElementById('new<% $id %>').disabled = false; -      document.getElementById('new<% $id %>').style.display = 'inline'; -      document.getElementById('new<% $id %>Label').style.display = 'inline'; -      document.getElementById('new<% $id %>T').disabled = false; -      document.getElementById('new<% $id %>T').style.display = 'inline'; -      document.getElementById('new<% $id %>TLabel').style.display = 'inline'; +    // toggle visibility of 'new reason' fields +    var new_fields = document.getElementById('<% $id %>_new_fields'); +    if ( select_reason.value == -1 ) { +      new_fields.disabled = false; +      new_fields.style.display = '';      } else { -      document.getElementById('new<% $id %>').disabled = true; -      document.getElementById('new<% $id %>').style.display = 'none'; -      document.getElementById('new<% $id %>Label').style.display = 'none'; -      document.getElementById('new<% $id %>T').disabled = true; -      document.getElementById('new<% $id %>T').style.display = 'none'; -      document.getElementById('new<% $id %>TLabel').style.display = 'none'; +      new_fields.disabled = true; +      new_fields.style.display = 'none';      } -%} -    } +  <&| onload.js &> <% $id %>_changed(); </&>  </SCRIPT> -<TR> -  <TD ALIGN="right"><% mt('Reason') |h %></TD> -  <TD> -    <SELECT id="<% $id %>" name="<% $name %>" onFocus="sh_add<% $func_suffix %>()" onChange="sh_add<% $func_suffix %>()"> -      <OPTION VALUE="" <% ($init_reason eq '') ? 'SELECTED' : '' %>><% mt('Select Reason...') |h %></OPTION> -%    foreach my $reason (@reasons) { -      <OPTION VALUE="<% $reason->reasonnum %>" <% ($init_reason == $reason->reasonnum) ? 'SELECTED' : '' %>><% $reason->reasontype->type %> : <% $reason->reason %></OPTION> -%    } -%    if ($curuser->access_right($add_access_right)) { -      <OPTION VALUE="-1" <% ($init_reason == -1) ? 'SELECTED' : '' %>><% mt('Add new reason') |h %></OPTION> -%    } -% -    </SELECT> -  </TD> -</TR> - -%   my @types = qsearch( 'reason_type', { 'class' => $class } ); -%   if (scalar(@types) < 1) {  # we should never reach this -<TR> -  <TD ALIGN="right"> -    <P><% mt('No reason types. Please add some.') |h %></P> -  </TD> -</TR> -%   }elsif (scalar(@types) == 1) { -<TR> -  <TD ALIGN="right"> -    <P id="new<% $name %>TLabel" style="display:<% $display %>"><% mt('Reason Type') |h %></P> -  </TD> -  <TD> -    <P id="new<% $name %>T" disabled="<% $disabled %>" style="display:<% $display %>"><% $types[0]->type %> -    <INPUT type="hidden" name="new<% $name %>T" value="<% $types[0]->typenum %>"> -  </TD> -</TR> - -%   }else{ - -<TR> -  <TD ALIGN="right"> -    <P id="new<% $id %>TLabel" style="display:<% $display %>"><% mt('Reason Type') |h %></P> -  </TD> -  <TD> -    <SELECT id="new<% $id %>T" name="new<% $name %>T" "<% $disabled %>" style="display:<% $display %>"> -%     for my $type (@types) { -        <OPTION VALUE="<% $type->typenum %>" <% ($init_type == $type->typenum) ? 'SELECTED' : '' %>><% $type->type %></OPTION> -%     } -    </SELECT> -  </TD> -</TR> -%   } +%# sadly can't just use add_inline here, as we have non-text fields +<& tr-select-table.html, +  'label'           => 'Reason', +  'field'           => $name, +  'id'              => $id, +  'table'           => 'reason', +  'records'         => \@reasons, +  'label_callback'  => sub { my $reason = shift; +                             $reason->type . ' : ' .  $reason->reason }, +  'disable_empty'   => 1, +  'pre_options'     => [ 0 => 'Select reason...' ], +  'post_options'    => [ -1 => 'Add new reason' ], +  'curr_value'      => $init_reason, +  'onchange'        => $id.'_changed()', +&> + +% # "add new reason" fields +% # should be a <fieldset>, but that doesn't fit well into the table + +<TR id="<% $id %>_new_fields"> +  <TD COLSPAN=2> +    <TABLE CLASS="inv" STYLE="text-align: left"> + +      <& tr-input-text.html, +        label => 'New reason', +        field => $id.'_new_reason' +      &> + +% my @types = qsearch( 'reason_type', { 'class' => $class } ); +% if (scalar(@types) < 1) {  # we should never reach this +      <TR> +        <TD ALIGN="right"> +          <P><% mt('No reason types. Please add some.') |h %></P> +        </TD> +      </TR> +% } elsif (scalar(@types) == 1) { +      <& tr-fixed.html, +        label => 'Reason type', +        field => $id.'_new_reason_type', +        curr_value => $types[0]->typenum, +        formatted_value => $types[0]->type, +      &> +% } else { # more than one type, the normal case +      <& tr-select-table.html, +        label         => 'Reason type', +        field         => $id.'_new_reason_type', +        table         => 'reason_type', +        name_col      => 'type', +        hashref       => { 'class' => $class }, +        disable_empty => 1, +      &> +% } # scalar(@types)  % if ( $class eq 'S' ) { -<TR> -  <TD COLSPAN=2 ALIGN="center" id="<% $id %>_hint"> -  </TD> -</TR> +      <& tr-checkbox.html, +        label => 'Credit the unused portion of service when suspending', +        field => $id.'_new_unused_credit', +        value => 'Y' +      &> +      <& tr-select-part_pkg.html, +        label   => 'Charge this fee when unsuspending', +        field   => $id.'_new_unsuspend_pkgpart', +        hashref => { disabled => '', freq => '0' }, +        empty_label => 'none', +      &> +      <& tr-checkbox.html, +        label => 'Hold unsuspension fee until the next bill', +        field => $id.'_new_unsuspend_hold', +        value => 'Y', +      &>  % } +    </table> +  </td> +</tr> +% # container for hints  <TR> -  <TD ALIGN="right"> -    <P id="new<% $id %>Label" style="display:<% $display %>"><% mt('New Reason') |h %></P> +  <TD COLSPAN=2 ALIGN="center" id="<% $id %>_hint" style="font-size:small">    </TD> -  <TD><INPUT id="new<% $id %>" name="new<% $name %>" type="text" value="<% $init_newreason |h %>" "<% $disabled %>" style="display:<% $display %>"></TD>  </TR>  <%init> @@ -148,11 +158,7 @@ if ( $opt{'cgi'} ) {    $init_reason = $opt{'curr_value'};  } -my $controlledbutton = $opt{'control_button'}; - -( my $func_suffix = $name ) =~ s/\./_/g; - -my $id = $opt{'id'} || $func_suffix; +my $id = $opt{'id'} || $name;  my $add_access_right;  if ($class eq 'C') { @@ -165,41 +171,21 @@ if ($class eq 'C') {    die "illegal class: $class";  } -my( $display, $disabled ) = ( 'none', 'DISABLED' ); -my( $init_type, $init_newreason ) = ( '', '' ); -if ($init_reason == -1 || ref($init_reason) ) { - -  $display = 'inline'; -  $disabled = ''; - -  if ( ref($init_reason) ) { -    $init_type      = $init_reason->{'typenum'}; -    $init_newreason = $init_reason->{'reason'}; -    $init_reason = -1; -  } elsif ( $opt{'cgi'} ) { -    $init_type      = $opt{'cgi'}->param( "new${name}T" ); -    $init_newreason = $opt{'cgi'}->param( "new$name"    ); -  } - -} - -my $extra_sql = -  "WHERE class = '$class' and (disabled = '' OR disabled is NULL)"; -  my @reasons = qsearch({ -  table     => 'reason',  -  hashref   => {}, -  extra_sql => $extra_sql, -  addl_from => 'LEFT JOIN reason_type '. -               ' ON reason_type.typenum = reason.reason_type', -  order_by  => 'ORDER BY reason_type.type ASC, reason.reason ASC', +  'table'           => 'reason', +  'addl_from'       => ' LEFT JOIN reason_type'. +                       ' ON (reason.reason_type = reason_type.typenum)', +  'hashref'         => { disabled => '' }, +  'extra_sql'       => " AND reason_type.class = '$class'", +  'order_by'        => ' ORDER BY type, reason',  }); -my @hints; +my %all_hints;  if ( $class eq 'S' ) {    my $conf = FS::Conf->new; -  @hints = ( '' ); +  %all_hints = ( 0 => '', -1 => '' );    foreach my $reason (@reasons) { +    my @hints;      if ( $reason->unsuspend_pkgpart ) {        my $part_pkg = FS::part_pkg->by_key($reason->unsuspend_pkgpart);        if ( $part_pkg ) { @@ -223,15 +209,13 @@ if ( $class eq 'S' ) {            '<FONT COLOR="#ff0000">Unsuspend pkg #'.$reason->unsuspend_pkgpart.            ' not found.</FONT>';        } -    } else { #no unsuspend_pkgpart -      push @hints, '';      } +    if ( $reason->unused_credit ) { +      push @hints, mt('The customer will be credited for unused time.'); +    } +    $all_hints{ $reason->reasonnum } = join('<BR>', @hints);    } -  push @hints, ''; # for the "new reason" case -  @hints = map {'<FONT SIZE="-1">'.$_.'</FONT>'} @hints;  } -  my $curuser = $FS::CurrentUser::CurrentUser; -  </%init> diff --git a/httemplate/misc/cancel_cust.html b/httemplate/misc/cancel_cust.html index 3259a03f6..e4bfdba76 100644 --- a/httemplate/misc/cancel_cust.html +++ b/httemplate/misc/cancel_cust.html @@ -50,7 +50,7 @@ STYLE="margin-left:auto; margin-right:auto">               'field'          => 'reasonnum',               'reason_class'   => 'C',               'cgi'            => $cgi, -             'control_button' => "document.getElementById('confirm_cancel_cust_button')", +             'control_button' => 'confirm_cancel_cust_button',  &>  </TABLE> diff --git a/httemplate/misc/cancel_pkg.html b/httemplate/misc/cancel_pkg.html index f9a46a898..6d076549d 100755 --- a/httemplate/misc/cancel_pkg.html +++ b/httemplate/misc/cancel_pkg.html @@ -6,9 +6,9 @@  <INPUT TYPE="hidden" NAME="pkgnum" VALUE="<% $pkgnum %>">  <INPUT TYPE="hidden" NAME="method" VALUE="<% $method %>"> -<BR><BR> +<BR>  <% emt(ucfirst($method)." [_1]", $part_pkg->pkg_comment) %> -<% ntable("#cccccc", 2) %> +<table style="background-color: #cccccc; border-spacing: 2; width: 100%">  % my $date_init = 0;  % if ($method eq 'expire' || $method eq 'adjourn' || $method eq 'resume') { @@ -58,7 +58,7 @@         field          => 'reasonnum',         reason_class   => $class,         curr_value     => $reasonnum, -       control_button => "document.getElementById('confirm_cancel_pkg_button')", +       control_button => "confirm_cancel_pkg_button",    &>  % } diff --git a/httemplate/misc/cust_main-cancel.cgi b/httemplate/misc/cust_main-cancel.cgi index 2ae9f1021..a78a8b3dc 100755 --- a/httemplate/misc/cust_main-cancel.cgi +++ b/httemplate/misc/cust_main-cancel.cgi @@ -22,51 +22,43 @@ if ( $cgi->param('custnum') =~ /^(\d+)$/ ) {    $custnum = $1;  } -#false laziness w/process/cancel_pkg.html -#untaint reasonnum -my $reasonnum = $cgi->param('reasonnum'); -$reasonnum =~ /^(-?\d+)$/ || die "Illegal reasonnum"; -$reasonnum = $1; - -if ($reasonnum == -1) { -  $reasonnum = { -    'typenum' => scalar( $cgi->param('newreasonnumT') ), -    'reason'  => scalar( $cgi->param('newreasonnum' ) ), -  }; +#untaint reasonnum / create new reason +my ($reasonnum, $error) = $m->comp('process/elements/reason'); +if (!$reasonnum) { +  $error ||= 'Reason required'  } -#eslaf -  my $cust_main = qsearchs( {    'table'     => 'cust_main',    'hashref'   => { 'custnum' => $custnum },    'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,  } ); -my @errors; -if($cgi->param('now_or_later')) { +if ( $error ) { +  # do nothing +} elsif ( $cgi->param('now_or_later') ) {    $expire = parse_datetime($expire);    if($expire) {      #warn "setting expire dates on custnum#$custnum\n";      my @pkgs = $cust_main->ncancelled_pkgs; -    @errors = grep {$_} map { $_->cancel( +    my @errors = grep {$_} map { $_->cancel(        'reason'  => $reasonnum,        'date'    => $expire,      ) } @pkgs; +    $error = join(' / ', @errors);    }    else { -    @errors = ("error parsing expire date: ".$cgi->param('expire')); +    $error = ("error parsing expire date: ".$cgi->param('expire'));    }  }  else {    warn "cancelling $cust_main"; -  @errors = $cust_main->cancel( +  $error = $cust_main->cancel(      'ban'    => $ban,      'reason' => $reasonnum,    );  } -my $error = join(' / ', @errors) if scalar(@errors);  if ( $error ) {    $cgi->param('error', $error); diff --git a/httemplate/misc/cust_main-suspend.cgi b/httemplate/misc/cust_main-suspend.cgi index 61851364e..7a501d61a 100755 --- a/httemplate/misc/cust_main-suspend.cgi +++ b/httemplate/misc/cust_main-suspend.cgi @@ -22,50 +22,39 @@ if ( $cgi->param('custnum') =~ /^(\d+)$/ ) {    $custnum = $1;  } -#false laziness w/process/cancel_pkg.html - -#untaint reasonnum -my $reasonnum = $cgi->param('reasonnum'); -$reasonnum =~ /^(-?\d+)$/ || die "Illegal reasonnum"; -$reasonnum = $1; - -if ($reasonnum == -1) { -  $reasonnum = { -    'typenum' => scalar( $cgi->param('newreasonnumT') ), -    'reason'  => scalar( $cgi->param('newreasonnum' ) ), -  }; +#untaint reasonnum / create new reason +my ($reasonnum, $error) = $m->comp('process/elements/reason'); +if (!$reasonnum) { +  $error ||= 'Reason required';  } -#eslaf -  my $cust_main = qsearchs( {    'table'     => 'cust_main',    'hashref'   => { 'custnum' => $custnum },    'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,  } ); -my @errors; -if($cgi->param('now_or_later')) { +if ( $error ) { +  # do nothing +} elsif ( $cgi->param('now_or_later') ) {    $adjourn = parse_datetime($adjourn);    if($adjourn) {      #warn "setting adjourn dates on custnum#$custnum\n";      my @pkgs = $cust_main->unsuspended_pkgs; -    @errors = grep {$_} map { $_->suspend( +    my @errors = grep {$_} map { $_->suspend(        'reason'  => $reasonnum,        'date'    => $adjourn,      ) } @pkgs; +    $error = join(' / ', @errors); +  } else { +    $error = ("error parsing adjourn date: ".$cgi->param('adjourn'));    } -  else { -    @errors = ("error parsing adjourn date: ".$cgi->param('adjourn')); -  } -} -else { +} else {    warn "suspending $cust_main"; -  @errors = $cust_main->suspend( +  $error = $cust_main->suspend(      'reason' => $reasonnum,    );  } -my $error = join(' / ', @errors) if scalar(@errors);  if ( $error ) {    $cgi->param('error', $error); diff --git a/httemplate/misc/process/cancel_pkg.html b/httemplate/misc/process/cancel_pkg.html index a106b845a..47ceca23b 100755 --- a/httemplate/misc/process/cancel_pkg.html +++ b/httemplate/misc/process/cancel_pkg.html @@ -65,17 +65,12 @@ if ( $method eq 'suspend' ) { #or 'adjourn'  my $cust_pkg = qsearchs( 'cust_pkg', {'pkgnum'=>$pkgnum} ); -#untaint reasonnum -my $reasonnum = $cgi->param('reasonnum'); -if ( $method !~ /^(unsuspend|uncancel)$/ ) { -  $reasonnum =~ /^(-?\d+)$/ or die "Illegal reasonnum"; -  $reasonnum = $1; - -  if ($reasonnum == -1) { -    $reasonnum = { -      'typenum' => scalar( $cgi->param('newreasonnumT') ), -      'reason'  => scalar( $cgi->param('newreasonnum' ) ), -    }; +#untaint reasonnum, and set up new reason if appropriate +my ($reasonnum, $error); +if ($method ne 'resume' and $method ne 'uncancel') { +  ($reasonnum, $error) = $m->comp('elements/reason'); +  if (!$reasonnum) { +    $error ||= 'Reason required';    }  } @@ -87,7 +82,7 @@ my $bill =  my $svc_fatal = ( $cgi->param('svc_not_fatal') ne 'Y' ); -my $error = $cust_pkg->$method( 'reason'      => $reasonnum, +$error ||=  $cust_pkg->$method( 'reason'      => $reasonnum,                                  'date'        => $date,                                  'resume_date' => $resume_date,                                  'last_bill'   => $last_bill, diff --git a/httemplate/misc/process/elements/reason b/httemplate/misc/process/elements/reason new file mode 100644 index 000000000..ae92a7528 --- /dev/null +++ b/httemplate/misc/process/elements/reason @@ -0,0 +1,17 @@ +<%init> +#untaint reasonnum, and set up new reason if appropriate +my $reasonnum = $cgi->param('reasonnum'); +$reasonnum =~ /^(-?\d+)$/ or die "Illegal reasonnum"; +$reasonnum = $1; + +my $error; +if ($reasonnum == -1) { +  my $new_reason = FS::reason->new({ +    map { $_ => scalar( $cgi->param("reasonnum_new_$_") ) } +    qw( reason_type reason unsuspend_pkgpart unsuspend_hold unused_credit ) +  }); # not sanitizing them here, but check() will do it +  $error = $new_reason->insert; +  $reasonnum = $new_reason->reasonnum; +} +return ($reasonnum, $error); +</%init> diff --git a/httemplate/misc/suspend_cust.html b/httemplate/misc/suspend_cust.html index e0d17f30b..3a49e136d 100644 --- a/httemplate/misc/suspend_cust.html +++ b/httemplate/misc/suspend_cust.html @@ -42,7 +42,7 @@ STYLE="margin-left:auto; margin-right:auto">               'field'          => 'reasonnum',               'reason_class'   => 'S',               'cgi'            => $cgi, -             'control_button' => "document.getElementById('confirm_suspend_cust_button')", +             'control_button' => 'confirm_suspend_cust_button',  &>  </TABLE> diff --git a/httemplate/view/cust_main.cgi b/httemplate/view/cust_main.cgi index 7a6e425be..99f02b08d 100755 --- a/httemplate/view/cust_main.cgi +++ b/httemplate/view/cust_main.cgi @@ -60,8 +60,8 @@ function areyousure(href, message) {                  'actionlabel' => emt('Confirm Suspension'),                  'color'       => '#ff9900',                  'cust_main'   => $cust_main, -                'width'       => 616, #make room for reasons -                'height'      => 366, +                'width'       => 768, #make room for reasons +                'height'      => 450,                 }    &> |   % } @@ -91,7 +91,7 @@ function areyousure(href, message) {                  'color'       => '#ff0000',                  'cust_main'   => $cust_main,                  'width'       => 616, #make room for reasons -                'height'      => 366, +                'height'      => 410,                }    &> |   % } diff --git a/httemplate/view/cust_main/packages/status.html b/httemplate/view/cust_main/packages/status.html index 339c2ab19..971a9cf98 100644 --- a/httemplate/view/cust_main/packages/status.html +++ b/httemplate/view/cust_main/packages/status.html @@ -580,6 +580,7 @@ sub pkg_suspend_link {               'actionlabel' => emt('Suspend'),               'color'       => '#FF9900',               'cust_pkg'    => shift, +             'height'      => 420,           )  } @@ -590,6 +591,7 @@ sub pkg_adjourn_link {               'actionlabel' => emt('Adjourn'),               'color'       => '#CC6600',               'cust_pkg'    => shift, +             'height'      => 445,           )  } | 
