BaseController.php
3 years ago
ChargeController.php
3 years ago
CustomerController.php
3 years ago
DownloadController.php
3 years ago
InvoiceController.php
3 years ago
OrderController.php
2 years ago
PaymentMethodController.php
2 years ago
SubscriptionController.php
2 years ago
UserController.php
3 years ago
CustomerController.php
136 lines
| 1 | <?php |
| 2 | namespace SureCartBlocks\Controllers; |
| 3 | |
| 4 | use SureCart\Models\Component; |
| 5 | use SureCart\Models\Customer; |
| 6 | use SureCart\Models\User; |
| 7 | |
| 8 | /** |
| 9 | * Payment method block controller class. |
| 10 | */ |
| 11 | class CustomerController extends BaseController { |
| 12 | /** |
| 13 | * List all payment methods. |
| 14 | * |
| 15 | * @param array $attributes Block attributes. |
| 16 | * @param string $content Block content. |
| 17 | * |
| 18 | * @return function |
| 19 | */ |
| 20 | public function preview( $attributes, $content ) { |
| 21 | if ( ! is_user_logged_in() ) { |
| 22 | return; |
| 23 | } |
| 24 | |
| 25 | $output = ''; |
| 26 | |
| 27 | // show test. |
| 28 | if ( ! empty( User::current()->customerId( 'test' ) ) ) { |
| 29 | $output .= '<sc-dashboard-customer-details heading="' . esc_attr( $attributes['title'] ?? '' ) . '" customer-id="' . User::current()->customerId( 'test' ) . '"></sc-dashboard-customer-details>'; |
| 30 | } |
| 31 | // show live. |
| 32 | if ( ! empty( User::current()->customerId( 'live' ) ) ) { |
| 33 | $output .= '<sc-dashboard-customer-details heading="' . esc_attr( $attributes['title'] ?? '' ) . '" customer-id="' . User::current()->customerId( 'live' ) . '"></sc-dashboard-customer-details>'; |
| 34 | } |
| 35 | // show for non-customers. |
| 36 | if ( empty( $output ) ) { |
| 37 | $output .= '<sc-dashboard-customer-details heading="' . esc_attr( $attributes['title'] ?? '' ) . '" customer-id=""></sc-dashboard-customer-details>'; |
| 38 | } |
| 39 | |
| 40 | return $output; |
| 41 | } |
| 42 | |
| 43 | public function show() { |
| 44 | $back = add_query_arg( [ 'tab' => $this->getTab() ], remove_query_arg( array_keys( $_GET ) ) ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended |
| 45 | |
| 46 | ob_start(); ?> |
| 47 | |
| 48 | <sc-spacing style="--spacing: var(--sc-spacing-large)"> |
| 49 | <sc-breadcrumbs> |
| 50 | <sc-breadcrumb href="<?php echo esc_url( $back ); ?>"> |
| 51 | <?php esc_html_e( 'Dashboard', 'surecart' ); ?> |
| 52 | </sc-breadcrumb> |
| 53 | <sc-breadcrumb> |
| 54 | <?php esc_html_e( 'Billing', 'surecart' ); ?> |
| 55 | </sc-breadcrumb> |
| 56 | </sc-breadcrumbs> |
| 57 | |
| 58 | |
| 59 | <?php echo ( new PaymentMethodController() )->index( [ 'title' => esc_html( 'Payment Methods', 'surecart' ) ], '' ); ?> |
| 60 | |
| 61 | <?php echo $this->preview( [ 'title' => esc_html( 'Billing Details', 'surecart' ) ], '' ); ?> |
| 62 | |
| 63 | </sc-spacing> |
| 64 | |
| 65 | <?php |
| 66 | return ob_get_clean(); |
| 67 | } |
| 68 | |
| 69 | /** |
| 70 | * Show a view to add a payment method. |
| 71 | * |
| 72 | * @return function |
| 73 | */ |
| 74 | public function edit() { |
| 75 | $back = add_query_arg( [ 'tab' => $this->getTab() ], remove_query_arg( array_keys( $_GET ) ) ); // phpcs:ignore WordPress.Security.NonceVerification.Recommended |
| 76 | |
| 77 | $id = $this->getId(); |
| 78 | |
| 79 | if ( ! current_user_can( 'edit_sc_customer', $id, [] ) ) { |
| 80 | wp_die( 'You are not allowed to edit this customer', 'surecart' ); |
| 81 | } |
| 82 | |
| 83 | ob_start(); |
| 84 | ?> |
| 85 | |
| 86 | <sc-spacing style="--spacing: var(--sc-spacing-large)"> |
| 87 | <sc-breadcrumbs> |
| 88 | <sc-breadcrumb href="<?php echo esc_url( $back ); ?>"> |
| 89 | <?php esc_html_e( 'Dashboard', 'surecart' ); ?> |
| 90 | </sc-breadcrumb> |
| 91 | <sc-breadcrumb href=" |
| 92 | <?php |
| 93 | echo esc_url( |
| 94 | add_query_arg( |
| 95 | [ |
| 96 | 'tab' => $this->getTab(), |
| 97 | 'model' => 'customer', |
| 98 | 'action' => 'show', |
| 99 | 'id' => $this->getId(), |
| 100 | ], |
| 101 | remove_query_arg( array_keys( $_GET ) ) // phpcs:ignore WordPress.Security.NonceVerification.Recommended |
| 102 | ) |
| 103 | ); |
| 104 | ?> |
| 105 | "> |
| 106 | <?php esc_html_e( 'Billing', 'surecart' ); ?> |
| 107 | </sc-breadcrumb> |
| 108 | <sc-breadcrumb> |
| 109 | <?php esc_html_e( 'Billing Details', 'surecart' ); ?> |
| 110 | </sc-breadcrumb> |
| 111 | </sc-breadcrumbs> |
| 112 | |
| 113 | <?php |
| 114 | $customer = Customer::with( [ 'shipping_address', 'billing_address', 'tax_identifier' ] )->find( $id ); |
| 115 | if ( ! $customer ) { |
| 116 | return; |
| 117 | } |
| 118 | echo wp_kses_post( |
| 119 | Component::tag( 'sc-customer-edit' ) |
| 120 | ->id( 'customer-customer-edit-live' ) |
| 121 | ->with( |
| 122 | [ |
| 123 | 'header' => __( 'Update Billing Details', 'surecart' ), |
| 124 | 'customer' => $customer, |
| 125 | 'successUrl' => esc_url_raw( $back ), |
| 126 | ] |
| 127 | )->render() |
| 128 | ); |
| 129 | ?> |
| 130 | </sc-spacing> |
| 131 | |
| 132 | <?php |
| 133 | return ob_get_clean(); |
| 134 | } |
| 135 | } |
| 136 |