[CakePHP] Pagination + Search ページ遷移時に検索条件を維持させる

CakeのPagenateについて。バージョンは1.3。

Pagenate使ってるときにconditionsを使うと、自動生成されるナビゲーションにはその条件が反映されない。
1ページ目は検索条件通り出てるのに2ページ目に進むとクリアされる現象が起きる。
その事についてはかなり既出のようだ。

検索条件を維持したままページ遷移するにはPagenateにクエリを渡さなければならない。

view/posts/index.ctp

<?php
//ファイルの先頭
$paginator->options(array('url' => $this->passedArgs));
?>
<?php echo $this->Form->create('Post',array('name'=>'search')); ?>
<?php echo $form->select('search.category', $category_label, NULL); ?>
<?php echo $this->Form->end('Search');?>

$category_label はfind(‘list’)で得たカテゴリーのidとラベルが入っているものとする。
(カテゴリーの選択は1記事あたりに1つのみってことで)
これで送信するとPostsControllerのindexメソッドで$this->data[‘search’]として受け取る事が出来る。

controller/posts_controller.php

var $paginate = array(
        'limit' => 25,
        'order' => array(
            'Post.id' => 'asc'
        )
    );
function index()
{
	if(is_numeric($this->data['search']['category'])){
		$this->paginate['conditions']['category'] = $this->data['search']['category'];
		$this->passedArgs['category'] = urlencode($this->data['search']['category']);
	}
	if(!empty($this->passedArgs['category'])){
		$this->paginate['conditions']['category'] =  $this->passedArgs['category'];
	}
        $this->set('posts',$this->paginate('Post'));
}

Pagenateの設定の仕方は殆どfind()と同じらしい。
$this->passedArgsに配列形式でクエリを渡せばページ移動しても検索状態が維持出来る。

渡す値は一応Sanitizeしといた方がいい気がする。

App::import('Sanitize');
Sanitize::clean($this->data['search']['category']);

Leave a Comment.