141 lines
3.5 KiB
PHP
141 lines
3.5 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* @package Joomla.Site
|
||
|
* @subpackage com_finder
|
||
|
*
|
||
|
* @copyright Copyright (C) 2005 - 2013 Open Source Matters, Inc. All rights reserved.
|
||
|
* @license GNU General Public License version 2 or later; see LICENSE
|
||
|
*/
|
||
|
|
||
|
defined('_JEXEC') or die;
|
||
|
|
||
|
define('FINDER_PATH_INDEXER', JPATH_ADMINISTRATOR . '/components/com_finder/helpers/indexer');
|
||
|
JLoader::register('FinderIndexerHelper', FINDER_PATH_INDEXER . '/helper.php');
|
||
|
|
||
|
/**
|
||
|
* Suggestions model class for the Finder package.
|
||
|
*
|
||
|
* @package Joomla.Site
|
||
|
* @subpackage com_finder
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
class FinderModelSuggestions extends JModelList
|
||
|
{
|
||
|
/**
|
||
|
* Context string for the model type.
|
||
|
*
|
||
|
* @var string
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
protected $context = 'com_finder.suggestions';
|
||
|
|
||
|
/**
|
||
|
* Method to get an array of data items.
|
||
|
*
|
||
|
* @return array An array of data items.
|
||
|
*
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
public function getItems()
|
||
|
{
|
||
|
// Get the items.
|
||
|
$items = parent::getItems();
|
||
|
|
||
|
// Convert them to a simple array.
|
||
|
foreach ($items as $k => $v)
|
||
|
{
|
||
|
$items[$k] = $v->term;
|
||
|
}
|
||
|
|
||
|
return $items;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Method to build a database query to load the list data.
|
||
|
*
|
||
|
* @return JDatabaseQuery A database query
|
||
|
*
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
protected function getListQuery()
|
||
|
{
|
||
|
// Create a new query object.
|
||
|
$db = $this->getDbo();
|
||
|
$query = $db->getQuery(true);
|
||
|
|
||
|
// Select required fields
|
||
|
$query->select('t.term')
|
||
|
->from($db->quoteName('#__finder_terms') . ' AS t')
|
||
|
->where('t.term LIKE ' . $db->quote($db->escape($this->getState('input'), true) . '%'))
|
||
|
->where('t.common = 0')
|
||
|
->where('t.language IN (' . $db->quote($db->escape($this->getState('language'), true)) . ', ' . $db->quote('*') . ')')
|
||
|
->order('t.links DESC')
|
||
|
->order('t.weight DESC');
|
||
|
|
||
|
return $query;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Method to get a store id based on model the configuration state.
|
||
|
*
|
||
|
* This is necessary because the model is used by the component and
|
||
|
* different modules that might need different sets of data or different
|
||
|
* ordering requirements.
|
||
|
*
|
||
|
* @param string $id An identifier string to generate the store id. [optional]
|
||
|
*
|
||
|
* @return string A store id.
|
||
|
*
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
protected function getStoreId($id = '')
|
||
|
{
|
||
|
// Add the search query state.
|
||
|
$id .= ':' . $this->getState('input');
|
||
|
$id .= ':' . $this->getState('language');
|
||
|
|
||
|
// Add the list state.
|
||
|
$id .= ':' . $this->getState('list.start');
|
||
|
$id .= ':' . $this->getState('list.limit');
|
||
|
|
||
|
return parent::getStoreId($id);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Method to auto-populate the model state. Calling getState in this method will result in recursion.
|
||
|
*
|
||
|
* @param string $ordering An optional ordering field.
|
||
|
* @param string $direction An optional direction (asc|desc).
|
||
|
*
|
||
|
* @return void
|
||
|
*
|
||
|
* @since 2.5
|
||
|
*/
|
||
|
protected function populateState($ordering = null, $direction = null)
|
||
|
{
|
||
|
// Get the configuration options.
|
||
|
$app = JFactory::getApplication();
|
||
|
$input = $app->input;
|
||
|
$params = JComponentHelper::getParams('com_finder');
|
||
|
$user = JFactory::getUser();
|
||
|
|
||
|
// Get the query input.
|
||
|
$this->setState('input', $input->request->get('q', '', 'string'));
|
||
|
|
||
|
// Set the query language
|
||
|
$lang = FinderIndexerHelper::getDefaultLanguage();
|
||
|
$lang = FinderIndexerHelper::getPrimaryLanguage($lang);
|
||
|
$this->setState('language', $lang);
|
||
|
|
||
|
// Load the list state.
|
||
|
$this->setState('list.start', 0);
|
||
|
$this->setState('list.limit', 10);
|
||
|
|
||
|
// Load the parameters.
|
||
|
$this->setState('params', $params);
|
||
|
|
||
|
// Load the user state.
|
||
|
$this->setState('user.id', (int) $user->get('id'));
|
||
|
}
|
||
|
}
|