You've already forked isop-mirror
feat: implement internship creation and company listing
This commit is contained in:
@@ -3,10 +3,21 @@
|
|||||||
namespace App\Http\Controllers;
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
use App\Models\Company;
|
use App\Models\Company;
|
||||||
|
use App\Models\User;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
class CompanyController extends Controller
|
class CompanyController extends Controller
|
||||||
{
|
{
|
||||||
|
public function all_simple() {
|
||||||
|
$companies = Company::all()->makeHidden(['created_at', 'updated_at']);
|
||||||
|
|
||||||
|
$companies->each(function ($company) {
|
||||||
|
$company->contact = User::find($company->contact)->makeHidden(['created_at', 'updated_at', 'email_verified_at']);
|
||||||
|
});
|
||||||
|
|
||||||
|
return response()->json($companies);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Display a listing of the resource.
|
* Display a listing of the resource.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -53,7 +53,59 @@ class InternshipController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function store(Request $request)
|
public function store(Request $request)
|
||||||
{
|
{
|
||||||
//
|
$user = auth()->user();
|
||||||
|
|
||||||
|
$request->validate([
|
||||||
|
'company_id' => ['required', 'exists:companies,id'],
|
||||||
|
'start' => ['required', 'date'],
|
||||||
|
'end' => ['required', 'date', 'after:start'],
|
||||||
|
'year_of_study' => ['required', 'integer', 'between:1,5'],
|
||||||
|
'semester' => ['required', 'in:WINTER,SUMMER'],
|
||||||
|
'position_description' => ['required', 'string', 'min:1']
|
||||||
|
]);
|
||||||
|
|
||||||
|
$request->merge([
|
||||||
|
'start' => date('Y-m-d H:i:s', strtotime($request->start)),
|
||||||
|
'end' => date('Y-m-d H:i:s', strtotime($request->end))
|
||||||
|
]);
|
||||||
|
|
||||||
|
// je už nejaká prax ktorá sa časovo prekrýva?
|
||||||
|
$existingInternship = Internship::where('user_id', $user->id)
|
||||||
|
->where(function ($query) use ($request) {
|
||||||
|
$query->whereBetween('start', [$request->start, $request->end])
|
||||||
|
->orWhereBetween('end', [$request->start, $request->end])
|
||||||
|
->orWhere(function ($q) use ($request) {
|
||||||
|
$q->where('start', '<=', $request->start)
|
||||||
|
->where('end', '>=', $request->end);
|
||||||
|
});
|
||||||
|
})
|
||||||
|
->exists();
|
||||||
|
if ($existingInternship) {
|
||||||
|
return response()->json([
|
||||||
|
'message' => 'You already have an internship during this period.'
|
||||||
|
], 422);
|
||||||
|
}
|
||||||
|
|
||||||
|
$Internship = Internship::create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'company_id' => $request->company_id,
|
||||||
|
'start' => $request->start,
|
||||||
|
'end' => $request->end,
|
||||||
|
'year_of_study' => $request->year_of_study,
|
||||||
|
'semester' => $request->semester,
|
||||||
|
'position_description' => $request->position_description,
|
||||||
|
'agreement' => null
|
||||||
|
]);
|
||||||
|
|
||||||
|
InternshipStatus::create([
|
||||||
|
'internship_id' => $Internship->id,
|
||||||
|
'status' => 'SUBMITTED',
|
||||||
|
'changed' => now(),
|
||||||
|
'note' => null,
|
||||||
|
'modified_by' => $user->id
|
||||||
|
]);
|
||||||
|
|
||||||
|
return response()->noContent();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
use App\Http\Controllers\Auth\RegisteredUserController;
|
use App\Http\Controllers\Auth\RegisteredUserController;
|
||||||
|
use App\Http\Controllers\CompanyController;
|
||||||
use App\Http\Controllers\InternshipController;
|
use App\Http\Controllers\InternshipController;
|
||||||
use App\Models\Company;
|
use App\Models\Company;
|
||||||
use App\Models\StudentData;
|
use App\Models\StudentData;
|
||||||
@@ -23,4 +24,14 @@ Route::post('/password-reset', [RegisteredUserController::class, 'reset_password
|
|||||||
->middleware(['guest', 'throttle:6,1'])
|
->middleware(['guest', 'throttle:6,1'])
|
||||||
->name('password.reset');
|
->name('password.reset');
|
||||||
|
|
||||||
Route::get('/internships', [InternshipController::class, 'all'])->middleware(['auth'])->name("api.internships");
|
Route::prefix('/internships')->group(function () {
|
||||||
|
Route::get("/", [InternshipController::class, 'all'])->name("api.internships");
|
||||||
|
|
||||||
|
Route::middleware("auth:sanctum")->group(function () {
|
||||||
|
Route::put("/new", [InternshipController::class, 'store'])->name("api.internships.create");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
Route::prefix('/companies')->middleware("auth:sanctum")->group(function () {
|
||||||
|
Route::get("/simple", [CompanyController::class, 'all_simple']);
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user