%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/tradesc/www/relax/wp-content/plugins/wpforms-lite/src/Integrations/Stripe/Admin/
Upload File :
Create Path :
Current File : /home/tradesc/www/relax/wp-content/plugins/wpforms-lite/src/Integrations/Stripe/Admin/Settings.php

<?php

namespace WPForms\Integrations\Stripe\Admin;

use WPForms\Integrations\Stripe\Api\PaymentIntents;
use WPForms\Integrations\Stripe\Helpers;
use WPForms\Admin\Notice;

/**
 * Stripe "Settings" section methods.
 *
 * @since 1.8.2
 */
class Settings {

	/**
	 * Stripe Connect.
	 *
	 * @since 1.8.2
	 *
	 * @var Connect
	 */
	protected $connect;

	/**
	 * Stripe Webhook Settings.
	 *
	 * @since 1.8.4
	 *
	 * @var WebhookSettings
	 */
	protected $webhook_settings;

	/**
	 * Initialize class.
	 *
	 * @since 1.8.2
	 */
	public function init() {

		$this->connect          = ( new Connect() )->init();
		$this->webhook_settings = ( new WebhookSettings() )->init();

		$this->hooks();
	}

	/**
	 * Register hooks.
	 *
	 * @since 1.8.2
	 */
	private function hooks() {

		add_action( 'wpforms_settings_init', [ $this, 'connection_is_missing_notice' ] );
		add_action( 'wpforms_settings_init', [ $this, 'not_supported_currency_notice' ] );
		add_action( 'wpforms_settings_enqueue', [ $this, 'enqueue_assets' ] );
		add_filter( 'wpforms_settings_defaults', [ $this, 'register_settings_fields' ], 6 );
	}

	/**
	 * Stripe is not connected for the current payment mode notice.
	 *
	 * @since 1.8.2
	 */
	public function connection_is_missing_notice() {

		if ( ! Helpers::is_pro() || Helpers::has_stripe_keys() ) {
			return;
		}

		$account = $this->connect->get_connected_account();

		if ( ! empty( $account->id ) ) {
			return;
		}

		Notice::warning(
			esc_html__( 'Stripe is not connected for your current payment mode. Please press the "Connect with Stripe" button to complete this setup.', 'wpforms-lite' )
		);
	}

	/**
	 * Selected currency is not supported for connected account.
	 *
	 * @since 1.8.2
	 */
	public function not_supported_currency_notice() {

		if ( ! Helpers::has_stripe_keys() ) {
			return;
		}

		$account = $this->connect->get_connected_account();

		if ( is_null( $account ) ) {
			return;
		}

		$selected_currency = strtolower( wpforms_get_currency() );

		if ( $selected_currency === $account->default_currency ) {
			return;
		}

		$country_specs = ( new PaymentIntents() )->get_country_specs( $account->country );

		if ( ! $country_specs || in_array( $selected_currency, $country_specs->supported_payment_currencies, true ) ) {
			return;
		}

		Notice::error(
			sprintf(
				wp_kses( /* translators: %1$s - Selected currency on the WPForms Settings admin page. */
					__( '<strong>Payments Cannot Be Processed</strong><br>The currency you have set (%1$s) is not supported by Stripe. Please choose a different currency.', 'wpforms-lite' ),
					[
						'strong' => [],
						'br'     => [],
					]
				),
				esc_html( wpforms_get_currency() )
			)
		);
	}

	/**
	 * Enqueue "Settings" scripts and styles.
	 *
	 * @since 1.8.2
	 */
	public function enqueue_assets() {

		$min = wpforms_get_min_suffix();

		wp_enqueue_style(
			'wpforms-admin-settings-stripe',
			WPFORMS_PLUGIN_URL . "assets/css/integrations/stripe/admin-settings-stripe{$min}.css",
			[],
			WPFORMS_VERSION
		);

		wp_enqueue_script(
			'wpforms-admin-settings-stripe',
			WPFORMS_PLUGIN_URL . "assets/js/integrations/stripe/admin-settings-stripe{$min}.js",
			[ 'jquery' ],
			WPFORMS_VERSION,
			true
		);

		$admin_settings_stripe_l10n = [
			'mode_update'  => wp_kses(
				__( '<p>Switching test/live modes requires Stripe account reconnection.</p><p>Press the <em>"Connect with Stripe"</em> button after saving the settings to reconnect.</p>', 'wpforms-lite' ),
				[
					'p'  => [],
					'em' => [],
				]
			),
			'webhook_urls' => [
				'rest' => Helpers::get_webhook_url_for_rest(),
				'curl' => Helpers::get_webhook_url_for_curl(),
			],
		];

		wp_localize_script(
			'wpforms-admin-settings-stripe',
			'wpforms_admin_settings_stripe',
			$admin_settings_stripe_l10n
		);
	}

