Files
wp-multisite-waas/inc/limitations/class-limit-site-templates.php
2025-02-09 12:30:02 -07:00

261 lines
5.1 KiB
PHP

<?php
/**
* Site_Templates Limit Module.
*
* @package WP_Ultimo
* @subpackage Limitations
* @since 2.0.0
*/
namespace WP_Ultimo\Limitations;
// Exit if accessed directly
defined('ABSPATH') || exit;
/**
* Site_Templates Limit Module.
*
* @since 2.0.0
*/
class Limit_Site_Templates extends Limit {
/**
* The module id.
*
* @since 2.0.0
* @var string
*/
protected $id = 'site_templates';
/**
* The mode of template assignment/selection.
*
* @since 2.0.0
* @var string
*/
protected $mode = 'default';
/**
* Allows sub-type limits to set their own default value for enabled.
*
* @since 2.0.0
* @var bool
*/
private bool $enabled_default_value = true;
/**
* Sets up the module based on the module data.
*
* @since 2.0.0
*
* @param array $data The module data.
* @return void
*/
public function setup($data): void {
parent::setup($data);
$this->mode = wu_get_isset($data, 'mode', 'default');
}
/**
* Returns the mode. Can be one of three: default, assign_template and choose_available_templates.
*
* @since 2.0.0
* @return string
*/
public function get_mode() {
return $this->mode;
}
/**
* The check method is what gets called when allowed is called.
*
* Each module needs to implement a check method, that returns a boolean.
* This check can take any form the developer wants.
*
* @since 2.0.0
*
* @param mixed $value_to_check Value to check.
* @param mixed $limit The list of limits in this modules.
* @param string $type Type for sub-checking.
* @return bool
*/
public function check($value_to_check, $limit, $type = '') {
$template = (object) $this->{$value_to_check};
$types = [
'available' => 'available' === $template->behavior,
'not_available' => 'not_available' === $template->behavior,
'pre_selected' => 'pre_selected' === $template->behavior,
];
return wu_get_isset($types, $type, true);
}
/**
* Adds a magic getter for themes.
*
* @since 2.0.0
*
* @param string $template_id The template site id.
* @return object
*/
public function __get($template_id) {
$template_id = str_replace('site_', '', $template_id);
$template = (object) wu_get_isset($this->get_limit(), $template_id, $this->get_default_permissions($template_id));
return (object) wp_parse_args($template, $this->get_default_permissions($template_id));
}
/**
* Returns default permissions.
*
* @since 2.0.0
*
* @param string $type Type for sub-checking.
* @return array
*/
public function get_default_permissions($type) {
return [
'behavior' => 'available',
];
}
/**
* Checks if a theme exists on the current module.
*
* @since 2.0.0
*
* @param string $template_id The template site id.
* @return bool
*/
public function exists($template_id) {
$template_id = str_replace('site_', '', $template_id);
$results = wu_get_isset($this->get_limit(), $template_id, []);
return wu_get_isset($results, 'behavior', 'not-set') !== 'not-set';
}
/**
* Get all themes.
*
* @since 2.0.0
* @return array List of theme stylesheets.
*/
public function get_all_templates(): array {
$templates = (array) $this->get_limit();
return array_keys($templates);
}
/**
* Get available themes.
*
* @since 2.0.0
* @return array
*/
public function get_available_site_templates() {
$limits = $this->get_limit();
if ( ! $limits) {
return false;
}
$limits = (array) $limits;
$available = [];
foreach ($limits as $site_id => $site_settings) {
$site_settings = (object) $site_settings;
if ('available' === $site_settings->behavior || 'pre_selected' === $site_settings->behavior || 'default' === $this->mode) {
$available[] = $site_id;
}
}
return $available;
}
/**
* Get the forced active theme for the current limitations.
*
* @since 2.0.0
* @return string
*/
public function get_pre_selected_site_template() {
$limits = $this->get_limit();
$pre_selected_site_template = false;
if ( ! $limits) {
return $pre_selected_site_template;
}
foreach ($limits as $site_id => $site_settings) {
$site_settings = (object) $site_settings;
if ('pre_selected' === $site_settings->behavior) {
$pre_selected_site_template = $site_id;
}
}
return $pre_selected_site_template;
}
/**
* Handles limits on post submission.
*
* @since 2.0.0
* @return mixed
*/
public function handle_limit() {
$module = wu_get_isset($_POST['modules'], $this->id, []);
return wu_get_isset($module, 'limit', $this->get_limit());
}
/**
* Handles other elements when saving. Used for custom attributes.
*
* @since 2.0.0
*
* @param array $module The current module, extracted from the request.
* @return array
*/
public function handle_others($module) {
$_module = wu_get_isset($_POST['modules'], $this->id, []);
$module['mode'] = wu_get_isset($_module, 'mode', 'default');
return $module;
}
/**
* Returns a default state.
*
* @since 2.0.0
* @return array
*/
public static function default_state() {
return [
'enabled' => true,
'limit' => null,
'mode' => 'default',
];
}
}