mirror of
https://code.castopod.org/adaures/castopod
synced 2025-04-19 13:01:19 +00:00
51 lines
1.7 KiB
PHP
51 lines
1.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use ViewThemes\Theme;
|
|
|
|
/**
|
|
* The goal of this file is to allow developers a location where they can overwrite core procedural functions and
|
|
* replace them with their own. This file is loaded during the bootstrap process and is called during the framework's
|
|
* execution.
|
|
*
|
|
* This can be looked at as a `master helper` file that is loaded early on, and may also contain additional functions
|
|
* that you'd like to use throughout your entire application
|
|
*
|
|
* @see: https://codeigniter.com/user_guide/extending/common.html
|
|
*/
|
|
|
|
if (! function_exists('view')) {
|
|
/**
|
|
* Grabs the current RendererInterface-compatible class and tells it to render the specified view. Simply provides a
|
|
* convenience method that can be used in Controllers, libraries, and routed closures.
|
|
*
|
|
* NOTE: Does not provide any escaping of the data, so that must all be handled manually by the developer.
|
|
*
|
|
* @param array<string, mixed> $data
|
|
* @param array<string, mixed> $options Unused - reserved for third-party extensions.
|
|
*/
|
|
function view(string $name, array $data = [], array $options = []): string
|
|
{
|
|
if (array_key_exists('theme', $options)) {
|
|
Theme::setTheme($options['theme']);
|
|
}
|
|
|
|
$path = Theme::path();
|
|
|
|
/** @var CodeIgniter\View\View $renderer */
|
|
$renderer = single_service('renderer', $path);
|
|
|
|
$saveData = config('View')
|
|
->saveData;
|
|
|
|
if (array_key_exists('saveData', $options)) {
|
|
$saveData = (bool) $options['saveData'];
|
|
unset($options['saveData']);
|
|
}
|
|
|
|
return $renderer->setData($data, 'raw')
|
|
->render($name, $options, $saveData);
|
|
}
|
|
}
|