acf
This commit is contained in:
		| @ -0,0 +1,48 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Controller; | ||||
|  | ||||
| \defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\Language\Text; | ||||
| use Joomla\CMS\MVC\Controller\BaseController; | ||||
| use Joomla\CMS\Router\Route; | ||||
|  | ||||
| /** | ||||
|  * Highlights master display controller. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class DisplayController extends BaseController | ||||
| { | ||||
| 	/** | ||||
| 	 * The default view. | ||||
| 	 * | ||||
| 	 * @var    string | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $default_view = 'highlights'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to display a view. | ||||
| 	 * | ||||
| 	 * @param   boolean  $cachable   If true, the view output will be cached | ||||
| 	 * @param   array    $urlparams  An array of safe URL parameters and their variable types, for valid values see {@link InputFilter::clean()}. | ||||
| 	 * | ||||
| 	 * @return  BaseController|boolean  This object to support chaining. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function display($cachable = false, $urlparams = array()) | ||||
| 	{ | ||||
| 		return parent::display(); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,24 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Controller; | ||||
|  | ||||
| \defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\MVC\Controller\FormController; | ||||
|  | ||||
| /** | ||||
|  * Etichetta controller class. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class EtichettaController extends FormController | ||||
| { | ||||
| 	protected $view_list = 'etichette'; | ||||
| } | ||||
| @ -0,0 +1,116 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Controller; | ||||
|  | ||||
| \defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\Application\SiteApplication; | ||||
| use Joomla\CMS\Factory; | ||||
| use Joomla\CMS\Language\Multilanguage; | ||||
| use Joomla\CMS\Language\Text; | ||||
| use Joomla\CMS\MVC\Controller\AdminController; | ||||
| use Joomla\CMS\Router\Route; | ||||
| use Joomla\CMS\Uri\Uri; | ||||
| use Joomla\Utilities\ArrayHelper; | ||||
|  | ||||
| /** | ||||
|  * Etichette list controller class. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class EtichetteController extends AdminController | ||||
| { | ||||
| 	/** | ||||
| 	 * Method to clone existing Etichette | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @throws  Exception | ||||
| 	 */ | ||||
| 	public function duplicate() | ||||
| 	{ | ||||
| 		// Check for request forgeries | ||||
| 		$this->checkToken(); | ||||
|  | ||||
| 		// Get id(s) | ||||
| 		$pks = $this->input->post->get('cid', array(), 'array'); | ||||
|  | ||||
| 		try | ||||
| 		{ | ||||
| 			if (empty($pks)) | ||||
| 			{ | ||||
| 				throw new \Exception(Text::_('COM_HIGHLIGHTS_NO_ELEMENT_SELECTED')); | ||||
| 			} | ||||
|  | ||||
| 			ArrayHelper::toInteger($pks); | ||||
| 			$model = $this->getModel(); | ||||
| 			$model->duplicate($pks); | ||||
| 			$this->setMessage(Text::_('COM_HIGHLIGHTS_ITEMS_SUCCESS_DUPLICATED')); | ||||
| 		} | ||||
| 		catch (\Exception $e) | ||||
| 		{ | ||||
| 			Factory::getApplication()->enqueueMessage($e->getMessage(), 'warning'); | ||||
| 		} | ||||
|  | ||||
| 		$this->setRedirect('index.php?option=com_highlights&view=etichette'); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Proxy for getModel. | ||||
| 	 * | ||||
| 	 * @param   string  $name    Optional. Model name | ||||
| 	 * @param   string  $prefix  Optional. Class prefix | ||||
| 	 * @param   array   $config  Optional. Configuration array for model | ||||
| 	 * | ||||
| 	 * @return  object	The Model | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getModel($name = 'Etichetta', $prefix = 'Administrator', $config = array()) | ||||
| 	{ | ||||
| 		return parent::getModel($name, $prefix, array('ignore_request' => true)); | ||||
| 	} | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to save the submitted ordering values for records via AJAX. | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 * | ||||
| 	 * @throws  Exception | ||||
| 	 */ | ||||
| 	public function saveOrderAjax() | ||||
| 	{ | ||||
| 		// Get the input | ||||
| 		$pks   = $this->input->post->get('cid', array(), 'array'); | ||||
| 		$order = $this->input->post->get('order', array(), 'array'); | ||||
|  | ||||
| 		// Sanitize the input | ||||
| 		ArrayHelper::toInteger($pks); | ||||
| 		ArrayHelper::toInteger($order); | ||||
|  | ||||
| 		// Get the model | ||||
| 		$model = $this->getModel(); | ||||
|  | ||||
| 		// Save the ordering | ||||
| 		$return = $model->saveorder($pks, $order); | ||||
|  | ||||
| 		if ($return) | ||||
| 		{ | ||||
| 			echo "1"; | ||||
| 		} | ||||
|  | ||||
| 		// Close the application | ||||
| 		Factory::getApplication()->close(); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,24 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Controller; | ||||
|  | ||||
| \defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\MVC\Controller\FormController; | ||||
|  | ||||
| /** | ||||
|  * Highlight controller class. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HighlightController extends FormController | ||||
| { | ||||
| 	protected $view_list = 'highlights'; | ||||
| } | ||||
| @ -0,0 +1,116 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Controller; | ||||
|  | ||||
| \defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\Application\SiteApplication; | ||||
| use Joomla\CMS\Factory; | ||||
| use Joomla\CMS\Language\Multilanguage; | ||||
| use Joomla\CMS\Language\Text; | ||||
| use Joomla\CMS\MVC\Controller\AdminController; | ||||
| use Joomla\CMS\Router\Route; | ||||
| use Joomla\CMS\Uri\Uri; | ||||
| use Joomla\Utilities\ArrayHelper; | ||||
|  | ||||
| /** | ||||
|  * Highlights list controller class. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HighlightsController extends AdminController | ||||
| { | ||||
| 	/** | ||||
| 	 * Method to clone existing Highlights | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @throws  Exception | ||||
| 	 */ | ||||
| 	public function duplicate() | ||||
| 	{ | ||||
| 		// Check for request forgeries | ||||
| 		$this->checkToken(); | ||||
|  | ||||
| 		// Get id(s) | ||||
| 		$pks = $this->input->post->get('cid', array(), 'array'); | ||||
|  | ||||
| 		try | ||||
| 		{ | ||||
| 			if (empty($pks)) | ||||
| 			{ | ||||
| 				throw new \Exception(Text::_('COM_HIGHLIGHTS_NO_ELEMENT_SELECTED')); | ||||
| 			} | ||||
|  | ||||
| 			ArrayHelper::toInteger($pks); | ||||
| 			$model = $this->getModel(); | ||||
| 			$model->duplicate($pks); | ||||
| 			$this->setMessage(Text::_('COM_HIGHLIGHTS_ITEMS_SUCCESS_DUPLICATED')); | ||||
| 		} | ||||
| 		catch (\Exception $e) | ||||
| 		{ | ||||
| 			Factory::getApplication()->enqueueMessage($e->getMessage(), 'warning'); | ||||
| 		} | ||||
|  | ||||
| 		$this->setRedirect('index.php?option=com_highlights&view=highlights'); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Proxy for getModel. | ||||
| 	 * | ||||
| 	 * @param   string  $name    Optional. Model name | ||||
| 	 * @param   string  $prefix  Optional. Class prefix | ||||
| 	 * @param   array   $config  Optional. Configuration array for model | ||||
| 	 * | ||||
| 	 * @return  object	The Model | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getModel($name = 'Highlight', $prefix = 'Administrator', $config = array()) | ||||
| 	{ | ||||
| 		return parent::getModel($name, $prefix, array('ignore_request' => true)); | ||||
| 	} | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to save the submitted ordering values for records via AJAX. | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 * | ||||
| 	 * @throws  Exception | ||||
| 	 */ | ||||
| 	public function saveOrderAjax() | ||||
| 	{ | ||||
| 		// Get the input | ||||
| 		$pks   = $this->input->post->get('cid', array(), 'array'); | ||||
| 		$order = $this->input->post->get('order', array(), 'array'); | ||||
|  | ||||
| 		// Sanitize the input | ||||
| 		ArrayHelper::toInteger($pks); | ||||
| 		ArrayHelper::toInteger($order); | ||||
|  | ||||
| 		// Get the model | ||||
| 		$model = $this->getModel(); | ||||
|  | ||||
| 		// Save the ordering | ||||
| 		$return = $model->saveorder($pks, $order); | ||||
|  | ||||
| 		if ($return) | ||||
| 		{ | ||||
| 			echo "1"; | ||||
| 		} | ||||
|  | ||||
| 		// Close the application | ||||
| 		Factory::getApplication()->close(); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,77 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Extension; | ||||
|  | ||||
| defined('JPATH_PLATFORM') or die; | ||||
|  | ||||
| use Pcrt\Component\Highlights\Administrator\Service\Html\HIGHLIGHTS; | ||||
| use Joomla\CMS\Application\SiteApplication; | ||||
| use Joomla\CMS\Association\AssociationServiceInterface; | ||||
| use Joomla\CMS\Association\AssociationServiceTrait; | ||||
| use Joomla\CMS\Categories\CategoryServiceTrait; | ||||
| use Joomla\CMS\Component\Router\RouterServiceInterface; | ||||
| use Joomla\CMS\Component\Router\RouterServiceTrait; | ||||
| use Joomla\CMS\Extension\BootableExtensionInterface; | ||||
| use Joomla\CMS\Extension\MVCComponent; | ||||
| use Joomla\CMS\HTML\HTMLRegistryAwareTrait; | ||||
| use Joomla\CMS\Tag\TagServiceTrait; | ||||
| use Psr\Container\ContainerInterface; | ||||
| use Joomla\CMS\Categories\CategoryServiceInterface; | ||||
|  | ||||
| /** | ||||
|  * Component class for Highlights | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HighlightsComponent extends MVCComponent implements RouterServiceInterface, BootableExtensionInterface, CategoryServiceInterface | ||||
| { | ||||
| 	use AssociationServiceTrait; | ||||
| 	use RouterServiceTrait; | ||||
| 	use HTMLRegistryAwareTrait; | ||||
| 	use CategoryServiceTrait, TagServiceTrait { | ||||
| 		CategoryServiceTrait::getTableNameForSection insteadof TagServiceTrait; | ||||
| 		CategoryServiceTrait::getStateColumnForSection insteadof TagServiceTrait; | ||||
| 	} | ||||
|  | ||||
| 	/** @inheritdoc  */ | ||||
| 	public function boot(ContainerInterface $container) | ||||
| 	{ | ||||
| 		$db = $container->get('DatabaseDriver'); | ||||
| 		$this->getRegistry()->register('highlights', new HIGHLIGHTS($db)); | ||||
| 	} | ||||
|  | ||||
| 	 | ||||
| /** | ||||
|  * Returns the table for the count items functions for the given section. | ||||
| 	 * | ||||
| 	 * @param   string    The section | ||||
| 	 * | ||||
| 	 * * @return  string|null | ||||
| 	 * | ||||
| 	 * @since   4.0.0 | ||||
| 	 */ | ||||
| 	    protected function getTableNameForSection(string $section = null)             | ||||
| 	{ | ||||
| 	} | ||||
| 	 | ||||
| 	/** | ||||
|      * Adds Count Items for Category Manager. | ||||
|      * | ||||
|      * @param   \stdClass[]  $items    The category objects | ||||
|      * @param   string       $section  The section | ||||
|      * | ||||
|      * @return  void | ||||
|      * | ||||
|      * @since   4.0.0 | ||||
|      */ | ||||
|     public function countItems(array $items, string $section) | ||||
|     { | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,67 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Field; | ||||
|  | ||||
| defined('JPATH_BASE') or die; | ||||
|  | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Form\FormField; | ||||
| use \Joomla\CMS\User\UserFactoryInterface; | ||||
|  | ||||
| /** | ||||
|  * Supports an HTML select list of categories | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class CreatedbyField extends FormField | ||||
| { | ||||
| 	/** | ||||
| 	 * The form field type. | ||||
| 	 * | ||||
| 	 * @var    tring | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $type = 'createdby'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field input markup. | ||||
| 	 * | ||||
| 	 * @return  string    The field input markup. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getInput() | ||||
| 	{ | ||||
| 		// Initialize variables. | ||||
| 		$html = array(); | ||||
|  | ||||
| 		// Load user | ||||
| 		$user_id = $this->value; | ||||
|  | ||||
| 		if ($user_id) | ||||
| 		{ | ||||
| 			$container = \Joomla\CMS\Factory::getContainer(); | ||||
|             $userFactory = $container->get(UserFactoryInterface::class); | ||||
|             $user = $userFactory->loadUserById($user_id); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$user = Factory::getApplication()->getIdentity(); | ||||
| 			$html[] = '<input type="hidden" name="' . $this->name . '" value="' . $user->id . '" />'; | ||||
| 		} | ||||
|  | ||||
| 		if (!$this->hidden) | ||||
| 		{ | ||||
| 			$html[] = "<div>" . $user->name . " (" . $user->username . ")</div>"; | ||||
| 		} | ||||
|  | ||||
| 		return implode($html); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,297 @@ | ||||
| <?php | ||||
|  | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Field; | ||||
|  | ||||
| defined('JPATH_BASE') or die; | ||||
|  | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\HTML\HTMLHelper; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Form\Field\ListField; | ||||
|  | ||||
| /** | ||||
|  * Supports a value from an external table | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| #[\AllowDynamicProperties] | ||||
|  class ForeignKeyField extends ListField | ||||
| { | ||||
| 	/** | ||||
| 	 * The form field type. | ||||
| 	 * | ||||
| 	 * @var    string | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $type = 'foreignkey'; | ||||
|  | ||||
| 	protected $layout = 'joomla.form.field.list-fancy-select'; | ||||
|  | ||||
| 	/** | ||||
| 	 * The translate. | ||||
| 	 * | ||||
| 	 * @var    boolean | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $translate = true; | ||||
|  | ||||
| 	protected $header = false; | ||||
|  | ||||
| 	private $input_type; | ||||
|  | ||||
| 	private $table; | ||||
|  | ||||
| 	private $key_field; | ||||
|  | ||||
| 	private $value_field; | ||||
|  | ||||
| 	private $option_key_field; | ||||
|  | ||||
| 	private $option_value_field; | ||||
|  | ||||
| 	private $condition; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field input markup. | ||||
| 	 * | ||||
| 	 * @return  string  The field input markup. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function processQuery() | ||||
| 	{ | ||||
| 		// Type of input the field shows | ||||
| 		$this->input_type = $this->getAttribute('input_type'); | ||||
|  | ||||
| 		// Database Table | ||||
| 		$this->table = $this->getAttribute('table'); | ||||
|  | ||||
| 		// The field that the field will save on the database | ||||
| 		$this->key_field = (string) $this->getAttribute('key_field'); | ||||
|  | ||||
| 		// The column that the field shows in the input | ||||
| 		$this->value_field = (string) $this->getAttribute('value_field'); | ||||
|  | ||||
| 		// The option field that the field will save on the database | ||||
| 		$this->option_key_field = (string) $this->getAttribute('option_key_field'); | ||||
|  | ||||
| 		// The option value that the field shows in the input | ||||
| 		$this->option_value_field = (string) $this->getAttribute('option_value_field'); | ||||
|  | ||||
| 		// Flag to identify if the fk_value is multiple | ||||
| 		$this->value_multiple = (int) $this->getAttribute('value_multiple', 0); | ||||
|  | ||||
| 		$this->required = (string) $this->getAttribute('required', 0); | ||||
|  | ||||
| 		// Flag to identify if the fk_value hides the trashed items | ||||
| 		$this->hideTrashed = (int) $this->getAttribute('hide_trashed', 0); | ||||
| 		 | ||||
| 		// Flag to identify if the fk_value hides the unpublished items	 | ||||
| 		$this->hideUnpublished = (int) $this->getAttribute('hide_unpublished', 0); | ||||
|  | ||||
| 		// Flag to identify if the fk_value hides the published items | ||||
| 		$this->hidePublished = (int) $this->getAttribute('hide_published', 0); | ||||
|  | ||||
| 		// Flag to identify if the fk_value hides the archived items | ||||
| 		$this->hideArchived = (int) $this->getAttribute('hide_archived', 0); | ||||
|  | ||||
| 		// Flag to identify if the fk has default order | ||||
| 		$this->fk_ordering = (string) $this->getAttribute('fk_ordering'); | ||||
|  | ||||
| 		// The where SQL for foreignkey | ||||
| 		$this->condition = (string) $this->getAttribute('condition'); | ||||
|  | ||||
| 		// Flag for translate options | ||||
| 		$this->translate = (bool) $this->getAttribute('translate'); | ||||
|  | ||||
| 		// Initialize variables. | ||||
| 		$html     = ''; | ||||
| 		$fk_value = ''; | ||||
|  | ||||
| 		// Load all the field options | ||||
| 		$db    = Factory::getContainer()->get('DatabaseDriver'); | ||||
| 		$query = $db->getQuery(true); | ||||
|  | ||||
| 		// Support for multiple fields on fk_values | ||||
| 		if ($this->value_multiple == 1) | ||||
| 		{ | ||||
| 			// Get the fields for multiple value | ||||
| 			$this->value_fields = (string) $this->getAttribute('value_field_multiple'); | ||||
| 			$this->value_fields = explode(',', $this->value_fields); | ||||
| 			$this->separator    = (string) $this->getAttribute('separator'); | ||||
|  | ||||
| 			$fk_value = ' CONCAT('; | ||||
|  | ||||
| 			foreach ($this->value_fields as $field) | ||||
| 			{ | ||||
| 				$fk_value .= $db->quoteName($field) . ', \'' . $this->separator . '\', '; | ||||
| 			} | ||||
| 			 | ||||
| 			$fk_value = substr($fk_value, 0, -(strlen($this->separator) + 6)); | ||||
| 			$fk_value .= ') AS ' . $db->quoteName($this->value_field); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$fk_value = $db->quoteName($this->value_field); | ||||
| 		} | ||||
|  | ||||
| 		$query | ||||
| 			->select( | ||||
| 				array( | ||||
| 					$db->quoteName($this->key_field), | ||||
| 					$fk_value | ||||
| 				) | ||||
| 			) | ||||
| 			->from($this->table); | ||||
|  | ||||
| 		if ($this->hideTrashed) | ||||
| 		{ | ||||
| 			$query->where($db->quoteName('state') . ' != -2'); | ||||
| 		} | ||||
|  | ||||
| 		if ($this->hideUnpublished) | ||||
| 		{ | ||||
| 			$query->where($db->quoteName('state') . ' != 0'); | ||||
| 		} | ||||
|  | ||||
| 		if ($this->hidePublished) | ||||
| 		{ | ||||
| 			$query->where($db->quoteName('state') . ' != 1'); | ||||
| 		} | ||||
|  | ||||
| 		if ($this->hideArchived) | ||||
| 		{ | ||||
| 			$query->where($db->quoteName('state') . ' != 2'); | ||||
| 		} | ||||
|  | ||||
| 		if ($this->fk_ordering) | ||||
| 		{ | ||||
| 			$query->order($this->fk_ordering); | ||||
| 		} | ||||
|  | ||||
| 		if($this->condition) | ||||
| 		{ | ||||
| 			$query->where($this->condition); | ||||
| 		} | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		return $query; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field input for a foreignkey field. | ||||
| 	 * | ||||
| 	 * @return  string  The field input. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getInput() | ||||
| 	{ | ||||
| 		$data = $this->getLayoutData(); | ||||
|  | ||||
| 		if (!\is_array($this->value) && !empty($this->value)) | ||||
| 		{ | ||||
| 			if (\is_object($this->value)) | ||||
| 			{ | ||||
| 				$this->value = get_object_vars($this->value); | ||||
| 			} | ||||
|  | ||||
| 			// String in format 2,5,4 | ||||
| 			if (\is_string($this->value)) | ||||
| 			{ | ||||
| 				$this->value = explode(',', $this->value); | ||||
| 			} | ||||
|  | ||||
| 			// Integer is given | ||||
| 			if (\is_int($this->value)) | ||||
| 			{ | ||||
| 				$this->value = array($this->value); | ||||
| 			} | ||||
|  | ||||
| 			$data['value'] = $this->value; | ||||
| 		} | ||||
|  | ||||
| 		$data['options']       = $this->getOptions(); | ||||
|  | ||||
| 		return $this->getRenderer($this->layout)->render($data); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field options. | ||||
| 	 * | ||||
| 	 * @return  array  The field option objects. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getOptions() | ||||
| 	{ | ||||
| 		$options = array(); | ||||
| 		$db    = Factory::getContainer()->get('DatabaseDriver'); | ||||
| 		try | ||||
| 		{ | ||||
| 			$db->setQuery($this->processQuery()); | ||||
| 			$results = $db->loadObjectList(); | ||||
| 		} | ||||
| 		catch (ExecutionFailureException $e) | ||||
| 		{ | ||||
| 			Factory::getApplication()->enqueueMessage(Text::_('JERROR_AN_ERROR_HAS_OCCURRED'), 'error'); | ||||
| 		} | ||||
|  | ||||
| 		// Add header. | ||||
| 		if (!empty($this->header)) | ||||
| 		{ | ||||
| 			$options[] = (object) ["value" => '', "text" => Text::_($this->header)]; | ||||
| 		} | ||||
|  | ||||
| 		if(!empty($this->option_value_field) || !empty($this->option_key_field)) | ||||
| 		{ | ||||
| 			$options[] = (object) ["value" => $this->option_key_field, "text" => Text::_($this->option_value_field)]; | ||||
| 		} | ||||
|  | ||||
| 		// Build the field options. | ||||
| 		if (!empty($results)) | ||||
| 		{ | ||||
| 			foreach ($results as $item) | ||||
| 			{ | ||||
| 				$options[] = (object) [ | ||||
| 									"value"     => $item->{$this->key_field}, | ||||
| 									"text"      => $this->translate == true ? Text::_($item->{$this->value_field}) : $item->{$this->value_field} | ||||
| 									]; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// Merge any additional options in the XML definition. | ||||
| 		$options = array_merge(parent::getOptions(), $options); | ||||
|  | ||||
| 		return $options; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Wrapper method for getting attributes from the form element | ||||
| 	 * | ||||
| 	 * @param   string  $attr_name  Attribute name | ||||
| 	 * @param   mixed   $default    Optional value to return if attribute not found | ||||
| 	 * | ||||
| 	 * @return  mixed The value of the attribute if it exists, null otherwise | ||||
| 	 */ | ||||
| 	public function getAttribute($attr_name, $default = null) | ||||
| 	{ | ||||
| 		if (!empty($this->element[$attr_name])) | ||||
| 		{ | ||||
| 			return $this->element[$attr_name]; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			return $default; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,52 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Field; | ||||
|  | ||||
| defined('JPATH_BASE') or die; | ||||
|  | ||||
| use \Joomla\CMS\Form\FormField; | ||||
| use \Joomla\CMS\Factory; | ||||
|  | ||||
| /** | ||||
|  * Supports an HTML select list of categories | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class ModifiedbyField extends \Joomla\CMS\Form\FormField | ||||
| { | ||||
| 	/** | ||||
| 	 * The form field type. | ||||
| 	 * | ||||
| 	 * @var    string | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $type = 'modifiedby'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field input markup. | ||||
| 	 * | ||||
| 	 * @return  string    The field input markup. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getInput() | ||||
| 	{ | ||||
| 		// Initialize variables. | ||||
| 		$html   = array(); | ||||
| 		$user = Factory::getApplication()->getIdentity(); | ||||
| 		$html[] = '<input type="hidden" name="' . $this->name . '" value="' . $user->id . '" />'; | ||||
| 		if (!$this->hidden) | ||||
| 		{ | ||||
| 			$html[] = "<div>" . $user->name . " (" . $user->username . ")</div>"; | ||||
| 		} | ||||
|  | ||||
| 		return implode($html); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,83 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Field; | ||||
|  | ||||
| defined('JPATH_BASE') or die; | ||||
|  | ||||
| use Joomla\CMS\Helper\UserGroupsHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use Joomla\CMS\Form\Field\ListField; | ||||
|  | ||||
| /** | ||||
|  * Supports an HTML select list of categories | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class NestedparentField extends ListField | ||||
| { | ||||
| 	/** | ||||
| 	 * The form field type. | ||||
| 	 * | ||||
| 	 * @var    string | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $type = 'nestedparent'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field options. | ||||
| 	 * | ||||
| 	 * @return  array  The field option objects. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getOptions() | ||||
| 	{ | ||||
| 		$options = array(); | ||||
| 		$table   = $this->getAttribute('table'); | ||||
|  | ||||
| 		$db = Factory::getContainer()->get('DatabaseDriver'); | ||||
| 		$query = $db->getQuery(true) | ||||
| 			->select('DISTINCT(a.id) AS value, a.title AS text, a.level, a.lft') | ||||
| 			->from($table . ' AS a'); | ||||
|  | ||||
|  | ||||
| 		// Prevent parenting to children of this item. | ||||
| 		if ($id = $this->form->getValue('id')) | ||||
| 		{ | ||||
| 			$query->join('LEFT', $db->quoteName($table) . ' AS p ON p.id = ' . (int) $id) | ||||
| 				->where('NOT(a.lft >= p.lft AND a.rgt <= p.rgt)'); | ||||
| 		} | ||||
|  | ||||
| 		$query->order('a.lft ASC'); | ||||
|  | ||||
| 		// Get the options. | ||||
| 		$db->setQuery($query); | ||||
|  | ||||
| 		try | ||||
| 		{ | ||||
| 			$options = $db->loadObjectList(); | ||||
| 		} | ||||
| 		catch (\RuntimeException $e) | ||||
| 		{ | ||||
| 			throw new \Exception($e->getMessage(), 500); | ||||
| 		} | ||||
|  | ||||
| 		// Pad the option text with spaces using depth level as a multiplier. | ||||
| 		for ($i = 0, $n = count($options); $i < $n; $i++) | ||||
| 		{ | ||||
| 				$options[$i]->text = str_repeat('- ', $options[$i]->level) . $options[$i]->text; | ||||
| 		} | ||||
|  | ||||
| 		// Merge any additional options in the XML definition. | ||||
| 		$options = array_merge(parent::getOptions(), $options); | ||||
|  | ||||
| 		return $options; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,65 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Field; | ||||
|  | ||||
| defined('JPATH_BASE') or die; | ||||
|  | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Form\FormField; | ||||
| use \Joomla\CMS\Date\Date; | ||||
|  | ||||
| /** | ||||
|  * Supports an HTML select list of categories | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class TimecreatedField extends FormField | ||||
| { | ||||
| 	/** | ||||
| 	 * The form field type. | ||||
| 	 * | ||||
| 	 * @var    string | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $type = 'timecreated'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field input markup. | ||||
| 	 * | ||||
| 	 * @return  string    The field input markup. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getInput() | ||||
| 	{ | ||||
| 		// Initialize variables. | ||||
| 		$html = array(); | ||||
|  | ||||
| 		$time_created = $this->value; | ||||
|  | ||||
| 		if (!strtotime($time_created)) | ||||
| 		{ | ||||
| 			$time_created = Factory::getDate('now', Factory::getConfig()->get('offset'))->toSql(true); | ||||
| 			$html[]       = '<input type="hidden" name="' . $this->name . '" value="' . $time_created . '" />'; | ||||
| 		} | ||||
|  | ||||
| 		$hidden = (boolean) $this->element['hidden']; | ||||
|  | ||||
| 		if ($hidden == null || !$hidden) | ||||
| 		{ | ||||
| 			$jdate       = new Date($time_created); | ||||
| 			$pretty_date = $jdate->format(Text::_('DATE_FORMAT_LC2')); | ||||
| 			$html[]      = "<div>" . $pretty_date . "</div>"; | ||||
| 		} | ||||
|  | ||||
| 		return implode($html); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,68 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Field; | ||||
|  | ||||
| defined('JPATH_BASE') or die; | ||||
|  | ||||
| use \Joomla\CMS\Form\FormField; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Date\Date; | ||||
|  | ||||
| /** | ||||
|  * Supports an HTML select list of categories | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class TimeupdatedField extends FormField | ||||
| { | ||||
| 	/** | ||||
| 	 * The form field type. | ||||
| 	 * | ||||
| 	 * @var    string | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $type = 'timeupdated'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the field input markup. | ||||
| 	 * | ||||
| 	 * @return  string    The field input markup. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getInput() | ||||
| 	{ | ||||
| 		// Initialize variables. | ||||
| 		$html = array(); | ||||
|  | ||||
| 		$old_time_updated = $this->value; | ||||
| 		$hidden           = (boolean) $this->element['hidden']; | ||||
|  | ||||
| 		if ($hidden == null || !$hidden) | ||||
| 		{ | ||||
| 			if (!strtotime($old_time_updated)) | ||||
| 			{ | ||||
| 				$html[] = '-'; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$jdate       = new Date($old_time_updated); | ||||
| 				$pretty_date = $jdate->format(Text::_('DATE_FORMAT_LC2')); | ||||
| 				$html[]      = "<div>" . $pretty_date . "</div>"; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$time_updated = Factory::getDate('now', Factory::getConfig()->get('offset'))->toSql(true); | ||||
| 		$html[]       = '<input type="hidden" name="' . $this->name . '" value="' . $time_updated . '" />'; | ||||
|  | ||||
| 		return implode($html); | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1 @@ | ||||
| <html><body></body></html> | ||||
| @ -0,0 +1,77 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Helper; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Object\CMSObject; | ||||
|  | ||||
| /** | ||||
|  * Highlights helper. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HighlightsHelper | ||||
| { | ||||
| 	/** | ||||
| 	 * Gets the files attached to an item | ||||
| 	 * | ||||
| 	 * @param   int     $pk     The item's id | ||||
| 	 * | ||||
| 	 * @param   string  $table  The table's name | ||||
| 	 * | ||||
| 	 * @param   string  $field  The field's name | ||||
| 	 * | ||||
| 	 * @return  array  The files | ||||
| 	 */ | ||||
| 	public static function getFiles($pk, $table, $field) | ||||
| 	{ | ||||
| 		$db = Factory::getContainer()->get('DatabaseDriver'); | ||||
| 		$query = $db->getQuery(true); | ||||
|  | ||||
| 		$query | ||||
| 			->select($field) | ||||
| 			->from($table) | ||||
| 			->where('id = ' . (int) $pk); | ||||
|  | ||||
| 		$db->setQuery($query); | ||||
|  | ||||
| 		return explode(',', $db->loadResult()); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Gets a list of the actions that can be performed. | ||||
| 	 * | ||||
| 	 * @return  CMSObject | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public static function getActions() | ||||
| 	{ | ||||
| 		$user = Factory::getApplication()->getIdentity(); | ||||
| 		$result = new CMSObject; | ||||
|  | ||||
| 		$assetName = 'com_highlights'; | ||||
|  | ||||
| 		$actions = array( | ||||
| 			'core.admin', 'core.manage', 'core.create', 'core.edit', 'core.edit.own', 'core.edit.state', 'core.delete' | ||||
| 		); | ||||
|  | ||||
| 		foreach ($actions as $action) | ||||
| 		{ | ||||
| 			$result->set($action, $user->authorise($action, $assetName)); | ||||
| 		} | ||||
|  | ||||
| 		return $result; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -0,0 +1,277 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Model; | ||||
| // No direct access. | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\Table\Table; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Plugin\PluginHelper; | ||||
| use \Joomla\CMS\MVC\Model\AdminModel; | ||||
| use \Joomla\CMS\Helper\TagsHelper; | ||||
| use \Joomla\CMS\Filter\OutputFilter; | ||||
| use \Joomla\CMS\Event\Model; | ||||
| use Joomla\CMS\Event\AbstractEvent; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Etichetta model. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class EtichettaModel extends AdminModel | ||||
| { | ||||
| 	/** | ||||
| 	 * @var    string  The prefix to use with controller messages. | ||||
| 	 * | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $text_prefix = 'COM_HIGHLIGHTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * @var    string  Alias to manage history control | ||||
| 	 * | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	public $typeAlias = 'com_highlights.etichetta'; | ||||
|  | ||||
| 	/** | ||||
| 	 * @var    null  Item data | ||||
| 	 * | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $item = null; | ||||
|  | ||||
| 	 | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns a reference to the a Table object, always creating it. | ||||
| 	 * | ||||
| 	 * @param   string  $type    The table type to instantiate | ||||
| 	 * @param   string  $prefix  A prefix for the table class name. Optional. | ||||
| 	 * @param   array   $config  Configuration array for model. Optional. | ||||
| 	 * | ||||
| 	 * @return  Table    A database object | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getTable($type = 'Etichetta', $prefix = 'Administrator', $config = array()) | ||||
| 	{ | ||||
| 		return parent::getTable($type, $prefix, $config); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the record form. | ||||
| 	 * | ||||
| 	 * @param   array    $data      An optional array of data for the form to interogate. | ||||
| 	 * @param   boolean  $loadData  True if the form is to load its own data (default case), false if not. | ||||
| 	 * | ||||
| 	 * @return  \JForm|boolean  A \JForm object on success, false on failure | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getForm($data = array(), $loadData = true) | ||||
| 	{ | ||||
| 		// Initialise variables. | ||||
| 		$app = Factory::getApplication(); | ||||
|  | ||||
| 		// Get the form. | ||||
| 		$form = $this->loadForm( | ||||
| 								'com_highlights.etichetta',  | ||||
| 								'etichetta', | ||||
| 								array( | ||||
| 									'control' => 'jform', | ||||
| 									'load_data' => $loadData  | ||||
| 								) | ||||
| 							); | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		if (empty($form)) | ||||
| 		{ | ||||
| 			return false; | ||||
| 		} | ||||
|  | ||||
| 		return $form; | ||||
| 	} | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the data that should be injected in the form. | ||||
| 	 * | ||||
| 	 * @return  mixed  The data for the form. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function loadFormData() | ||||
| 	{ | ||||
| 		// Check the session for previously entered form data. | ||||
| 		$data = Factory::getApplication()->getUserState('com_highlights.edit.etichetta.data', array()); | ||||
|  | ||||
| 		if (empty($data)) | ||||
| 		{ | ||||
| 			if ($this->item === null) | ||||
| 			{ | ||||
| 				$this->item = $this->getItem(); | ||||
| 			} | ||||
|  | ||||
| 			$data = $this->item; | ||||
| 			 | ||||
| 		} | ||||
|  | ||||
| 		return $data; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get a single record. | ||||
| 	 * | ||||
| 	 * @param   integer  $pk  The id of the primary key. | ||||
| 	 * | ||||
| 	 * @return  mixed    Object on success, false on failure. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getItem($pk = null) | ||||
| 	{ | ||||
| 		 | ||||
| 			if ($item = parent::getItem($pk)) | ||||
| 			{ | ||||
| 				if (isset($item->params)) | ||||
| 				{ | ||||
| 					$item->params = json_encode($item->params); | ||||
| 				} | ||||
| 				 | ||||
| 				// Do any procesing on fields here if needed | ||||
| 			} | ||||
|  | ||||
| 			return $item; | ||||
| 		 | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to duplicate an Etichetta | ||||
| 	 * | ||||
| 	 * @param   array  &$pks  An array of primary key IDs. | ||||
| 	 * | ||||
| 	 * @return  boolean  True if successful. | ||||
| 	 * | ||||
| 	 * @throws  Exception | ||||
| 	 */ | ||||
| 	public function duplicate(&$pks) | ||||
| 	{ | ||||
| 		$app = Factory::getApplication(); | ||||
| 		$user = $app->getIdentity(); | ||||
|         $dispatcher = $this->getDispatcher(); | ||||
|  | ||||
| 		// Access checks. | ||||
| 		if (!$user->authorise('core.create', 'com_highlights')) | ||||
| 		{ | ||||
| 			throw new \Exception(Text::_('JERROR_CORE_CREATE_NOT_PERMITTED')); | ||||
| 		} | ||||
|  | ||||
| 		$context    = $this->option . '.' . $this->name; | ||||
|  | ||||
| 		// Include the plugins for the save events. | ||||
| 		PluginHelper::importPlugin($this->events_map['save']); | ||||
|  | ||||
| 		$table = $this->getTable(); | ||||
|  | ||||
| 		foreach ($pks as $pk) | ||||
| 		{ | ||||
| 			 | ||||
| 				if ($table->load($pk, true)) | ||||
| 				{ | ||||
| 					// Reset the id to create a new record. | ||||
| 					$table->id = 0; | ||||
|  | ||||
| 					if (!$table->check()) | ||||
| 					{ | ||||
| 						throw new \Exception($table->getError()); | ||||
| 					} | ||||
| 					 | ||||
|  | ||||
| 					// Create the before save event. | ||||
| 					$beforeSaveEvent = AbstractEvent::create( | ||||
| 						$this->event_before_save, | ||||
| 						[ | ||||
| 							'context' => $context, | ||||
| 							'subject' => $table, | ||||
| 							'isNew'   => true, | ||||
| 							'data'    => $table, | ||||
| 						] | ||||
| 					); | ||||
|  | ||||
| 					// Trigger the before save event. | ||||
| 					$dispatchResult = Factory::getApplication()->getDispatcher()->dispatch($this->event_before_save, $beforeSaveEvent); | ||||
|  | ||||
| 					// Check if dispatch result is an array and handle accordingly | ||||
| 					$result = isset($dispatchResult['result']) ? $dispatchResult['result'] : []; | ||||
|  | ||||
| 					// Proceed with your logic | ||||
| 					if (in_array(false, $result, true) || !$table->store()) { | ||||
| 						throw new \Exception($table->getError()); | ||||
| 					} | ||||
|  | ||||
| 					// Trigger the after save event. | ||||
| 					Factory::getApplication()->getDispatcher()->dispatch( | ||||
| 						$this->event_after_save, | ||||
| 						AbstractEvent::create( | ||||
| 							$this->event_after_save, | ||||
| 							[ | ||||
| 								'context'    => $context, | ||||
| 								'subject'    => $table, | ||||
| 								'isNew'      => true, | ||||
| 								'data'       => $table, | ||||
| 							] | ||||
| 						) | ||||
| 					);			 | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					throw new \Exception($table->getError()); | ||||
| 				} | ||||
| 			 | ||||
| 		} | ||||
|  | ||||
| 		// Clean cache | ||||
| 		$this->cleanCache(); | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Prepare and sanitise the table prior to saving. | ||||
| 	 * | ||||
| 	 * @param   Table  $table  Table Object | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function prepareTable($table) | ||||
| 	{ | ||||
| 		jimport('joomla.filter.output'); | ||||
|  | ||||
| 		if (empty($table->id)) | ||||
| 		{ | ||||
| 			// Set ordering to the last item if not set | ||||
| 			if (@$table->ordering === '') | ||||
| 			{ | ||||
| 				$db = $this->getDbo(); | ||||
| 				$db->setQuery('SELECT MAX(ordering) FROM #__highlights_etichetta'); | ||||
| 				$max             = $db->loadResult(); | ||||
| 				$table->ordering = $max + 1; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,206 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Model; | ||||
| // No direct access. | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\MVC\Model\ListModel; | ||||
| use \Joomla\Component\Fields\Administrator\Helper\FieldsHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Helper\TagsHelper; | ||||
| use \Joomla\Database\ParameterType; | ||||
| use \Joomla\Utilities\ArrayHelper; | ||||
| use Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
|  | ||||
| /** | ||||
|  * Methods supporting a list of Etichette records. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class EtichetteModel extends ListModel | ||||
| { | ||||
| 	/** | ||||
| 	* Constructor. | ||||
| 	* | ||||
| 	* @param   array  $config  An optional associative array of configuration settings. | ||||
| 	* | ||||
| 	* @see        JController | ||||
| 	* @since      1.6 | ||||
| 	*/ | ||||
| 	public function __construct($config = array()) | ||||
| 	{ | ||||
| 		if (empty($config['filter_fields'])) | ||||
| 		{ | ||||
| 			$config['filter_fields'] = array( | ||||
| 				'id', 'a.id', | ||||
| 				'state', 'a.state', | ||||
| 				'ordering', 'a.ordering', | ||||
| 				'created_by', 'a.created_by', | ||||
| 				'modified_by', 'a.modified_by', | ||||
| 				'nome', 'a.nome', | ||||
| 				'lingua', 'a.lingua', | ||||
| 			); | ||||
| 		} | ||||
|  | ||||
| 		parent::__construct($config); | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to auto-populate the model state. | ||||
| 	 * | ||||
| 	 * Note. Calling getState in this method will result in recursion. | ||||
| 	 * | ||||
| 	 * @param   string  $ordering   Elements order | ||||
| 	 * @param   string  $direction  Order direction | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	protected function populateState($ordering = null, $direction = null) | ||||
| 	{ | ||||
| 		// List state information. | ||||
| 		parent::populateState("a.id", "ASC"); | ||||
|  | ||||
| 		$context = $this->getUserStateFromRequest($this->context.'.filter.search', 'filter_search'); | ||||
| 		$this->setState('filter.search', $context); | ||||
|  | ||||
| 		// Split context into component and optional section | ||||
| 		if (!empty($context)) | ||||
| 		{ | ||||
| 			$parts = FieldsHelper::extract($context); | ||||
|  | ||||
| 			if ($parts) | ||||
| 			{ | ||||
| 				$this->setState('filter.component', $parts[0]); | ||||
| 				$this->setState('filter.section', $parts[1]); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get a store id based on model configuration state. | ||||
| 	 * | ||||
| 	 * This is necessary because the model is used by the component and | ||||
| 	 * different modules that might need different sets of data or different | ||||
| 	 * ordering requirements. | ||||
| 	 * | ||||
| 	 * @param   string  $id  A prefix for the store id. | ||||
| 	 * | ||||
| 	 * @return  string A store id. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getStoreId($id = '') | ||||
| 	{ | ||||
| 		// Compile the store id. | ||||
| 		$id .= ':' . $this->getState('filter.search'); | ||||
| 		$id .= ':' . $this->getState('filter.state'); | ||||
|  | ||||
| 		 | ||||
| 		return parent::getStoreId($id); | ||||
| 		 | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Build an SQL query to load the list data. | ||||
| 	 * | ||||
| 	 * @return  DatabaseQuery | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getListQuery() | ||||
| 	{ | ||||
| 		// Create a new query object. | ||||
| 		$db    = $this->getDbo(); | ||||
| 		$query = $db->getQuery(true); | ||||
|  | ||||
| 		// Select the required fields from the table. | ||||
| 		$query->select( | ||||
| 			$this->getState( | ||||
| 				'list.select', 'DISTINCT a.*' | ||||
| 			) | ||||
| 		); | ||||
| 		$query->from('`#__highlights_etichetta` AS a'); | ||||
| 		 | ||||
| 		// Join over the users for the checked out user | ||||
| 		$query->select("uc.name AS uEditor"); | ||||
| 		$query->join("LEFT", "#__users AS uc ON uc.id=a.checked_out"); | ||||
|  | ||||
| 		// Join over the user field 'created_by' | ||||
| 		$query->select('`created_by`.name AS `created_by`'); | ||||
| 		$query->join('LEFT', '#__users AS `created_by` ON `created_by`.id = a.`created_by`'); | ||||
|  | ||||
| 		// Join over the user field 'modified_by' | ||||
| 		$query->select('`modified_by`.name AS `modified_by`'); | ||||
| 		$query->join('LEFT', '#__users AS `modified_by` ON `modified_by`.id = a.`modified_by`'); | ||||
| 		 | ||||
|  | ||||
| 		// Filter by published state | ||||
| 		$published = $this->getState('filter.state'); | ||||
|  | ||||
| 		if (is_numeric($published)) | ||||
| 		{ | ||||
| 			$query->where('a.state = ' . (int) $published); | ||||
| 		} | ||||
| 		elseif (empty($published)) | ||||
| 		{ | ||||
| 			$query->where('(a.state IN (0, 1))'); | ||||
| 		} | ||||
|  | ||||
| 		// Filter by search in title | ||||
| 		$search = $this->getState('filter.search'); | ||||
|  | ||||
| 		if (!empty($search)) | ||||
| 		{ | ||||
| 			if (stripos($search, 'id:') === 0) | ||||
| 			{ | ||||
| 				$query->where('a.id = ' . (int) substr($search, 3)); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$search = $db->Quote('%' . $db->escape($search, true) . '%'); | ||||
| 				 | ||||
| 			} | ||||
| 		} | ||||
| 		 | ||||
| 		// Add the list ordering clause. | ||||
| 		$orderCol  = $this->state->get('list.ordering', "a.id"); | ||||
| 		$orderDirn = $this->state->get('list.direction', "ASC"); | ||||
|  | ||||
| 		if ($orderCol && $orderDirn) | ||||
| 		{ | ||||
| 			$query->order($db->escape($orderCol . ' ' . $orderDirn)); | ||||
| 		} | ||||
|  | ||||
| 		return $query; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get an array of data items | ||||
| 	 * | ||||
| 	 * @return mixed Array of data items on success, false on failure. | ||||
| 	 */ | ||||
| 	public function getItems() | ||||
| 	{ | ||||
| 		$items = parent::getItems(); | ||||
| 		 | ||||
|  | ||||
| 		return $items; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,289 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Model; | ||||
| // No direct access. | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\Table\Table; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Plugin\PluginHelper; | ||||
| use \Joomla\CMS\MVC\Model\AdminModel; | ||||
| use \Joomla\CMS\Helper\TagsHelper; | ||||
| use \Joomla\CMS\Filter\OutputFilter; | ||||
| use \Joomla\CMS\Event\Model; | ||||
| use Joomla\CMS\Event\AbstractEvent; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Highlight model. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HighlightModel extends AdminModel | ||||
| { | ||||
| 	/** | ||||
| 	 * @var    string  The prefix to use with controller messages. | ||||
| 	 * | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $text_prefix = 'COM_HIGHLIGHTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * @var    string  Alias to manage history control | ||||
| 	 * | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	public $typeAlias = 'com_highlights.highlight'; | ||||
|  | ||||
| 	/** | ||||
| 	 * @var    null  Item data | ||||
| 	 * | ||||
| 	 * @since  1.0.0 | ||||
| 	 */ | ||||
| 	protected $item = null; | ||||
|  | ||||
| 	 | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns a reference to the a Table object, always creating it. | ||||
| 	 * | ||||
| 	 * @param   string  $type    The table type to instantiate | ||||
| 	 * @param   string  $prefix  A prefix for the table class name. Optional. | ||||
| 	 * @param   array   $config  Configuration array for model. Optional. | ||||
| 	 * | ||||
| 	 * @return  Table    A database object | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getTable($type = 'Highlight', $prefix = 'Administrator', $config = array()) | ||||
| 	{ | ||||
| 		return parent::getTable($type, $prefix, $config); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the record form. | ||||
| 	 * | ||||
| 	 * @param   array    $data      An optional array of data for the form to interogate. | ||||
| 	 * @param   boolean  $loadData  True if the form is to load its own data (default case), false if not. | ||||
| 	 * | ||||
| 	 * @return  \JForm|boolean  A \JForm object on success, false on failure | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getForm($data = array(), $loadData = true) | ||||
| 	{ | ||||
| 		// Initialise variables. | ||||
| 		$app = Factory::getApplication(); | ||||
|  | ||||
| 		// Get the form. | ||||
| 		$form = $this->loadForm( | ||||
| 								'com_highlights.highlight',  | ||||
| 								'highlight', | ||||
| 								array( | ||||
| 									'control' => 'jform', | ||||
| 									'load_data' => $loadData  | ||||
| 								) | ||||
| 							); | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		if (empty($form)) | ||||
| 		{ | ||||
| 			return false; | ||||
| 		} | ||||
|  | ||||
| 		return $form; | ||||
| 	} | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get the data that should be injected in the form. | ||||
| 	 * | ||||
| 	 * @return  mixed  The data for the form. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function loadFormData() | ||||
| 	{ | ||||
| 		// Check the session for previously entered form data. | ||||
| 		$data = Factory::getApplication()->getUserState('com_highlights.edit.highlight.data', array()); | ||||
|  | ||||
| 		if (empty($data)) | ||||
| 		{ | ||||
| 			if ($this->item === null) | ||||
| 			{ | ||||
| 				$this->item = $this->getItem(); | ||||
| 			} | ||||
|  | ||||
| 			$data = $this->item; | ||||
| 			 | ||||
| 		} | ||||
|  | ||||
| 		return $data; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get a single record. | ||||
| 	 * | ||||
| 	 * @param   integer  $pk  The id of the primary key. | ||||
| 	 * | ||||
| 	 * @return  mixed    Object on success, false on failure. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getItem($pk = null) | ||||
| 	{ | ||||
| 		 | ||||
| 			if ($item = parent::getItem($pk)) | ||||
| 			{ | ||||
| 				if (isset($item->params)) | ||||
| 				{ | ||||
| 					$item->params = json_encode($item->params); | ||||
| 				} | ||||
| 				 | ||||
| 				// Do any procesing on fields here if needed | ||||
| 			} | ||||
|  | ||||
| 			return $item; | ||||
| 		 | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to duplicate an Highlight | ||||
| 	 * | ||||
| 	 * @param   array  &$pks  An array of primary key IDs. | ||||
| 	 * | ||||
| 	 * @return  boolean  True if successful. | ||||
| 	 * | ||||
| 	 * @throws  Exception | ||||
| 	 */ | ||||
| 	public function duplicate(&$pks) | ||||
| 	{ | ||||
| 		$app = Factory::getApplication(); | ||||
| 		$user = $app->getIdentity(); | ||||
|         $dispatcher = $this->getDispatcher(); | ||||
|  | ||||
| 		// Access checks. | ||||
| 		if (!$user->authorise('core.create', 'com_highlights')) | ||||
| 		{ | ||||
| 			throw new \Exception(Text::_('JERROR_CORE_CREATE_NOT_PERMITTED')); | ||||
| 		} | ||||
|  | ||||
| 		$context    = $this->option . '.' . $this->name; | ||||
|  | ||||
| 		// Include the plugins for the save events. | ||||
| 		PluginHelper::importPlugin($this->events_map['save']); | ||||
|  | ||||
| 		$table = $this->getTable(); | ||||
|  | ||||
| 		foreach ($pks as $pk) | ||||
| 		{ | ||||
| 			 | ||||
| 				if ($table->load($pk, true)) | ||||
| 				{ | ||||
| 					// Reset the id to create a new record. | ||||
| 					$table->id = 0; | ||||
|  | ||||
| 					if (!$table->check()) | ||||
| 					{ | ||||
| 						throw new \Exception($table->getError()); | ||||
| 					} | ||||
| 					 | ||||
| 				if (!empty($table->etichetta)) | ||||
| 				{ | ||||
| 					if (is_array($table->etichetta)) | ||||
| 					{ | ||||
| 						$table->etichetta = implode(',', $table->etichetta); | ||||
| 					} | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					$table->etichetta = ''; | ||||
| 				} | ||||
|  | ||||
|  | ||||
| 					// Create the before save event. | ||||
| 					$beforeSaveEvent = AbstractEvent::create( | ||||
| 						$this->event_before_save, | ||||
| 						[ | ||||
| 							'context' => $context, | ||||
| 							'subject' => $table, | ||||
| 							'isNew'   => true, | ||||
| 							'data'    => $table, | ||||
| 						] | ||||
| 					); | ||||
|  | ||||
| 					// Trigger the before save event. | ||||
| 					$dispatchResult = Factory::getApplication()->getDispatcher()->dispatch($this->event_before_save, $beforeSaveEvent); | ||||
|  | ||||
| 					// Check if dispatch result is an array and handle accordingly | ||||
| 					$result = isset($dispatchResult['result']) ? $dispatchResult['result'] : []; | ||||
|  | ||||
| 					// Proceed with your logic | ||||
| 					if (in_array(false, $result, true) || !$table->store()) { | ||||
| 						throw new \Exception($table->getError()); | ||||
| 					} | ||||
|  | ||||
| 					// Trigger the after save event. | ||||
| 					Factory::getApplication()->getDispatcher()->dispatch( | ||||
| 						$this->event_after_save, | ||||
| 						AbstractEvent::create( | ||||
| 							$this->event_after_save, | ||||
| 							[ | ||||
| 								'context'    => $context, | ||||
| 								'subject'    => $table, | ||||
| 								'isNew'      => true, | ||||
| 								'data'       => $table, | ||||
| 							] | ||||
| 						) | ||||
| 					);			 | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					throw new \Exception($table->getError()); | ||||
| 				} | ||||
| 			 | ||||
| 		} | ||||
|  | ||||
| 		// Clean cache | ||||
| 		$this->cleanCache(); | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Prepare and sanitise the table prior to saving. | ||||
| 	 * | ||||
| 	 * @param   Table  $table  Table Object | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function prepareTable($table) | ||||
| 	{ | ||||
| 		jimport('joomla.filter.output'); | ||||
|  | ||||
| 		if (empty($table->id)) | ||||
| 		{ | ||||
| 			// Set ordering to the last item if not set | ||||
| 			if (@$table->ordering === '') | ||||
| 			{ | ||||
| 				$db = $this->getDbo(); | ||||
| 				$db->setQuery('SELECT MAX(ordering) FROM #__highlights_'); | ||||
| 				$max             = $db->loadResult(); | ||||
| 				$table->ordering = $max + 1; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,248 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Model; | ||||
| // No direct access. | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\MVC\Model\ListModel; | ||||
| use \Joomla\Component\Fields\Administrator\Helper\FieldsHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Helper\TagsHelper; | ||||
| use \Joomla\Database\ParameterType; | ||||
| use \Joomla\Utilities\ArrayHelper; | ||||
| use Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
|  | ||||
| /** | ||||
|  * Methods supporting a list of Highlights records. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HighlightsModel extends ListModel | ||||
| { | ||||
| 	/** | ||||
| 	* Constructor. | ||||
| 	* | ||||
| 	* @param   array  $config  An optional associative array of configuration settings. | ||||
| 	* | ||||
| 	* @see        JController | ||||
| 	* @since      1.6 | ||||
| 	*/ | ||||
| 	public function __construct($config = array()) | ||||
| 	{ | ||||
| 		if (empty($config['filter_fields'])) | ||||
| 		{ | ||||
| 			$config['filter_fields'] = array( | ||||
| 				'id', 'a.id', | ||||
| 				'state', 'a.state', | ||||
| 				'ordering', 'a.ordering', | ||||
| 				'created_by', 'a.created_by', | ||||
| 				'modified_by', 'a.modified_by', | ||||
| 				'etichetta', 'a.etichetta', | ||||
| 				'titolo', 'a.titolo', | ||||
| 				'sottotitolo', 'a.sottotitolo', | ||||
| 				'descrizione', 'a.descrizione', | ||||
| 				'lingua', 'a.lingua', | ||||
| 				'link_pulsante', 'a.link_pulsante', | ||||
| 				'testo_pulsante', 'a.testo_pulsante', | ||||
| 				'data', 'a.data', | ||||
| 				'immagine_main', 'a.immagine_main', | ||||
| 				'immagine_secondaria', 'a.immagine_secondaria', | ||||
| 				'data_inizio_pubblicazione', 'a.data_inizio_pubblicazione', | ||||
| 				'data_fine_pubblicazione', 'a.data_fine_pubblicazione', | ||||
| 			); | ||||
| 		} | ||||
|  | ||||
| 		parent::__construct($config); | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	 | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to auto-populate the model state. | ||||
| 	 * | ||||
| 	 * Note. Calling getState in this method will result in recursion. | ||||
| 	 * | ||||
| 	 * @param   string  $ordering   Elements order | ||||
| 	 * @param   string  $direction  Order direction | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	protected function populateState($ordering = null, $direction = null) | ||||
| 	{ | ||||
| 		// List state information. | ||||
| 		parent::populateState('id', 'ASC'); | ||||
|  | ||||
| 		$context = $this->getUserStateFromRequest($this->context.'.filter.search', 'filter_search'); | ||||
| 		$this->setState('filter.search', $context); | ||||
|  | ||||
| 		// Split context into component and optional section | ||||
| 		if (!empty($context)) | ||||
| 		{ | ||||
| 			$parts = FieldsHelper::extract($context); | ||||
|  | ||||
| 			if ($parts) | ||||
| 			{ | ||||
| 				$this->setState('filter.component', $parts[0]); | ||||
| 				$this->setState('filter.section', $parts[1]); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to get a store id based on model configuration state. | ||||
| 	 * | ||||
| 	 * This is necessary because the model is used by the component and | ||||
| 	 * different modules that might need different sets of data or different | ||||
| 	 * ordering requirements. | ||||
| 	 * | ||||
| 	 * @param   string  $id  A prefix for the store id. | ||||
| 	 * | ||||
| 	 * @return  string A store id. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getStoreId($id = '') | ||||
| 	{ | ||||
| 		// Compile the store id. | ||||
| 		$id .= ':' . $this->getState('filter.search'); | ||||
| 		$id .= ':' . $this->getState('filter.state'); | ||||
|  | ||||
| 		 | ||||
| 		return parent::getStoreId($id); | ||||
| 		 | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Build an SQL query to load the list data. | ||||
| 	 * | ||||
| 	 * @return  DatabaseQuery | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function getListQuery() | ||||
| 	{ | ||||
| 		// Create a new query object. | ||||
| 		$db    = $this->getDbo(); | ||||
| 		$query = $db->getQuery(true); | ||||
|  | ||||
| 		// Select the required fields from the table. | ||||
| 		$query->select( | ||||
| 			$this->getState( | ||||
| 				'list.select', 'DISTINCT a.*' | ||||
| 			) | ||||
| 		); | ||||
| 		$query->from('`#__highlights_` AS a'); | ||||
| 		 | ||||
| 		// Join over the users for the checked out user | ||||
| 		$query->select("uc.name AS uEditor"); | ||||
| 		$query->join("LEFT", "#__users AS uc ON uc.id=a.checked_out"); | ||||
|  | ||||
| 		// Join over the user field 'created_by' | ||||
| 		$query->select('`created_by`.name AS `created_by`'); | ||||
| 		$query->join('LEFT', '#__users AS `created_by` ON `created_by`.id = a.`created_by`'); | ||||
|  | ||||
| 		// Join over the user field 'modified_by' | ||||
| 		$query->select('`modified_by`.name AS `modified_by`'); | ||||
| 		$query->join('LEFT', '#__users AS `modified_by` ON `modified_by`.id = a.`modified_by`'); | ||||
| 		// Join over the foreign key 'etichetta' | ||||
| 		$query->select('`#__highlights_etichetta_4129035`.`nome` AS etichette_fk_value_4129035'); | ||||
| 		$query->join('LEFT', '#__highlights_etichetta AS #__highlights_etichetta_4129035 ON #__highlights_etichetta_4129035.`nome` = a.`etichetta`'); | ||||
| 		 | ||||
|  | ||||
| 		// Filter by published state | ||||
| 		$published = $this->getState('filter.state'); | ||||
|  | ||||
| 		if (is_numeric($published)) | ||||
| 		{ | ||||
| 			$query->where('a.state = ' . (int) $published); | ||||
| 		} | ||||
| 		elseif (empty($published)) | ||||
| 		{ | ||||
| 			$query->where('(a.state IN (0, 1))'); | ||||
| 		} | ||||
|  | ||||
| 		// Filter by search in title | ||||
| 		$search = $this->getState('filter.search'); | ||||
|  | ||||
| 		if (!empty($search)) | ||||
| 		{ | ||||
| 			if (stripos($search, 'id:') === 0) | ||||
| 			{ | ||||
| 				$query->where('a.id = ' . (int) substr($search, 3)); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$search = $db->Quote('%' . $db->escape($search, true) . '%'); | ||||
| 				 | ||||
| 			} | ||||
| 		} | ||||
| 		 | ||||
| 		// Add the list ordering clause. | ||||
| 		$orderCol  = $this->state->get('list.ordering', 'id'); | ||||
| 		$orderDirn = $this->state->get('list.direction', 'ASC'); | ||||
|  | ||||
| 		if ($orderCol && $orderDirn) | ||||
| 		{ | ||||
| 			$query->order($db->escape($orderCol . ' ' . $orderDirn)); | ||||
| 		} | ||||
|  | ||||
| 		return $query; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get an array of data items | ||||
| 	 * | ||||
| 	 * @return mixed Array of data items on success, false on failure. | ||||
| 	 */ | ||||
| 	public function getItems() | ||||
| 	{ | ||||
| 		$items = parent::getItems(); | ||||
| 		 | ||||
| 		foreach ($items as $oneItem) | ||||
| 		{ | ||||
|  | ||||
| 			if (isset($oneItem->etichetta)) | ||||
| 			{ | ||||
| 				$values    = explode(',', $oneItem->etichetta); | ||||
| 				$textValue = array(); | ||||
|  | ||||
| 				foreach ($values as $value) | ||||
| 				{ | ||||
| 					$db    = $this->getDbo(); | ||||
| 					$query = $db->getQuery(true); | ||||
| 					$query | ||||
| 						->select('`#__highlights_etichetta_4129035`.`nome`') | ||||
| 						->from($db->quoteName('#__highlights_etichetta', '#__highlights_etichetta_4129035')) | ||||
| 						->where($db->quoteName('#__highlights_etichetta_4129035.nome') . ' = '. $db->quote($db->escape($value))); | ||||
|  | ||||
| 					$db->setQuery($query); | ||||
| 					$results = $db->loadObject(); | ||||
|  | ||||
| 					if ($results) | ||||
| 					{ | ||||
| 						$textValue[] = $results->nome; | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				$oneItem->etichetta = !empty($textValue) ? implode(', ', $textValue) : $oneItem->etichetta; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $items; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,53 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Service\Html; | ||||
|  | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\Utilities\ArrayHelper; | ||||
| use Joomla\CMS\Language\Text; | ||||
| use Joomla\CMS\MVC\Model\DatabaseAwareTrait; | ||||
| use Joomla\Database\DatabaseDriver; | ||||
|  | ||||
| /** | ||||
|  * Highlights HTML Helper. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HIGHLIGHTS | ||||
| { | ||||
| 	use DatabaseAwareTrait; | ||||
|  | ||||
| 	/** | ||||
| 	 * Public constructor. | ||||
| 	 * | ||||
| 	 * @param   DatabaseDriver  $db  The Joomla DB driver object for the site's database. | ||||
| 	 */ | ||||
| 	public function __construct(DatabaseDriver $db) | ||||
| 	{ | ||||
| 		$this->setDbo($db); | ||||
| 	} | ||||
|  | ||||
| 	public function toggle($value = 0, $view='', $field='', $i='') | ||||
| 	{ | ||||
| 		$states = array( | ||||
| 			0 => array('icon-unpublish', Text::_('Toggle'), ''), | ||||
| 			1 => array('icon-publish', Text::_('Toggle'), '') | ||||
| 		); | ||||
|  | ||||
| 		$state  = ArrayHelper::getValue($states, (int) $value, $states[0]); | ||||
| 		$text   = '<span aria-hidden="true" class="' . $state[0] . '"></span>'; | ||||
| 		$html   = '<a href="javascript:void(0);" class="tbody-icon ' . $state[2] . '"'; | ||||
| 		$html  .= 'onclick="return Joomla.toggleField(\'cb'.$i.'\',\'' . $view . '.toggle\',\'' . $field . '\')" title="' . Text::_($state[1]) . '">' . $text . '</a>'; | ||||
|  | ||||
| 		return $html; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,279 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Table; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\Utilities\ArrayHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Access\Access; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Table\Table as Table; | ||||
| use \Joomla\CMS\Versioning\VersionableTableInterface; | ||||
| use Joomla\CMS\Tag\TaggableTableInterface; | ||||
| use Joomla\CMS\Tag\TaggableTableTrait; | ||||
| use \Joomla\Database\DatabaseDriver; | ||||
| use \Joomla\CMS\Filter\OutputFilter; | ||||
| use \Joomla\CMS\Filesystem\File; | ||||
| use \Joomla\Registry\Registry; | ||||
| use \Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
| use \Joomla\CMS\Helper\ContentHelper; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Etichetta table | ||||
|  * | ||||
|  * @since 1.0.0 | ||||
|  */ | ||||
| class EtichettaTable extends Table implements VersionableTableInterface, TaggableTableInterface | ||||
| { | ||||
| 	use TaggableTableTrait; | ||||
|  | ||||
| 	/** | ||||
|      * Indicates that columns fully support the NULL value in the database | ||||
|      * | ||||
|      * @var    boolean | ||||
|      * @since  4.0.0 | ||||
|      */ | ||||
|     protected $_supportNullValue = true; | ||||
|  | ||||
| 	 | ||||
| 	/** | ||||
| 	 * Constructor | ||||
| 	 * | ||||
| 	 * @param   JDatabase  &$db  A database connector object | ||||
| 	 */ | ||||
| 	public function __construct(DatabaseDriver $db) | ||||
| 	{ | ||||
| 		$this->typeAlias = 'com_highlights.etichetta'; | ||||
| 		parent::__construct('#__highlights_etichetta', 'id', $db); | ||||
| 		$this->setColumnAlias('published', 'state'); | ||||
| 		 | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get the type alias for the history table | ||||
| 	 * | ||||
| 	 * @return  string  The alias as described above | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getTypeAlias() | ||||
| 	{ | ||||
| 		return $this->typeAlias; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Overloaded bind function to pre-process the params. | ||||
| 	 * | ||||
| 	 * @param   array  $array   Named array | ||||
| 	 * @param   mixed  $ignore  Optional array or list of parameters to ignore | ||||
| 	 * | ||||
| 	 * @return  boolean  True on success. | ||||
| 	 * | ||||
| 	 * @see     Table:bind | ||||
| 	 * @since   1.0.0 | ||||
| 	 * @throws  \InvalidArgumentException | ||||
| 	 */ | ||||
| 	public function bind($array, $ignore = '') | ||||
| 	{ | ||||
| 		$date = Factory::getDate(); | ||||
| 		$task = Factory::getApplication()->input->get('task'); | ||||
| 		$user = Factory::getApplication()->getIdentity(); | ||||
| 		 | ||||
| 		$input = Factory::getApplication()->input; | ||||
| 		$task = $input->getString('task', ''); | ||||
|  | ||||
| 		if ($array['id'] == 0 && empty($array['created_by'])) | ||||
| 		{ | ||||
| 			$array['created_by'] = Factory::getUser()->id; | ||||
| 		} | ||||
|  | ||||
| 		if ($array['id'] == 0 && empty($array['modified_by'])) | ||||
| 		{ | ||||
| 			$array['modified_by'] = Factory::getUser()->id; | ||||
| 		} | ||||
|  | ||||
| 		if ($task == 'apply' || $task == 'save') | ||||
| 		{ | ||||
| 			$array['modified_by'] = Factory::getUser()->id; | ||||
| 		} | ||||
|  | ||||
| 		if (isset($array['params']) && is_array($array['params'])) | ||||
| 		{ | ||||
| 			$registry = new Registry; | ||||
| 			$registry->loadArray($array['params']); | ||||
| 			$array['params'] = (string) $registry; | ||||
| 		} | ||||
|  | ||||
| 		if (isset($array['metadata']) && is_array($array['metadata'])) | ||||
| 		{ | ||||
| 			$registry = new Registry; | ||||
| 			$registry->loadArray($array['metadata']); | ||||
| 			$array['metadata'] = (string) $registry; | ||||
| 		} | ||||
|  | ||||
| 		if (!$user->authorise('core.admin', 'com_highlights.etichetta.' . $array['id'])) | ||||
| 		{ | ||||
| 			$actions         = Access::getActionsFromFile( | ||||
| 				JPATH_ADMINISTRATOR . '/components/com_highlights/access.xml', | ||||
| 				"/access/section[@name='etichetta']/" | ||||
| 			); | ||||
| 			$default_actions = Access::getAssetRules('com_highlights.etichetta.' . $array['id'])->getData(); | ||||
| 			$array_jaccess   = array(); | ||||
|  | ||||
| 			foreach ($actions as $action) | ||||
| 			{ | ||||
| 				if (key_exists($action->name, $default_actions)) | ||||
| 				{ | ||||
| 					$array_jaccess[$action->name] = $default_actions[$action->name]; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			$array['rules'] = $this->JAccessRulestoArray($array_jaccess); | ||||
| 		} | ||||
|  | ||||
| 		// Bind the rules for ACL where supported. | ||||
| 		if (isset($array['rules']) && is_array($array['rules'])) | ||||
| 		{ | ||||
| 			$this->setRules($array['rules']); | ||||
| 		} | ||||
|  | ||||
| 		return parent::bind($array, $ignore); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to store a row in the database from the Table instance properties. | ||||
| 	 * | ||||
| 	 * If a primary key value is set the row with that primary key value will be updated with the instance property values. | ||||
| 	 * If no primary key value is set a new row will be inserted into the database with the properties from the Table instance. | ||||
| 	 * | ||||
| 	 * @param   boolean  $updateNulls  True to update fields even if they are null. | ||||
| 	 * | ||||
| 	 * @return  boolean  True on success. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function store($updateNulls = true) | ||||
| 	{ | ||||
| 		 | ||||
| 		 | ||||
| 		return parent::store($updateNulls); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * This function convert an array of Access objects into an rules array. | ||||
| 	 * | ||||
| 	 * @param   array  $jaccessrules  An array of Access objects. | ||||
| 	 * | ||||
| 	 * @return  array | ||||
| 	 */ | ||||
| 	private function JAccessRulestoArray($jaccessrules) | ||||
| 	{ | ||||
| 		$rules = array(); | ||||
|  | ||||
| 		foreach ($jaccessrules as $action => $jaccess) | ||||
| 		{ | ||||
| 			$actions = array(); | ||||
|  | ||||
| 			if ($jaccess) | ||||
| 			{ | ||||
| 				foreach ($jaccess->getData() as $group => $allow) | ||||
| 				{ | ||||
| 					$actions[$group] = ((bool)$allow); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			$rules[$action] = $actions; | ||||
| 		} | ||||
|  | ||||
| 		return $rules; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Overloaded check function | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function check() | ||||
| 	{ | ||||
| 		// If there is an ordering column and this is a new row then get the next ordering value | ||||
| 		if (property_exists($this, 'ordering') && $this->id == 0) | ||||
| 		{ | ||||
| 			$this->ordering = self::getNextOrder(); | ||||
| 		} | ||||
| 		 | ||||
| 		 | ||||
|  | ||||
| 		return parent::check(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Define a namespaced asset name for inclusion in the #__assets table | ||||
| 	 * | ||||
| 	 * @return string The asset name | ||||
| 	 * | ||||
| 	 * @see Table::_getAssetName | ||||
| 	 */ | ||||
| 	protected function _getAssetName() | ||||
| 	{ | ||||
| 		$k = $this->_tbl_key; | ||||
|  | ||||
| 		return $this->typeAlias . '.' . (int) $this->$k; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns the parent asset's id. If you have a tree structure, retrieve the parent's id using the external key field | ||||
| 	 * | ||||
| 	 * @param   Table   $table  Table name | ||||
| 	 * @param   integer  $id     Id | ||||
| 	 * | ||||
| 	 * @see Table::_getAssetParentId | ||||
| 	 * | ||||
| 	 * @return mixed The id on success, false on failure. | ||||
| 	 */ | ||||
| 	protected function _getAssetParentId($table = null, $id = null) | ||||
| 	{ | ||||
| 		// We will retrieve the parent-asset from the Asset-table | ||||
| 		$assetParent = Table::getInstance('Asset'); | ||||
|  | ||||
| 		// Default: if no asset-parent can be found we take the global asset | ||||
| 		$assetParentId = $assetParent->getRootId(); | ||||
|  | ||||
| 		// The item has the component as asset-parent | ||||
| 		$assetParent->loadByName('com_highlights'); | ||||
|  | ||||
| 		// Return the found asset-parent-id | ||||
| 		if ($assetParent->id) | ||||
| 		{ | ||||
| 			$assetParentId = $assetParent->id; | ||||
| 		} | ||||
|  | ||||
| 		return $assetParentId; | ||||
| 	} | ||||
|  | ||||
| 	//XXX_CUSTOM_TABLE_FUNCTION | ||||
|  | ||||
| 	 | ||||
|     /** | ||||
|      * Delete a record by id | ||||
|      * | ||||
|      * @param   mixed  $pk  Primary key value to delete. Optional | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function delete($pk = null) | ||||
|     { | ||||
|         $this->load($pk); | ||||
|         $result = parent::delete($pk); | ||||
|          | ||||
|         return $result; | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,314 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\Table; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\Utilities\ArrayHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Joomla\CMS\Access\Access; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\CMS\Table\Table as Table; | ||||
| use \Joomla\CMS\Versioning\VersionableTableInterface; | ||||
| use Joomla\CMS\Tag\TaggableTableInterface; | ||||
| use Joomla\CMS\Tag\TaggableTableTrait; | ||||
| use \Joomla\Database\DatabaseDriver; | ||||
| use \Joomla\CMS\Filter\OutputFilter; | ||||
| use \Joomla\CMS\Filesystem\File; | ||||
| use \Joomla\Registry\Registry; | ||||
| use \Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
| use \Joomla\CMS\Helper\ContentHelper; | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Highlight table | ||||
|  * | ||||
|  * @since 1.0.0 | ||||
|  */ | ||||
| class HighlightTable extends Table implements VersionableTableInterface, TaggableTableInterface | ||||
| { | ||||
| 	use TaggableTableTrait; | ||||
|  | ||||
| 	/** | ||||
|      * Indicates that columns fully support the NULL value in the database | ||||
|      * | ||||
|      * @var    boolean | ||||
|      * @since  4.0.0 | ||||
|      */ | ||||
|     protected $_supportNullValue = true; | ||||
|  | ||||
| 	 | ||||
| 	/** | ||||
| 	 * Constructor | ||||
| 	 * | ||||
| 	 * @param   JDatabase  &$db  A database connector object | ||||
| 	 */ | ||||
| 	public function __construct(DatabaseDriver $db) | ||||
| 	{ | ||||
| 		$this->typeAlias = 'com_highlights.highlight'; | ||||
| 		parent::__construct('#__highlights_', 'id', $db); | ||||
| 		$this->setColumnAlias('published', 'state'); | ||||
| 		 | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get the type alias for the history table | ||||
| 	 * | ||||
| 	 * @return  string  The alias as described above | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function getTypeAlias() | ||||
| 	{ | ||||
| 		return $this->typeAlias; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Overloaded bind function to pre-process the params. | ||||
| 	 * | ||||
| 	 * @param   array  $array   Named array | ||||
| 	 * @param   mixed  $ignore  Optional array or list of parameters to ignore | ||||
| 	 * | ||||
| 	 * @return  boolean  True on success. | ||||
| 	 * | ||||
| 	 * @see     Table:bind | ||||
| 	 * @since   1.0.0 | ||||
| 	 * @throws  \InvalidArgumentException | ||||
| 	 */ | ||||
| 	public function bind($array, $ignore = '') | ||||
| 	{ | ||||
| 		$date = Factory::getDate(); | ||||
| 		$task = Factory::getApplication()->input->get('task'); | ||||
| 		$user = Factory::getApplication()->getIdentity(); | ||||
| 		 | ||||
| 		$input = Factory::getApplication()->input; | ||||
| 		$task = $input->getString('task', ''); | ||||
|  | ||||
| 		if ($array['id'] == 0 && empty($array['created_by'])) | ||||
| 		{ | ||||
| 			$array['created_by'] = Factory::getUser()->id; | ||||
| 		} | ||||
|  | ||||
| 		if ($array['id'] == 0 && empty($array['modified_by'])) | ||||
| 		{ | ||||
| 			$array['modified_by'] = Factory::getUser()->id; | ||||
| 		} | ||||
|  | ||||
| 		if ($task == 'apply' || $task == 'save') | ||||
| 		{ | ||||
| 			$array['modified_by'] = Factory::getUser()->id; | ||||
| 		} | ||||
|  | ||||
| 		// Support for multiple or not foreign key field: etichetta | ||||
| 			if(!empty($array['etichetta'])) | ||||
| 			{ | ||||
| 				if(is_array($array['etichetta'])){ | ||||
| 					$array['etichetta'] = implode(',',$array['etichetta']); | ||||
| 				} | ||||
| 				else if(strrpos($array['etichetta'], ',') != false){ | ||||
| 					$array['etichetta'] = explode(',',$array['etichetta']); | ||||
| 				} | ||||
| 			} | ||||
| 			else { | ||||
| 				$array['etichetta'] = 0; | ||||
| 			} | ||||
|  | ||||
| 		// Support for empty date field: data | ||||
| 		if($array['data'] == '0000-00-00' || empty($array['data'])) | ||||
| 		{ | ||||
| 			$array['data'] = NULL; | ||||
| 			$this->data = NULL; | ||||
| 		} | ||||
|  | ||||
| 		// Support for empty date field: data_inizio_pubblicazione | ||||
| 		if($array['data_inizio_pubblicazione'] == '0000-00-00' || empty($array['data_inizio_pubblicazione'])) | ||||
| 		{ | ||||
| 			$array['data_inizio_pubblicazione'] = NULL; | ||||
| 			$this->data_inizio_pubblicazione = NULL; | ||||
| 		} | ||||
|  | ||||
| 		// Support for empty date field: data_fine_pubblicazione | ||||
| 		if($array['data_fine_pubblicazione'] == '0000-00-00' || empty($array['data_fine_pubblicazione'])) | ||||
| 		{ | ||||
| 			$array['data_fine_pubblicazione'] = NULL; | ||||
| 			$this->data_fine_pubblicazione = NULL; | ||||
| 		} | ||||
|  | ||||
| 		if (isset($array['params']) && is_array($array['params'])) | ||||
| 		{ | ||||
| 			$registry = new Registry; | ||||
| 			$registry->loadArray($array['params']); | ||||
| 			$array['params'] = (string) $registry; | ||||
| 		} | ||||
|  | ||||
| 		if (isset($array['metadata']) && is_array($array['metadata'])) | ||||
| 		{ | ||||
| 			$registry = new Registry; | ||||
| 			$registry->loadArray($array['metadata']); | ||||
| 			$array['metadata'] = (string) $registry; | ||||
| 		} | ||||
|  | ||||
| 		if (!$user->authorise('core.admin', 'com_highlights.highlight.' . $array['id'])) | ||||
| 		{ | ||||
| 			$actions         = Access::getActionsFromFile( | ||||
| 				JPATH_ADMINISTRATOR . '/components/com_highlights/access.xml', | ||||
| 				"/access/section[@name='highlight']/" | ||||
| 			); | ||||
| 			$default_actions = Access::getAssetRules('com_highlights.highlight.' . $array['id'])->getData(); | ||||
| 			$array_jaccess   = array(); | ||||
|  | ||||
| 			foreach ($actions as $action) | ||||
| 			{ | ||||
| 				if (key_exists($action->name, $default_actions)) | ||||
| 				{ | ||||
| 					$array_jaccess[$action->name] = $default_actions[$action->name]; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			$array['rules'] = $this->JAccessRulestoArray($array_jaccess); | ||||
| 		} | ||||
|  | ||||
| 		// Bind the rules for ACL where supported. | ||||
| 		if (isset($array['rules']) && is_array($array['rules'])) | ||||
| 		{ | ||||
| 			$this->setRules($array['rules']); | ||||
| 		} | ||||
|  | ||||
| 		return parent::bind($array, $ignore); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Method to store a row in the database from the Table instance properties. | ||||
| 	 * | ||||
| 	 * If a primary key value is set the row with that primary key value will be updated with the instance property values. | ||||
| 	 * If no primary key value is set a new row will be inserted into the database with the properties from the Table instance. | ||||
| 	 * | ||||
| 	 * @param   boolean  $updateNulls  True to update fields even if they are null. | ||||
| 	 * | ||||
| 	 * @return  boolean  True on success. | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	public function store($updateNulls = true) | ||||
| 	{ | ||||
| 		 | ||||
| 		 | ||||
| 		return parent::store($updateNulls); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * This function convert an array of Access objects into an rules array. | ||||
| 	 * | ||||
| 	 * @param   array  $jaccessrules  An array of Access objects. | ||||
| 	 * | ||||
| 	 * @return  array | ||||
| 	 */ | ||||
| 	private function JAccessRulestoArray($jaccessrules) | ||||
| 	{ | ||||
| 		$rules = array(); | ||||
|  | ||||
| 		foreach ($jaccessrules as $action => $jaccess) | ||||
| 		{ | ||||
| 			$actions = array(); | ||||
|  | ||||
| 			if ($jaccess) | ||||
| 			{ | ||||
| 				foreach ($jaccess->getData() as $group => $allow) | ||||
| 				{ | ||||
| 					$actions[$group] = ((bool)$allow); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			$rules[$action] = $actions; | ||||
| 		} | ||||
|  | ||||
| 		return $rules; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Overloaded check function | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function check() | ||||
| 	{ | ||||
| 		// If there is an ordering column and this is a new row then get the next ordering value | ||||
| 		if (property_exists($this, 'ordering') && $this->id == 0) | ||||
| 		{ | ||||
| 			$this->ordering = self::getNextOrder(); | ||||
| 		} | ||||
| 		 | ||||
| 		 | ||||
|  | ||||
| 		return parent::check(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Define a namespaced asset name for inclusion in the #__assets table | ||||
| 	 * | ||||
| 	 * @return string The asset name | ||||
| 	 * | ||||
| 	 * @see Table::_getAssetName | ||||
| 	 */ | ||||
| 	protected function _getAssetName() | ||||
| 	{ | ||||
| 		$k = $this->_tbl_key; | ||||
|  | ||||
| 		return $this->typeAlias . '.' . (int) $this->$k; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns the parent asset's id. If you have a tree structure, retrieve the parent's id using the external key field | ||||
| 	 * | ||||
| 	 * @param   Table   $table  Table name | ||||
| 	 * @param   integer  $id     Id | ||||
| 	 * | ||||
| 	 * @see Table::_getAssetParentId | ||||
| 	 * | ||||
| 	 * @return mixed The id on success, false on failure. | ||||
| 	 */ | ||||
| 	protected function _getAssetParentId($table = null, $id = null) | ||||
| 	{ | ||||
| 		// We will retrieve the parent-asset from the Asset-table | ||||
| 		$assetParent = Table::getInstance('Asset'); | ||||
|  | ||||
| 		// Default: if no asset-parent can be found we take the global asset | ||||
| 		$assetParentId = $assetParent->getRootId(); | ||||
|  | ||||
| 		// The item has the component as asset-parent | ||||
| 		$assetParent->loadByName('com_highlights'); | ||||
|  | ||||
| 		// Return the found asset-parent-id | ||||
| 		if ($assetParent->id) | ||||
| 		{ | ||||
| 			$assetParentId = $assetParent->id; | ||||
| 		} | ||||
|  | ||||
| 		return $assetParentId; | ||||
| 	} | ||||
|  | ||||
| 	//XXX_CUSTOM_TABLE_FUNCTION | ||||
|  | ||||
| 	 | ||||
|     /** | ||||
|      * Delete a record by id | ||||
|      * | ||||
|      * @param   mixed  $pk  Primary key value to delete. Optional | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function delete($pk = null) | ||||
|     { | ||||
|         $this->load($pk); | ||||
|         $result = parent::delete($pk); | ||||
|          | ||||
|         return $result; | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,114 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\View\Etichetta; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\MVC\View\HtmlView as BaseHtmlView; | ||||
| use \Joomla\CMS\Toolbar\ToolbarHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
| use \Joomla\CMS\Language\Text; | ||||
|  | ||||
| /** | ||||
|  * View class for a single Etichetta. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HtmlView extends BaseHtmlView | ||||
| { | ||||
| 	protected $state; | ||||
|  | ||||
| 	protected $item; | ||||
|  | ||||
| 	protected $form; | ||||
|  | ||||
| 	/** | ||||
| 	 * Display the view | ||||
| 	 * | ||||
| 	 * @param   string  $tpl  Template name | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	public function display($tpl = null) | ||||
| 	{ | ||||
| 		$this->state = $this->get('State'); | ||||
| 		$this->item  = $this->get('Item'); | ||||
| 		$this->form  = $this->get('Form'); | ||||
|  | ||||
| 		// Check for errors. | ||||
| 		if (count($errors = $this->get('Errors'))) | ||||
| 		{ | ||||
| 			throw new \Exception(implode("\n", $errors)); | ||||
| 		} | ||||
| 				$this->addToolbar(); | ||||
| 		 | ||||
| 		parent::display($tpl); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Add the page title and toolbar. | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	protected function addToolbar() | ||||
| 	{ | ||||
| 		Factory::getApplication()->input->set('hidemainmenu', true); | ||||
|  | ||||
| 		$user  = Factory::getApplication()->getIdentity(); | ||||
| 		$isNew = ($this->item->id == 0); | ||||
|  | ||||
| 		if (isset($this->item->checked_out)) | ||||
| 		{ | ||||
| 			$checkedOut = !($this->item->checked_out == 0 || $this->item->checked_out == $user->get('id')); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$checkedOut = false; | ||||
| 		} | ||||
|  | ||||
| 		$canDo = HighlightsHelper::getActions(); | ||||
|  | ||||
| 		ToolbarHelper::title(Text::_('COM_HIGHLIGHTS_TITLE_ETICHETTA'), "generic"); | ||||
|  | ||||
| 		// If not checked out, can save the item. | ||||
| 		if (!$checkedOut && ($canDo->get('core.edit') || ($canDo->get('core.create')))) | ||||
| 		{ | ||||
| 			ToolbarHelper::apply('etichetta.apply', 'JTOOLBAR_APPLY'); | ||||
| 			ToolbarHelper::save('etichetta.save', 'JTOOLBAR_SAVE'); | ||||
| 		} | ||||
|  | ||||
| 		if (!$checkedOut && ($canDo->get('core.create'))) | ||||
| 		{ | ||||
| 			ToolbarHelper::custom('etichetta.save2new', 'save-new.png', 'save-new_f2.png', 'JTOOLBAR_SAVE_AND_NEW', false); | ||||
| 		} | ||||
|  | ||||
| 		// If an existing item, can save to a copy. | ||||
| 		if (!$isNew && $canDo->get('core.create')) | ||||
| 		{ | ||||
| 			ToolbarHelper::custom('etichetta.save2copy', 'save-copy.png', 'save-copy_f2.png', 'JTOOLBAR_SAVE_AS_COPY', false); | ||||
| 		} | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		if (empty($this->item->id)) | ||||
| 		{ | ||||
| 			ToolbarHelper::cancel('etichetta.cancel', 'JTOOLBAR_CANCEL'); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			ToolbarHelper::cancel('etichetta.cancel', 'JTOOLBAR_CLOSE'); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,177 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\View\Etichette; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\MVC\View\HtmlView as BaseHtmlView; | ||||
| use \Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
| use \Joomla\CMS\Toolbar\Toolbar; | ||||
| use \Joomla\CMS\Toolbar\ToolbarHelper; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\Component\Content\Administrator\Extension\ContentComponent; | ||||
| use \Joomla\CMS\Form\Form; | ||||
| use \Joomla\CMS\HTML\Helpers\Sidebar; | ||||
| /** | ||||
|  * View class for a list of Etichette. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HtmlView extends BaseHtmlView | ||||
| { | ||||
| 	protected $items; | ||||
|  | ||||
| 	protected $pagination; | ||||
|  | ||||
| 	protected $state; | ||||
|  | ||||
| 	/** | ||||
| 	 * Display the view | ||||
| 	 * | ||||
| 	 * @param   string  $tpl  Template name | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	public function display($tpl = null) | ||||
| 	{ | ||||
| 		$this->state = $this->get('State'); | ||||
| 		$this->items = $this->get('Items'); | ||||
| 		$this->pagination = $this->get('Pagination'); | ||||
| 		$this->filterForm = $this->get('FilterForm'); | ||||
| 		$this->activeFilters = $this->get('ActiveFilters'); | ||||
|  | ||||
| 		// Check for errors. | ||||
| 		if (count($errors = $this->get('Errors'))) | ||||
| 		{ | ||||
| 			throw new \Exception(implode("\n", $errors)); | ||||
| 		} | ||||
|  | ||||
| 		$this->addToolbar(); | ||||
|  | ||||
| 		$this->sidebar = Sidebar::render(); | ||||
| 		parent::display($tpl); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Add the page title and toolbar. | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function addToolbar() | ||||
| 	{ | ||||
| 		$state = $this->get('State'); | ||||
| 		$canDo = HighlightsHelper::getActions(); | ||||
|  | ||||
| 		ToolbarHelper::title(Text::_('COM_HIGHLIGHTS_TITLE_ETICHETTE'), "generic"); | ||||
|  | ||||
| 		$toolbar = Toolbar::getInstance('toolbar'); | ||||
|  | ||||
| 		// Check if the form exists before showing the add/edit buttons | ||||
| 		$formPath = JPATH_COMPONENT_ADMINISTRATOR . '/src/View/Etichette'; | ||||
|  | ||||
| 		if (file_exists($formPath)) | ||||
| 		{ | ||||
| 			if ($canDo->get('core.create')) | ||||
| 			{ | ||||
| 				$toolbar->addNew('etichetta.add'); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ($canDo->get('core.edit.state')) | ||||
| 		{ | ||||
| 			$dropdown = $toolbar->dropdownButton('status-group') | ||||
| 				->text('JTOOLBAR_CHANGE_STATUS') | ||||
| 				->toggleSplit(false) | ||||
| 				->icon('fas fa-ellipsis-h') | ||||
| 				->buttonClass('btn btn-action') | ||||
| 				->listCheck(true); | ||||
|  | ||||
| 			$childBar = $dropdown->getChildToolbar(); | ||||
|  | ||||
| 			if (isset($this->items[0]->state)) | ||||
| 			{ | ||||
| 				$childBar->publish('etichette.publish')->listCheck(true); | ||||
| 				$childBar->unpublish('etichette.unpublish')->listCheck(true); | ||||
| 				$childBar->archive('etichette.archive')->listCheck(true); | ||||
| 			} | ||||
|  | ||||
| 			$childBar->standardButton('duplicate') | ||||
| 				->text('JTOOLBAR_DUPLICATE') | ||||
| 				->icon('fas fa-copy') | ||||
| 				->task('etichette.duplicate') | ||||
| 				->listCheck(true); | ||||
|  | ||||
| 			if (isset($this->items[0]->checked_out)) | ||||
| 			{ | ||||
| 				$childBar->checkin('etichette.checkin')->listCheck(true); | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->items[0]->state)) | ||||
| 			{ | ||||
| 				$childBar->trash('etichette.trash')->listCheck(true); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		// Show trash and delete for components that uses the state field | ||||
| 		if (isset($this->items[0]->state)) | ||||
| 		{ | ||||
|  | ||||
| 			if ($this->state->get('filter.state') == ContentComponent::CONDITION_TRASHED && $canDo->get('core.delete')) | ||||
| 			{ | ||||
| 				$toolbar->delete('etichette.delete') | ||||
| 					->text('JTOOLBAR_EMPTY_TRASH') | ||||
| 					->message('JGLOBAL_CONFIRM_DELETE') | ||||
| 					->listCheck(true); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ($canDo->get('core.admin')) | ||||
| 		{ | ||||
| 			$toolbar->preferences('com_highlights'); | ||||
| 		} | ||||
|  | ||||
| 		// Set sidebar action | ||||
| 		Sidebar::setAction('index.php?option=com_highlights&view=etichette'); | ||||
| 	} | ||||
| 	 | ||||
| 	/** | ||||
| 	 * Method to order fields  | ||||
| 	 * | ||||
| 	 * @return void  | ||||
| 	 */ | ||||
| 	protected function getSortFields() | ||||
| 	{ | ||||
| 		return array( | ||||
| 			'a.`id`' => Text::_('JGRID_HEADING_ID'), | ||||
| 			'a.`state`' => Text::_('JSTATUS'), | ||||
| 			'a.`ordering`' => Text::_('JGRID_HEADING_ORDERING'), | ||||
| 			'a.`nome`' => Text::_('COM_HIGHLIGHTS_ETICHETTE_NOME'), | ||||
| 			'a.`lingua`' => Text::_('COM_HIGHLIGHTS_ETICHETTE_LINGUA'), | ||||
| 		); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Check if state is set | ||||
| 	 * | ||||
| 	 * @param   mixed  $state  State | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function getState($state) | ||||
| 	{ | ||||
| 		return isset($this->state->{$state}) ? $this->state->{$state} : false; | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,114 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\View\Highlight; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use Joomla\CMS\MVC\View\HtmlView as BaseHtmlView; | ||||
| use \Joomla\CMS\Toolbar\ToolbarHelper; | ||||
| use \Joomla\CMS\Factory; | ||||
| use \Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
| use \Joomla\CMS\Language\Text; | ||||
|  | ||||
| /** | ||||
|  * View class for a single Highlight. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HtmlView extends BaseHtmlView | ||||
| { | ||||
| 	protected $state; | ||||
|  | ||||
| 	protected $item; | ||||
|  | ||||
| 	protected $form; | ||||
|  | ||||
| 	/** | ||||
| 	 * Display the view | ||||
| 	 * | ||||
| 	 * @param   string  $tpl  Template name | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	public function display($tpl = null) | ||||
| 	{ | ||||
| 		$this->state = $this->get('State'); | ||||
| 		$this->item  = $this->get('Item'); | ||||
| 		$this->form  = $this->get('Form'); | ||||
|  | ||||
| 		// Check for errors. | ||||
| 		if (count($errors = $this->get('Errors'))) | ||||
| 		{ | ||||
| 			throw new \Exception(implode("\n", $errors)); | ||||
| 		} | ||||
| 				$this->addToolbar(); | ||||
| 		 | ||||
| 		parent::display($tpl); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Add the page title and toolbar. | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	protected function addToolbar() | ||||
| 	{ | ||||
| 		Factory::getApplication()->input->set('hidemainmenu', true); | ||||
|  | ||||
| 		$user  = Factory::getApplication()->getIdentity(); | ||||
| 		$isNew = ($this->item->id == 0); | ||||
|  | ||||
| 		if (isset($this->item->checked_out)) | ||||
| 		{ | ||||
| 			$checkedOut = !($this->item->checked_out == 0 || $this->item->checked_out == $user->get('id')); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$checkedOut = false; | ||||
| 		} | ||||
|  | ||||
| 		$canDo = HighlightsHelper::getActions(); | ||||
|  | ||||
| 		ToolbarHelper::title(Text::_('COM_HIGHLIGHTS_TITLE_HIGHLIGHT'), "generic"); | ||||
|  | ||||
| 		// If not checked out, can save the item. | ||||
| 		if (!$checkedOut && ($canDo->get('core.edit') || ($canDo->get('core.create')))) | ||||
| 		{ | ||||
| 			ToolbarHelper::apply('highlight.apply', 'JTOOLBAR_APPLY'); | ||||
| 			ToolbarHelper::save('highlight.save', 'JTOOLBAR_SAVE'); | ||||
| 		} | ||||
|  | ||||
| 		if (!$checkedOut && ($canDo->get('core.create'))) | ||||
| 		{ | ||||
| 			ToolbarHelper::custom('highlight.save2new', 'save-new.png', 'save-new_f2.png', 'JTOOLBAR_SAVE_AND_NEW', false); | ||||
| 		} | ||||
|  | ||||
| 		// If an existing item, can save to a copy. | ||||
| 		if (!$isNew && $canDo->get('core.create')) | ||||
| 		{ | ||||
| 			ToolbarHelper::custom('highlight.save2copy', 'save-copy.png', 'save-copy_f2.png', 'JTOOLBAR_SAVE_AS_COPY', false); | ||||
| 		} | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		if (empty($this->item->id)) | ||||
| 		{ | ||||
| 			ToolbarHelper::cancel('highlight.cancel', 'JTOOLBAR_CANCEL'); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			ToolbarHelper::cancel('highlight.cancel', 'JTOOLBAR_CLOSE'); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @ -0,0 +1,177 @@ | ||||
| <?php | ||||
| /** | ||||
|  * @version    CVS: 1.0.0 | ||||
|  * @package    Com_Highlights | ||||
|  * @author     Eddy Prosperi <eddy.prosperi@protocollicreativi.it> | ||||
|  * @copyright  2024 Eddy Prosperi | ||||
|  * @license    GNU General Public License versione 2 o successiva; vedi LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| namespace Pcrt\Component\Highlights\Administrator\View\Highlights; | ||||
| // No direct access | ||||
| defined('_JEXEC') or die; | ||||
|  | ||||
| use \Joomla\CMS\MVC\View\HtmlView as BaseHtmlView; | ||||
| use \Pcrt\Component\Highlights\Administrator\Helper\HighlightsHelper; | ||||
| use \Joomla\CMS\Toolbar\Toolbar; | ||||
| use \Joomla\CMS\Toolbar\ToolbarHelper; | ||||
| use \Joomla\CMS\Language\Text; | ||||
| use \Joomla\Component\Content\Administrator\Extension\ContentComponent; | ||||
| use \Joomla\CMS\Form\Form; | ||||
| use \Joomla\CMS\HTML\Helpers\Sidebar; | ||||
| /** | ||||
|  * View class for a list of Highlights. | ||||
|  * | ||||
|  * @since  1.0.0 | ||||
|  */ | ||||
| class HtmlView extends BaseHtmlView | ||||
| { | ||||
| 	protected $items; | ||||
|  | ||||
| 	protected $pagination; | ||||
|  | ||||
| 	protected $state; | ||||
|  | ||||
| 	/** | ||||
| 	 * Display the view | ||||
| 	 * | ||||
| 	 * @param   string  $tpl  Template name | ||||
| 	 * | ||||
| 	 * @return void | ||||
| 	 * | ||||
| 	 * @throws Exception | ||||
| 	 */ | ||||
| 	public function display($tpl = null) | ||||
| 	{ | ||||
| 		$this->state = $this->get('State'); | ||||
| 		$this->items = $this->get('Items'); | ||||
| 		$this->pagination = $this->get('Pagination'); | ||||
| 		$this->filterForm = $this->get('FilterForm'); | ||||
| 		$this->activeFilters = $this->get('ActiveFilters'); | ||||
|  | ||||
| 		// Check for errors. | ||||
| 		if (count($errors = $this->get('Errors'))) | ||||
| 		{ | ||||
| 			throw new \Exception(implode("\n", $errors)); | ||||
| 		} | ||||
|  | ||||
| 		$this->addToolbar(); | ||||
|  | ||||
| 		$this->sidebar = Sidebar::render(); | ||||
| 		parent::display($tpl); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Add the page title and toolbar. | ||||
| 	 * | ||||
| 	 * @return  void | ||||
| 	 * | ||||
| 	 * @since   1.0.0 | ||||
| 	 */ | ||||
| 	protected function addToolbar() | ||||
| 	{ | ||||
| 		$state = $this->get('State'); | ||||
| 		$canDo = HighlightsHelper::getActions(); | ||||
|  | ||||
| 		ToolbarHelper::title(Text::_('COM_HIGHLIGHTS_TITLE_HIGHLIGHTS'), "generic"); | ||||
|  | ||||
| 		$toolbar = Toolbar::getInstance('toolbar'); | ||||
|  | ||||
| 		// Check if the form exists before showing the add/edit buttons | ||||
| 		$formPath = JPATH_COMPONENT_ADMINISTRATOR . '/src/View/Highlights'; | ||||
|  | ||||
| 		if (file_exists($formPath)) | ||||
| 		{ | ||||
| 			if ($canDo->get('core.create')) | ||||
| 			{ | ||||
| 				$toolbar->addNew('highlight.add'); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ($canDo->get('core.edit.state')) | ||||
| 		{ | ||||
| 			$dropdown = $toolbar->dropdownButton('status-group') | ||||
| 				->text('JTOOLBAR_CHANGE_STATUS') | ||||
| 				->toggleSplit(false) | ||||
| 				->icon('fas fa-ellipsis-h') | ||||
| 				->buttonClass('btn btn-action') | ||||
| 				->listCheck(true); | ||||
|  | ||||
| 			$childBar = $dropdown->getChildToolbar(); | ||||
|  | ||||
| 			if (isset($this->items[0]->state)) | ||||
| 			{ | ||||
| 				$childBar->publish('highlights.publish')->listCheck(true); | ||||
| 				$childBar->unpublish('highlights.unpublish')->listCheck(true); | ||||
| 				$childBar->archive('highlights.archive')->listCheck(true); | ||||
| 			} | ||||
|  | ||||
| 			$childBar->standardButton('duplicate') | ||||
| 				->text('JTOOLBAR_DUPLICATE') | ||||
| 				->icon('fas fa-copy') | ||||
| 				->task('highlights.duplicate') | ||||
| 				->listCheck(true); | ||||
|  | ||||
| 			if (isset($this->items[0]->checked_out)) | ||||
| 			{ | ||||
| 				$childBar->checkin('highlights.checkin')->listCheck(true); | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->items[0]->state)) | ||||
| 			{ | ||||
| 				$childBar->trash('highlights.trash')->listCheck(true); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		 | ||||
|  | ||||
| 		// Show trash and delete for components that uses the state field | ||||
| 		if (isset($this->items[0]->state)) | ||||
| 		{ | ||||
|  | ||||
| 			if ($this->state->get('filter.state') == ContentComponent::CONDITION_TRASHED && $canDo->get('core.delete')) | ||||
| 			{ | ||||
| 				$toolbar->delete('highlights.delete') | ||||
| 					->text('JTOOLBAR_EMPTY_TRASH') | ||||
| 					->message('JGLOBAL_CONFIRM_DELETE') | ||||
| 					->listCheck(true); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ($canDo->get('core.admin')) | ||||
| 		{ | ||||
| 			$toolbar->preferences('com_highlights'); | ||||
| 		} | ||||
|  | ||||
| 		// Set sidebar action | ||||
| 		Sidebar::setAction('index.php?option=com_highlights&view=highlights'); | ||||
| 	} | ||||
| 	 | ||||
| 	/** | ||||
| 	 * Method to order fields  | ||||
| 	 * | ||||
| 	 * @return void  | ||||
| 	 */ | ||||
| 	protected function getSortFields() | ||||
| 	{ | ||||
| 		return array( | ||||
| 			'a.`id`' => Text::_('JGRID_HEADING_ID'), | ||||
| 			'a.`state`' => Text::_('JSTATUS'), | ||||
| 			'a.`ordering`' => Text::_('JGRID_HEADING_ORDERING'), | ||||
| 			'a.`etichetta`' => Text::_('COM_HIGHLIGHTS_HIGHLIGHTS_ETICHETTA'), | ||||
| 			'a.`titolo`' => Text::_('COM_HIGHLIGHTS_HIGHLIGHTS_TITOLO'), | ||||
| 		); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Check if state is set | ||||
| 	 * | ||||
| 	 * @param   mixed  $state  State | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function getState($state) | ||||
| 	{ | ||||
| 		return isset($this->state->{$state}) ? $this->state->{$state} : false; | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user