kernel version 0.1.4

This commit is contained in:
Kavalar 2025-01-15 15:00:30 +03:00
parent 64dad0aaf9
commit 3e178f6633
4 changed files with 59 additions and 1 deletions

View File

@ -7,6 +7,7 @@ namespace kernel;
use kernel\helpers\Debug; use kernel\helpers\Debug;
use kernel\modules\user\models\User; use kernel\modules\user\models\User;
use kernel\services\ModuleService; use kernel\services\ModuleService;
use kernel\services\ThemeService;
use Phroute\Phroute\Dispatcher; use Phroute\Phroute\Dispatcher;
class App class App
@ -24,6 +25,8 @@ class App
public ModuleService $moduleService; public ModuleService $moduleService;
public ThemeService $themeService;
public static Database $db; public static Database $db;
public function run(): void public function run(): void
@ -39,6 +42,7 @@ class App
public function load(): static public function load(): static
{ {
$this->moduleService = new ModuleService(); $this->moduleService = new ModuleService();
$this->themeService = new ThemeService();
App::$collector = new CgRouteCollector(); App::$collector = new CgRouteCollector();
$this->setRouting(); $this->setRouting();
@ -53,6 +57,10 @@ class App
foreach ($modules_routs as $rout){ foreach ($modules_routs as $rout){
include "$rout"; include "$rout";
} }
$activeTheme = getConst($this->themeService->getActiveTheme());
if (!empty($activeTheme)){
include $activeTheme . "/" . $this->themeService->getThemeRout($activeTheme);
}
} }
public static function create(): App public static function create(): App

View File

@ -2,6 +2,8 @@
namespace kernel; namespace kernel;
use kernel\helpers\Debug;
class CgView class CgView
{ {
public string $viewPath = ''; public string $viewPath = '';
@ -61,6 +63,13 @@ class CgView
private function createContent(string $viewFile, array $data = []): false|string private function createContent(string $viewFile, array $data = []): false|string
{ {
ob_start(); ob_start();
if ($this->varToLayout){
foreach ($this->varToLayout as $key => $datum) {
${"$key"} = $datum;
}
}
$view = $this; $view = $this;
foreach ($data as $key => $datum) { foreach ($data as $key => $datum) {
${"$key"} = $datum; ${"$key"} = $datum;

View File

@ -1,6 +1,6 @@
{ {
"name": "Kernel", "name": "Kernel",
"version": "0.1.3", "version": "0.1.4",
"author": "ITGuild", "author": "ITGuild",
"slug": "kernel", "slug": "kernel",
"type": "kernel", "type": "kernel",

View File

@ -0,0 +1,41 @@
<?php
namespace kernel\services;
use kernel\models\Option;
class ThemeService
{
protected Option $option;
protected string $active_theme = "";
public function __construct()
{
$this->option = new Option();
$this->findActiveAdminTheme();
}
public function findActiveAdminTheme(): void
{
$model = $this->option::where("key", "active_theme")->first();
$this->active_theme = $model->value;
}
public function getActiveTheme(): string
{
return $this->active_theme;
}
public function getThemeRout(string $path)
{
if (file_exists($path . "/manifest.json")){
$manifest = json_decode(file_get_contents($path . "/manifest.json"), true);
if ($manifest['routs']) {
return $manifest['routs'];
}
}
return false;
}
}