Фильтр не работает, когда я нажимаю на разбивку на страницы в базе данных laravel и mongo


У меня есть функция фильтрации с разбиением на страницы. Фильтр работает изначально. Когда я нажимаю на кнопку "Разбиение на страницы", результат не отображается на основе фильтра.

Например: У меня есть три страны в поле фильтра. Я выбрал два, затем нажмите кнопку "Фильтр", затем результат отображается правильно на первой странице, но когда я нажимаю кнопку "Следующая страница", все три страны показывают результат без добавления фильтра.

Спасибо, любая помощь будет признательна

Фреймворк: laravel 5.5

База данных: MongoDB

Route.php

Route::match(['get', 'post'], '/search', 'SearchController@index')->name('search');

SearchController.php

public function index(SearchRequest $request)
    {
        $data = $request->all();
        $cabin = Cabin::select('_id', 'name', 'country', 'region', 'interior', 'sleeping_place', 'height', 'other_details', 'interior')
            ->where('is_delete', 0)
            ->where('other_cabin', "0");

        if(isset($request->cabinname)){
            $cabin->where('name', $request->cabinname);
        }

        if(isset($request->country)){
            $cabin->whereIn('country', $data['country']);
        }

        //dd($cabin->count());
        if(isset($request->region)){
            $cabin->whereIn('region', $data['region']);
        }

        $cabinSearchResult = $cabin->simplePaginate(5);

        return view('searchResult', ['cabinSearchResult' => $cabinSearchResult]);
    }

Search.blade.php

<form action="{{ route('search') }}" method="POST" class="navbar-form navbar-left" id="search-nav-home">

   {{ csrf_field() }}

    <div class="form-group navbar-form navbar-left" id="prefetch">
         <input type="text" class="form-control-home typeahead" name="cabinname" id="cabinname" placeholder="Search Cabin">
    </div>

     <ul class="nav navbar-nav" id="filter-home">

         @if($services->country())
            <li class="dropdown">
               <!-- Dropdown in Filter -->
               <a href="#" class="dropdown-toggle dropdown-toggle-home" data-toggle="dropdown">Country <span class="caret"></span></a>
                <ul class="dropdown-menu dropdown-menu-home">
                   @foreach($services->country() as $land)
                     <li class="check-it-list-home"><input type="checkbox" class="check-it-home" name="country[]" value="{{ $land->name }}"> {{ $land->name }}</li>
                   @endforeach
                </ul>
               </li>
          @endif

          @if($services->regions())
             <li class="dropdown">

              <a href="#" class="dropdown-toggle dropdown-toggle-home" data-toggle="dropdown">Region<span class="caret"></span></a>
                 <ul class="dropdown-menu dropdown-menu-home drop-height">
                    @foreach($services->regions() as $region)
                    <li class="check-it-list-home"><input type="checkbox" name="region[]" value="{{ $region->name }}" class="check-it-home"> {{ $region->name }}

                    </li>
                  @endforeach
                </ul>
               </li>
            @endif

          </ul>

          <div class="form-group navbar-form navbar-right" id="navbar-right-filter-home">
          <button type="submit" class="btn btn-default-home btn-filter-home">Filter Cabins</button>
  </div>
</form>

enter image description here

Author: sam sam, 2018-05-20

1 answers

В представлении результатов вам может потребоваться добавить ссылку на запрос к сгенерированной ссылке на страницу:

Сначала в вашем контроллере отправьте результат поиска в представление, например:

....
 return view('searchResult', ['cabinSearchResult' => $cabinSearchResult, 'next_query' => $data]);

Затем, по вашему мнению, используйте методы appends и link() в $searchResult, где вы отображаете ссылку с разбивкой по страницам вместо только link() или render(), например:

....
{{ $searchResult->appends($next_query)->links() }}

Это должно генерировать ссылки со строкой запроса, содержащей ваш старый поисковый запрос, на всех созданных страницах.

Подробнее о разбивка на страницы в Документах Laravel

 0
Author: Oluwatobi Samuel Omisakin, 2018-05-21 11:19:24