diff --git a/app/View/Components/Button.php b/app/View/Components/Button.php new file mode 100644 index 0000000..ba68d1d --- /dev/null +++ b/app/View/Components/Button.php @@ -0,0 +1,58 @@ +variant) { + 'secondary' => [ + 'base' => 'bg-secondary text-text', + 'hover' => 'hover:bg-secondary-dark', + 'disabled' => 'disabled:bg-secondary', + ], + 'outline' => [ + 'base' => 'bg-outline border border-primary text-primary', + 'hover' => 'hover:bg-primary hover:text-text-inverted', + 'disabled' => 'disabled:bg-outline disabled:text-primary', + ], + default => [ + 'base' => 'bg-primary text-text-inverted', + 'hover' => 'hover:bg-primary-dark', + 'disabled' => 'disabled:bg-primary' + ] + }; + + $baseDisabled = 'disabled:cursor-not-allowed disabled:opacity-60'; + + return trim( + $base . ' ' . + $classes['base'] . ' ' . + $classes['hover'] . ' ' . + $baseDisabled . ' ' . + $classes['disabled'] + ); + } + + /** + * Get the view / contents that represent the component. + */ + public function render(): View|Closure|string + { + return view('components.button'); + } +} diff --git a/resources/views/components/button.blade.php b/resources/views/components/button.blade.php new file mode 100644 index 0000000..4e20927 --- /dev/null +++ b/resources/views/components/button.blade.php @@ -0,0 +1,8 @@ + diff --git a/resources/views/storybook/index.blade.php b/resources/views/storybook/index.blade.php index 59b0a40..b3fa365 100644 --- a/resources/views/storybook/index.blade.php +++ b/resources/views/storybook/index.blade.php @@ -27,33 +27,29 @@