Files
wp-multisite-waas/inc/functions/checkout-form.php
2025-02-09 00:20:10 -07:00

212 lines
4.9 KiB
PHP

<?php
/**
* Checkout Form Functions
*
* @package WP_Ultimo\Functions
* @since 2.0.0
*/
// Exit if accessed directly
defined('ABSPATH') || exit;
use WP_Ultimo\Checkout\Checkout;
use WP_Ultimo\Models\Checkout_Form;
/**
* Returns a checkout_form.
*
* @since 2.0.0
*
* @param int $checkout_form_id The ID of the checkout_form.
* @return \WP_Ultimo\Models\Checkout_Form|false
*/
function wu_get_checkout_form($checkout_form_id) {
return \WP_Ultimo\Models\Checkout_Form::get_by_id($checkout_form_id);
}
/**
* Queries checkout_forms.
*
* @since 2.0.0
*
* @param array $query Query arguments.
* @return \WP_Ultimo\Models\Checkout_Form[]
*/
function wu_get_checkout_forms($query = []) {
return \WP_Ultimo\Models\Checkout_Form::query($query);
}
/**
* Returns a checkout_form based on slug.
*
* @since 2.0.0
*
* @param string $checkout_form_slug The slug of the checkout_form.
* @return \WP_Ultimo\Models\Checkout_Form|false
*/
function wu_get_checkout_form_by_slug($checkout_form_slug) {
/**
* Fixed case: Upgrade/Downgrade forms.
*
* In this particular case, the fields are fixed,
* although they can be modified via a filter in the
* Checkout_Form::membership_change_form_fields() method.
*
* @see wu_checkout_form_membership_change_form_fields filter.
*/
if ('wu-checkout' === $checkout_form_slug) {
$checkout_form = new \WP_Ultimo\Models\Checkout_Form();
$checkout_fields = Checkout_Form::membership_change_form_fields();
$checkout_form->set_settings($checkout_fields);
return $checkout_form;
} elseif ('wu-add-new-site' === $checkout_form_slug) {
$checkout_form = new \WP_Ultimo\Models\Checkout_Form();
$checkout_fields = Checkout_Form::add_new_site_form_fields();
$checkout_form->set_settings($checkout_fields);
return $checkout_form;
} elseif ('wu-finish-checkout' === $checkout_form_slug) {
$checkout_form = new \WP_Ultimo\Models\Checkout_Form();
$checkout_fields = Checkout_Form::finish_checkout_form_fields();
$checkout_form->set_settings($checkout_fields);
return $checkout_form;
}
return \WP_Ultimo\Models\Checkout_Form::get_by('slug', $checkout_form_slug);
}
/**
* Creates a new checkout form.
*
* @since 2.0.0
*
* @param array $checkout_form_data Checkout_Form data.
* @return \WP_Error|\WP_Ultimo\Models\Checkout_Form
*/
function wu_create_checkout_form($checkout_form_data) {
$checkout_form_data = wp_parse_args(
$checkout_form_data,
[
'name' => false,
'slug' => false,
'settings' => [],
'allowed_countries' => [],
'date_created' => wu_get_current_time('mysql', true),
'date_modified' => wu_get_current_time('mysql', true),
]
);
$checkout_form = new Checkout_Form($checkout_form_data);
$saved = $checkout_form->save();
return is_wp_error($saved) ? $saved : $checkout_form;
}
/**
* Returns a list of all the available domain options in all registered forms.
*
* @since 2.0.11
* @return array
*/
function wu_get_available_domain_options() {
$fields = [];
$main_form = wu_get_checkout_form_by_slug('main-form');
if ($main_form) {
$fields = $main_form->get_all_fields_by_type('site_url');
} else {
$forms = wu_get_checkout_forms(
[
'number' => 1,
]
);
if ($forms) {
$fields = $forms[0]->get_all_fields_by_type('site_url');
}
}
$domain_options = [];
if ($fields) {
foreach ($fields as $field) {
$available_domains = $field['available_domains'] ?? '';
$field_domain_options = explode(PHP_EOL, (string) $available_domains);
if (isset($field['enable_domain_selection']) && $field['enable_domain_selection'] && $field_domain_options) {
$domain_options = array_merge($domain_options, $field_domain_options);
}
}
}
return $domain_options;
}
/**
* Check if the field is preselected in request.
*
* @since 2.0.19
* @param string $field_slug Path to attach to the end of the URL.
* @return bool
*/
function wu_is_form_field_pre_selected($field_slug) {
$checkout = Checkout::get_instance();
$pre_selected = $checkout->request_or_session('pre_selected', []);
$from_request = stripslashes_deep(wu_get_isset($_GET, $field_slug)) || isset($pre_selected[ $field_slug ]);
return wu_request('wu_preselected') === $field_slug || $from_request;
}
/**
* Get the request arg slug from a field.
*
* @since 2.0.19
* @param array $field The field from form step.
* @return string
*/
function wu_form_field_request_arg($field) {
if ($field['type'] === 'template_selection') {
return 'template_id';
}
if ($field['type'] === 'pricing_table') {
return 'products';
}
return $field['id'];
}
/**
* Check if the field should be hidden in form
*
* @since 2.0.19
* @param array $field The field from form step.
* @return bool
*/
function wu_should_hide_form_field($field) {
$hide_preselect = (bool) (int) wu_get_isset($field, "hide_{$field['type']}_when_pre_selected");
return $hide_preselect && wu_is_form_field_pre_selected(wu_form_field_request_arg($field));
}