wu_ajax_url(), ] ); wp_enqueue_script('wu-template-switching'); } /** * The list of fields to be added to Gutenberg. * * @since 2.0.0 * @return array */ public function fields() { $fields = []; $fields['header'] = [ 'title' => __('Layout', 'wp-ultimo'), 'desc' => __('Layout', 'wp-ultimo'), 'type' => 'header', ]; $fields['template_selection_template'] = [ 'type' => 'group', 'desc' => Field_Templates_Manager::get_instance()->render_preview_block('template_selection'), 'fields' => [ 'template_selection_template' => [ 'type' => 'select', 'title' => __('Template Selector Layout', 'wp-ultimo'), 'placeholder' => __('Select your Layout', 'wp-ultimo'), 'default' => 'clean', 'options' => [$this, 'get_template_selection_templates'], 'wrapper_classes' => 'wu-flex-grow', 'html_attr' => [ 'v-model' => 'template_selection_template', ], ], ], ]; $fields['_dev_note_develop_your_own_template_1'] = [ 'type' => 'note', 'order' => 99, 'wrapper_classes' => 'sm:wu-p-0 sm:wu-block', 'classes' => '', 'desc' => sprintf('
%s
', __('Want to add customized template selection templates?
See how you can do that here.', 'wp-ultimo')), ]; return $fields; } /** * The list of keywords for this element. * * @since 2.0.0 * * @return array */ public function keywords() { return [ 'WP Ultimo', 'WP Multisite WaaS', 'Template', 'Template Switching', ]; } /** * List of default parameters for the element. * * @since 2.0.0 * @return array */ public function defaults() { $site_template_ids = wu_get_site_templates( [ 'fields' => 'ids', ] ); return [ 'slug' => 'template-switching', 'template_selection_template' => 'clean', 'template_selection_sites' => implode(',', $site_template_ids), ]; } /** * Runs early on the request lifecycle as soon as we detect the shortcode is present. * * @since 2.0.0 * @return void */ public function setup(): void { $this->site = wu_get_current_site(); if ( ! $this->site || ! $this->site->is_customer_allowed()) { $this->set_display(false); return; } $this->membership = $this->site->get_membership(); $this->products = []; $all_membership_products = []; 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(); } } } } /** * 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(): void { $this->site = wu_mock_site(); } /** * 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(); } $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')); } $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( [ 'redirect_url' => add_query_arg( [ 'updated' => 1, ], $_SERVER['HTTP_REFERER'] ), ] ); } } /** * 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'] = []; } $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 = [ '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'] = [ 'type' => 'note', 'order' => 0, 'desc' => sprintf('%s', __('← Back to Template Selection', 'wp-ultimo')), 'wrapper_html_attr' => [ 'v-init:original_template_id' => $this->site->get_template_id(), 'v-show' => 'template_id != original_template_id', 'v-cloak' => '1', ], ]; $checkout_fields['template_element'] = [ 'type' => 'note', 'wrapper_classes' => 'wu-w-full', 'classes' => 'wu-w-full', 'desc' => $content, 'wrapper_html_attr' => [ 'v-show' => 'template_id == original_template_id', 'v-cloak' => '1', ], ]; $checkout_fields['confirm_switch'] = [ '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' => [ 'v-model' => 'confirm_switch', ], 'wrapper_html_attr' => [ 'v-show' => 'template_id != 0 && template_id != original_template_id', 'v-cloak' => 1, ], ]; $checkout_fields['submit_switch'] = [ 'type' => 'link', 'display_value' => __('Process Switch', 'wp-ultimo'), 'wrapper_classes' => 'wu-text-right wu-bg-gray-100', 'classes' => 'button button-primary', 'wrapper_html_attr' => [ 'v-cloak' => 1, 'v-show' => 'confirm_switch', 'v-on:click.prevent' => 'ready = true', ], ]; $checkout_fields['template_id'] = [ 'type' => 'hidden', 'html_attr' => [ '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, [ '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(); } return ''; } /** * 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; } }