Laravel.Две таблицы в отношениях, подборка многих фотографий - PullRequest
0 голосов
/ 24 ноября 2018

У меня есть две таблицы: Календарь и Фото в отношении одного события календаря ко многим фотографиям.

Я хотел бы добавить много фотографий при создании события.В настоящее время у меня может быть только один, один к одному.

Мой код: Связь модели календаря с Фото:

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).Спасибо за любую помощь!

1 Ответ

0 голосов
/ 24 ноября 2018

1- Измените ваш выбор на множественный ввод

<input type="file" name="photos[]" class="form-control">

1- Создайте foreach в контроллере для итерации по каждому изображению

if($photos=$request->file('photos')){
    foreach($photos as $image){
        $name = $photo->getClientOriginalName();
        $photo = Photo::where('name',$name)->first();
        if(is_null($photo)) {
            $photo = new Photo();
        }
        $photo->name = $name;
        $photo->calendar_id = $calendar->id;
        $photo->save();
    }
}

3- Может быть, вы можете использовать какой-нибудь PHPпакет для изображений, таких как http://image.intervention.io/

4- Посмотрите на этот ответ .. https://stackoverflow.com/questions/42643265/how-to-upload-multiple-image-in-laravel

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...