@my wife Roline van der Merwe @copyright Copyright (C) 2015. All Rights Reserved @license GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html Builds Complex Joomla Components /-----------------------------------------------------------------------------------------------------------------------------*/ // No direct access to this file defined('_JEXEC') or die('Restricted access'); // import the list field type jimport('joomla.form.helper'); JFormHelper::loadFieldClass('list'); /** * Dbtables Form Field class for the Componentbuilder component */ class JFormFieldDbtables extends JFormFieldList { /** * The dbtables field type. * * @var string */ public $type = 'dbtables'; /** * Override to add new button * * @return string The field input markup. * * @since 3.2 */ public function getInput() { // see if we should add buttons $setButton = $this->getAttribute('button'); // get html $html = parent::getInput(); // if true set button if ($setButton === 'true') { $user = JFactory::getUser(); // only add if user allowed to create if ($user->authorise('core.create', 'com_componentbuilder')) { // get the input from url $jinput = JFactory::getApplication()->input; // get the view name & id $values = $jinput->getArray(array( 'id' => 'int', 'view' => 'word' )); // check if new item $ref = ''; if (!is_null($values['id']) && strlen($values['view'])) { // only load referal if not new item. $ref = '&ref=' . $values['view'] . '&refid=' . $values['id']; } // build the button $button = ' ' . JText::_('COM_COMPONENTBUILDER_NEW') . ''; // return the button attached to input field return $html . $button; } } return $html; } /** * Method to get a list of options for a list input. * * @return array An array of JHtml options. */ public function getOptions() { $db = JFactory::getDBO(); $tables= $db->getTableList(); $config = JFactory::getConfig(); $options = array(); $db = JFactory::getDBO(); $options[] = JHtml::_('select.option', '', 'Select an option'); for ($i=0; $i < count($tables); $i++) { //only tables with primary key $db->setQuery('SHOW FIELDS FROM `'.$tables[$i].'` WHERE LOWER( `Key` ) = \'pri\''); if ($db->loadResult()) { $dbprefix = version_compare(JVERSION,'3.0','lt') ? $config->getValue('config.dbprefix') : $config->get('dbprefix'); $key = $i+1; $options[$key] = new stdClass; $options[$key]->value = str_replace($dbprefix, '', $tables[$i]); $options[$key]->text = $tables[$i]; } } return $options; } }