This commit is contained in:
2024-12-31 11:07:09 +01:00
parent df7915205d
commit e089172b15
1916 changed files with 165422 additions and 271 deletions

View File

@ -0,0 +1,81 @@
<?php
/**
* @package Advanced Custom Fields
* @version 2.8.8 Pro
*
* @author Tassos Marinos <info@tassos.gr>
* @link http://www.tassos.gr
* @copyright Copyright © 2020 Tassos Marinos All Rights Reserved
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> or later
*/
defined('_JEXEC') or die;
use Joomla\CMS\Factory;
JLoader::register('ACF_Field', JPATH_PLUGINS . '/system/acf/helper/plugin.php');
if (!class_exists('ACF_Field'))
{
Factory::getApplication()->enqueueMessage('Advanced Custom Fields System Plugin is missing', 'error');
return;
}
class PlgFieldsACFChainedFields extends ACF_Field
{
/**
* Override the field type
*
* @var string
*/
protected $overrideType = 'NRChainedFields';
/**
* Prepares the field value for the (front-end) layout
*
* @param string $context The context.
* @param stdclass $item The item.
* @param stdclass $field The field.
*
* @return string
*/
public function onCustomFieldsPrepareField($context, $item, $field)
{
// Check if the field should be processed by us
if (!$this->isTypeSupported($field->type))
{
return parent::onCustomFieldsPrepareField($context, $item, $field);
}
$data_source = $field->fieldparams->get('data_source', 'custom');
$dataset = '';
switch ($data_source)
{
case 'custom':
$dataset = $field->fieldparams->get('data_source_custom', '');
break;
case 'csv_file':
$csv_file = $field->fieldparams->get('data_source_csv', '');
if (!file_exists($csv_file))
{
return $parent;
}
$dataset = $csv_file;
break;
}
if (!$choices = \NRFramework\Helpers\ChainedFields::loadCSV($dataset, $data_source, $field->fieldparams->get('separator'), $field->name . '_', $field->name))
{
return $parent;
}
$field->choices = $choices;
return parent::onCustomFieldsPrepareField($context, $item, $field);
}
}

View File

@ -0,0 +1,21 @@
<?xml version="1.0" encoding="utf-8" ?>
<extension type="plugin" version="3.7.0" group="fields" method="upgrade">
<name>ACF_CHAINEDFIELDS</name>
<description>ACF_CHAINEDFIELDS_DESC</description>
<author>Tassos Marinos</author>
<creationDate>November 2022</creationDate>
<copyright>Copyright (C) 2019 Tassos Marinos. All rights reserved.</copyright>
<license>GNU General Public License version 2 or later; see LICENSE.txt</license>
<authorEmail>info@tassos.gr</authorEmail>
<authorUrl>www.tassos.gr</authorUrl>
<version>1.0</version>
<scriptfile>script.install.php</scriptfile>
<files>
<filename plugin="acfchainedfields">acfchainedfields.php</filename>
<filename>script.install.helper.php</filename>
<filename>version.php</filename>
<folder>language</folder>
<folder>params</folder>
<folder>tmpl</folder>
</files>
</extension>

View File

