Skip to content

Commit 4eee34a

Browse files
committed
Register theme autoloader
1 parent e9274ce commit 4eee34a

File tree

3 files changed

+36
-4
lines changed

3 files changed

+36
-4
lines changed

.gitignore

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
1-
vendor/
2-
.idea/
3-
build/
1+
vendor
2+
.idea
3+
.vscode
4+
build
45
.DS_Store
5-
*.cache
6+
*.cache

src/Theme.php

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
use Codions\ThemesManager\Events\ThemeEnabled;
88
use Codions\ThemesManager\Events\ThemeEnabling;
99
use Codions\ThemesManager\Facades\ThemesManager;
10+
use Codions\ThemesManager\Traits\Autoloader;
1011
use Codions\ThemesManager\Traits\HasConfigs;
1112
use Codions\ThemesManager\Traits\HasHelpers;
1213
use Codions\ThemesManager\Traits\HasTranslations;
@@ -24,6 +25,7 @@ class Theme
2425
use HasViews;
2526
use HasHelpers;
2627
use HasConfigs;
28+
use Autoloader;
2729

2830
/**
2931
* The theme name.
@@ -196,6 +198,14 @@ public function getVendor(): string
196198
return $this->vendor;
197199
}
198200

201+
public function getNamespace(string $path = null): string
202+
{
203+
$vendor = Str::studly($this->vendor);
204+
$name = Str::studly($this->name);
205+
206+
return "Themes\\$vendor\\$name\\" . $path;
207+
}
208+
199209
/**
200210
* Check if has parent Theme.
201211
*/
@@ -275,6 +285,7 @@ public function enable(bool $withEvent = true): self
275285
}
276286

277287
$this->enabled = true;
288+
$this->registerAutoloader();
278289
$this->loadViews();
279290
$this->loadTranlastions();
280291
$this->loadHelpers();

src/Traits/Autoloader.php

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
<?php
2+
3+
namespace Codions\ThemesManager\Traits;
4+
5+
trait Autoloader
6+
{
7+
public function registerAutoloader()
8+
{
9+
spl_autoload_register(function ($class) {
10+
$class = str_replace($this->getNamespace(), '', $class);
11+
12+
$class = str_replace('\\', DIRECTORY_SEPARATOR, $class);
13+
$file = $this->getPath("src/{$class}.php");
14+
15+
if (file_exists($file)) {
16+
require_once $file;
17+
}
18+
});
19+
}
20+
}

0 commit comments

Comments
 (0)