* @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'); /** * Fieldsfilterdatatype Form Field class for the Componentbuilder component */ class JFormFieldFieldsfilterdatatype extends JFormFieldList { /** * The fieldsfilterdatatype field type. * * @var string */ public $type = 'fieldsfilterdatatype'; /** * 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('datatype')); $query->from($db->quoteName('#__componentbuilder_field')); $query->order($db->quoteName('datatype') . ' 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_DATA_TYPE') . ' -'); if ($results) { // get fieldsmodel $model = ComponentbuilderHelper::getModel('fields'); $results = array_unique($results); foreach ($results as $datatype) { // Translate the datatype selection $text = $model->selectionTranslation($datatype,'datatype'); // Now add the datatype and its text to the options array $_filter[] = JHtml::_('select.option', $datatype, JText::_($text)); } } return $_filter; } }