@ -0,0 +1,24 @@
; @package Advanced Custom Fields
; @version 2.8.8 Pro
;
; @author Tassos Marinos - http://www.tassos.gr/joomla-extensions
; @copyright Copyright (c) 2019 Tassos Marinos. All rights reserved.
; @license http://www.tassos.gr
PLG_FIELDS_ACFCHAINEDFIELDS_LABEL="ACF - Chained Fields"
ACF_CHAINEDFIELDS_VALUE_DESC="Select a value from a dropdown to reveal the next available options."
ACF_CHAINEDFIELDS="Fields - ACF Chained Fields"
ACF_CHAINEDFIELDS_DESC="Create select fields that dynamically change based on the previous selection."
ACF_CHAINEDFIELDS_DATA_SOURCE="Data Source"
ACF_CHAINEDFIELDS_DATA_SOURCE_DESC="Select the data source. You can either enter the expected format via text or upload a CSV file."
ACF_CHAINEDFIELDS_FROM_CSV_FILE="From CSV File"
ACF_CHAINEDFIELDS_DATA_SOURCE_CUSTOM="Custom Data Source"
ACF_CHAINEDFIELDS_DATA_SOURCE_CUSTOM_DESC="Enter the data source source manually. Format:<br />Year,Make,Model<br />2015,Audi,A3<br />2016,BMW,X3<br />2017,FIAT,500"
ACF_CHAINEDFIELDS_CSV="CSV Data Source"
ACF_CHAINEDFIELDS_CSV_DESC="Upload a CSV file to import your choices."
ACF_CHAINEDFIELDS_CSV_SEPARATOR="CSV Separator"
ACF_CHAINEDFIELDS_CSV_SEPARATOR_DESC="Enter the separator used in the CSV file."
ACF_CHAINEDFIELDS_LAYOUT="Layout"
ACF_CHAINEDFIELDS_LAYOUT_DESC="Select the layout that will be used to display the field."
ACF_CHAINEDFIELDS_CUSTOM_LAYOUT="Custom Layout"
ACF_CHAINEDFIELDS_CUSTOM_LAYOUT_DESC="Enter the custom layout.<br />You can use the following Smart Tags for each dropdown fields to retrieve their values: {field.1.value} where 1 is the first dropdown field which will return its value.<br />Similarly, you can use the Smart Tag {field.1.label} to retrieve each dropdown label.<br /><br />Replace 1 with 2 for the second dropdown field, etc..."

View File

@ -0,0 +1,9 @@
; @package Advanced Custom Fields
; @version 2.8.8 Pro
;
; @author Tassos Marinos - http://www.tassos.gr/joomla-extensions
; @copyright Copyright (c) 2019 Tassos Marinos. All rights reserved.
; @license http://www.tassos.gr
ACF_CHAINEDFIELDS="Fields - ACF Chained Fields"
ACF_CHAINEDFIELDS_DESC="Create select fields that dynamically change based on the previous selection."

View File

@ -0,0 +1,24 @@
; @package Advanced Custom Fields
; @version 2.8.8 Pro
;
; @author Tassos Marinos - http://www.tassos.gr/joomla-extensions
; @copyright Copyright (c) 2019 Tassos Marinos. All rights reserved.
; @license http://www.tassos.gr
PLG_FIELDS_ACFCHAINEDFIELDS_LABEL="ACF - Campos Encadenados"
ACF_CHAINEDFIELDS_VALUE_DESC="Seleccione un valor del menú desplegable para revelar las siguientes opciones disponibles."
ACF_CHAINEDFIELDS="Campos - ACF Campos Encadenados"
ACF_CHAINEDFIELDS_DESC="Cree campos de selección que cambien dinámicamente en función de la selección anterior."
ACF_CHAINEDFIELDS_DATA_SOURCE="Fuente de datos"
ACF_CHAINEDFIELDS_DATA_SOURCE_DESC="Seleccione la fuente de datos. Puede ingresar el formato esperado a través de texto o cargar un archivo CSV."
ACF_CHAINEDFIELDS_FROM_CSV_FILE="Desde archivo CSV"
ACF_CHAINEDFIELDS_DATA_SOURCE_CUSTOM="Fuente de datos personalizada"
ACF_CHAINEDFIELDS_DATA_SOURCE_CUSTOM_DESC="Ingrese la fuente de origen de datos manualmente. Formato:<br>Año, Marca, Modelo<br>2015,Audi,A3<br>2016,BMW,X3<br>2017,FIAT,500"
ACF_CHAINEDFIELDS_CSV="Fuente de datos CSV"
ACF_CHAINEDFIELDS_CSV_DESC="Cargue un archivo CSV para importar sus opciones."
ACF_CHAINEDFIELDS_CSV_SEPARATOR="Separador CSV"
ACF_CHAINEDFIELDS_CSV_SEPARATOR_DESC="Introduzca el separador utilizado en el archivo CSV."
ACF_CHAINEDFIELDS_LAYOUT="Disposición"
ACF_CHAINEDFIELDS_LAYOUT_DESC="Seleccione el diseño que se utilizará para mostrar el campo."
ACF_CHAINEDFIELDS_CUSTOM_LAYOUT="Diseño personalizado"
ACF_CHAINEDFIELDS_CUSTOM_LAYOUT_DESC="Introduzca el diseño personalizado.<br>Puede usar las siguientes etiquetas inteligentes para cada campo desplegable para recuperar sus valores: {field.1.value} donde 1 es el primer campo desplegable que devolverá su valor.<br>De manera similar, puede usar la etiqueta inteligente {field.1.label} para recuperar cada etiqueta desplegable.<br><br>Reemplace 1 con 2 para el segundo campo desplegable, etc."

