Files
wp-multisite-waas/inc/ui/class-template-switching-element.php

466 lines
11 KiB
PHP

<?php
/**
* Adds the Template Selection UI to the Admin Panel.
*
* @package WP_Ultimo
* @subpackage UI
* @since 2.0.0
*/
namespace WP_Ultimo\UI;
use \WP_Ultimo\UI\Base_Element;
use \WP_Ultimo\Managers\Field_Templates_Manager;
// Exit if accessed directly
defined('ABSPATH') || exit;
/**
* Adds the Template Selection Element UI to the Admin Panel.
*
* @since 2.0.0
*/
class Template_Switching_Element extends Base_Element {
use \WP_Ultimo\Traits\Singleton;
/**
* The id of the element.
*
* @since 2.0.0
*
* @var string
*/
public $id = 'template-switching';
/**
* The current site element.
*
* @since 2.0.18
*
* @var string
*/
protected $site;
/**
* The membership object.
*
* @since 2.2.0
* @var \WP_Ultimo\Models\Membership
*/
protected $membership;
/**
* The list of products associated with the current membership.
*
* @since 2.2.0
* @var array
*/
protected $products;
/**
* The icon of the UI element.
* e.g. return fa fa-search
*
* @since 2.0.0
* @param string $context One of the values: block, elementor or bb.
*/
public function get_icon($context = 'block'): string {
if ($context === 'elementor') {
return 'eicon-cart-medium';
} // end if;
return 'fa fa-search';
} // end get_icon;
/**
* The title of the UI element.
*
* @since 2.0.0
* @return string
*/
public function get_title() {
return __('Template Switching', 'wp-ultimo');
} // end get_title;
/**
* The description of the UI element.
*
* @since 2.0.0
* @return string
*/
public function get_description() {
return __('Adds the template switching form to this page.', 'wp-ultimo');
} // end get_description;
/**
* Initializes the singleton.
*
* @since 2.0.0
* @return void
*/
public function init() {
add_action('wu_ajax_wu_switch_template', array($this, 'switch_template'));
parent::init();
} // end init;
/**
* Register element scripts.
*
* @since 2.0.4
*
* @return void
*/
public function register_scripts() {
wp_register_script('wu-template-switching', wu_get_asset('template-switching.js', 'js'), array('jquery', 'wu-vue-apps', 'wu-selectizer', 'wp-hooks', 'wu-cookie-helpers'));
wp_localize_script('wu-template-switching', 'wu_template_switching_params', array(
'ajaxurl' => wu_ajax_url(),
));
wp_enqueue_script('wu-template-switching');
} // end register_scripts;
/**
* The list of fields to be added to Gutenberg.
*
* @since 2.0.0
* @return array
*/
public function fields() {
$fields = array();
$fields['header'] = array(
'title' => __('Layout', 'wp-ultimo'),
'desc' => __('Layout', 'wp-ultimo'),
'type' => 'header',
);
$fields['template_selection_template'] = array(
'type' => 'group',
'desc' => Field_Templates_Manager::get_instance()->render_preview_block('template_selection'),
'fields' => array(
'template_selection_template' => array(
'type' => 'select',
'title' => __('Template Selector Layout', 'wp-ultimo'),
'placeholder' => __('Select your Layout', 'wp-ultimo'),
'default' => 'clean',
'options' => array($this, 'get_template_selection_templates'),
'wrapper_classes' => 'wu-flex-grow',
'html_attr' => array(
'v-model' => 'template_selection_template',
),
),
),
);
$fields['_dev_note_develop_your_own_template_1'] = array(
'type' => 'note',
'order' => 99,
'wrapper_classes' => 'sm:wu-p-0 sm:wu-block',
'classes' => '',
'desc' => sprintf('<div class="wu-p-4 wu-bg-blue-100 wu-text-grey-600">%s</div>', __('Want to add customized template selection templates?<br><a target="_blank" class="wu-no-underline" href="https://help.wpultimo.com/article/343-customize-your-checkout-flow-using-field-templates">See how you can do that here</a>.', 'wp-ultimo')),
);
return $fields;
} // end fields;
/**
* The list of keywords for this element.
*
* @since 2.0.0
*
* @return array
*/
public function keywords() {
return array(
'WP Ultimo',
'WP Multisite WaaS',
'Template',
'Template Switching',
);
} // end keywords;
/**
* List of default parameters for the element.
*
* @since 2.0.0
* @return array
*/
public function defaults() {
$site_template_ids = wu_get_site_templates(array(
'fields' => 'ids',
));
return array(
'slug' => 'template-switching',
'template_selection_template' => 'clean',
'template_selection_sites' => implode(',', $site_template_ids),
);
} // end defaults;
/**
* Runs early on the request lifecycle as soon as we detect the shortcode is present.
*
* @since 2.0.0
* @return void
*/
public function setup() {
$this->site = wu_get_current_site();
if (!$this->site || !$this->site->is_customer_allowed()) {
$this->set_display(false);
return;
} // end if;
$this->membership = $this->site->get_membership();
$this->products = array();
$all_membership_products = array();
if ($this->membership) {
$all_membership_products = $this->membership->get_all_products();
if (is_array($all_membership_products) && $all_membership_products) {
foreach ($all_membership_products as $product) {
$this->products[] = $product['product']->get_id();
} // end foreach;
} // end if;
} // end if;
} // end setup;
/**
* Runs early on the request lifecycle as soon as we detect the shortcode is present.
*
* @since 2.0.4
*
* @return void
*/
public function setup_preview() {
$this->site = wu_mock_site();
} // end setup_preview;
/**
* Ajax action to change the template for a given site.
*
* @since 2.0.4
*
* @return json|\WP_Error Switch template response.
*/
public function switch_template() {
if (!$this->site) {
$this->site = wu_get_current_site();
} // end if;
$template_id = wu_request('template_id', '');
if (!$template_id) {
return new \WP_Error('template_id_required', __('You need to provide a valid template to duplicate.', 'wp-ultimo'));
} // end if;
$switch = \WP_Ultimo\Helpers\Site_Duplicator::override_site($template_id, $this->site->get_id());
/**
* Allow plugin developers to hook functions after a user or super admin switches the site template
*
* @since 1.9.8
* @param integer Site ID
* @return void
*/
do_action('wu_after_switch_template', $this->site->get_id());
if ($switch) {
wp_send_json_success(array(
'redirect_url' => add_query_arg(array(
'updated' => 1,
), $_SERVER['HTTP_REFERER']),
));
} // end if;
} // end switch_template;
/**
* The content to be output on the screen.
*
* Should return HTML markup to be used to display the block.
* This method is shared between the block render method and
* the shortcode implementation.
*
* @since 2.0.0
*
* @param array $atts Parameters of the block/shortcode.
* @param string|null $content The content inside the shortcode.
* @return string
*/
public function output($atts, $content = null) {
if ($this->site) {
$filter_template_limits = new \WP_Ultimo\Limits\Site_Template_Limits();
$atts['products'] = $this->products;
$template_selection_field = $filter_template_limits->maybe_filter_template_selection_options($atts);
if (!isset($template_selection_field['sites'])) {
$template_selection_field['sites'] = array();
} // end if;
$atts['template_selection_sites'] = implode(',', $template_selection_field['sites']);
$site_list = explode(',', $atts['template_selection_sites']);
$sites = array_map('wu_get_site', $site_list);
$sites = array_filter($sites);
$categories = \WP_Ultimo\Models\Site::get_all_categories($sites);
$template_attributes = array(
'sites' => $sites,
'name' => '',
'categories' => $categories,
);
$reducer_class = new \WP_Ultimo\Checkout\Signup_Fields\Signup_Field_Template_Selection();
$template_class = Field_Templates_Manager::get_instance()->get_template_class('template_selection', $atts['template_selection_template']);
$content = $template_class ? $template_class->render_container($template_attributes, $reducer_class) : __('Template does not exist.', 'wp-ultimo');
$checkout_fields['back_to_template_selection'] = array(
'type' => 'note',
'order' => 0,
'desc' => sprintf('<a href="#" class="wu-no-underline wu-mt-1 wu-uppercase wu-text-2xs wu-font-semibold wu-text-gray-600" v-on:click.prevent="template_id = original_template_id; confirm_switch = false">%s</a>', __('&larr; Back to Template Selection', 'wp-ultimo')),
'wrapper_html_attr' => array(
'v-init:original_template_id' => $this->site->get_template_id(),
'v-show' => 'template_id != original_template_id',
'v-cloak' => '1',
),
);
$checkout_fields['template_element'] = array(
'type' => 'note',
'wrapper_classes' => 'wu-w-full',
'classes' => 'wu-w-full',
'desc' => $content,
'wrapper_html_attr' => array(
'v-show' => 'template_id == original_template_id',
'v-cloak' => '1',
),
);
$checkout_fields['confirm_switch'] = array(
'type' => 'toggle',
'title' => __('Confirm template switch?', 'wp-ultimo'),
'desc' => __('Switching your current template completely overwrites the content of your site with the contents of the newly chosen template. All customizations will be lost. This action cannot be undone.', 'wp-ultimo'),
'tooltip' => '',
'wrapper_classes' => '',
'value' => 0,
'html_attr' => array(
'v-model' => 'confirm_switch'
),
'wrapper_html_attr' => array(
'v-show' => 'template_id != 0 && template_id != original_template_id',
'v-cloak' => 1,
),
);
$checkout_fields['submit_switch'] = array(
'type' => 'link',
'display_value' => __('Process Switch', 'wp-ultimo'),
'wrapper_classes' => 'wu-text-right wu-bg-gray-100',
'classes' => 'button button-primary',
'wrapper_html_attr' => array(
'v-cloak' => 1,
'v-show' => 'confirm_switch',
'v-on:click.prevent' => 'ready = true'
),
);
$checkout_fields['template_id'] = array(
'type' => 'hidden',
'html_attr' => array(
'v-model' => 'template_id',
'v-init:template_id' => $this->site->get_template_id(),
),
);
$section_slug = 'wu-template-switching-form';
$form = new Form($section_slug, $checkout_fields, array(
'views' => 'admin-pages/fields',
'classes' => 'wu-striped wu-widget-inset',
'field_wrapper_classes' => 'wu-w-full wu-box-border wu-items-center wu-flex wu-justify-between wu-p-4 wu-py-5 wu-m-0 wu-border-t wu-border-l-0 wu-border-r-0 wu-border-b-0 wu-border-gray-300 wu-border-solid'
));
ob_start();
$form->render();
return ob_get_clean();
} // end if;
return '';
} // end output;
/**
* Returns the list of available pricing table templates.
*
* @since 2.0.0
* @return array
*/
public function get_template_selection_templates() {
$available_templates = Field_Templates_Manager::get_instance()->get_templates_as_options('template_selection');
return $available_templates;
} // end get_template_selection_templates;
} // end class Template_Switching_Element;