summaryrefslogtreecommitdiff
path: root/ng_selfservice/payment_cc.php
blob: 37f57c057e72dc07d538efb6f01fa0d7b4cb05b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<? $title ='Credit Card Payment'; include('elements/header.php'); ?>
<? $current_menu = 'payment_cc.php'; include('elements/menu.php'); ?>
<?

if ( isset($_POST['amount']) && $_POST['amount'] ) {

  $payment_results = $freeside->process_payment(array(
    'session_id' => $_COOKIE['session_id'],
    'payby'      => 'CARD',
    'amount'     => $_POST['amount'],
    'payinfo'    => $_POST['payinfo'],
    'paycvv'     => $_POST['paycvv'],
    'month'      => $_POST['month'],
    'year'       => $_POST['year'],
    'payname'    => $_POST['payname'],
    'address1'   => $_POST['address1'],
    'address2'   => $_POST['address2'],
    'city'       => $_POST['city'],
    'state'      => $_POST['state'],
    'zip'        => $_POST['zip'],
    'country'    => $_POST['country'],
    'save'       => $_POST['save'],
    'auto'       => $_POST['auto'],
    'paybatch'   => $_POST['paybatch'],
    //'discount_term' => $discount_term,
  ));

  if ( $payment_results['error'] ) {
    $payment_error = $payment_results['error'];
  } else {
    $receipt_html = $payment_results['receipt_html'];
  }

}

if ( $receipt_html ) { ?>

  Your payment was processed successfully.  Thank you.<BR><BR>
  <? echo $receipt_html; ?>

<? } else {

  $payment_info = $freeside->payment_info( array(
    'session_id' => $_COOKIE['session_id'],
    'payment_payby' => 'CARD',
  ) );

  if ( isset($payment_info['error']) && $payment_info['error'] ) {
    $error = $payment_info['error'];
    header('Location:index.php?error='. urlencode($error));
    die();
  }

  extract($payment_info);

  $error = $payment_error;

  $tr_amount_fee = $freeside->mason_comp(array(
      'session_id' => $_COOKIE['session_id'],
      'comp'       => '/elements/tr-amount_fee.html',
      'args'       => [ 'amount',  $balance ],
  ));
  //$tr_amount_fee = $tr_amount_fee->{'error'} || $tr_amount_fee->{'output'};
  $tr_amount_fee = $tr_amount_fee['output'];

  ?>

  <? include('elements/error.php'); ?>

  <FORM NAME="OneTrueForm" METHOD="POST" ACTION="payment_cc.php" onSubmit="document.OneTrueForm.process.disabled=true">

  <TABLE>
  <TR>
    <TD ALIGN="right">Amount&nbsp;Due</TD>
    <TD COLSPAN=7>
      <TABLE><TR><TD>
        $<? echo sprintf("%.2f", $balance) ?>
      </TD></TR></TABLE>
    </TD>
  </TR>

  <? echo $tr_amount_fee; ?>

  <? //include('elements/discount_term.php') ?>

  <TR>
    <TD ALIGN="right">Card&nbsp;type</TD>
    <TD COLSPAN=7>
      <SELECT NAME="card_type"><OPTION></OPTION>
        <? foreach ( $card_types AS $ct ) { ?>
          <OPTION <? if ( $card_type == $ct ) { echo 'SELECTED'; } ?>
                  VALUE="<? echo $ct; ?>"><? echo $ct; ?>
        <? } ?>
      </SELECT>
    </TD>
  </TR>

  <? include('elements/card.php'); ?>

  <TR>
    <TD COLSPAN=8>
      <INPUT TYPE="checkbox" <? if ( ! $save_unchecked ) { echo 'CHECKED'; } ?> NAME="save" VALUE="1">
      Remember this card and billing address
    </TD>
  </TR><TR>
    <TD COLSPAN=8>
      <INPUT TYPE="checkbox" <? if ( $payby == 'CARD' ) { echo ' CHECKED'; } ?> NAME="auto" VALUE="1" onClick="if (this.checked) { document.OneTrueForm.save.checked=true; }">
      Charge future payments to this card automatically
    </TD>
  </TR>
  </TABLE>
  <BR>
  <INPUT TYPE="hidden" NAME="paybatch" VALUE="<? echo $paybatch ?>">
  <INPUT TYPE="submit" NAME="process" VALUE="Process payment"> <!-- onClick="this.disabled=true"> -->
  </FORM>

<? } ?>

<? include('elements/menu_footer.php'); ?>
<? include('elements/footer.php'); ?>