View File

@ -0,0 +1,9 @@
; @package Advanced Custom Fields
; @version 2.8.8 Pro
;
; @author Tassos Marinos - http://www.tassos.gr/joomla-extensions
; @copyright Copyright (c) 2019 Tassos Marinos. All rights reserved.
; @license http://www.tassos.gr
ACF_CHAINEDFIELDS="Campos - ACF Campos Encadenados"
ACF_CHAINEDFIELDS_DESC="Cree campos de selección que cambien dinámicamente en función de la selección anterior."

View File

@ -0,0 +1,54 @@
<?xml version="1.0" encoding="utf-8"?>
<form>
<fields name="fieldparams">
<fieldset name="fieldparams">
<field name="data_source" type="radio"
label="ACF_CHAINEDFIELDS_DATA_SOURCE"
description="ACF_CHAINEDFIELDS_DATA_SOURCE_DESC"
class="btn-group btn-group-yesno"
default="custom">
<option value="custom">NR_CUSTOM</option>
<option value="csv_file">ACF_CHAINEDFIELDS_FROM_CSV_FILE</option>
</field>
<field name="data_source_custom" type="editor"
label="ACF_CHAINEDFIELDS_DATA_SOURCE_CUSTOM"
description="ACF_CHAINEDFIELDS_DATA_SOURCE_CUSTOM_DESC"
showon="data_source:custom"
editor="codemirror|none"
filter="raw"
rows="10"
/>
<field name="data_source_csv" type="NRInlineFileUpload"
label="ACF_CHAINEDFIELDS_CSV"
description="ACF_CHAINEDFIELDS_CSV_DESC"
accept=".csv"
upload_folder="media/acfchainedfields"
showon="data_source:csv_file"
/>
<field name="separator" type="text"
label="ACF_CHAINEDFIELDS_CSV_SEPARATOR"
description="ACF_CHAINEDFIELDS_CSV_SEPARATOR_DESC"
default=","
showon="data_source:csv_file"
/>
<field name="layout" type="radio"
label="ACF_CHAINEDFIELDS_LAYOUT"
description="ACF_CHAINEDFIELDS_LAYOUT_DESC"
class="btn-group btn-group-yesno"
default="default">
<option value="default">JDEFAULT</option>
<option value="custom">NR_CUSTOM</option>
</field>
<field name="custom_layout" type="editor"
label="ACF_CHAINEDFIELDS_CUSTOM_LAYOUT"
description="ACF_CHAINEDFIELDS_CUSTOM_LAYOUT_DESC"
showon="layout:custom"
editor="codemirror|none"
filter="raw"
rows="5"
default="{field.1.label}: {field.1.value}, {field.2.label}: {field.2.value}"
/>
</fieldset>
</fields>
</form>

View File

