2016-01-30 20:28:43 +00:00
|
|
|
<?php
|
2021-03-05 03:08:47 +00:00
|
|
|
/**
|
|
|
|
* @package Joomla.Component.Builder
|
|
|
|
*
|
|
|
|
* @created 30th April, 2015
|
2022-07-09 15:45:08 +00:00
|
|
|
* @author Llewellyn van der Merwe <https://dev.vdm.io>
|
|
|
|
* @git Joomla Component Builder <https://git.vdm.dev/joomla/Component-Builder>
|
2021-03-05 03:08:47 +00:00
|
|
|
* @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');
|
|
|
|
|
2024-03-02 20:10:30 +00:00
|
|
|
use Joomla\CMS\Factory;
|
|
|
|
use Joomla\CMS\Language\Text;
|
|
|
|
use Joomla\CMS\HTML\HTMLHelper as Html;
|
|
|
|
|
2021-03-05 03:08:47 +00:00
|
|
|
// 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.
|
|
|
|
*
|
2024-03-02 20:10:30 +00:00
|
|
|
* @var string
|
2021-03-05 03:08:47 +00:00
|
|
|
*/
|
|
|
|
public $type = 'dbtables';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Method to get a list of options for a list input.
|
|
|
|
*
|
2024-03-02 20:10:30 +00:00
|
|
|
* @return array An array of Html options.
|
2021-03-05 03:08:47 +00:00
|
|
|
*/
|
|
|
|
protected function getOptions()
|
|
|
|
{
|
2018-10-29 16:38:00 +00:00
|
|
|
// get db object
|
2024-03-09 19:41:29 +00:00
|
|
|
$db = Factory::getDBO();
|
2018-10-29 16:38:00 +00:00
|
|
|
// get all tables
|
|
|
|
$tables= $db->getTableList();
|
|
|
|
// get config
|
2024-03-09 19:41:29 +00:00
|
|
|
$config = Factory::getConfig();
|
|
|
|
$dbprefix = \version_compare(JVERSION,'3.0','lt') ? $config->getValue('config.dbprefix') : $config->get('dbprefix');
|
2018-10-29 16:38:00 +00:00
|
|
|
$options = array();
|
2024-03-09 19:41:29 +00:00
|
|
|
$options[] = Html::_('select.option', '', 'Select an option');
|
2018-10-29 16:38:00 +00:00
|
|
|
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())
|
|
|
|
{
|
|
|
|
$key = $i+1;
|
2024-03-09 19:41:29 +00:00
|
|
|
$options[$key] = new \stdClass;
|
2018-10-29 16:38:00 +00:00
|
|
|
$options[$key]->value = str_replace($dbprefix, '', $tables[$i]);
|
|
|
|
$options[$key]->text = $tables[$i];
|
|
|
|
}
|
|
|
|
}
|
2021-03-05 03:08:47 +00:00
|
|
|
return $options;
|
|
|
|
}
|
|
|
|
}
|