@copyright Copyright (C) 2020 Vast Development Method. All rights reserved. @license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html Portal for mobile health clinics /-----------------------------------------------------------------------------------------------------------------------------*/ // No direct access to this file defined('_JEXEC') or die('Restricted access'); use Joomla\CMS\Factory; use Joomla\CMS\Language\Text; use Joomla\CMS\HTML\HTMLHelper as Html; // import the list field type jimport('joomla.form.helper'); JFormHelper::loadFieldClass('list'); /** * Breastcancersfilterpatient Form Field class for the Ehealthportal component */ class JFormFieldBreastcancersfilterpatient extends JFormFieldList { /** * The breastcancersfilterpatient field type. * * @var string */ public $type = 'breastcancersfilterpatient'; /** * Method to get a list of options for a list input. * * @return array An array of Html options. */ protected function getOptions() { // Get a db connection. $db = Factory::getDbo(); // Create a new query object. $query = $db->getQuery(true); // Select the text. $query->select($db->quoteName('patient')); $query->from($db->quoteName('#__ehealthportal_breast_cancer')); $query->order($db->quoteName('patient') . ' ASC'); // Reset the query using our newly populated query object. $db->setQuery($query); $_results = $db->loadColumn(); $_filter = []; $_filter[] = Html::_('select.option', '', '- ' . Text::_('COM_EHEALTHPORTAL_FILTER_SELECT_PATIENT_NAME') . ' -'); if ($_results) { $_results = array_unique($_results); foreach ($_results as $patient) { // Now add the patient and its text to the options array $_filter[] = Html::_('select.option', $patient, Factory::getUser($patient)->name); } } return $_filter; } }