@ -0,0 +1,691 @@
<?php
/**
* Installer Script Helper
*
* @author Tassos Marinos <info@tassos.gr>
* @link http://www.tassos.gr
* @copyright Copyright © 2016 Tassos Marinos All Rights Reserved
* @license http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
*/
defined('_JEXEC') or die;
use Joomla\CMS\Installer\Installer;
use Joomla\CMS\Factory;
use Joomla\CMS\Language\Text;
use Joomla\Filesystem\File;
use Joomla\Filesystem\Folder;
class PlgFieldsAcfchainedfieldsInstallerScriptHelper
{
public $name = '';
public $alias = '';
public $extname = '';
public $extension_type = '';
public $plugin_folder = 'system';
public $module_position = 'status';
public $client_id = 1;
public $install_type = 'install';
public $show_message = true;
public $autopublish = true;
public $db = null;
public $app = null;
public $installedVersion;
public function __construct(&$params)
{
$this->extname = $this->extname ?: $this->alias;
$this->db = Factory::getDbo();
$this->app = Factory::getApplication();
$this->installedVersion = $this->getVersion($this->getInstalledXMLFile());
}
/**
* Preflight event
*
* @param string
* @param JAdapterInstance
*
* @return boolean
*/
public function preflight($route, $adapter)
{
if (!in_array($route, array('install', 'update')))
{
return;
}
Factory::getLanguage()->load('plg_system_novaraininstaller', JPATH_PLUGINS . '/system/novaraininstaller');
if ($this->show_message && $this->isInstalled())
{
$this->install_type = 'update';
}
if ($this->onBeforeInstall() === false)
{
return false;
}
}
/**
* Preflight event
*
* @param string
* @param JAdapterInstance
*
* @return boolean
*/
public function postflight($route, $adapter)
{
Factory::getLanguage()->load($this->getPrefix() . '_' . $this->extname, $this->getMainFolder());
if (!in_array($route, array('install', 'update')))
{
return;
}
if ($this->onAfterInstall() === false)
{
return false;
}
if ($route == 'install' && $this->autopublish)
{
$this->publishExtension();
}
if ($this->show_message)
{
$this->addInstalledMessage();
}
Factory::getCache()->clean('com_plugins');
Factory::getCache()->clean('_system');
}
public function isInstalled()
{
if (!is_file($this->getInstalledXMLFile()))
{
return false;
}
$query = $this->db->getQuery(true)
->select('extension_id')
->from('#__extensions')
->where($this->db->quoteName('type') . ' = ' . $this->db->quote($this->extension_type))
->where($this->db->quoteName('element') . ' = ' . $this->db->quote($this->getElementName()));
$this->db->setQuery($query, 0, 1);
$result = $this->db->loadResult();
return empty($result) ? false : true;
}
public function getMainFolder()
{
switch ($this->extension_type)
{
case 'plugin' :
return JPATH_SITE . '/plugins/' . $this->plugin_folder . '/' . $this->extname;
case 'component' :
return JPATH_ADMINISTRATOR . '/components/com_' . $this->extname;
case 'module' :
return JPATH_ADMINISTRATOR . '/modules/mod_' . $this->extname;
case 'library' :
return JPATH_SITE . '/libraries/' . $this->extname;
}
}
public function getInstalledXMLFile()
{
return $this->getXMLFile($this->getMainFolder());
}
public function getCurrentXMLFile()
{
return $this->getXMLFile(__DIR__);
}
public function getXMLFile($folder)
{
switch ($this->extension_type)
{
case 'module' :
return $folder . '/mod_' . $this->extname . '.xml';
default :
return $folder . '/' . $this->extname . '.xml';
}
}
public function foldersExist($folders = array())
{
foreach ($folders as $folder)
{
if (is_dir($folder))
{
return true;
}
}
return false;
}
public function publishExtension()
{
switch ($this->extension_type)
{
case 'plugin' :
$this->publishPlugin();
case 'module' :
$this->publishModule();
}
}
public function publishPlugin()
{
$query = $this->db->getQuery(true)
->update('#__extensions')
->set($this->db->quoteName('enabled') . ' = 1')
->where($this->db->quoteName('type') . ' = ' . $this->db->quote('plugin'))
->where($this->db->quoteName('element') . ' = ' . $this->db->quote($this->extname))
->where($this->db->quoteName('folder') . ' = ' . $this->db->quote($this->plugin_folder));
$this->db->setQuery($query);
$this->db->execute();
}
public function publishModule()
{
// Get module id
$query = $this->db->getQuery(true)
->select('id')
->from('#__modules')
->where($this->db->quoteName('module') . ' = ' . $this->db->quote('mod_' . $this->extname))
->where($this->db->quoteName('client_id') . ' = ' . (int) $this->client_id);
$this->db->setQuery($query, 0, 1);
$id = $this->db->loadResult();
if (!$id)
{
return;
}
// check if module is already in the modules_menu table (meaning is is already saved)
$query->clear()
->select('moduleid')
->from('#__modules_menu')
->where($this->db->quoteName('moduleid') . ' = ' . (int) $id);
$this->db->setQuery($query, 0, 1);
$exists = $this->db->loadResult();
if ($exists)
{
return;
}
// Get highest ordering number in position
$query->clear()
->select('ordering')
->from('#__modules')
->where($this->db->quoteName('position') . ' = ' . $this->db->quote($this->module_position))
->where($this->db->quoteName('client_id') . ' = ' . (int) $this->client_id)
->order('ordering DESC');
$this->db->setQuery($query, 0, 1);
$ordering = $this->db->loadResult();
$ordering++;
// publish module and set ordering number
$query->clear()
->update('#__modules')
->set($this->db->quoteName('published') . ' = 1')
->set($this->db->quoteName('ordering') . ' = ' . (int) $ordering)
->set($this->db->quoteName('position') . ' = ' . $this->db->quote($this->module_position))
->where($this->db->quoteName('id') . ' = ' . (int) $id);
$this->db->setQuery($query);
$this->db->execute();
// add module to the modules_menu table
$query->clear()
->insert('#__modules_menu')
->columns(array($this->db->quoteName('moduleid'), $this->db->quoteName('menuid')))
->values((int) $id . ', 0');
$this->db->setQuery($query);
$this->db->execute();
}
public function addInstalledMessage()
{
Factory::getApplication()->enqueueMessage(
Text::sprintf(
Text::_($this->install_type == 'update' ? 'NRI_THE_EXTENSION_HAS_BEEN_UPDATED_SUCCESSFULLY' : 'NRI_THE_EXTENSION_HAS_BEEN_INSTALLED_SUCCESSFULLY'),
'<strong>' . Text::_($this->name) . '</strong>',
'<strong>' . $this->getVersion() . '</strong>',
$this->getFullType()
)
);
}
public function getPrefix()
{
switch ($this->extension_type)
{
case 'plugin';
return Text::_('plg_' . strtolower($this->plugin_folder));
case 'component':
return Text::_('com');
case 'module':
return Text::_('mod');
case 'library':
return Text::_('lib');
default:
return $this->extension_type;
}
}
public function getElementName($type = null, $extname = null)
{
$type = is_null($type) ? $this->extension_type : $type;
$extname = is_null($extname) ? $this->extname : $extname;
switch ($type)
{
case 'component' :
return 'com_' . $extname;
case 'module' :
return 'mod_' . $extname;
case 'plugin' :
default:
return $extname;
}
}
public function getFullType()
{
return Text::_('NRI_' . strtoupper($this->getPrefix()));
}
public function isPro()
{
$versionFile = __DIR__ . "/version.php";
// If version file does not exist we assume a PRO version
if (!is_file($versionFile))
{
return true;
}
// Load version file
require_once $versionFile;
return (bool) $NR_PRO;
}
public function getVersion($file = '')
{
$file = $file ?: $this->getCurrentXMLFile();
if (!is_file($file))
{
return '';
}
$xml = Installer::parseXMLInstallFile($file);
if (!$xml || !isset($xml['version']))
{
return '';
}
return $xml['version'];
}
/**
* Checks wether the extension can be installed or not
*
* @return boolean
*/
public function canInstall()
{
// The extension is not installed yet. Accept Install.
if (!$installed_version = $this->getVersion($this->getInstalledXMLFile()))
{
return true;
}
// Path to extension's version file
$versionFile = $this->getMainFolder() . "/version.php";
$NR_PRO = true;
// If version file does not exist we assume we have a PRO version installed
if (file_exists($versionFile))
{
require_once($versionFile);
}
// The free version is installed. Accept install.
if (!(bool)$NR_PRO)
{
return true;
}
// Current package is a PRO version. Accept install.
if ($this->isPro())
{
return true;
}
// User is trying to update from PRO version to FREE. Do not accept install.
Factory::getLanguage()->load($this->getPrefix() . '_' . $this->extname, __DIR__);
Factory::getApplication()->enqueueMessage(
Text::_('NRI_ERROR_PRO_TO_FREE'), 'error'
);
Factory::getApplication()->enqueueMessage(
html_entity_decode(
Text::sprintf(
'NRI_ERROR_UNINSTALL_FIRST',
'<a href="http://www.tassos.gr/joomla-extensions/' . $this->getUrlAlias() . '" target="_blank">',
'</a>',
Text::_($this->name)
)
), 'error'
);
return false;
}
/**
* Returns the URL alias of the extension.
*
* @return string
*/
private function getUrlAlias()
{
$alias = $this->alias;
switch ($alias)
{
case 'smilepack':
$alias = 'smile-pack';
break;
case 'convertforms':
$alias = 'convert-forms';
break;
case 'rstbox':
$alias = 'engagebox';
break;
case 'gsd':
$alias = 'google-structured-data';
break;
}
// ACF
if ($this->plugin_folder === 'fields' && ($alias === 'acf' || $this->startsWith($alias, 'acf')))
{
$alias = 'advanced-custom-fields';
}
return $alias;
}
/**
* Checks whether string starts with substring.
*
* @param string $string
* @param string $query
*
* @return bool
*/
public static function startsWith($string, $query)
{
return substr($string, 0, strlen($query)) === $query;
}
/**
* Checks if current version is newer than the installed one
* Used for Novarain Framework
*
* @return boolean [description]
*/
public function isNewer()
{
if (!$installed_version = $this->getVersion($this->getInstalledXMLFile()))
{
return true;
}
$package_version = $this->getVersion();
return version_compare($installed_version, $package_version, '<=');
}
/**
* Helper method triggered before installation
*
* @return bool
*/
public function onBeforeInstall()
{
if (!$this->canInstall())
{
return false;
}
}
/**
* Helper method triggered after installation
*/
public function onAfterInstall()
{
}
/**
* Delete files
*
* @param array $folders
*/
public function deleteFiles($files = array())
{
foreach ($files as $key => $file)
{
if (!is_file($file))
{
continue;
}
File::delete($file);
}
}
/**
* Deletes folders
*
* @param array $folders
*/
public function deleteFolders($folders = array())
{
foreach ($folders as $folder)
{
if (!is_dir($folder))
{
continue;
}
Folder::delete($folder);
}
}
public function dropIndex($table, $index)
{
$db = $this->db;
// Check if index exists first
$query = 'SHOW INDEX FROM ' . $db->quoteName('#__' . $table) . ' WHERE KEY_NAME = ' . $db->quote($index);
$db->setQuery($query);
$db->execute();
if (!$db->loadResult())
{
return;
}
// Remove index
$query = 'ALTER TABLE ' . $db->quoteName('#__' . $table) . ' DROP INDEX ' . $db->quoteName($index);
$db->setQuery($query);
$db->execute();
}
public function dropUnwantedTables($tables) {
if (!$tables) {
return;
}
foreach ($tables as $table) {
$query = "DROP TABLE IF EXISTS #__".$this->db->escape($table);
$this->db->setQuery($query);
$this->db->execute();
}
}
public function dropUnwantedColumns($table, $columns) {
if (!$columns || !$table) {
return;
}
$db = $this->db;
// Check if columns exists in database
function qt($n) {
return(Factory::getDBO()->quote($n));
}
$query = 'SHOW COLUMNS FROM #__'.$table.' WHERE Field IN ('.implode(",", array_map("qt", $columns)).')';
$db->setQuery($query);
$rows = $db->loadColumn(0);
// Abort if we don't have any rows
if (!$rows) {
return;
}
// Let's remove the columns
$q = "";
foreach ($rows as $key => $column) {
$comma = (($key+1) < count($rows)) ? "," : "";
$q .= "drop ".$this->db->escape($column).$comma;
}
$query = "alter table #__".$table." $q";
$db->setQuery($query);
$db->execute();
}
public function fetch($table, $columns = "*", $where = null, $singlerow = false) {
if (!$table) {
return;
}
$db = $this->db;
$query = $db->getQuery(true);
$query
->select($columns)
->from("#__$table");
if (isset($where)) {
$query->where("$where");
}
$db->setQuery($query);
return ($singlerow) ? $db->loadObject() : $db->loadObjectList();
}
/**
* Load the Novarain Framework
*
* @return boolean
*/
public function loadFramework()
{
if (is_file(JPATH_PLUGINS . '/system/nrframework/autoload.php'))
{
include_once JPATH_PLUGINS . '/system/nrframework/autoload.php';
}
}
/**
* Re-orders plugin after passed array of plugins
*
* @param string $plugin Plugin element name
* @param array $lowerPluginOrder Array of plugin element names
*
* @return boolean
*/
public function pluginOrderAfter($lowerPluginOrder)
{
if (!is_array($lowerPluginOrder) || !count($lowerPluginOrder))
{
return;
}
$db = $this->db;
// Get plugins max order
$query = $db->getQuery(true);
$query
->select($db->quoteName('b.ordering'))
->from($db->quoteName('#__extensions', 'b'))
->where($db->quoteName('b.element') . ' IN ("'.implode("\",\"",$lowerPluginOrder).'")')
->order('b.ordering desc');
$db->setQuery($query);
$maxOrder = $db->loadResult();
if (is_null($maxOrder))
{
return;
}
// Get plugin details
$query
->clear()
->select(array($db->quoteName('extension_id'), $db->quoteName('ordering')))
->from($db->quoteName('#__extensions'))
->where($db->quoteName('element') . ' = ' . $db->quote($this->alias));
$db->setQuery($query);
$pluginInfo = $db->loadObject();
if (!isset($pluginInfo->ordering) || $pluginInfo->ordering > $maxOrder)
{
return;
}
// Update the new plugin order
$object = new stdClass();
$object->extension_id = $pluginInfo->extension_id;
$object->ordering = ($maxOrder + 1);
try {
$db->updateObject('#__extensions', $object, 'extension_id');
} catch (Exception $e) {
return $e->getMessage();
}
}
}

