frontend richtig schick gemacht und backend geordnet. ComfyUI Prompt zum Seeder hinzugefügt.

This commit is contained in:
2025-12-02 21:24:18 +01:00
parent 7b7a12ed27
commit 908b1dcdff
17 changed files with 473 additions and 260 deletions

View File

@@ -2,29 +2,24 @@
namespace App\Filament\Resources\AiModels;
use BackedEnum;
use App\Filament\Resources\AiModels\Pages;
use App\Filament\Resources\AiModels\RelationManagers;
use App\Models\AiModel;
use Filament\Schemas\Schema;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Columns\IconColumn;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Illuminate\Database\Eloquent\Model;
use App\Models\ApiProvider;
use App\Api\Plugins\PluginLoader;
use App\Api\Plugins\ApiPluginInterface;
use App\Api\Plugins\PluginLoader;
use App\Models\AiModel;
use App\Models\ApiProvider;
use Filament\Actions\Action;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\CreateAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\Textarea;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Toggle;
use Filament\Forms\Components\Textarea;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\IconColumn;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Model;
class AiModelResource extends Resource
{
@@ -32,6 +27,13 @@ class AiModelResource extends Resource
// protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
protected static ?int $navigationSort = -100;
public static function getNavigationGroup(): ?string
{
return __('filament.navigation.groups.ai_models');
}
public static function form(Schema $schema): Schema
{
return $schema
@@ -49,16 +51,16 @@ class AiModelResource extends Resource
->rows(15),
]);
}
protected static function canSearchModelsWithAnyProvider(?array $apiProviderIds): bool
{
if (empty($apiProviderIds)) {
return false;
}
foreach ($apiProviderIds as $apiProviderId) {
$apiProvider = ApiProvider::find($apiProviderId);
if (!$apiProvider || !$apiProvider->plugin) {
if (! $apiProvider || ! $apiProvider->plugin) {
continue;
}
try {
@@ -71,16 +73,17 @@ class AiModelResource extends Resource
continue;
}
}
return false;
}
protected static function getPluginInstance(?int $apiProviderId): ?ApiPluginInterface
{
if (!$apiProviderId) {
if (! $apiProviderId) {
return null;
}
$apiProvider = ApiProvider::find($apiProviderId);
if (!$apiProvider || !$apiProvider->plugin) {
if (! $apiProvider || ! $apiProvider->plugin) {
return null;
}
try {
@@ -93,15 +96,16 @@ class AiModelResource extends Resource
protected static function canSearchModels(?int $apiProviderId): bool
{
if (!$apiProviderId) {
if (! $apiProviderId) {
return false;
}
$apiProvider = ApiProvider::find($apiProviderId);
if (!$apiProvider || !$apiProvider->plugin) {
if (! $apiProvider || ! $apiProvider->plugin) {
return false;
}
try {
$pluginInstance = PluginLoader::getPlugin($apiProvider->plugin, $apiProvider);
return method_exists($pluginInstance, 'searchModels');
} catch (\Exception $e) {
// Log the exception if needed
@@ -141,14 +145,14 @@ class AiModelResource extends Resource
CreateAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
@@ -156,5 +160,5 @@ class AiModelResource extends Resource
'create' => Pages\CreateAiModel::route('/create'),
'edit' => Pages\EditAiModel::route('/{record}/edit'),
];
}
}
}

View File

@@ -2,28 +2,22 @@
namespace App\Filament\Resources\ApiProviders;
use App\Filament\Resources\ApiProviders\Pages;
use App\Filament\Resources\ApiProviders\RelationManagers;
use App\Api\Plugins\ApiPluginInterface;
use App\Models\ApiProvider;
use Filament\Schemas;
use Filament\Schemas\Schema;
use Filament\Resources\Resource;
use Filament\Tables;
use BackedEnum;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\CreateAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Filament\Forms\Components\TextInput;
use Filament\Tables\Columns\TextColumn;
use Filament\Forms\Components\Select;
use Illuminate\Support\Facades\File;
use App\Api\Plugins\ApiPluginInterface;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Toggle;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\IconColumn;
use BackedEnum;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Support\Facades\File;
class ApiProviderResource extends Resource
{
@@ -31,9 +25,17 @@ class ApiProviderResource extends Resource
protected static BackedEnum|string|null $navigationIcon = 'heroicon-o-rectangle-stack';
protected static ?int $navigationSort = -90;
public static function getNavigationGroup(): ?string
{
return __('filament.navigation.groups.ai_models');
}
public static function form(Schema $schema): Schema
{
$plugins = self::getAvailablePlugins();
return $schema
->components([
TextInput::make('name')
@@ -86,14 +88,14 @@ class ApiProviderResource extends Resource
CreateAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
@@ -102,23 +104,24 @@ class ApiProviderResource extends Resource
'edit' => Pages\EditApiProvider::route('/{record}/edit'),
];
}
protected static function getAvailablePlugins(): array
{
$plugins = [];
$path = app_path('Api/Plugins');
$files = File::files($path);
foreach ($files as $file) {
$filename = $file->getFilenameWithoutExtension();
if (in_array($filename, ['ApiPluginInterface', 'PluginLoader'])) {
continue;
}
$class = "App\Api\Plugins\\" . $filename;
$class = "App\Api\Plugins\\".$filename;
if (class_exists($class) && in_array(ApiPluginInterface::class, class_implements($class))) {
$plugins[$filename] = $filename;
}
}
return $plugins;
}
}

View File

@@ -2,25 +2,19 @@
namespace App\Filament\Resources\Images;
use BackedEnum;
use App\Filament\Resources\Images\Pages;
use App\Filament\Resources\Images\RelationManagers;
use App\Models\Image;
use Filament\Schemas;
use Filament\Schemas\Schema;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Filament\Forms\Components\TextInput;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Columns\ImageColumn;
use Filament\Forms\Components\FileUpload;
use Filament\Forms\Components\Toggle;
use BackedEnum;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\CreateAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\FileUpload;
use Filament\Forms\Components\Toggle;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\ImageColumn;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
class ImageResource extends Resource
{
@@ -28,6 +22,11 @@ class ImageResource extends Resource
protected static BackedEnum|string|null $navigationIcon = 'heroicon-o-rectangle-stack';
public static function getNavigationGroup(): ?string
{
return __('filament.navigation.groups.content');
}
public static function form(Schema $schema): Schema
{
return $schema
@@ -65,14 +64,14 @@ class ImageResource extends Resource
CreateAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [

View File

@@ -2,30 +2,28 @@
namespace App\Filament\Resources\Roles;
use UnitEnum;
use App\Filament\Resources\Roles\Pages;
use App\Filament\Resources\Roles\RelationManagers;
use App\Models\Role;
use Filament\Schemas;
use Filament\Schemas\Schema;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Filament\Forms\Components\TextInput;
use Filament\Tables\Columns\TextColumn;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\CreateAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\TextInput;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use UnitEnum;
class RoleResource extends Resource
{
protected static ?string $model = Role::class;
protected static UnitEnum|string|null $navigationGroup = 'User Management';
protected static ?string $navigationLabel = 'User Roles';
protected static bool $shouldRegisterNavigation = false;
public static function form(Schema $schema): Schema
{
return $schema
@@ -57,14 +55,14 @@ class RoleResource extends Resource
CreateAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
@@ -72,5 +70,5 @@ class RoleResource extends Resource
'create' => Pages\CreateRole::route('/create'),
'edit' => Pages\EditRole::route('/{record}/edit'),
];
}
}
}

View File

@@ -1,38 +1,43 @@
<?php
namespace App\Filament\Resources\Styles;
use BackedEnum;
use App\Filament\Resources\Styles\Pages;
use App\Models\Style;
use Filament\Schemas;
use Filament\Schemas\Schema;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Textarea;
use Filament\Forms\Components\FileUpload;
use Filament\Forms\Components\Select;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Columns\ImageColumn;
use Filament\Forms\Components\Toggle;
use Filament\Tables\Columns\IconColumn;
use Filament\Tables\Filters\SelectFilter;
use Filament\Schemas\Components\Grid;
use Filament\Schemas\Components\Tabs;
use Filament\Schemas\Components\Tabs\Tab;
use BackedEnum;
use Filament\Actions\Action;
use Filament\Actions\BulkAction;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\CreateAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\FileUpload;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\Textarea;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Toggle;
use Filament\Resources\Resource;
use Filament\Schemas\Components\Grid;
use Filament\Schemas\Components\Tabs;
use Filament\Schemas\Components\Tabs\Tab;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\IconColumn;
use Filament\Tables\Columns\ImageColumn;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Filters\SelectFilter;
use Filament\Tables\Table;
class StyleResource extends Resource
{
protected static ?string $model = Style::class;
protected static BackedEnum|string|null $navigationIcon = 'heroicon-o-rectangle-stack';
protected static BackedEnum|string|null $navigationIcon = 'heroicon-o-rectangle-stack';
protected static ?int $navigationSort = -80;
public static function getNavigationGroup(): ?string
{
return __('filament.navigation.groups.ai_models');
}
public static function form(Schema $schema): Schema
{
@@ -109,8 +114,9 @@ class StyleResource extends Resource
->icon('heroicon-o-document-duplicate')
->action(function (\App\Models\Style $record) {
$newStyle = $record->replicate();
$newStyle->title = $record->title . ' (Kopie)';
$newStyle->title = $record->title.' (Kopie)';
$newStyle->save();
return redirect()->to(\App\Filament\Resources\Styles\StyleResource::getUrl('edit', ['record' => $newStyle->id]));
}),
])
@@ -135,14 +141,14 @@ class StyleResource extends Resource
CreateAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
@@ -150,5 +156,5 @@ class StyleResource extends Resource
'create' => Pages\CreateStyle::route('/create'),
'edit' => Pages\EditStyle::route('/{record}/edit'),
];
}
}
}

View File

@@ -2,31 +2,27 @@
namespace App\Filament\Resources\Users;
use UnitEnum;
use App\Filament\Resources\Users\Pages;
use App\Filament\Resources\Users\RelationManagers;
use App\Models\User;
use Filament\Schemas;
use Filament\Schemas\Schema;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Table;
use Illuminate\Database\Eloquent\SoftDeletingScope;
use Filament\Forms\Components\TextInput;
use Filament\Tables\Columns\TextColumn;
use Filament\Forms\Components\Select;
use Filament\Schemas\Components\Section;
use Filament\Forms\Components\Toggle;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\CreateAction;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Toggle;
use Filament\Resources\Resource;
use Filament\Schemas\Components\Section;
use Filament\Schemas\Schema;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use UnitEnum;
class UserResource extends Resource
{
protected static ?string $model = User::class;
protected static string|UnitEnum|null $navigationGroup = 'User Management';
protected static ?string $navigationLabel = 'Users';
public static function form(Schema $schema): Schema
@@ -98,14 +94,14 @@ class UserResource extends Resource
CreateAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
@@ -122,6 +118,6 @@ class UserResource extends Resource
public static function getNavigationLabel(): string
{
return __('filament.navigation.user_roles');
}
return __('filament.navigation.users');
}
}