This commit is contained in:
Adam Weston
2022-12-05 00:36:03 -05:00
parent a45b10717e
commit 0ae390601a
13 changed files with 277 additions and 380 deletions

View File

@@ -11,4 +11,4 @@ contact_links:
about: Learn how to notify us for sensitive bugs about: Learn how to notify us for sensitive bugs
- name: Report a bug - name: Report a bug
url: https://github.com/:vendor_name/:package_name/issues/new url: https://github.com/:vendor_name/:package_name/issues/new
about: Report a reproducable bug about: Report a reproducible bug

View File

@@ -1,4 +1,5 @@
name: dependabot-auto-merge name: Dependabot Auto Merge
on: pull_request_target on: pull_request_target
permissions: permissions:
@@ -29,4 +30,4 @@ jobs:
run: gh pr merge --auto --merge "$PR_URL" run: gh pr merge --auto --merge "$PR_URL"
env: env:
PR_URL: ${{github.event.pull_request.html_url}} PR_URL: ${{github.event.pull_request.html_url}}
GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}} GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}

View File

@@ -1,4 +1,4 @@
name: Fix PHP code style issues name: Fix PHP Code Styling
on: [push] on: [push]
@@ -18,4 +18,4 @@ jobs:
- name: Commit changes - name: Commit changes
uses: stefanzweifel/git-auto-commit-action@v4 uses: stefanzweifel/git-auto-commit-action@v4
with: with:
commit_message: Fix styling commit_message: Fix styling

View File

@@ -1,4 +1,4 @@
name: run-tests name: Run Tests
on: on:
push: push:
@@ -44,4 +44,4 @@ jobs:
composer update --${{ matrix.stability }} --prefer-dist --no-interaction composer update --${{ matrix.stability }} --prefer-dist --no-interaction
- name: Execute tests - name: Execute tests
run: vendor/bin/pest run: vendor/bin/pest

View File

@@ -1,4 +1,4 @@
name: "Update Changelog" name: Update Changelog
on: on:
release: release:
@@ -25,4 +25,4 @@ jobs:
with: with:
branch: main branch: main
commit_message: Update CHANGELOG commit_message: Update CHANGELOG
file_pattern: CHANGELOG.md file_pattern: CHANGELOG.md

View File

