Exemplo n.º 1
0
 /**
  *
  * Returns the stored list of facets for the last search
  * GH:
  * The function is overridden because the current VF2 implementation does'nt take care (22.12.2014) about the number of facets shown for each category.
  * It always displays a fix number (at the moment five items defined in the Recommend\SideFacets.phtml)
  * Because we implemented a more flexible definition for Solr it has to be changed somehow for Summon too. I guess this is matter of change in the future by VuFind
  * so I don't invest too much into it
  *
  * @param array $filter Array of field => on-screen description listing
  * all of the desired facet fields; set to null to get all configured values.
  *
  * @return array        Facets data arrays
  */
 public function getFacetList($filter = null)
 {
     $finalResult = parent::getFacetList($filter);
     $configResultSettings = $this->getServiceLocator()->get('VuFind\\Config')->get('Summon')->Results_Settings;
     if ($configResultSettings) {
         $defaultLimit = $configResultSettings->facet_limit_default ? $configResultSettings->facet_limit_default : 4;
         foreach ($finalResult as $key => $value) {
             $finalResult[$key]['displayLimit'] = isset($configResultSettings->{'facet_limit_' . $key}) ? $configResultSettings->{'facet_limit_' . $key} : $defaultLimit;
         }
     } else {
         // in case something isn't configured as expected,
         // we need to define a displayLimit for the category otherwise the template using it stumbled upon it
         foreach ($finalResult as $key => $value) {
             $finalResult[$key]['displayLimit'] = 5;
         }
     }
     return $finalResult;
 }
Exemplo n.º 2
0
 /**
  * If we have to create a new Summon results object, this method is used to
  * configure it with appropriate settings.
  *
  * @param \VuFind\Search\Summon\Results $results Search results object
  *
  * @return void
  */
 protected function configureSummonResults(\VuFind\Search\Summon\Results $results)
 {
     $results->getParams()->setBasicSearch($this->lookfor, 'AllFields');
 }