Current File : /home/pacjaorg/public_html/2024/wp-content/plugins/formidable/stripe/models/FrmTransLiteAction.php
<?php
if ( ! defined( 'ABSPATH' ) ) {
	die( 'You are not allowed to call this page directly.' );
}

class FrmTransLiteAction extends FrmFormAction {

	public function __construct() {
		$action_ops = array(
			'classes'  => 'frm_stripe_icon frm_credit_card_alt_icon frm_icon_font',
			// This is 99 in the Payments submodule but Stripe Lite only supports a single action.
			'limit'    => 1,
			'active'   => true,
			// After user registration.
			'priority' => 45,
			'event'    => array( 'create' ),
			'color'    => 'var(--green)',
		);

		$this->FrmFormAction( 'payment', __( 'Collect a Payment', 'formidable' ), $action_ops );
	}

	/**
	 * @param WP_Post $instance
	 * @param array   $args
	 */
	public function form( $instance, $args = array() ) {
		$form_action = $instance;

		global $wpdb;

		$list_fields         = self::get_defaults();
		$action_control      = $this;
		$options             = $form_action->post_content;
		$form_fields         = $this->get_field_options( $args['form']->id );
		$field_dropdown_atts = compact( 'form_fields', 'form_action' );
		$currencies          = FrmCurrencyHelper::get_currencies();
		$repeat_times        = FrmTransLiteAppHelper::get_repeat_times();

		if ( ! isset( $form_action->post_content['payment_limit'] ) ) {
			$form_action->post_content['payment_limit'] = '';
		}

		include FrmTransLiteAppHelper::plugin_path() . '/views/action-settings/payments-options.php';
	}

	/**
	 * Capturing a payment later is only available in the Stripe add on.
	 * This echos the HTML for a faded out capture payment dropdown.
	 * When it is clicked, it should prompt to install Stripe.
	 *
	 * @since 6.5
	 *
	 * @return void
	 */
	public function echo_capture_payment_upsell() {
		// Add an upsell placeholder for the capture payment setting.
		$upgrading      = FrmAddonsController::install_link( 'stripe' );
		$upgrade_params = array();
		if ( isset( $upgrading['url'] ) ) {
			$upgrade_params['data-oneclick'] = json_encode( $upgrading );
		} else {
			$upgrade_params['data-requires'] = FrmAddonsController::get_addon_required_plan( 28136428 );
		}
		unset( $upgrading );
		include FrmTransLiteAppHelper::plugin_path() . '/views/action-settings/capture-payments-upsell.php';
	}

	/**
	 * @return array
	 */
	public function get_defaults() {
		$defaults = array(
			'description'          => '',
			'email'                => '',
			'amount'               => '',
			'type'                 => '',
			'interval_count'       => 1,
			'interval'             => 'month',
			'payment_count'        => 9999,
			'trial_interval_count' => 0,
			'currency'             => $this->default_currency(),
			'gateway'              => array(),
			'credit_card'          => '',
			'billing_first_name'   => '',
			'billing_last_name'    => '',
		);
		return (array) apply_filters( 'frm_pay_action_defaults', $defaults );
	}

	/**
	 * @since 6.5, introduced in v2.01 of the Payments submodule.
	 *
	 * @return string
	 */
	private function default_currency() {
		$frm_settings = FrmAppHelper::get_settings();
		$currency     = trim( $frm_settings->currency );
		if ( ! $currency ) {
			$currency = 'USD';
		}

		return strtolower( $currency );
	}

	/**
	 * @param mixed $form_id
	 * @return array
	 */
	public function get_field_options( $form_id ) {

		$form_id  = absint( $form_id );
		$form_ids = $form_id;

		/**
		 * Allows updating form ids used to query fields for displaying options with in the Payment action.
		 *
		 * @since 6.8
		 *
		 * @param int|int[] $form_ids
		 * @param int $form_id
		 */
		$form_ids = apply_filters( 'frm_trans_action_get_field_options_form_id', $form_ids, $form_id );

		$form_fields = FrmField::getAll(
			array(
				'fi.form_id'  => $form_ids,
				'fi.type not' => array( 'divider', 'end_divider', 'html', 'break', 'captcha', 'rte', 'form' ),
			),
			'field_order'
		);

		return $form_fields;
	}

	/**
	 * Get the ID of the credit card field.
	 * We assume there is only a single credit card field in Stripe Lite.
	 * This is saved as part of the Stripe payment action.
	 *
	 * @param array $form_atts
	 * @return int
	 */
	public function get_credit_card_field_id( $form_atts ) {
		$field_id = 0;

		foreach ( $form_atts['form_fields'] as $field ) {
			if ( 'credit_card' === $field->type ) {
				$field_id = (int) $field->id;
				break;
			}
		}

		return $field_id;
	}

	/**
	 * Show the dropdown fields for custom form fields.
	 * This is used for first and last name fields.
	 *
	 * @param  array $form_atts
	 * @param  array $field_atts
	 * @return void
	 */
	public function show_fields_dropdown( $form_atts, $field_atts ) {
		if ( ! isset( $field_atts['allowed_fields'] ) ) {
			$field_atts['allowed_fields'] = array();
		}
		$has_field = false;
		?>
		<select class="frm_with_left_label" name="<?php echo esc_attr( $this->get_field_name( $field_atts['name'] ) ); ?>" id="<?php echo esc_attr( $this->get_field_id( $field_atts['name'] ) ); ?>">
			<option value=""><?php esc_html_e( '&mdash; Select &mdash;' ); ?></option>
			<?php
			foreach ( $form_atts['form_fields'] as $field ) {
				$type_is_allowed = empty( $field_atts['allowed_fields'] ) || in_array( $field->type, (array) $field_atts['allowed_fields'], true );

				if ( ! $type_is_allowed ) {
					continue;
				}

				$has_field  = true;
				$key_exists = array_key_exists( $field_atts['name'], $form_atts['form_action']->post_content );
				?>
				<option value="<?php echo esc_attr( $field->id ); ?>" <?php selected( $key_exists ? $form_atts['form_action']->post_content[ $field_atts['name'] ] : 0, $field->id ); ?>>
					<?php
					echo esc_attr( FrmAppHelper::truncate( $field->name, 50, 1 ) );

					if ( 'name' === $field->type && isset( $field_atts['name'] ) ) {
						switch ( $field_atts['name'] ) {
							case 'billing_first_name':
								echo ' (';
								esc_html_e( 'First', 'formidable' );
								echo ')';
								break;

							case 'billing_last_name':
								echo ' (';
								esc_html_e( 'Last', 'formidable' );
								echo ')';
								break;
						}
					}
					?>
				</option>
				<?php
				unset( $field );
			}//end foreach

			if ( ! $has_field && ! empty( $field_atts['allowed_fields'] ) ) {
				$readable_fields = str_replace( '_', ' ', implode( ', ', (array) $field_atts['allowed_fields'] ) );
				?>
				<option value="">
					<?php
					// translators: %s: The comma separated field types expected in the form.
					echo esc_html( sprintf( __( 'Oops! You need a %s field in your form.', 'formidable' ), $readable_fields ) );
					?>
				</option>
				<?php
			}
			?>
		</select>
		<?php
	}

	public static function get_single_action_type( $action_id, $type = '' ) {
		/**
		 * @var FrmFormAction
		 */
		$action_control = FrmFormActionsController::get_form_actions( 'payment' );
		return $action_control->get_single_action( $action_id );
	}
}
Site is undergoing maintenance

PACJA Events

Maintenance mode is on

Site will be available soon. Thank you for your patience!