| Server IP : 123.56.80.60 / Your IP : 216.73.216.78 Web Server : Apache/2.4.54 (Win32) OpenSSL/1.1.1s PHP/7.4.33 mod_fcgid/2.3.10-dev System : Windows NT iZhx3sob14hnz7Z 10.0 build 14393 (Windows Server 2016) i586 User : SYSTEM ( 0) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : C:/site/20241224/spunner/wp-content/plugins/wp-statistics/src/Service/Admin/ModalHandler/ |
Upload File : |
<?php
namespace WP_Statistics\Service\Admin\ModalHandler;
use WP_Statistics\Components\View;
use WP_STATISTICS\Option;
class Modal {
const MODAL_OPTION_KEY = 'user_modals';
/**
* Returns the relative path to the modals directory.
*
* @return string
*/
private static function getModalsDir()
{
return '/components/modals/';
}
/**
* Shows the modal if the user has not seen it before.
*
* @param string $modalId The name of the modal to show.
*
* @return void
*/
public static function showOnce($modalId)
{
if (empty(self::getState($modalId))) {
self::show($modalId);
}
}
/**
* Shows the modal and updates the state. (stateful modal)
*
* @param string $modalId The name of the modal to show.
*
* @return void
*/
public static function show($modalId)
{
self::updateState($modalId);
self::render($modalId);
}
/**
* Renders the modal with the given ID. (stateless modal)
*
* @param string $modalId The ID of the modal to render.
*
* @return void
*/
public static function render($modalId)
{
View::load(self::getModalsDir() . "/{$modalId}/{$modalId}-modal");
}
/**
* Updates the state of a modal.
*
* @param string $modalId The name of the modal.
*
* @return void
*/
private static function updateState($modalId)
{
$modals = self::getStates();
$modals[$modalId] = self::generateStateObject($modalId);
Option::saveOptionGroup(get_current_user_id(), $modals, self::MODAL_OPTION_KEY);
}
/**
* Retrieves the state of the modals.
*
* @return array The state of all modals.
*/
private static function getStates()
{
return Option::getOptionGroup(self::MODAL_OPTION_KEY, get_current_user_id(), []);
}
/**
* Retrieves the state of a modal.
*
* @param string $modal.
*
* @return array|false The state of the modal, or false if the modal has not been opened before.
*/
private static function getState($modal)
{
$modals = self::getStates();
return $modals[$modal] ?? false;
}
/**
* Generates a new state object for a given modalId.
*
* @param string $modalId
*
* @return array The state object.
*/
private static function generateStateObject($modalId)
{
$modal = self::getState($modalId);
$state = [
'times_opened' => isset($modal['times_opened']) ? $modal['times_opened'] + 1 : 1,
'last_opened' => date('Y-m-d H:i:s')
];
return $state;
}
}