referring to the DB query itself (as printed at the bottom of the
page, for example)?
Have you tried debugging $searchOptions immediately after the switch
block? Perhaps also debug $this->data at the beginning of the action.
On Thu, Sep 2, 2010 at 11:24 AM, Michael Gaiser <mjgaiser@gmail.com> wrote:
> So, I have been trying to get this paginate feature working and I can get
> the first page properly, but when it returns the 2nd page, the query is
> empty. Anyone see anything wrong? I suspect it has something to do with the
> $searchStr arg but am unsure how to get around not having an arg in that
> function. Thanks.
>
> ~Michael
>
>
>
> function index($searchStr = null) {
> $results = array();
>
> //Use the searchStr if there is no data.
> if(empty($this->data) && $searchStr != null) {
> $this->data['autoComplete'] = $searchStr;
> $this->data['Location']['constrainType'] = -1;
> }
>
> if (!empty($this->data)) {
> $autoCompleteStr = '';
> if($this->data['autoComplete'] != '**') {
> $autoCompleteStr = $this->data['autoComplete'];
> }
>
> $locationType = $this->data['Location']['constrainType'] - 1;
> if ($locationType < 0) $locationType = "%";
>
>
>
> $this->paginate = array(
> 'limit'=>10,
> 'contain' =>array('ParentLocation.name',
> 'ParentLocation.type', 'ParentLocation.id', 'ConfirmedUser.username'),
> 'fields'=>array('Location.id', 'Location.name',
> 'Location.type', 'Location.parent_id', 'Location.longitude',
> 'Location.latitude', 'Location.confirmed_id'),
> 'order'=>array('Location.name ASC')
> );
> $searchOptions = array('Location.name LIKE' =>
> $autoCompleteStr.'%', 'Location.type' => $locationType);
>
>
> switch($this->data['Location']['adminConstrainType']){
> case 0:
> default:
> break;
>
> case 1:
> //Non Confirmed
> $adminCondition = array('Location.confirmed_id' =>
> null);
> $searchOptions = array_merge($searchOptions,
> $adminCondition);
> break;
>
> case 2:
> //Confirmed
> $adminCondition = array('Location.confirmed_id <>' =>
> null);
> $searchOptions = array_merge($searchOptions,
> $adminCondition);
> break;
> }
> $results = $this->paginate('Location', $searchOptions);
>
> $this->set('locations', $results);
> debug($results);
> }
> $this->set('constrainTypes', $this->__getConstrainTypes());
> $this->set('autocomplete', $this->data['autoComplete']);
> $this->set('adminContrainTypes', $this->__getAdminContrainTypes());
> }
>
> Check out the new CakePHP Questions site http://cakeqs.org and help others
> with their CakePHP related questions.
>
> You received this message because you are subscribed to the Google Groups
> "CakePHP" group.
> To post to this group, send email to cake-php@googlegroups.com
> To unsubscribe from this group, send email to
> cake-php+unsubscribe@googlegroups.com For more options, visit this group at
> http://groups.google.com/group/cake-php?hl=en
>
Check out the new CakePHP Questions site http://cakeqs.org and help others with their CakePHP related questions.
You received this message because you are subscribed to the Google Groups "CakePHP" group.
To post to this group, send email to cake-php@googlegroups.com
To unsubscribe from this group, send email to
cake-php+unsubscribe@googlegroups.com For more options, visit this group at http://groups.google.com/group/cake-php?hl=en
No comments:
Post a Comment