hasil done
This commit is contained in:
parent
3ed205998d
commit
2795c1deac
|
@ -3,103 +3,135 @@
|
||||||
namespace App\Filament\Resources;
|
namespace App\Filament\Resources;
|
||||||
|
|
||||||
use App\Filament\Resources\HasilResource\Pages;
|
use App\Filament\Resources\HasilResource\Pages;
|
||||||
use App\Filament\Resources\HasilResource\RelationManagers;
|
use App\Models\Parameter;
|
||||||
use App\Models\Hasil;
|
|
||||||
use Filament\Forms;
|
|
||||||
use Filament\Forms\Form;
|
use Filament\Forms\Form;
|
||||||
use Filament\Resources\Resource;
|
use Filament\Resources\Resource;
|
||||||
use Filament\Tables;
|
use Filament\Tables;
|
||||||
use Filament\Tables\Table;
|
use Filament\Tables\Table;
|
||||||
use Illuminate\Database\Eloquent\Builder;
|
|
||||||
use Illuminate\Database\Eloquent\SoftDeletingScope;
|
|
||||||
use Filament\Forms\Components\Select;
|
|
||||||
use Filament\Forms\Components\TextInput;
|
|
||||||
use Filament\Tables\Columns\TextColumn;
|
use Filament\Tables\Columns\TextColumn;
|
||||||
|
use Filament\Forms\Components\TextInput;
|
||||||
|
use Filament\Notifications\Notification;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
|
||||||
class HasilResource extends Resource
|
class HasilResource extends Resource
|
||||||
{
|
{
|
||||||
protected static ?string $model = Hasil::class;
|
protected static ?string $model = Parameter::class;
|
||||||
|
public static $kuota = 0;
|
||||||
|
|
||||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
protected static ?string $navigationIcon = 'heroicon-o-clipboard-document-check';
|
||||||
protected static ?string $navigationGroup = 'Penilaian';
|
protected static ?string $navigationGroup = 'Penilaian';
|
||||||
|
protected static ?string $navigationLabel = 'Hasil Penilaian';
|
||||||
protected static ?int $navigationSort = 2;
|
protected static ?int $navigationSort = 2;
|
||||||
|
protected static ?string $slug = 'hasil-penilaian';
|
||||||
|
|
||||||
public static function form(Form $form): Form
|
protected static ?string $modelLabel = 'Hasil Penilaian';
|
||||||
{
|
protected static ?string $pluralModelLabel = 'Hasil Penilaian';
|
||||||
return $form
|
protected static ?string $breadcrumb = 'Hasil Penilaian';
|
||||||
->schema([
|
|
||||||
Select::make('mahasiswa_id')
|
|
||||||
->label('Mahasiswa')
|
|
||||||
->relationship('mahasiswa', 'nama')
|
|
||||||
->searchable()
|
|
||||||
->required(),
|
|
||||||
|
|
||||||
TextInput::make('total_bobot')
|
|
||||||
->label('Total Bobot')
|
|
||||||
->numeric()
|
|
||||||
->readOnly(),
|
|
||||||
|
|
||||||
Select::make('status')
|
|
||||||
->label('Status')
|
|
||||||
->options([
|
|
||||||
'Layak' => 'Layak',
|
|
||||||
'Dipertimbangkan' => 'Dipertimbangkan',
|
|
||||||
'Tidak Layak' => 'Tidak Layak',
|
|
||||||
])
|
|
||||||
->required(),
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function table(Table $table): Table
|
public static function table(Table $table): Table
|
||||||
{
|
{
|
||||||
return $table
|
return $table
|
||||||
|
->headerActions([
|
||||||
|
Tables\Actions\Action::make('setKuota')
|
||||||
|
->label('Set Kuota Penerimaan')
|
||||||
|
->form([
|
||||||
|
TextInput::make('kuota')
|
||||||
|
->label('Jumlah Kuota')
|
||||||
|
->numeric()
|
||||||
|
->required()
|
||||||
|
->minValue(1)
|
||||||
|
->helperText('Masukkan jumlah kuota penerimaan. Hanya mahasiswa dengan nilai tertinggi dan berkas valid yang akan diterima.'),
|
||||||
|
])
|
||||||
|
->action(function (array $data): void {
|
||||||
|
DB::beginTransaction();
|
||||||
|
try {
|
||||||
|
// Reset semua hasil terlebih dahulu
|
||||||
|
Parameter::query()->update(['hasil' => 'Tidak Layak']);
|
||||||
|
|
||||||
|
// Ambil semua data parameter yang valid dan urutkan berdasarkan total nilai
|
||||||
|
$validParameters = Parameter::where('status', 'valid')
|
||||||
|
->orderBy('total_nilai', 'desc')
|
||||||
|
->get();
|
||||||
|
|
||||||
|
$kuota = (int) $data['kuota'];
|
||||||
|
$index = 0;
|
||||||
|
|
||||||
|
foreach ($validParameters as $parameter) {
|
||||||
|
// Gunakan update langsung ke database untuk memastikan perubahan tersimpan
|
||||||
|
if ($index < $kuota) {
|
||||||
|
DB::table('parameters')
|
||||||
|
->where('id', $parameter->id)
|
||||||
|
->update(['hasil' => 'Layak']);
|
||||||
|
} elseif ($index < ($kuota + 3)) {
|
||||||
|
DB::table('parameters')
|
||||||
|
->where('id', $parameter->id)
|
||||||
|
->update(['hasil' => 'Dipertimbangkan']);
|
||||||
|
}
|
||||||
|
$index++;
|
||||||
|
}
|
||||||
|
|
||||||
|
DB::commit();
|
||||||
|
|
||||||
|
Notification::make()
|
||||||
|
->title("Berhasil mengatur kuota penerimaan untuk {$kuota} mahasiswa")
|
||||||
|
->success()
|
||||||
|
->send();
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
DB::rollBack();
|
||||||
|
Notification::make()
|
||||||
|
->title('Terjadi kesalahan: ' . $e->getMessage())
|
||||||
|
->danger()
|
||||||
|
->send();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
->requiresConfirmation()
|
||||||
|
->modalHeading('Set Kuota Penerimaan')
|
||||||
|
->modalDescription('Apakah Anda yakin ingin mengatur kuota penerimaan? Tindakan ini akan mengubah status kelayakan semua mahasiswa.')
|
||||||
|
->modalSubmitActionLabel('Ya, Set Kuota')
|
||||||
|
->successNotificationTitle('Kuota berhasil diatur'),
|
||||||
|
])
|
||||||
|
->modifyQueryUsing(fn ($query) => $query->where('status', 'valid'))
|
||||||
->columns([
|
->columns([
|
||||||
|
TextColumn::make('no')
|
||||||
|
->label('No.')
|
||||||
|
->rowIndex(false)
|
||||||
|
->alignCenter(),
|
||||||
|
|
||||||
TextColumn::make('mahasiswa.nama')
|
TextColumn::make('mahasiswa.nama')
|
||||||
->label('Nama Mahasiswa')
|
->label('Nama Mahasiswa')
|
||||||
->sortable()
|
->searchable()
|
||||||
->searchable(),
|
|
||||||
|
|
||||||
TextColumn::make('total_bobot')
|
|
||||||
->label('Total Bobot')
|
|
||||||
->sortable(),
|
->sortable(),
|
||||||
|
|
||||||
TextColumn::make('status')
|
TextColumn::make('total_nilai')
|
||||||
->label('Status')
|
->label('Total Nilai')
|
||||||
|
->formatStateUsing(fn ($state) => number_format($state, 4))
|
||||||
|
->sortable(),
|
||||||
|
|
||||||
|
TextColumn::make('hasil')
|
||||||
|
->label('Hasil')
|
||||||
->badge()
|
->badge()
|
||||||
->color(fn ($record) => match ($record->status) {
|
->color(fn (string $state): string => match ($state) {
|
||||||
'Layak' => 'success',
|
'Layak' => 'success',
|
||||||
'Dipertimbangkan' => 'warning',
|
'Dipertimbangkan' => 'warning',
|
||||||
'Tidak Layak' => 'danger',
|
'Tidak Layak' => 'danger',
|
||||||
|
default => 'gray',
|
||||||
}),
|
}),
|
||||||
|
|
||||||
|
|
||||||
])
|
])
|
||||||
|
->defaultSort('total_nilai', 'desc')
|
||||||
->filters([
|
->filters([
|
||||||
//
|
Tables\Filters\SelectFilter::make('hasil')
|
||||||
])
|
->options([
|
||||||
->actions([
|
'Layak' => 'Layak',
|
||||||
Tables\Actions\EditAction::make(),
|
'Dipertimbangkan' => 'Dipertimbangkan',
|
||||||
])
|
'Tidak Layak' => 'Tidak Layak',
|
||||||
->bulkActions([
|
|
||||||
Tables\Actions\BulkActionGroup::make([
|
|
||||||
Tables\Actions\DeleteBulkAction::make(),
|
|
||||||
]),
|
]),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getRelations(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
//
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function getPages(): array
|
public static function getPages(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
'index' => Pages\ListHasils::route('/'),
|
'index' => Pages\ListHasil::route('/'),
|
||||||
'create' => Pages\CreateHasil::route('/create'),
|
|
||||||
'edit' => Pages\EditHasil::route('/{record}/edit'),
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,19 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Filament\Resources\HasilResource\Pages;
|
|
||||||
|
|
||||||
use App\Filament\Resources\HasilResource;
|
|
||||||
use Filament\Actions;
|
|
||||||
use Filament\Resources\Pages\EditRecord;
|
|
||||||
|
|
||||||
class EditHasil extends EditRecord
|
|
||||||
{
|
|
||||||
protected static string $resource = HasilResource::class;
|
|
||||||
|
|
||||||
protected function getHeaderActions(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
Actions\DeleteAction::make(),
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -3,10 +3,9 @@
|
||||||
namespace App\Filament\Resources\HasilResource\Pages;
|
namespace App\Filament\Resources\HasilResource\Pages;
|
||||||
|
|
||||||
use App\Filament\Resources\HasilResource;
|
use App\Filament\Resources\HasilResource;
|
||||||
use Filament\Actions;
|
use Filament\Resources\Pages\ListRecords;
|
||||||
use Filament\Resources\Pages\CreateRecord;
|
|
||||||
|
|
||||||
class CreateHasil extends CreateRecord
|
class ListHasil extends ListRecords
|
||||||
{
|
{
|
||||||
protected static string $resource = HasilResource::class;
|
protected static string $resource = HasilResource::class;
|
||||||
}
|
}
|
|
@ -1,19 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Filament\Resources\HasilResource\Pages;
|
|
||||||
|
|
||||||
use App\Filament\Resources\HasilResource;
|
|
||||||
use Filament\Actions;
|
|
||||||
use Filament\Resources\Pages\ListRecords;
|
|
||||||
|
|
||||||
class ListHasils extends ListRecords
|
|
||||||
{
|
|
||||||
protected static string $resource = HasilResource::class;
|
|
||||||
|
|
||||||
protected function getHeaderActions(): array
|
|
||||||
{
|
|
||||||
return [
|
|
||||||
Actions\CreateAction::make(),
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Models;
|
|
||||||
|
|
||||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
||||||
use Illuminate\Database\Eloquent\Model;
|
|
||||||
|
|
||||||
class hasil extends Model
|
|
||||||
{
|
|
||||||
use HasFactory;
|
|
||||||
|
|
||||||
protected $fillable = ['mahasiswa_id', 'total_bobot', 'status'];
|
|
||||||
|
|
||||||
public function mahasiswa()
|
|
||||||
{
|
|
||||||
return $this->belongsTo(mahasiswa::class);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -42,7 +42,8 @@ class parameter extends Model
|
||||||
'nilai_kondisi_ekonomi',
|
'nilai_kondisi_ekonomi',
|
||||||
'status_orang_tua',
|
'status_orang_tua',
|
||||||
'nilai_status_orang_tua',
|
'nilai_status_orang_tua',
|
||||||
'total_nilai'
|
'total_nilai',
|
||||||
|
'hasil'
|
||||||
];
|
];
|
||||||
|
|
||||||
public function getBerkasKipUrlAttribute()
|
public function getBerkasKipUrlAttribute()
|
||||||
|
@ -171,6 +172,15 @@ protected static function boot()
|
||||||
}
|
}
|
||||||
|
|
||||||
$parameter->total_nilai = $totalNilai;
|
$parameter->total_nilai = $totalNilai;
|
||||||
|
|
||||||
|
// Tentukan hasil berdasarkan total nilai
|
||||||
|
if ($totalNilai >= 0.75) {
|
||||||
|
$parameter->hasil = 'Layak';
|
||||||
|
} elseif ($totalNilai >= 0.5) {
|
||||||
|
$parameter->hasil = 'Dipertimbangkan';
|
||||||
|
} else {
|
||||||
|
$parameter->hasil = 'Tidak Layak';
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,30 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
use Illuminate\Database\Migrations\Migration;
|
|
||||||
use Illuminate\Database\Schema\Blueprint;
|
|
||||||
use Illuminate\Support\Facades\Schema;
|
|
||||||
|
|
||||||
return new class extends Migration
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Run the migrations.
|
|
||||||
*/
|
|
||||||
public function up(): void
|
|
||||||
{
|
|
||||||
Schema::create('hasils', function (Blueprint $table) {
|
|
||||||
$table->id();
|
|
||||||
$table->foreignId('mahasiswa_id')->constrained('mahasiswas')->onDelete('cascade'); // Relasi ke tabel mahasiswa
|
|
||||||
$table->decimal('total_bobot', 5, 2); // Skor akhir hasil perhitungan SMARTER
|
|
||||||
$table->enum('status', ['Layak','Dipertimbangkan', 'Tidak Layak'])->default('Tidak Layak'); // Status keputusan
|
|
||||||
$table->timestamps();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reverse the migrations.
|
|
||||||
*/
|
|
||||||
public function down(): void
|
|
||||||
{
|
|
||||||
Schema::dropIfExists('hasils');
|
|
||||||
}
|
|
||||||
};
|
|
|
@ -0,0 +1,30 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::table('parameters', function (Blueprint $table) {
|
||||||
|
$table->enum('hasil', ['Layak', 'Dipertimbangkan', 'Tidak Layak'])
|
||||||
|
->after('total_nilai')
|
||||||
|
->nullable();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::table('parameters', function (Blueprint $table) {
|
||||||
|
$table->dropColumn('hasil');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
|
@ -0,0 +1,22 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::table('parameters', function (Blueprint $table) {
|
||||||
|
$table->enum('hasil', ['Layak', 'Dipertimbangkan', 'Tidak Layak'])->nullable()->after('total_nilai');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::table('parameters', function (Blueprint $table) {
|
||||||
|
$table->dropColumn('hasil');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
Loading…
Reference in New Issue