/** * @dataProvider getBuildPagerWithPage2Tests */ public function testBuildPagerWithPage2($page, $perPage) { $this->pager->expects($this->once())->method('setMaxPerPage')->with($this->equalTo('50'))->will($this->returnValue(null)); $this->pager->expects($this->once())->method('setPage')->with($this->equalTo('3'))->will($this->returnValue(null)); $this->datagrid = new Datagrid($this->query, $this->columns, $this->pager, $this->formBuilder, array()); $this->datagrid->setValue('_per_page', null, $perPage); $this->datagrid->setValue('_page', null, $page); $this->datagrid->buildPager(); $this->assertSame(array('_per_page' => array('type' => null, 'value' => $perPage), '_page' => array('type' => null, 'value' => $page)), $this->datagrid->getValues()); $this->assertInstanceOf('Symfony\\Component\\Form\\FormBuilder', $this->formBuilder->get('_sort_by')); $this->assertInstanceOf('Symfony\\Component\\Form\\FormBuilder', $this->formBuilder->get('_sort_order')); $this->assertInstanceOf('Symfony\\Component\\Form\\FormBuilder', $this->formBuilder->get('_page')); $this->assertInstanceOf('Symfony\\Component\\Form\\FormBuilder', $this->formBuilder->get('_per_page')); }
/** * {@inheritdoc} */ public function buildPager() { if ($this->bound) { return; } foreach ($this->getFilters() as $name => $filter) { list($type, $options) = $filter->getRenderSettings(); $this->formBuilder->add($filter->getFormName(), $type, $options); } $this->formBuilder->add('_sort_by', 'hidden'); $this->formBuilder->get('_sort_by')->addViewTransformer(new CallbackTransformer(function ($value) { return $value; }, function ($value) { return $value instanceof FieldDescriptionInterface ? $value->getName() : $value; })); $this->formBuilder->add('_sort_order', 'hidden'); $this->formBuilder->add('_page', 'hidden'); $this->formBuilder->add('_per_page', 'hidden'); $this->form = $this->formBuilder->getForm(); $this->form->submit($this->values); $data = $this->form->getData(); foreach ($this->getFilters() as $name => $filter) { $this->values[$name] = isset($this->values[$name]) ? $this->values[$name] : null; $filter->apply($this->query, $data[$filter->getFormName()]); } if (isset($this->values['_sort_by'])) { if (!$this->values['_sort_by'] instanceof FieldDescriptionInterface) { throw new UnexpectedTypeException($this->values['_sort_by'], 'FieldDescriptionInterface'); } if ($this->values['_sort_by']->isSortable()) { $this->query->setSortBy($this->values['_sort_by']->getSortParentAssociationMapping(), $this->values['_sort_by']->getSortFieldMapping()); $this->query->setSortOrder(isset($this->values['_sort_order']) ? $this->values['_sort_order'] : null); } } $maxPerPage = 25; if (isset($this->values['_per_page'])) { // check for `is_array` can be safely removed if php 5.3 support will be dropped if (is_array($this->values['_per_page'])) { if (isset($this->values['_per_page']['value'])) { $maxPerPage = $this->values['_per_page']['value']; } } else { $maxPerPage = $this->values['_per_page']; } } $this->pager->setMaxPerPage($maxPerPage); $page = 1; if (isset($this->values['_page'])) { // check for `is_array` can be safely removed if php 5.3 support will be dropped if (is_array($this->values['_page'])) { if (isset($this->values['_page']['value'])) { $page = $this->values['_page']['value']; } } else { $page = $this->values['_page']; } } $this->pager->setPage($page); $this->pager->setQuery($this->query); $this->pager->init(); $this->bound = true; }
public function testGetResults() { $this->assertEquals(null, $this->datagrid->getResults()); $this->pager->expects($this->once())->method('getResults')->will($this->returnValue(array('foo', 'bar'))); $this->assertEquals(array('foo', 'bar'), $this->datagrid->getResults()); }