	/**
	 * Register "Stripe" settings fields.
	 *
	 * @since 1.8.2
	 *
	 * @param array $settings Admin area settings list.
	 *
	 * @return array
	 */
	public function register_settings_fields( $settings ) {

		// Bail early, in case "Payments" settings is not registered.
		if ( ! isset( $settings['payments'] ) ) {
			return $settings;
		}

		$stripe_settings = [
			'stripe-heading'           => [
				'id'       => 'stripe-heading',
				'content'  => $this->get_heading_content(),
				'type'     => 'content',
				'no_label' => true,
				'class'    => [ 'section-heading' ],
			],
			'stripe-connection-status' => [
				'id'      => 'stripe-connection-status',
				'name'    => esc_html__( 'Connection Status', 'wpforms-lite' ),
				'content' => $this->get_connection_status_content(),
				'type'    => 'content',
			],
			'stripe-test-mode'         => [
				'id'     => 'stripe-test-mode',
				'name'   => esc_html__( 'Test Mode', 'wpforms-lite' ),
				'type'   => 'toggle',
				'status' => true,
				'desc'   => sprintf(
					wp_kses( /* translators: %s - WPForms.com URL for Stripe payments with more details. */
						__( 'Prevent Stripe from processing live transactions. Please see <a href="%s" target="_blank" rel="noopener noreferrer">our documentation on Stripe test payments</a> for full details.', 'wpforms-lite' ),
						[
							'a' => [
								'href'   => [],
								'target' => [],
								'rel'    => [],
								'class'  => [],
							],
						]
					),
					esc_url( wpforms_utm_link( 'https://wpforms.com/docs/how-to-test-stripe-payments-on-your-site/', 'Settings - Payments', 'Stripe Test Payments Documentation' ) )
				),
			],
		];

		$stripe_settings = $this->webhook_settings->settings( $stripe_settings );

		$this->maybe_set_card_mode();

		// phpcs:ignore WordPress.Security.NonceVerification.Recommended
		if ( ! empty( $_GET['stripe_card_mode'] ) || ! Helpers::is_payment_element_enabled() ) {
			$stripe_settings['stripe-card-mode'] = [
				'id'         => 'stripe-card-mode',
				'name'       => esc_html__( 'Credit Card Field Mode', 'wpforms-lite' ),
				'type'       => 'radio',
				'default'    => 'payment',
				'desc_after' => $this->get_credit_card_field_desc_after(),
				'options'    => [
					'card'    => esc_html__( 'Card Element', 'wpforms-lite' ),
					'payment' => esc_html__( 'Payment Element', 'wpforms-lite' ),
				],
			];
		}

		$settings['payments'] = array_merge( $settings['payments'], $stripe_settings );

		return $settings;
	}

	/**
	 * Maybe set card mode setting.
	 *
	 * @since 1.8.2
	 */
	private function maybe_set_card_mode() {

		// Bail out if a card mode is already set.
		if ( wpforms_setting( 'stripe-card-mode' ) ) {
			return;
		}

		$settings                     = (array) get_option( 'wpforms_settings', [] );
		$settings['stripe-card-mode'] = Helpers::has_stripe_keys() ? 'card' : 'payment';

		update_option( 'wpforms_settings', $settings );
	}

	/**
	 * Section header content.
	 *
	 * @since 1.8.2
	 *
	 * @return string
	 */
	private function get_heading_content() {

		return '<h4>' . esc_html__( 'Stripe', 'wpforms-lite' ) . '</h4>' .
			'<p>' .
			sprintf(
				wp_kses( /* translators: %s - WPForms.com Stripe documentation article URL. */
					__( 'Easily collect credit card payments with Stripe. For getting started and more information, see our <a href="%s" target="_blank" rel="noopener noreferrer">Stripe documentation</a>.', 'wpforms-lite' ),
					[
						'a' => [
							'href'   => [],
							'target' => [],
							'rel'    => [],
						],
					]
				),
				esc_url( wpforms_utm_link( 'https://wpforms.com/docs/how-to-install-and-use-the-stripe-addon-with-wpforms/', 'Settings - Payments', 'Stripe Documentation' ) )
			) .
			'</p>' .
			Notices::get_fee_notice();
	}

