У меня есть две таблицы: Календарь и Фото в отношении одного события календаря ко многим фотографиям.
Я хотел бы добавить много фотографий при создании события.В настоящее время у меня может быть только один, один к одному.
Мой код: Связь модели календаря с Фото:
public function photos()
{
return $this->hasMany(Photo::class);
}
Связь модели фото с Календарем:
public function calendar()
{
return $this->belongsTo(Calendar::class, 'calendar_id');
}
все нормально и работает.
Фрагмент представления create.blade.php:
<div class="card-body">
<form action="{{ action ('CalendarController@store')}}" method="POST"
enctype="multipart/form-data">
<input type="hidden" name="_token" value="{{csrf_token() }}"/>
<div class="form-group">
<label for="photo">Photo:</label> <select class="form-control" name="photo">
@foreach($photos as $photo)
<option value="{{ $photo->id }}">{{ $photo->path }}</option>
@endforeach
</select>
</div>
<div class="form-group">
<label for="header">Header</label> <input type="text" class="form-control" name="header"/></div>
<div class="form-group">
<label for="description">Description</label><input type="text" class="form-control" name="description"/></div>
<div class="form-group">
<label for="date">Date</label> <input type="date" class="form-control" name="date"/></div>
<input type="submit" value="Create" class="btn btn-primary"/>
</form>
</div>
На данный момент у меня есть классический список выбора, где я могу выбрать только одинопция.
Код контроллера календаря (функция создания и сохранения):
public function create()
{
$photos = Photo::all();
return view('pages.calendar.create', [
"photos" => $photos
]);
}
public function store(Request $request)
{
$request->validate([
'header' => 'required|max:255',
'description' => 'required',
'date' => 'required',
]);
$calendar = new Calendar();
$calendar->header = $request->input('header');
$calendar->description = $request->input('description');
$calendar->date = $request->input('date');
$calendar->save();
$photo = Photo::find($request->input('photo'));
if($photo !== null) {
$photo->calendar_id = $calendar->id;
$photo->save();
}
return redirect()->action('CalendarController@clist');
}
Как изменить этот фрагмент кода на фотографии с несколькими магазинами:
$photo = Photo::find($request->input('photo'));
if($photo !== null) {
$photo->calendar_id = $calendar->id;
$photo->save();
}
У меня естьcalendar_id в Таблице фотографий (клавиша Fereign).Спасибо за любую помощь!