mirror of
https://github.com/alextselegidis/easyappointments.git
synced 2024-11-10 10:02:33 +03:00
171 lines
4.7 KiB
PHP
171 lines
4.7 KiB
PHP
<?php defined('BASEPATH') or exit('No direct script access allowed');
|
|
|
|
/* ----------------------------------------------------------------------------
|
|
* Easy!Appointments - Online Appointment Scheduler
|
|
*
|
|
* @package EasyAppointments
|
|
* @author A.Tselegidis <alextselegidis@gmail.com>
|
|
* @copyright Copyright (c) Alex Tselegidis
|
|
* @license https://opensource.org/licenses/GPL-3.0 - GPLv3
|
|
* @link https://easyappointments.org
|
|
* @since v1.3.0
|
|
* ---------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* Get / set the specified config value.
|
|
*
|
|
* If an array is passed as the key, we will assume you want to set an array of values.
|
|
*
|
|
* Example "Get":
|
|
*
|
|
* $version = config('version', '1.0.0');
|
|
*
|
|
* Example "Set":
|
|
*
|
|
* config(['version' => '1.0.0']);
|
|
*
|
|
* @param array|string $key Configuration key.
|
|
* @param mixed|null $default Default value in case the requested config has no value.
|
|
*
|
|
* @return mixed|NULL Returns the requested value or NULL if you assign a new configuration value.
|
|
*
|
|
* @throws InvalidArgumentException
|
|
*/
|
|
function config(array|string $key, mixed $default = null): mixed
|
|
{
|
|
/** @var EA_Controller $CI */
|
|
$CI = &get_instance();
|
|
|
|
if (empty($key)) {
|
|
throw new InvalidArgumentException('The $key argument cannot be empty.');
|
|
}
|
|
|
|
if (is_array($key)) {
|
|
foreach ($key as $item => $value) {
|
|
$CI->config->set_item($item, $value);
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
$value = $CI->config->item($key);
|
|
|
|
return $value ?? $default;
|
|
}
|
|
|
|
if (!function_exists('script_vars')) {
|
|
/**
|
|
* Get / set the specified JS config value.
|
|
*
|
|
* If an array is passed as the key, we will assume you want to set an array of values.
|
|
*
|
|
* Example "Get":
|
|
*
|
|
* $version = script_vars('version', '1.0.0');
|
|
*
|
|
* Example "Set":
|
|
*
|
|
* script_vars(['version' => '1.0.0']);
|
|
*
|
|
* @param array|string|null $key Configuration key.
|
|
* @param mixed|null $default Default value in case the requested config has no value.
|
|
*
|
|
* @return mixed|NULL Returns the requested value or NULL if you assign a new configuration value.
|
|
*
|
|
* @throws InvalidArgumentException
|
|
*/
|
|
function script_vars(array|string $key = null, mixed $default = null): mixed
|
|
{
|
|
$script_vars = config('script_vars', []);
|
|
|
|
if (empty($key)) {
|
|
return $script_vars;
|
|
}
|
|
|
|
if (is_array($key)) {
|
|
foreach ($key as $item => $value) {
|
|
$script_vars[$item] = $value;
|
|
}
|
|
|
|
config(['script_vars' => $script_vars]);
|
|
|
|
return null;
|
|
}
|
|
|
|
$value = $script_vars[$key] ?? null;
|
|
|
|
return $value ?? $default;
|
|
}
|
|
}
|
|
|
|
if (!function_exists('html_vars')) {
|
|
/**
|
|
* Get / set the specified HTML variable.
|
|
*
|
|
* If an array is passed as the key, we will assume you want to set an array of values.
|
|
*
|
|
* Example "Get":
|
|
*
|
|
* $version = html_vars('title', 'Default Title');
|
|
*
|
|
* Example "Set":
|
|
*
|
|
* html_vars(['title' => 'Test Title']);
|
|
*
|
|
* @param array|string|null $key Variable key.
|
|
* @param mixed|null $default Default value in case the requested variable has no value.
|
|
*
|
|
* @return mixed|NULL Returns the requested value or NULL if you assign a new configuration value.
|
|
*
|
|
* @throws InvalidArgumentException
|
|
*/
|
|
function html_vars(array|string $key = null, mixed $default = null): mixed
|
|
{
|
|
$html_vars = config('html_vars', []);
|
|
|
|
if (empty($key)) {
|
|
return $html_vars;
|
|
}
|
|
|
|
if (is_array($key)) {
|
|
foreach ($key as $item => $value) {
|
|
$html_vars[$item] = $value;
|
|
}
|
|
|
|
config(['html_vars' => $html_vars]);
|
|
|
|
return null;
|
|
}
|
|
|
|
$value = $html_vars[$key] ?? null;
|
|
|
|
return $value ?? $default;
|
|
}
|
|
}
|
|
|
|
if (!function_exists('vars')) {
|
|
/**
|
|
* Get / set the specified HTML & JS config value.
|
|
*
|
|
* If an array is passed as the key, we will assume you want to set an array of values.
|
|
*
|
|
* Example "Get":
|
|
*
|
|
* $version = vars('version', '1.0.0');
|
|
*
|
|
* Example "Set":
|
|
*
|
|
* vars(['version' => '1.0.0']);
|
|
*
|
|
* @param array|string|null $key Configuration key.
|
|
* @param mixed|null $default Default value in case the requested config has no value.
|
|
*
|
|
* @return mixed|NULL Returns the requested value or NULL if you assign a new configuration value.
|
|
*
|
|
* @throws InvalidArgumentException
|
|
*/
|
|
function vars(array|string $key = null, mixed $default = null): mixed
|
|
{
|
|
return html_vars($key) ?? (script_vars($key) ?? $default);
|
|
}
|
|
}
|