Add applications and positions

This commit is contained in:
Christoph Karlen
2026-02-02 17:39:41 +01:00
parent d2a517d2f5
commit b2366def84
26 changed files with 760 additions and 10 deletions

View File

@@ -0,0 +1,75 @@
<?php
namespace App\Filament\Jobs\Resources\Applications;
use App\Filament\Jobs\Resources\Applications\Pages\CreateApplication;
use App\Filament\Jobs\Resources\Applications\Pages\EditApplication;
use App\Filament\Jobs\Resources\Applications\Pages\ListApplications;
use App\Filament\Jobs\Resources\Applications\Pages\ViewApplication;
use App\Filament\Jobs\Resources\Applications\Schemas\ApplicationForm;
use App\Filament\Jobs\Resources\Applications\Tables\ApplicationsTable;
use App\Models\Application;
use BackedEnum;
use Filament\Infolists\Components\ImageEntry;
use Filament\Infolists\Components\TextEntry;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Support\Icons\Heroicon;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Support\HtmlString;
class ApplicationResource extends Resource
{
protected static ?string $model = Application::class;
protected static string|BackedEnum|null $navigationIcon = Heroicon::OutlinedRectangleStack;
protected static ?string $recordTitleAttribute = 'lastname';
public static function form(Schema $schema): Schema
{
return ApplicationForm::configure($schema);
}
public static function infolist(Schema $schema): Schema
{
return $schema->schema([
TextEntry::make('user.name'),
TextEntry::make('user.email'),
TextEntry::make('position.title'),
TextEntry::make('description')
->getStateUsing(function ($record) {
return new HtmlString($record->description);
}),
TextEntry::make('document')
->label('CV')
->url(
fn($record) => route('documents.download', $record),
shouldOpenInNewTab: true
),
]);
}
public static function table(Table $table): Table
{
return ApplicationsTable::configure($table);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
'index' => ListApplications::route('/'),
'create' => CreateApplication::route('/create'),
'edit' => EditApplication::route('/{record}/edit'),
'view' => ViewApplication::route('/{record}/view'),
];
}
}

View File

@@ -0,0 +1,11 @@
<?php
namespace App\Filament\Jobs\Resources\Applications\Pages;
use App\Filament\Jobs\Resources\Applications\ApplicationResource;
use Filament\Resources\Pages\CreateRecord;
class CreateApplication extends CreateRecord
{
protected static string $resource = ApplicationResource::class;
}

View File

@@ -0,0 +1,19 @@
<?php
namespace App\Filament\Jobs\Resources\Applications\Pages;
use App\Filament\Jobs\Resources\Applications\ApplicationResource;
use Filament\Actions\DeleteAction;
use Filament\Resources\Pages\EditRecord;
class EditApplication extends EditRecord
{
protected static string $resource = ApplicationResource::class;
protected function getHeaderActions(): array
{
return [
DeleteAction::make(),
];
}
}

View File

@@ -0,0 +1,19 @@
<?php
namespace App\Filament\Jobs\Resources\Applications\Pages;
use App\Filament\Jobs\Resources\Applications\ApplicationResource;
use Filament\Actions\CreateAction;
use Filament\Resources\Pages\ListRecords;
class ListApplications extends ListRecords
{
protected static string $resource = ApplicationResource::class;
protected function getHeaderActions(): array
{
return [
// CreateAction::make(),
];
}
}

View File

@@ -0,0 +1,11 @@
<?php
namespace App\Filament\Jobs\Resources\Applications\Pages;
use App\Filament\Jobs\Resources\Applications\ApplicationResource;
use Filament\Resources\Pages\ViewRecord;
class ViewApplication extends ViewRecord
{
protected static string $resource = ApplicationResource::class;
}

View File

@@ -0,0 +1,19 @@
<?php
namespace App\Filament\Jobs\Resources\Applications\Schemas;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Textarea;
use Filament\Schemas\Schema;
class ApplicationForm
{
public static function configure(Schema $schema): Schema
{
return $schema
->components([
]);
}
}

View File

@@ -0,0 +1,60 @@
<?php
namespace App\Filament\Jobs\Resources\Applications\Tables;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Actions\ViewAction;
use Filament\Facades\Filament;
use Filament\Schemas\Components\Image;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Illuminate\Support\Facades\Storage;
class ApplicationsTable
{
public static function configure(Table $table): Table
{
return $table
->columns([
TextColumn::make('user.id')
->searchable(),
TextColumn::make('user.name')
->searchable(),
TextColumn::make('document')
->label('CV')
->url(
fn ($record) => route('documents.download', $record),
shouldOpenInNewTab: true
),
TextColumn::make('position.title')
->searchable(),
TextColumn::make('created_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
TextColumn::make('updated_at')
->dateTime()
->sortable()
->toggleable(isToggledHiddenByDefault: true),
])
->modifyQueryUsing(function ($query) {
if(Filament::getCurrentOrDefaultPanel()?->getId() !== 'admin'){
return $query->where('user_id', auth()->user()->id);
}
return $query;
})
->filters([
//
])
->recordActions([
ViewAction::make(),
])
->toolbarActions([
BulkActionGroup::make([
DeleteBulkAction::make(),
]),
]);
}
}