This commit is contained in:
171
application/helpers/config_helper.php
Normal file
171
application/helpers/config_helper.php
Normal file
@@ -0,0 +1,171 @@
|
||||
<?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|null $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|null $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|null $key = null, mixed $default = null): mixed
|
||||
{
|
||||
return html_vars($key) ?? (script_vars($key) ?? $default);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user