first commit
This commit is contained in:
21
plugins/system/guidedtours/guidedtours.xml
Normal file
21
plugins/system/guidedtours/guidedtours.xml
Normal file
@ -0,0 +1,21 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<extension type="plugin" group="system" method="upgrade">
|
||||
<name>plg_system_guidedtours</name>
|
||||
<author>Joomla! Project</author>
|
||||
<creationDate>2023-02</creationDate>
|
||||
<copyright>(C) 2023 Open Source Matters, Inc.</copyright>
|
||||
<license>GNU General Public License version 2 or later; see LICENSE.txt</license>
|
||||
<authorEmail>admin@joomla.org</authorEmail>
|
||||
<authorUrl>www.joomla.org</authorUrl>
|
||||
<version>4.3.0</version>
|
||||
<description>PLG_SYSTEM_GUIDEDTOURS_DESCRIPTION</description>
|
||||
<namespace path="src">Joomla\Plugin\System\GuidedTours</namespace>
|
||||
<files>
|
||||
<folder plugin="guidedtours">services</folder>
|
||||
<folder>src</folder>
|
||||
</files>
|
||||
<languages>
|
||||
<language tag="en-GB">language/en-GB/plg_system_guidedtours.ini</language>
|
||||
<language tag="en-GB">language/en-GB/plg_system_guidedtours.sys.ini</language>
|
||||
</languages>
|
||||
</extension>
|
||||
55
plugins/system/guidedtours/services/provider.php
Normal file
55
plugins/system/guidedtours/services/provider.php
Normal file
@ -0,0 +1,55 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @package Joomla.Plugin
|
||||
* @subpackage System.guidedtours
|
||||
*
|
||||
* @copyright (C) 2023 Open Source Matters, Inc. <https://www.joomla.org>
|
||||
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||
*/
|
||||
|
||||
\defined('_JEXEC') or die;
|
||||
|
||||
use Joomla\CMS\Extension\PluginInterface;
|
||||
use Joomla\CMS\Factory;
|
||||
use Joomla\CMS\Plugin\PluginHelper;
|
||||
use Joomla\CMS\WebAsset\WebAssetRegistry;
|
||||
use Joomla\DI\Container;
|
||||
use Joomla\DI\ServiceProviderInterface;
|
||||
use Joomla\Event\DispatcherInterface;
|
||||
use Joomla\Plugin\System\GuidedTours\Extension\GuidedTours;
|
||||
|
||||
return new class () implements ServiceProviderInterface {
|
||||
/**
|
||||
* Registers the service provider with a DI container.
|
||||
*
|
||||
* @param Container $container The DI container.
|
||||
*
|
||||
* @return void
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
public function register(Container $container)
|
||||
{
|
||||
$container->set(
|
||||
PluginInterface::class,
|
||||
function (Container $container) {
|
||||
$app = Factory::getApplication();
|
||||
|
||||
$plugin = new GuidedTours(
|
||||
$container->get(DispatcherInterface::class),
|
||||
(array) PluginHelper::getPlugin('system', 'guidedtours'),
|
||||
$app->isClient('administrator')
|
||||
);
|
||||
|
||||
$plugin->setApplication($app);
|
||||
|
||||
$wa = $container->get(WebAssetRegistry::class);
|
||||
|
||||
$wa->addRegistryFile('media/plg_system_guidedtours/joomla.asset.json');
|
||||
|
||||
return $plugin;
|
||||
}
|
||||
);
|
||||
}
|
||||
};
|
||||
260
plugins/system/guidedtours/src/Extension/GuidedTours.php
Normal file
260
plugins/system/guidedtours/src/Extension/GuidedTours.php
Normal file
@ -0,0 +1,260 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @package Joomla.Plugin
|
||||
* @subpackage System.guidedtours
|
||||
*
|
||||
* @copyright (C) 2023 Open Source Matters, Inc. <https://www.joomla.org>
|
||||
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||
*/
|
||||
|
||||
namespace Joomla\Plugin\System\GuidedTours\Extension;
|
||||
|
||||
use Joomla\CMS\Language\Text;
|
||||
use Joomla\CMS\Plugin\CMSPlugin;
|
||||
use Joomla\CMS\Session\Session;
|
||||
use Joomla\Component\Guidedtours\Administrator\Extension\GuidedtoursComponent;
|
||||
use Joomla\Event\DispatcherInterface;
|
||||
use Joomla\Event\Event;
|
||||
use Joomla\Event\SubscriberInterface;
|
||||
|
||||
// phpcs:disable PSR1.Files.SideEffects
|
||||
\defined('_JEXEC') or die;
|
||||
// phpcs:enable PSR1.Files.SideEffects
|
||||
|
||||
/**
|
||||
* Guided Tours plugin to add interactive tours to the administrator interface.
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
final class GuidedTours extends CMSPlugin implements SubscriberInterface
|
||||
{
|
||||
/**
|
||||
* A mapping for the step types
|
||||
*
|
||||
* @var string[]
|
||||
* @since 4.3.0
|
||||
*/
|
||||
protected $stepType = [
|
||||
GuidedtoursComponent::STEP_NEXT => 'next',
|
||||
GuidedtoursComponent::STEP_REDIRECT => 'redirect',
|
||||
GuidedtoursComponent::STEP_INTERACTIVE => 'interactive',
|
||||
];
|
||||
|
||||
/**
|
||||
* A mapping for the step interactive types
|
||||
*
|
||||
* @var string[]
|
||||
* @since 4.3.0
|
||||
*/
|
||||
protected $stepInteractiveType = [
|
||||
GuidedtoursComponent::STEP_INTERACTIVETYPE_FORM_SUBMIT => 'submit',
|
||||
GuidedtoursComponent::STEP_INTERACTIVETYPE_TEXT => 'text',
|
||||
GuidedtoursComponent::STEP_INTERACTIVETYPE_OTHER => 'other',
|
||||
GuidedtoursComponent::STEP_INTERACTIVETYPE_BUTTON => 'button',
|
||||
];
|
||||
|
||||
/**
|
||||
* An internal flag whether plugin should listen any event.
|
||||
*
|
||||
* @var bool
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
protected static $enabled = false;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @param DispatcherInterface $dispatcher The object to observe
|
||||
* @param array $config An optional associative array of configuration settings.
|
||||
* @param boolean $enabled An internal flag whether plugin should listen any event.
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
public function __construct(DispatcherInterface $dispatcher, array $config = [], bool $enabled = false)
|
||||
{
|
||||
self::$enabled = $enabled;
|
||||
|
||||
parent::__construct($dispatcher, $config);
|
||||
}
|
||||
|
||||
/**
|
||||
* function for getSubscribedEvents : new Joomla 4 feature
|
||||
*
|
||||
* @return array
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
public static function getSubscribedEvents(): array
|
||||
{
|
||||
return self::$enabled ? [
|
||||
'onAjaxGuidedtours' => 'startTour',
|
||||
'onBeforeCompileHead' => 'onBeforeCompileHead',
|
||||
] : [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve and starts a tour and its steps through Ajax.
|
||||
*
|
||||
* @return null|object
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
public function startTour(Event $event)
|
||||
{
|
||||
$tourId = (int) $this->getApplication()->getInput()->getInt('id');
|
||||
$tourUid = $this->getApplication()->getInput()->getString('uid', '');
|
||||
$tourUid = $tourUid !== '' ? urldecode($tourUid) : '';
|
||||
|
||||
$tour = null;
|
||||
|
||||
// Load plugin language files
|
||||
$this->loadLanguage();
|
||||
|
||||
if ($tourId > 0) {
|
||||
$tour = $this->getTour($tourId);
|
||||
} elseif ($tourUid !== '') {
|
||||
$tour = $this->getTour($tourUid);
|
||||
}
|
||||
|
||||
$event->setArgument('result', $tour ?? new \stdClass());
|
||||
|
||||
return $tour;
|
||||
}
|
||||
|
||||
/**
|
||||
* Listener for the `onBeforeCompileHead` event
|
||||
*
|
||||
* @return void
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
public function onBeforeCompileHead()
|
||||
{
|
||||
$app = $this->getApplication();
|
||||
$doc = $app->getDocument();
|
||||
$user = $app->getIdentity();
|
||||
|
||||
if ($user != null && $user->id > 0) {
|
||||
// Load plugin language files
|
||||
$this->loadLanguage();
|
||||
|
||||
Text::script('JCANCEL');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_BACK');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_COMPLETE');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_COULD_NOT_LOAD_THE_TOUR');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_NEXT');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_START');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_STEP_NUMBER_OF');
|
||||
Text::script('PLG_SYSTEM_GUIDEDTOURS_TOUR_ERROR');
|
||||
|
||||
$doc->addScriptOptions('com_guidedtours.token', Session::getFormToken());
|
||||
|
||||
// Load required assets
|
||||
$doc->getWebAssetManager()
|
||||
->usePreset('plg_system_guidedtours.guidedtours');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a tour and its steps or null if not found
|
||||
*
|
||||
* @param integer|string $tourId The ID or Uid of the tour to load
|
||||
*
|
||||
* @return null|object
|
||||
*
|
||||
* @since 4.3.0
|
||||
*/
|
||||
private function getTour($tourId)
|
||||
{
|
||||
$app = $this->getApplication();
|
||||
|
||||
$factory = $app->bootComponent('com_guidedtours')->getMVCFactory();
|
||||
|
||||
$tourModel = $factory->createModel(
|
||||
'Tour',
|
||||
'Administrator',
|
||||
['ignore_request' => true]
|
||||
);
|
||||
|
||||
$item = $tourModel->getItem($tourId);
|
||||
|
||||
return $this->processTour($item);
|
||||
}
|
||||
|
||||
/**
|
||||
* Return a tour and its steps or null if not found
|
||||
*
|
||||
* @param TourTable $item The tour to load
|
||||
*
|
||||
* @return null|object
|
||||
*
|
||||
* @since 5.0.0
|
||||
*/
|
||||
private function processTour($item)
|
||||
{
|
||||
$app = $this->getApplication();
|
||||
|
||||
$user = $app->getIdentity();
|
||||
$factory = $app->bootComponent('com_guidedtours')->getMVCFactory();
|
||||
|
||||
if (empty($item->id) || $item->published < 1 || !\in_array($item->access, $user->getAuthorisedViewLevels())) {
|
||||
return null;
|
||||
}
|
||||
|
||||
// We don't want to show all parameters, so take only a subset of the tour attributes
|
||||
$tour = new \stdClass();
|
||||
|
||||
$tour->id = $item->id;
|
||||
|
||||
$stepsModel = $factory->createModel(
|
||||
'Steps',
|
||||
'Administrator',
|
||||
['ignore_request' => true]
|
||||
);
|
||||
|
||||
$stepsModel->setState('filter.tour_id', $item->id);
|
||||
$stepsModel->setState('filter.published', 1);
|
||||
$stepsModel->setState('list.ordering', 'a.ordering');
|
||||
$stepsModel->setState('list.direction', 'ASC');
|
||||
|
||||
$steps = $stepsModel->getItems();
|
||||
|
||||
$tour->steps = [];
|
||||
|
||||
$temp = new \stdClass();
|
||||
|
||||
$temp->id = 0;
|
||||
$temp->title = $this->getApplication()->getLanguage()->_($item->title);
|
||||
$temp->description = $this->getApplication()->getLanguage()->_($item->description);
|
||||
$temp->url = $item->url;
|
||||
|
||||
// Replace 'images/' to '../images/' when using an image from /images in backend.
|
||||
$temp->description = preg_replace('*src\=\"(?!administrator\/)images/*', 'src="../images/', $temp->description);
|
||||
|
||||
$tour->steps[] = $temp;
|
||||
|
||||
foreach ($steps as $i => $step) {
|
||||
$temp = new \stdClass();
|
||||
|
||||
$temp->id = $i + 1;
|
||||
$temp->title = $this->getApplication()->getLanguage()->_($step->title);
|
||||
$temp->description = $this->getApplication()->getLanguage()->_($step->description);
|
||||
$temp->position = $step->position;
|
||||
$temp->target = $step->target;
|
||||
$temp->type = $this->stepType[$step->type];
|
||||
$temp->interactive_type = $this->stepInteractiveType[$step->interactive_type];
|
||||
$temp->url = $step->url;
|
||||
$temp->tour_id = $step->tour_id;
|
||||
$temp->step_id = $step->id;
|
||||
|
||||
// Replace 'images/' to '../images/' when using an image from /images in backend.
|
||||
$temp->description = preg_replace('*src\=\"(?!administrator\/)images/*', 'src="../images/', $temp->description);
|
||||
|
||||
$tour->steps[] = $temp;
|
||||
}
|
||||
|
||||
return $tour;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user