	/**
	 * Connection Status setting content.
	 *
	 * @since 1.8.2
	 *
	 * @return string
	 */
	protected function get_connection_status_content() {

		$output       = '';
		$current_mode = Helpers::get_stripe_mode();

		foreach ( Helpers::CONNECTION_MODES as $mode ) {

			$class_names = [
				'wpforms-stripe-connection-status',
				"wpforms-stripe-connection-status-{$mode}",
				$current_mode !== $mode ? 'wpforms-hide' : '',
			];
			$account     = $this->connect->get_connected_account( $mode );
			$output     .= sprintf( '<div %s>', wpforms_html_attributes( '', $class_names ) );

			if ( empty( $account->id ) ) {
				$output .= $this->get_disconnected_status_content( $mode );
			} else {
				$output .= $this->get_connected_status_content( $mode );
			}

			$output .= '</div>';
		}

		return $output;
	}

	/**
	 * Connected Status setting content.
	 *
	 * @since 1.8.2
	 *
	 * @param string $mode Stripe mode (e.g. 'live' or 'test').
	 *
	 * @return string
	 */
	private function get_connected_status_content( $mode = '' ) {

		$output           = '';
		$account_name     = $this->connect->get_connected_account_name( $mode );
		$connect_url      = $this->connect->get_connect_with_stripe_url( $mode );
		$connected_status = sprintf(
			wp_kses( /* translators: %1$s - Stripe account name connected, %2$s - Stripe mode connected (live or test). */
				__( 'Connected to Stripe as <em>%1$s</em> in <strong>%2$s Mode</strong>.', 'wpforms-lite' ),
				[
					'strong' => [],
					'em'     => [],
				]
			),
			esc_html( $account_name ),
			ucwords( $mode ? $mode : Helpers::get_stripe_mode() )
		);

		$output .= sprintf( '<div class="wpforms-connected"><p>%s</p></div>', $connected_status );

		$output .= '<p>' . sprintf(
			wp_kses( /* translators: %s - Stripe connect URL. */
				__( '<a href="%s">Switch Accounts</a>', 'wpforms-lite' ),
				[
					'a' => [
						'href' => [],
					],
				]
			),
			esc_url( $connect_url )
		) . '</p>';

		return $output;
	}

	/**
	 * Disconnected Status setting content.
	 *
	 * @since 1.8.2
	 *
	 * @param string $mode Stripe mode (e.g. 'live' or 'test').
	 *
	 * @return string
	 */
	protected function get_disconnected_status_content( $mode = '' ) {

		$connect_url    = $this->connect->get_connect_with_stripe_url( $mode );
		$connect_button = sprintf(
			wp_kses( /* translators: %s - WPForms.com Stripe documentation article URL. */
				__( 'Securely connect to Stripe with just a few clicks to begin accepting payments! <a href="%s" target="_blank" rel="noopener noreferrer" class="wpforms-learn-more">Learn More</a>', 'wpforms-lite' ),
				[
					'a' => [
						'href'   => [],
						'target' => [],
						'rel'    => [],
						'class'  => [],
					],
				]
			),
			esc_url( wpforms_utm_link( 'https://wpforms.com/docs/how-to-install-and-use-the-stripe-addon-with-wpforms/#connect-stripe', 'Settings - Payments', 'Stripe Documentation' ) )
		);

		return sprintf(
			'<div class="wpforms-connect"><a href="%s" class="wpforms-stripe-connect-button" title="%s"></a><p>%s</p></div>',
			esc_url( $connect_url ),
			esc_attr__( 'Connect with Stripe', 'wpforms-lite' ),
			$connect_button
		);
	}

	/**
	 * Credit Card mode description.
	 *
	 * @since 1.8.2
	 *
	 * @return string
	 */
	private function get_credit_card_field_desc_after() {

		return '<p class="desc">' . sprintf(
			wp_kses( /* translators: %s - WPForms.com Stripe documentation article URL. */
				__( 'Please see <a href="%s" target="_blank" rel="noopener noreferrer">our documentation on Stripe Credit Card field modes for full details</a>.', 'wpforms-lite' ),
				[
					'a' => [
						'href'   => [],
						'target' => [],
						'rel'    => [],
					],
				]
			),
			esc_url( wpforms_utm_link( 'https://wpforms.com/docs/how-to-install-and-use-the-stripe-addon-with-wpforms/#field-modes', 'Settings - Payments', 'Stripe Field Modes' ) )
		) . '</p>';
	}
}

Zerion Mini Shell 1.0