From 822c8978a9e341ca7b469a6df2734e38c7aff88a Mon Sep 17 00:00:00 2001 From: phpnut Date: Sat, 5 Jul 2008 09:44:42 +0000 Subject: [PATCH] Fixes #5002 Model name in PaginatorHelper sortKey. Closes #5032 Small performance improvement in App::!__load(); git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@7312 3807eeeb-6ff5-0310-8944-8be069107fe0 --- cake/libs/configure.php | 4 +- cake/libs/view/helpers/paginator.php | 6 ++ .../libs/view/helpers/paginator.test.php | 89 ++++++++++++++++--- 3 files changed, 86 insertions(+), 13 deletions(-) diff --git a/cake/libs/configure.php b/cake/libs/configure.php index 3471efcc6..2da86028b 100644 --- a/cake/libs/configure.php +++ b/cake/libs/configure.php @@ -947,7 +947,7 @@ class App extends Object { function __load($file) { $_this =& App::getInstance(); - if (!$_this->return && in_array($file, $_this->__loaded)) { + if (!$_this->return && isset($_this->__loaded[$file])) { return true; } @@ -955,7 +955,7 @@ class App extends Object { if (!$_this->return) { require($file); } - $_this->__loaded[] = $file; + $_this->__loaded[$file] = true; return true; } return false; diff --git a/cake/libs/view/helpers/paginator.php b/cake/libs/view/helpers/paginator.php index 063115fe2..efcc66ccd 100644 --- a/cake/libs/view/helpers/paginator.php +++ b/cake/libs/view/helpers/paginator.php @@ -280,6 +280,12 @@ class PaginatorHelper extends AppHelper { $sort = $direction = null; if (is_array($url['order'])) { list($sort, $direction) = array($this->sortKey($model, $url), current($url['order'])); + $key = array_keys($url['order']); + + if (strpos($key[0], '.') !== false) { + list($model) = explode('.', $key[0]); + $sort = $model . '.' . $sort; + } } unset($url['order']); $url = array_merge($url, compact('sort', 'direction')); diff --git a/cake/tests/cases/libs/view/helpers/paginator.test.php b/cake/tests/cases/libs/view/helpers/paginator.test.php index 701f3c1b4..2c50cd6a9 100644 --- a/cake/tests/cases/libs/view/helpers/paginator.test.php +++ b/cake/tests/cases/libs/view/helpers/paginator.test.php @@ -161,21 +161,11 @@ class PaginatorTest extends UnitTestCase { array('plugin' => null, 'controller' => 'accounts', 'action' => 'index', 'pass' => array(), 'form' => array(), 'url' => array('url' => 'accounts/', 'mod_rewrite' => 'true'), 'bare' => 0), array('plugin' => null, 'controller' => null, 'action' => null, 'base' => '/officespace', 'here' => '/officespace/accounts/', 'webroot' => '/officespace/', 'passedArgs' => array()) )); + $this->Paginator->params['paging']['Article']['options']['order'] = array('Article.title' => 'desc'); - $this->Paginator->params['paging']['named'] = array( - 'page' => 1, - 'sort' => 'Artist.title', - 'direction' => 'desc' - ); $result = $this->Paginator->sort('Title','Article.title'); $this->assertPattern('/\/accounts\/index\/page:1\/sort:Article.title\/direction:asc">Title<\/a>$/', $result); - - $this->Paginator->params['paging']['named'] = array( - 'page' => 1, - 'sort' => 'Artist.title', - 'direction' => 'asc' - ); $this->Paginator->params['paging']['Article']['options']['order'] = array('Article.title' => 'asc'); $result = $this->Paginator->sort('Title','Article.title'); $this->assertPattern('/\/accounts\/index\/page:1\/sort:Article.title\/direction:desc">Title<\/a>$/', $result); @@ -210,6 +200,11 @@ class PaginatorTest extends UnitTestCase { $this->Paginator->options(array('url' => array('param'))); $result = $this->Paginator->sort('title'); $this->assertPattern('/\/admin\/test\/index\/param\/page:1\/sort:title\/direction:asc"\s*>Title<\/a>$/', $result); + + $this->Paginator->options(array('url' => array('param'))); + $result = $this->Paginator->sort('Title', 'Article.title'); + $this->assertPattern('/\/admin\/test\/index\/param\/page:1\/sort:Article.title\/direction:asc"\s*>Title<\/a>$/', $result); + } /** * testUrlGeneration method @@ -232,6 +227,11 @@ class PaginatorTest extends UnitTestCase { $options = array('order' => array('Article' => 'desc')); $result = $this->Paginator->url($options); $this->assertEqual($result, '/index/page:2/sort:Article/direction:desc'); + + $this->Paginator->params['paging']['Article']['options']['page'] = 3; + $options = array('order' => array('Article.name' => 'desc')); + $result = $this->Paginator->url($options); + $this->assertEqual($result, '/index/page:3/sort:Article.name/direction:desc'); } /** * testOptions method @@ -267,6 +267,22 @@ class PaginatorTest extends UnitTestCase { )); $this->Paginator->options($options); $this->assertEqual($expected, $this->Paginator->params['paging']); + + $options = array('paging' => array('Article' => array( + 'order' => 'desc', + 'sort' => 'Article.title' + ))); + $this->Paginator->options($options); + + $expected = array('Article' => array( + 'order' => 'desc', + 'sort' => 'Article.title' + )); + $this->assertEqual($expected, $this->Paginator->params['paging']); + + $options = array('url' => array('controller' => 'blog', 'action' => 'index', 'admin' => false)); + $this->Paginator->options($options); + die(debug($this->Paginator->params['paging'])); } /** * testPagingLinks method @@ -297,6 +313,21 @@ class PaginatorTest extends UnitTestCase { $result = $this->Paginator->next('Next'); $this->assertPattern('/^]+>Next<\/a>$/', $result); $this->assertPattern('/href="\/index\/page:3"/', $result); + + $this->Paginator->params['paging'] = array('Client' => array( + 'page' => 1, 'current' => 3, 'count' => 13, 'prevPage' => false, 'nextPage' => true, 'pageCount' => 5, + 'defaults' => array(), + 'options' => array('page' => 1, 'limit' => 3, 'order' => array('Client.name' => 'DESC'), 'conditions' => array())) + ); + + $this->Paginator->params['paging']['Client']['page'] = 2; + $this->Paginator->params['paging']['Client']['prevPage'] = true; + $result = $this->Paginator->prev('<< Previous', null, null, array('class' => 'disabled')); + $this->assertPattern('/\/sort:Client.name\/direction:DESC"/', $result); + + $result = $this->Paginator->next('Next'); + $this->assertPattern('/\/sort:Client.name\/direction:DESC"/', $result); + } /** * testGenericLinks method @@ -317,6 +348,13 @@ class PaginatorTest extends UnitTestCase { $this->assertPattern('/\/page:2/', $result); $this->assertPattern('/\/sort:title/', $result); $this->assertPattern('/\/direction:desc/', $result); + + $this->Paginator->params['paging']['Article']['options']['page'] = 4; + $result = $this->Paginator->link('Sort by title on page 4', array('sort' => 'Article.title', 'direction' => 'desc')); + $this->assertPattern('/^]*>Sort by title on page 4<\/a>$/', $result); + $this->assertPattern('/\/page:4/', $result); + $this->assertPattern('/\/sort:Article.title/', $result); + $this->assertPattern('/\/direction:desc/', $result); } /** * testNumbers method @@ -438,6 +476,14 @@ class PaginatorTest extends UnitTestCase { $expected = '1 | 2 | 3'; $this->assertEqual($result, $expected); + $this->Paginator->params['paging'] = array('Client' => array( + 'page' => 2, 'current' => 10, 'count' => 31, 'prevPage' => true, 'nextPage' => true, 'pageCount' => 4, + 'defaults' => array('limit' => 10), + 'options' => array('page' => 1, 'order' => array('Client.name' => 'DESC'), 'conditions' => array())) + ); + $result = $this->Paginator->numbers(); + $expected = '1 | 2 | 3 | 4'; + $this->assertEqual($result, $expected); } /** * testFirstAndLast method @@ -487,6 +533,27 @@ class PaginatorTest extends UnitTestCase { $expected = ''; $this->assertEqual($result, $expected); + $this->Paginator->params['paging'] = array('Client' => array( + 'page' => 4, 'current' => 3, 'count' => 30, 'prevPage' => false, 'nextPage' => 2, 'pageCount' => 15, + 'defaults' => array('limit' => 3), + 'options' => array('page' => 1, 'limit' => 3, 'order' => array('Client.name' => 'DESC'), 'conditions' => array())) + ); + + $result = $this->Paginator->first(); + $expected = '<< first'; + $this->assertEqual($result, $expected); + + $result = $this->Paginator->last(); + $expected = 'last >>'; + $this->assertEqual($result, $expected); + + $result = $this->Paginator->last(1); + $expected = '...15'; + $this->assertEqual($result, $expected); + + $result = $this->Paginator->last(2); + $expected = '...14 | 15'; + $this->assertEqual($result, $expected); } /** * testCounter method