View File

@ -0,0 +1,23 @@
<?php
/**
* @package Advanced Custom Fields
* @version 2.8.8 Pro
*
* @author Tassos Marinos <info@tassos.gr>
* @link http://www.tassos.gr
* @copyright Copyright © 2019 Tassos Marinos All Rights Reserved
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> or later
*/
defined('_JEXEC') or die('Restricted access');
require_once __DIR__ . '/script.install.helper.php';
class PlgFieldsACFChainedFieldsInstallerScript extends PlgFieldsACFChainedFieldsInstallerScriptHelper
{
public $alias = 'acfchainedfields';
public $extension_type = 'plugin';
public $plugin_folder = "fields";
public $show_message = false;
}

View File

@ -0,0 +1,78 @@
<?php
/**
* @package Advanced Custom Fields
* @version 2.8.8 Pro
*
* @author Tassos Marinos <info@tassos.gr>
* @link http://www.tassos.gr
* @copyright Copyright © 2019 Tassos Marinos All Rights Reserved
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> or later
*/
defined('_JEXEC') or die;
if (!$value = $field->value)
{
return;
}
$value = array_values($value);
$layout = $fieldParams->get('layout', 'default');
// Default layout
if ($layout === 'default')
{
?><div class="acf-chained-fields"><?php
foreach ($value as $key => $_value)
{
if (!$_value)
{
continue;
}
$label = isset($field->choices['inputs'][$key]) ? $field->choices['inputs'][$key]['label'] : '';
?>
<div class="item">
<strong><?php echo $label; ?></strong>: <?php echo $_value; ?>
</div>
<?php
}
?>
</div>
<?php
}
// Custom Layout
else
{
if (!$layout = $fieldParams->get('custom_layout', null))
{
return;
}
// Make index start from 1
array_unshift($value, '');
unset($value[0]);
// Create Smart Tags instance
$st = new \NRFramework\SmartTags();
$values = [];
$labels = [];
foreach ($value as $key => $_value)
{
$label_value = isset($field->choices['inputs'][$key - 1]) ? $field->choices['inputs'][$key - 1]['label'] : '';
$labels[$key . '.label'] = $label_value;
$values[$key . '.value'] = $_value;
}
$st->add($labels, 'field.');
// Add values to Smart Tags
$st->add($values, 'field.');
// Replace Smart Tags
echo $st->replace($layout);
}

View File

@ -0,0 +1,16 @@
<?php
/**
* @package Advanced Custom Fields
* @version 2.8.8 Pro
*
* @author Tassos Marinos <info@tassos.gr>
* @link http://www.tassos.gr
* @copyright Copyright © 2018 Tassos Marinos All Rights Reserved
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html> or later
*/
defined('_JEXEC') or die('Restricted Access');
$NR_PRO = "1";
?>