Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions resources/stubs/template/composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,10 @@
"parent": "DummyParent",
"active": true
}
},
"autoload": {
"psr-4": {
"Themes\\DummyNamespace\\": "src"
}
}
}
24 changes: 24 additions & 0 deletions resources/stubs/template/src/Providers/ThemeServiceProvider.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<?php

namespace Themes\DummyNamespace\Providers;

use Illuminate\Support\ServiceProvider;

class ThemeServiceProvider extends ServiceProvider
{
/**
* Register any application services.
*/
public function register(): void
{
//
}

/**
* Bootstrap any application services.
*/
public function boot(): void
{
//
}
}
7 changes: 6 additions & 1 deletion resources/stubs/template/src/config/config.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,10 @@
*/

return [
'inspire' => 'Display an inspiring quote',
/*
* Theme Service Providers
*/
'providers' => [
\Themes\DummyNamespace\Providers\ThemeServiceProvider::class,
],
];
79 changes: 45 additions & 34 deletions src/Console/Generators/MakeTheme.php
Original file line number Diff line number Diff line change
Expand Up @@ -128,39 +128,6 @@ protected function validateName()
return true;
}

/**
* Replace placeholders in generated file.
*
* @param \Symfony\Component\Finder\SplFileInfo $file
* @return string
*/
protected function replacePlaceholders($file)
{
$this->sectionMessage('File generation', "{$file->getPathName()}");

$find = [
'DummyAuthorName',
'DummyAuthorEmail',
'DummyDescription',
'DummyName',
'DummyParent',
'DummyVendor',
'DummyVersion',
];

$replace = [
Str::title(Arr::get($this->theme, 'author-name', '')),
Arr::get($this->theme, 'author-email', ''),
Arr::get($this->theme, 'description', ''),
Arr::get($this->theme, 'name', ''),
Arr::get($this->theme, 'parent', ''),
Arr::get($this->theme, 'vendor', ''),
Arr::get($this->theme, 'version', '1.0'),
];

return str_replace($find, $replace, $file->getContents());
}

/**
* Ask for theme author information.
* Notice: if value is set in themes-manager.composer.author.name and themes-manager.composer.author.email config value
Expand Down Expand Up @@ -218,7 +185,7 @@ protected function askVendor()
*/
protected function askVersion()
{
$this->theme['version'] = $this->ask('Version number');
$this->theme['version'] = $this->ask('Version number', 'v1.0.0');

if (! strlen($this->theme['version'])) {
$this->theme['version'] = null;
Expand Down Expand Up @@ -257,4 +224,48 @@ private function generateTheme()
$this->files->put($filePath, $contents);
}
}

/**
* Replace placeholders in generated file.
*
* @param \Symfony\Component\Finder\SplFileInfo $file
* @return string
*/
protected function replacePlaceholders($file)
{
$this->sectionMessage('File generation', "{$file->getPathName()}");

$find = [
'DummyNamespace',
'DummyAuthorName',
'DummyAuthorEmail',
'DummyDescription',
'DummyName',
'DummyParent',
'DummyVendor',
'DummyVersion',
];

$vendor = Arr::get($this->theme, 'vendor', '');
$name = Arr::get($this->theme, 'name', '');

$namespace = Str::studly($vendor) . '\\' . Str::studly($name);

if (Str::contains($file, 'composer.json')) {
$namespace = Str::studly($vendor) . '\\\\' . Str::studly($name);
}

$replace = [
$namespace,
Str::title(Arr::get($this->theme, 'author-name', '')),
Arr::get($this->theme, 'author-email', ''),
Arr::get($this->theme, 'description', ''),
$name,
Arr::get($this->theme, 'parent', ''),
$vendor,
Arr::get($this->theme, 'version', '1.0.0'),
];

return str_replace($find, $replace, $file->getContents());
}
}
6 changes: 5 additions & 1 deletion src/Theme.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
use Codions\ThemesManager\Traits\Autoloader;
use Codions\ThemesManager\Traits\HasConfigs;
use Codions\ThemesManager\Traits\HasHelpers;
use Codions\ThemesManager\Traits\HasProviders;
use Codions\ThemesManager\Traits\HasTranslations;
use Codions\ThemesManager\Traits\HasViews;
use Illuminate\Filesystem\Filesystem;
Expand All @@ -21,11 +22,12 @@

class Theme
{
use Autoloader;
use HasProviders;
use HasTranslations;
use HasViews;
use HasHelpers;
use HasConfigs;
use Autoloader;

/**
* The theme name.
Expand Down Expand Up @@ -286,9 +288,11 @@ public function enable(bool $withEvent = true): self

$this->enabled = true;
$this->registerAutoloader();
$this->loadProviders();
$this->loadViews();
$this->loadTranlastions();
$this->loadHelpers();
$this->registerLivewireComponents();

if ($withEvent) {
event(new ThemeEnabled($this->name));
Expand Down
46 changes: 46 additions & 0 deletions src/Traits/Autoloader.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,12 @@

namespace Codions\ThemesManager\Traits;

use Illuminate\Filesystem\Filesystem;
use Illuminate\Support\Str;
use Livewire\Component;
use Livewire\Livewire;
use ReflectionClass;

trait Autoloader
{
public function registerAutoloader()
Expand All @@ -17,4 +23,44 @@ public function registerAutoloader()
}
});
}

protected function registerLivewireComponents()
{
$directory = $this->getPath('src/Http/Livewire');

$namespace = $this->getNamespace('Http\Livewire');

// If you ever decide to change, I suggest using something like "theme::".
$aliasPrefix = '';

$filesystem = new Filesystem();

if (! $filesystem->isDirectory($directory)) {
return false;
}

$files = collect($filesystem->allFiles($directory));

$files->map(function ($file) use ($namespace) {
return $namespace . '\\' . str_replace(['/', '.php'], ['\\', ''], $file->getRelativePathname());
})
->filter(function ($class) {
return is_subclass_of($class, Component::class) && ! (new ReflectionClass($class))->isAbstract();
})
->each(function ($class) use ($namespace, $aliasPrefix) {
$alias = $aliasPrefix . Str::of($class)
->after($namespace . '\\')
->replace(['/', '\\'], '.')
->explode('.')
->map([Str::class, 'kebab'])
->implode('.');

if (Str::endsWith($class, ['\Index', '\index'])) {
Livewire::component(Str::beforeLast($alias, '.index'), $class);
}

// dd($alias, $class);
Livewire::component($alias, $class);
});
}
}
13 changes: 13 additions & 0 deletions src/Traits/HasProviders.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?php

namespace Codions\ThemesManager\Traits;

trait HasProviders
{
public function loadProviders(): void
{
foreach ($this->config('providers', []) as $provider) {
app()->register($provider);
}
}
}