@@ -7,6 +7,10 @@
":package_slug" ":package_slug"
], ],
"homepage": "https://github.com/:vendor_slug/:package_slug", "homepage": "https://github.com/:vendor_slug/:package_slug",
"support": {
"issues": "https://github.com/:vendor_slug/:package_slug/issues",
"source": "https://github.com/:vendor_slug/:package_slug"
},
"license": "MIT", "license": "MIT",
"authors": [ "authors": [
{ {
@@ -17,7 +21,9 @@
], ],
"require": { "require": {
"php": "^8.0", "php": "^8.0",
"filament/filament": "^2.0", "filament/filament": "^3.0",
"filament/forms": "^3.0",
"filament/tables": "^3.0",
"spatie/laravel-package-tools": "^1.13.5", "spatie/laravel-package-tools": "^1.13.5",
"illuminate/contracts": "^9.0" "illuminate/contracts": "^9.0"
}, },

View File

@@ -17,40 +17,89 @@ $vendorSlug = slugify($vendorName);
$vendorNamespace = ucwords($vendorName); $vendorNamespace = ucwords($vendorName);
$vendorNamespace = ask('Vendor namespace', $vendorNamespace); $vendorNamespace = ask('Vendor namespace', $vendorNamespace);
$currentDirectory = getcwd(); $folderName = basename(getcwd());
$folderName = basename($currentDirectory);
$packageName = ask('Package name', $folderName); $packageName = ask('Package name', $folderName);
$packageSlug = slugify($packageName); $packageSlug = slugify($packageName);
$packageSlugWithoutPrefix = remove_prefix('laravel-', $packageSlug); $packageSlugWithoutPrefix = remove_prefix('filament-', $packageSlug);
$className = title_case($packageName); $className = title_case($packageName);
$className = ask('Class name', $className); $className = ask('Class name', $className);
$description = ask('Package description', "This is my package {$packageSlug}"); $description = ask('Package description');
$usePhpStan = confirm('Enable PhpStan?', true); $usePhpStan = confirm('Enable PhpStan?', true);
$usePint = confirm('Enable Pint?', true); $usePint = confirm('Enable Pint?', true);
$useDependabot = confirm('Enable Dependabot?', true);
$useLaravelRay = confirm('Use Ray for debugging?', true);
$useUpdateChangelogWorkflow = confirm('Use automatic changelog updater workflow?', true); $useUpdateChangelogWorkflow = confirm('Use automatic changelog updater workflow?', true);
writeln('------'); $isTheme = confirm("Is this a custom theme?");
writeln("Author : {$authorName} ({$authorUsername}, {$authorEmail})"); $formsOnly = ! $isTheme && confirm("Is this for Forms only?");
writeln("Vendor : {$vendorName} ({$vendorSlug})"); $tablesOnly = ! $formsOnly && confirm("Is this for Tables only?");
writeln("Package : {$packageSlug} <{$description}>");
writeln("Namespace : {$vendorNamespace}\\{$className}");
writeln("Class name : {$className}");
writeln('---');
writeln('Packages & Utilities');
writeln('Use Larastan/PhpStan : '.($usePhpStan ? 'yes' : 'no'));
writeln('Use Pint : '.($usePint ? 'yes' : 'no'));
writeln('Use Auto-Changelog : '.($useUpdateChangelogWorkflow ? 'yes' : 'no'));
writeln('------');
writeln("\r");
writeln('------');
writeln("Author : \e[0;36m{$authorName} ({$authorUsername}, {$authorEmail})\e[0m");
writeln("Vendor : \e[0;36m{$vendorName} ({$vendorSlug})\e[0m");
writeln('Package : '."\e[0;36m".$packageSlug.($description ? ' <{$description}>' : '')."\e[0m");
writeln("Namespace : \e[0;36m{$vendorNamespace}\\{$className}\e[0m");
writeln("Class name : \e[0;36m{$className}\e[0m");
writeln('---');
writeln("\e[1;37mPackages & Utilities\e[0m");
writeln('Larastan/PhpStan : '.($usePhpStan ? "\e[0;32mYes" : "\e[0;31mNo")."\e[0m");
writeln('Pint : '.($usePint ? "\e[0;32mYes" : "\e[0;31mNo")."\e[0m");
writeln('Use Dependabot : '.($useDependabot ? "\e[0;32mYes" : "\e[0;31mNo")."\e[0m");
writeln('Use Ray App : '.($useLaravelRay ? "\e[0;32mYes" : "\e[0;31mNo")."\e[0m");
writeln('Auto-Changelog : '.($useUpdateChangelogWorkflow ? "\e[0;32mYes" : "\e[0;31mNo")."\e[0m");
if ($formsOnly) {
writeln("Filament/Forms : \e[0;32mYes\e[0m");
} elseif ($tablesOnly) {
writeln("Filament/Tables : \e[0;32mYes\e[0m");
} else {
writeln("Filament/Filament : \e[0;32mYes\e[0m");
}
writeln('------');
writeln("\r");
writeln('This script will replace the above values in all relevant files in the project directory.'); writeln('This script will replace the above values in all relevant files in the project directory.');
writeln("\r");
if (! confirm('Modify files?', true)) { if (! confirm('Modify files?', true)) {
exit(1); exit(1);
} }
if ($formsOnly) {
safeUnlink(__DIR__.'/src/SkeletonTheme.php');
remove_composer_filament_deps([
'filament/filament',
'filament/tables',
]);
} elseif ($tablesOnly) {
safeUnlink(__DIR__.'/src/SkeletonTheme.php');
remove_composer_filament_deps([
'filament/filament',
'filament/forms',
]);
} else {
if ($isTheme) {
safeUnlink(__DIR__ . '/src/SkeletonServiceProvider.php');
remove_package_script(['purge']);
remove_package_script(['dev:scripts']);
remove_package_script(['build:scripts']);
remove_package_script(['@awcodes/filament-plugin-purge']);
remove_package_script(['esbuild']);
replace_in_file(__DIR__.'/package.json', [' && npm run purge' => '']);
} else {
safeUnlink(__DIR__.'/src/SkeletonTheme.php');
}
remove_composer_filament_deps([
'filament/forms',
'filament/tables',
]);
}
$files = (str_starts_with(strtoupper(PHP_OS), 'WIN') ? replaceForWindows() : replaceForAllOtherOSes()); $files = (str_starts_with(strtoupper(PHP_OS), 'WIN') ? replaceForWindows() : replaceForAllOtherOSes());
foreach ($files as $file) { foreach ($files as $file) {
@@ -72,23 +121,23 @@ foreach ($files as $file) {
match (true) { match (true) {
str_contains($file, determineSeparator('src/Skeleton.php')) => rename($file, determineSeparator('./src/'.$className.'.php')), str_contains($file, determineSeparator('src/Skeleton.php')) => rename($file, determineSeparator('./src/'.$className.'.php')),
str_contains($file, determineSeparator('src/SkeletonServiceProvider.php')) => rename($file, determineSeparator('./src/'.$className.'ServiceProvider.php')), str_contains($file, determineSeparator('src/SkeletonServiceProvider.php')) => rename($file, determineSeparator('./src/'.$className.'ServiceProvider.php')),
str_contains($file, determineSeparator('src/SkeletonTheme.php')) => rename($file, determineSeparator('./src/'.$className.'Theme.php')),
str_contains($file, determineSeparator('src/Facades/Skeleton.php')) => rename($file, determineSeparator('./src/Facades/'.$className.'.php')), str_contains($file, determineSeparator('src/Facades/Skeleton.php')) => rename($file, determineSeparator('./src/Facades/'.$className.'.php')),
str_contains($file, determineSeparator('src/Commands/SkeletonCommand.php')) => rename($file, determineSeparator('./src/Commands/'.$className.'Command.php')), str_contains($file, determineSeparator('src/Commands/SkeletonCommand.php')) => rename($file, determineSeparator('./src/Commands/'.$className.'Command.php')),
str_contains($file, determineSeparator('database/migrations/create_skeleton_table.php.stub')) => rename($file, determineSeparator('./database/migrations/create_'.$packageSlugWithoutPrefix.'_table.php.stub')), str_contains($file, determineSeparator('database/migrations/create_skeleton_table.php.stub')) => rename($file, determineSeparator('./database/migrations/create_'.$packageSlugWithoutPrefix.'_table.php.stub')),
str_contains($file, determineSeparator('config/skeleton.php')) => rename($file, determineSeparator('./config/'.$packageSlugWithoutPrefix.'.php')), str_contains($file, determineSeparator('config/skeleton.php')) => rename($file, determineSeparator('./config/'.$packageSlugWithoutPrefix.'.php')),
str_contains($file, 'README.md') => remove_readme_paragraphs($file), str_contains($file, 'README.md') => remove_tag($file, 'delete'),
default => [], default => [],
}; };
} }
if (! $usePint) { if (! $useDependabot) {
safeUnlink(__DIR__.'/.github/workflows/fix-php-code-style-issues.yml'); safeUnlink(__DIR__.'/.github/dependabot.yml');
safeUnlink(__DIR__.'/.github/workflows/dependabot-auto-merge.yml');
}
remove_composer_deps([ if (! $useLaravelRay) {
'laravel/pint', remove_composer_deps(['spatie/laravel-ray']);
]);
remove_composer_script(['pint']);
} }
if (! $usePhpStan) { if (! $usePhpStan) {
@@ -109,6 +158,16 @@ if (! $usePhpStan) {
]); ]);
} }
if (! $usePint) {
safeUnlink(__DIR__.'/.github/workflows/fix-php-code-style-issues.yml');
remove_composer_deps([
'laravel/pint',
]);
remove_composer_script(['pint']);
}
if (! $useUpdateChangelogWorkflow) { if (! $useUpdateChangelogWorkflow) {
safeUnlink(__DIR__.'/.github/workflows/update-changelog.yml'); safeUnlink(__DIR__.'/.github/workflows/update-changelog.yml');
} }
@@ -119,9 +178,8 @@ confirm('Let this script delete itself?', true) && unlink(__FILE__);
function ask(string $question, string $default = ''): string function ask(string $question, string $default = ''): string
{ {
$consoleColor = new ConsoleColor(); $def = $default ? "\e[0;33m ({$default})" : '';
$def = $default ? $consoleColor->apply('yellow', " ({$default})") : null; $answer = readline("\e[0;32m" . $question.$def . ": \e[0m");
$answer = readline($consoleColor->apply('green', $question.$def.': '));
if (! $answer) { if (! $answer) {
return $default; return $default;
@@ -132,11 +190,9 @@ function ask(string $question, string $default = ''): string
function confirm(string $question, bool $default = false): bool function confirm(string $question, bool $default = false): bool
{ {
$consoleColor = new ConsoleColor();
$answer = ask($question, ($default ? 'Y/n' : 'y/N')); $answer = ask($question, ($default ? 'Y/n' : 'y/N'));
if (! $answer) { if (strtolower($answer) === 'y/n') {
return $default; return $default;
} }
@@ -153,17 +209,6 @@ function run(string $command): string
return trim(shell_exec($command)); return trim(shell_exec($command));
} }
function str_after(string $subject, string $search): string
{
$pos = strrpos($subject, $search);
if ($pos === false) {
return $subject;
}
return substr($subject, $pos + strlen($search));
}
function slugify(string $subject): string function slugify(string $subject): string
{ {
return strtolower(trim(preg_replace('/[^A-Za-z0-9-]+/', '-', $subject), '-')); return strtolower(trim(preg_replace('/[^A-Za-z0-9-]+/', '-', $subject), '-'));
@@ -197,7 +242,7 @@ function remove_prefix(string $prefix, string $content): string
return $content; return $content;
} }
function remove_composer_deps(array $names) function remove_composer_deps(array $names): void
{ {
$data = json_decode(file_get_contents(__DIR__.'/composer.json'), true); $data = json_decode(file_get_contents(__DIR__.'/composer.json'), true);
@@ -210,7 +255,20 @@ function remove_composer_deps(array $names)
file_put_contents(__DIR__.'/composer.json', json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE)); file_put_contents(__DIR__.'/composer.json', json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
} }
function remove_composer_script(array $scriptNames) function remove_composer_filament_deps(array $names): void
{
$data = json_decode(file_get_contents(__DIR__.'/composer.json'), true);
foreach ($data['require'] as $name => $version) {
if (in_array($name, $names, true)) {
unset($data['require'][$name]);
}
}
file_put_contents(__DIR__.'/composer.json', json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
}
function remove_composer_script(array $scriptNames): void
{ {
$data = json_decode(file_get_contents(__DIR__.'/composer.json'), true); $data = json_decode(file_get_contents(__DIR__.'/composer.json'), true);
@@ -233,17 +291,57 @@ function remove_composer_script(array $scriptNames)
file_put_contents(__DIR__.'/composer.json', json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE)); file_put_contents(__DIR__.'/composer.json', json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE));
} }
function remove_readme_paragraphs(string $file): void function remove_package_script(array $scriptNames): void
{
$data = json_decode(file_get_contents(__DIR__.'/package.json'), true);
foreach ($data['scripts'] as $name => $script) {
if (is_array($script)) {
foreach ($script as $k => $s) {
if (in_array($s, $scriptNames)) {
unset($data['scripts'][$name][$k]);
break;
}
}
} elseif (in_array($name, $scriptNames)) {
unset($data['scripts'][$name]);
break;
}
}
foreach ($data['devDependencies'] as $name => $script) {
if (is_array($script)) {
foreach ($script as $k => $s) {
if (in_array($s, $scriptNames)) {
unset($data['devDependencies'][$name][$k]);
break;
}
}
} elseif (in_array($name, $scriptNames)) {
unset($data['devDependencies'][$name]);
break;
}
}
file_put_contents(__DIR__.'/package.json', json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES |
JSON_UNESCAPED_UNICODE));
}
function remove_tag(string $file, string $tag): void
{ {
$contents = file_get_contents($file); $contents = file_get_contents($file);
file_put_contents( file_put_contents(
$file, $file,
preg_replace('/<!--delete-->.*<!--\/delete-->/s', '', $contents) ?: $contents preg_replace('/<!--' . $tag . '-->.*<!--\/' . $tag . '-->/s', '', $contents) ?: $contents
); );
} }
function safeUnlink(string $filename) function safeUnlink(string $filename): void
{ {
if (file_exists($filename) && is_file($filename)) { if (file_exists($filename) && is_file($filename)) {
unlink($filename); unlink($filename);
@@ -264,301 +362,3 @@ function replaceForAllOtherOSes(): array
{ {
return explode(PHP_EOL, run('grep -E -r -l -i ":author|:vendor|:package|VendorName|skeleton|vendor_name|vendor_slug|author@domain.com" --exclude-dir=vendor ./* ./.github/* | grep -v '.basename(__FILE__))); return explode(PHP_EOL, run('grep -E -r -l -i ":author|:vendor|:package|VendorName|skeleton|vendor_name|vendor_slug|author@domain.com" --exclude-dir=vendor ./* ./.github/* | grep -v '.basename(__FILE__)));
} }
class ConsoleColor
{
const FOREGROUND = 38;
const BACKGROUND = 48;
const COLOR256_REGEXP = '~^(bg_)?color_([0-9]{1,3})$~';
const RESET_STYLE = 0;
/** @var bool */
private $isSupported;
/** @var bool */
private $forceStyle = false;
/** @var array */
private $styles = [
'none' => null,
'bold' => '1',
'dark' => '2',
'italic' => '3',
'underline' => '4',
'blink' => '5',
'reverse' => '7',
'concealed' => '8',
'default' => '39',
'black' => '30',
'red' => '31',
'green' => '32',
'yellow' => '33',
'blue' => '34',
'magenta' => '35',
'cyan' => '36',
'light_gray' => '37',
'dark_gray' => '90',
'light_red' => '91',
'light_green' => '92',
'light_yellow' => '93',
'light_blue' => '94',
'light_magenta' => '95',
'light_cyan' => '96',
'white' => '97',
'bg_default' => '49',
'bg_black' => '40',
'bg_red' => '41',
'bg_green' => '42',
'bg_yellow' => '43',
'bg_blue' => '44',
'bg_magenta' => '45',
'bg_cyan' => '46',
'bg_light_gray' => '47',
'bg_dark_gray' => '100',
'bg_light_red' => '101',
'bg_light_green' => '102',
'bg_light_yellow' => '103',
'bg_light_blue' => '104',
'bg_light_magenta' => '105',
'bg_light_cyan' => '106',
'bg_white' => '107',
];
/** @var array */
private $themes = [];
public function __construct()
{
$this->isSupported = $this->isSupported();
}
/**
* @param string|array $style
* @param string $text
* @return string
*
* @throws InvalidStyleException
* @throws \InvalidArgumentException
*/
public function apply($style, $text)
{
if (! $this->isStyleForced() && ! $this->isSupported()) {
return $text;
}
if (is_string($style)) {
$style = [$style];
}
if (! is_array($style)) {
throw new \InvalidArgumentException('Style must be string or array.');
}
$sequences = [];
foreach ($style as $s) {
if (isset($this->themes[$s])) {
$sequences = array_merge($sequences, $this->themeSequence($s));
} elseif ($this->isValidStyle($s)) {
$sequences[] = $this->styleSequence($s);
} else {
throw new InvalidStyleException($s);
}
}
$sequences = array_filter($sequences, function ($val) {
return $val !== null;
});
if (empty($sequences)) {
return $text;
}
return $this->escSequence(implode(';', $sequences)).$text.$this->escSequence(self::RESET_STYLE);
}
/**
* @param bool $forceStyle
*/
public function setForceStyle($forceStyle)
{
$this->forceStyle = (bool) $forceStyle;
}
/**
* @return bool
*/
public function isStyleForced()
{
return $this->forceStyle;
}
/**
* @param array $themes
*
* @throws InvalidStyleException
* @throws \InvalidArgumentException
*/
public function setThemes(array $themes)
{
$this->themes = [];
foreach ($themes as $name => $styles) {
$this->addTheme($name, $styles);
}
}
/**
* @param string $name
* @param array|string $styles
*
* @throws \InvalidArgumentException
* @throws InvalidStyleException
*/
public function addTheme($name, $styles)
{
if (is_string($styles)) {
$styles = [$styles];
}
if (! is_array($styles)) {
throw new \InvalidArgumentException('Style must be string or array.');
}
foreach ($styles as $style) {
if (! $this->isValidStyle($style)) {
throw new InvalidStyleException($style);
}
}
$this->themes[$name] = $styles;
}
/**
* @return array
*/
public function getThemes()
{
return $this->themes;
}
/**
* @param string $name
* @return bool
*/
public function hasTheme($name)
{
return isset($this->themes[$name]);
}
/**
* @param string $name
*/
public function removeTheme($name)
{
unset($this->themes[$name]);
}
/**
* @codeCoverageIgnore
*
* @return bool
*/
public function isSupported()
{
if (DIRECTORY_SEPARATOR === '\\') {
// phpcs:ignore Generic.PHP.NoSilencedErrors,PHPCompatibility.FunctionUse.NewFunctions.sapi_windows_vt100_supportFound
if (function_exists('sapi_windows_vt100_support') && @sapi_windows_vt100_support(STDOUT)) {
return true;
} elseif (getenv('ANSICON') !== false || getenv('ConEmuANSI') === 'ON') {
return true;
}
return false;
} else {
// phpcs:ignore Generic.PHP.NoSilencedErrors
return function_exists('posix_isatty') && @posix_isatty(STDOUT);
}
}
/**
* @codeCoverageIgnore
*
* @return bool
*/
public function are256ColorsSupported()
{
if (DIRECTORY_SEPARATOR === '\\') {
// phpcs:ignore Generic.PHP.NoSilencedErrors,PHPCompatibility.FunctionUse.NewFunctions.sapi_windows_vt100_supportFound
return function_exists('sapi_windows_vt100_support') && @sapi_windows_vt100_support(STDOUT);
} else {
return strpos(getenv('TERM'), '256color') !== false;
}
}
/**
* @return array
*/
public function getPossibleStyles()
{
return array_keys($this->styles);
}
/**
* @param string $name
* @return string[]
*/
private function themeSequence($name)
{
$sequences = [];
foreach ($this->themes[$name] as $style) {
$sequences[] = $this->styleSequence($style);
}
return $sequences;
}
/**
* @param string $style
* @return string
*/
private function styleSequence($style)
{
if (array_key_exists($style, $this->styles)) {
return $this->styles[$style];
}
if (! $this->are256ColorsSupported()) {
return null;
}
preg_match(self::COLOR256_REGEXP, $style, $matches);
$type = $matches[1] === 'bg_' ? self::BACKGROUND : self::FOREGROUND;
$value = $matches[2];
return "$type;5;$value";
}
/**
* @param string $style
* @return bool
*/
private function isValidStyle($style)
{
return array_key_exists($style, $this->styles) || preg_match(self::COLOR256_REGEXP, $style);
}
/**
* @param string|int $value
* @return string
*/
private function escSequence($value)
{
return "\033[{$value}m";
}
}

View File

@@ -17,6 +17,6 @@
"postcss": "^8.4.14", "postcss": "^8.4.14",
"prettier": "^2.7.1", "prettier": "^2.7.1",
"prettier-plugin-tailwindcss": "^0.1.13", "prettier-plugin-tailwindcss": "^0.1.13",
"tailwindcss": "^3.1.6" "tailwindcss": "^3.2"
} }
} }

View File

@@ -0,0 +1,19 @@
<?php
namespace VendorName\Skeleton\Commands;
use Illuminate\Console\Command;
class SkeletonCommand extends Command
{
public $signature = 'skeleton';
public $description = 'My command';
public function handle(): int
{
$this->comment('All done');
return self::SUCCESS;
}
}

16
src/Facades/Skeleton.php Normal file
View File

@@ -0,0 +1,16 @@
<?php
namespace VendorName\Skeleton\Facades;
use Illuminate\Support\Facades\Facade;
/**
* @see \VendorName\Skeleton\Skeleton
*/
class Skeleton extends Facade
{
protected static function getFacadeAccessor()
{
return \VendorName\Skeleton\Skeleton::class;
}
}

7
src/Skeleton.php Normal file
View File

@@ -0,0 +1,7 @@
<?php
namespace VendorName\Skeleton;
class Skeleton
{
}

View File

@@ -2,39 +2,56 @@
namespace VendorName\Skeleton; namespace VendorName\Skeleton;
//use Filament\Support\Assets\Js;
//use Filament\Support\Assets\Css;
use Filament\Support\Assets\Asset;
use Filament\PluginServiceProvider; use Filament\PluginServiceProvider;
use Spatie\LaravelPackageTools\Package; use Spatie\LaravelPackageTools\Package;
//use Filament\Support\Assets\AlpineComponent;
use VendorName\Skeleton\Commands\SkeletonCommand;
class SkeletonServiceProvider extends PluginServiceProvider class SkeletonServiceProvider extends PluginServiceProvider
{ {
public static string $name = 'skeleton'; public static string $name = 'skeleton';
protected array $resources = [
// CustomResource::class,
];
protected array $pages = [
// CustomPage::class,
];
protected array $widgets = [
// CustomWidget::class,
];
protected array $styles = [
'plugin-skeleton' => __DIR__.'/../resources/dist/skeleton.css',
];
protected array $scripts = [
'plugin-skeleton' => __DIR__.'/../resources/dist/skeleton.js',
];
// protected array $beforeCoreScripts = [
// 'plugin-skeleton' => __DIR__ . '/../resources/dist/skeleton.js',
// ];
public function configurePackage(Package $package): void public function configurePackage(Package $package): void
{ {
$package->name(static::$name); $package->name(static::$name)
->hasConfigFile()
->hasViews()
->hasMigration('create_skeleton_table')
->hasCommand(SkeletonCommand::class);
} }
public function packageRegistered(): void
{
parent::packageRegistered();
$this->app->bind('skeleton', function (): Skeleton {
return new Skeleton();
});
}
public function packageBooted(): void
{
parent::packageBooted();
}
protected function getAssetPackage(): ?string
{
return 'skeleton';
}
/**
* @return array<Asset>
*/
protected function getAssets(): array
{
return [
// AlpineComponent::make('skeleton', __DIR__ . '/../resources/dist/components/skeleton.js'),
// Css::make('echo', __DIR__ . '/../resources/dist/skeleton.js'),
// Js::make('echo', __DIR__ . '/../resources/dist/skeleton.js'),
];
}
} }

31
src/SkeletonTheme.php Normal file
View File

@@ -0,0 +1,31 @@
<?php
namespace Filament;
use Filament\Context;
use Filament\Contracts\Plugin;
use Filament\Support\Assets\Theme;
use Filament\Support\Facades\FilamentAsset;
class SkeletonTheme implements Plugin
{
public function getId(): string
{
return 'skeleton-theme';
}
public function register(Context $context): void
{
FilamentAsset::register([
Theme::make('skeleton', __DIR__ . '/../resources/dist/skeleton.css'),
]);
$context
->theme('skeleton');
}
public function boot(Context $context): void
{
//
}
}