|
@@ -3,6 +3,7 @@
|
|
|
namespace App\Services;
|
|
namespace App\Services;
|
|
|
|
|
|
|
|
use App\Models\StudentContract;
|
|
use App\Models\StudentContract;
|
|
|
|
|
+use App\Models\StudentMedia;
|
|
|
use Illuminate\Database\Eloquent\Collection;
|
|
use Illuminate\Database\Eloquent\Collection;
|
|
|
use Illuminate\Support\Facades\Storage;
|
|
use Illuminate\Support\Facades\Storage;
|
|
|
|
|
|
|
@@ -19,7 +20,7 @@ public function getAll(int $unitId, ?int $studentId = null): Collection
|
|
|
|
|
|
|
|
public function findById(int $id): ?StudentContract
|
|
public function findById(int $id): ?StudentContract
|
|
|
{
|
|
{
|
|
|
- return StudentContract::find($id);
|
|
|
|
|
|
|
+ return StudentContract::with(['student', 'classPackageUnit'])->find($id);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
public function create(array $data): StudentContract
|
|
public function create(array $data): StudentContract
|
|
@@ -57,20 +58,47 @@ public function attachFile(int $id, $file): ?StudentContract
|
|
|
return null;
|
|
return null;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- if ($model->file_url) {
|
|
|
|
|
- Storage::delete($model->file_url);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
/** @var \Illuminate\Http\UploadedFile $file */
|
|
/** @var \Illuminate\Http\UploadedFile $file */
|
|
|
- $model->update([
|
|
|
|
|
- 'file_url' => $file->store('student-contracts'),
|
|
|
|
|
- 'file_type' => $file->getMimeType(),
|
|
|
|
|
|
|
+ $path = $file->store('student-media');
|
|
|
|
|
+
|
|
|
|
|
+ StudentMedia::create([
|
|
|
|
|
+ 'student_id' => $model->student_id,
|
|
|
|
|
+ 'student_contract_id' => $model->id,
|
|
|
|
|
+ 'url' => $path,
|
|
|
|
|
+ 'file_type' => $file->getMimeType(),
|
|
|
|
|
+ 'type' => 'contract',
|
|
|
]);
|
|
]);
|
|
|
|
|
|
|
|
|
|
+ $model->update(['file_url' => Storage::url($path), 'file_type' => $file->getMimeType()]);
|
|
|
|
|
+
|
|
|
|
|
+ return $model->fresh();
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public function freeze(int $id): ?StudentContract
|
|
|
|
|
+ {
|
|
|
|
|
+ $model = $this->findById($id);
|
|
|
|
|
+
|
|
|
|
|
+ if (!$model) {
|
|
|
|
|
+ return null;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $model->update(['status' => 'frozen']);
|
|
|
|
|
+ return $model->fresh();
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ public function cancel(int $id): ?StudentContract
|
|
|
|
|
+ {
|
|
|
|
|
+ $model = $this->findById($id);
|
|
|
|
|
+
|
|
|
|
|
+ if (!$model) {
|
|
|
|
|
+ return null;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ $model->update(['status' => 'cancelled']);
|
|
|
return $model->fresh();
|
|
return $model->fresh();
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- public function updateStatus(int $id, string $status): ?StudentContract
|
|
|
|
|
|
|
+ public function reactivate(int $id): ?StudentContract
|
|
|
{
|
|
{
|
|
|
$model = $this->findById($id);
|
|
$model = $this->findById($id);
|
|
|
|
|
|
|
@@ -78,7 +106,7 @@ public function updateStatus(int $id, string $status): ?StudentContract
|
|
|
return null;
|
|
return null;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- $model->update(['status' => $status]);
|
|
|
|
|
|
|
+ $model->update(['status' => 'active']);
|
|
|
return $model->fresh();
|
|
return $model->fresh();
|
|
|
}
|
|
}
|
|
|
|
|
|