* @github Joomla Component Builder * @copyright Copyright (C) 2015 Vast Development Method. All rights reserved. * @license GNU General Public License version 2 or later; see LICENSE.txt */ // No direct access to this file defined('_JEXEC') or die('Restricted access'); // import the list field type jimport('joomla.form.helper'); JFormHelper::loadFieldClass('list'); /** * Customcodesfiltertype Form Field class for the Componentbuilder component */ class JFormFieldCustomcodesfiltertype extends JFormFieldList { /** * The customcodesfiltertype field type. * * @var string */ public $type = 'customcodesfiltertype'; /** * Method to get a list of options for a list input. * * @return array An array of JHtml options. */ protected function getOptions() { // Get a db connection. $db = JFactory::getDbo(); // Create a new query object. $query = $db->getQuery(true); // Select the text. $query->select($db->quoteName('type')); $query->from($db->quoteName('#__componentbuilder_custom_code')); $query->order($db->quoteName('type') . ' ASC'); // Reset the query using our newly populated query object. $db->setQuery($query); $results = $db->loadColumn(); $_filter = array(); $_filter[] = JHtml::_('select.option', '', '- ' . JText::_('COM_COMPONENTBUILDER_FILTER_SELECT_ADD_TYPE') . ' -'); if ($results) { // get custom_codesmodel $model = ComponentbuilderHelper::getModel('custom_codes'); $results = array_unique($results); foreach ($results as $type) { // Translate the type selection $text = $model->selectionTranslation($type,'type'); // Now add the type and its text to the options array $_filter[] = JHtml::_('select.option', $type, JText::_($text)); } } return $_filter; } }