2023-07-24 21:18:56 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This file is part of Zwii.
|
|
|
|
*
|
|
|
|
* For full copyright and license information, please see the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*
|
|
|
|
* @author Rémi Jean <remi.jean@outlook.com>
|
|
|
|
* @copyright Copyright (C) 2008-2018, Rémi Jean
|
|
|
|
* @author Frédéric Tempez <frederic.tempez@outlook.com>
|
|
|
|
* @copyright Copyright (C) 2018-2020, Frédéric Tempez
|
|
|
|
* @license GNU General Public License, version 3
|
|
|
|
* @link http://zwiicms.com/
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
class slider extends common
|
|
|
|
{
|
|
|
|
|
|
|
|
public static $actions = [
|
|
|
|
'config' => self::GROUP_MODERATOR,
|
|
|
|
'update' => self::GROUP_MODERATOR,
|
|
|
|
'theme' => self::GROUP_MODERATOR,
|
|
|
|
'delete' => self::GROUP_MODERATOR,
|
|
|
|
'dirs' => self::GROUP_MODERATOR,
|
|
|
|
'index' => self::GROUP_VISITOR
|
|
|
|
];
|
|
|
|
|
2024-08-19 10:11:29 +02:00
|
|
|
const VERSION = '6.6';
|
2023-07-24 21:18:56 +02:00
|
|
|
const REALNAME = 'Carrousel';
|
|
|
|
const DELETE = true;
|
|
|
|
const UPDATE = '0.0';
|
|
|
|
const DATADIRECTORY = ''; // Contenu localisé inclus par défaut (page.json et module.json)
|
|
|
|
|
|
|
|
public static $directories = [];
|
|
|
|
|
|
|
|
public static $firstPictures = [];
|
|
|
|
|
|
|
|
public static $galleries = [];
|
|
|
|
|
|
|
|
public static $pictures = [];
|
|
|
|
|
|
|
|
public static $pageList = [];
|
|
|
|
|
|
|
|
//Visibilité des boutons de navigation
|
|
|
|
public static $namespace = [
|
|
|
|
'white-btns' => 'Blancs',
|
|
|
|
'centered-btns' => 'Noirs',
|
|
|
|
'transparent-btns' => 'Bandes invisibles',
|
|
|
|
'large-btns' => 'Bandes grises',
|
|
|
|
];
|
|
|
|
|
|
|
|
// Pager
|
|
|
|
public static $pager = [
|
|
|
|
true => 'Puces visibles',
|
|
|
|
false => 'Puces invisibles'
|
|
|
|
];
|
|
|
|
|
|
|
|
public static $auto = [
|
|
|
|
true => 'Active',
|
|
|
|
false => 'Inactive'
|
|
|
|
];
|
|
|
|
|
|
|
|
// Largeur
|
|
|
|
public static $screenWidth = [
|
|
|
|
640 => '640 pixels',
|
|
|
|
720 => '720 pixels',
|
|
|
|
768 => '768 pixels',
|
|
|
|
800 => '800 pixels',
|
|
|
|
854 => '854 pixels',
|
|
|
|
1024 => '1024 pixels',
|
|
|
|
1280 => '1280 pixels',
|
|
|
|
1400 => '1400 pixels',
|
|
|
|
1600 => '1600 pixels',
|
|
|
|
1920 => '1920 pixels',
|
|
|
|
0 => 'Largeur de l\'écran'
|
|
|
|
];
|
2024-08-19 10:11:29 +02:00
|
|
|
public static $selectedMaxwidth = 640;
|
2023-07-24 21:18:56 +02:00
|
|
|
|
|
|
|
// Transition
|
|
|
|
public static $speed = [
|
|
|
|
'500' => '500 ms',
|
|
|
|
'1000' => '1 s',
|
|
|
|
'1500' => '1.5 s',
|
|
|
|
'2000' => '2 s',
|
|
|
|
'2500' => '2.5 s',
|
|
|
|
'3000' => '3 s',
|
|
|
|
'3500' => '3.5 s'
|
|
|
|
];
|
|
|
|
|
|
|
|
// Imeout
|
|
|
|
public static $timeout = [
|
|
|
|
'500' => '500 ms',
|
|
|
|
'1000' => '1 s',
|
|
|
|
'1500' => '1.5 s',
|
|
|
|
'2000' => '2 s',
|
|
|
|
'3000' => '3 s',
|
|
|
|
'5000' => '5 s',
|
|
|
|
'7000' => '7 s',
|
|
|
|
'10000' => '10 s'
|
|
|
|
];
|
|
|
|
|
|
|
|
//Visibilité de la légende
|
|
|
|
public static $visibilite_legende = [
|
|
|
|
'survol' => 'Au survol',
|
|
|
|
'toujours' => 'Toujours visible',
|
|
|
|
'jamais' => 'Jamais visible'
|
|
|
|
];
|
|
|
|
|
|
|
|
//Position de la légende
|
|
|
|
public static $position_legende = [
|
|
|
|
'haut' => 'En haut',
|
|
|
|
'bas' => 'En bas'
|
|
|
|
];
|
|
|
|
|
|
|
|
//Temps d'apparition légende et boutons
|
|
|
|
public static $apparition = [
|
|
|
|
'opacity 0.2s ease-in' => '0.2s',
|
|
|
|
'opacity 0.5s ease-in' => '0.5s',
|
|
|
|
'opacity 1s ease-in' => '1s',
|
|
|
|
'opacity 2s ease-in' => '2s'
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
//Choix du tri
|
|
|
|
public static $sort = [
|
2024-08-19 10:11:29 +02:00
|
|
|
'dsc' => 'Alphabétique naturel',
|
|
|
|
'asc' => 'Alphabétique naturel inverse',
|
2023-07-24 21:18:56 +02:00
|
|
|
'rand' => 'Aléatoire',
|
|
|
|
'none' => 'Par défaut, sans tri',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Mise à jour du dossier
|
|
|
|
*/
|
|
|
|
public function update()
|
|
|
|
{
|
|
|
|
// Soumission du formulaire
|
|
|
|
if ($this->isPost()) {
|
|
|
|
$this->setData([
|
|
|
|
'module',
|
|
|
|
$this->getUrl(0),
|
|
|
|
'directory',
|
|
|
|
$this->getInput('galleryUpdateDirectory', helper::FILTER_STRING_SHORT, true)
|
|
|
|
]);
|
|
|
|
$this->addOutput([
|
|
|
|
'redirect' => helper::baseUrl() . $this->getUrl(0) . '/config',
|
|
|
|
'notification' => 'Modifications enregistrées',
|
|
|
|
'state' => true
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'title' => 'Configuration de la galerie',
|
|
|
|
'view' => 'update'
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Configuration
|
|
|
|
*/
|
|
|
|
public function config()
|
|
|
|
{
|
|
|
|
// Initialise le module
|
|
|
|
$this->init();
|
|
|
|
|
|
|
|
// Liste des pages active à l'exclusion des barres latérales
|
|
|
|
$pagesId = $this->getHierarchy(null, false, null);
|
|
|
|
$excludeBar = $this->getHierarchy(null, false, true);
|
|
|
|
$pagesId = array_diff_key($pagesId, $excludeBar);
|
|
|
|
|
|
|
|
// Construit le tableau pour le select du formulaire
|
|
|
|
foreach ($pagesId as $parentKey => $parentValue) {
|
|
|
|
self::$pageList[$parentKey] = $this->getData(['page', $parentKey, 'title']);
|
|
|
|
foreach ($parentValue as $childKey) {
|
|
|
|
self::$pageList[$childKey] = $this->getData(['page', $childKey, 'title']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Aucun choix
|
|
|
|
self::$pageList = array_merge([0 => ''], self::$pageList);
|
|
|
|
|
|
|
|
// Soumission du formulaire
|
2023-08-28 11:02:38 +02:00
|
|
|
if (
|
|
|
|
$this->getUser('permission', __CLASS__, __FUNCTION__) === true &&
|
|
|
|
$this->isPost()
|
|
|
|
) {
|
2023-07-24 21:18:56 +02:00
|
|
|
|
|
|
|
$inputs['legends'] = $this->getInput('legends', null);
|
|
|
|
$inputs['uri'] = $this->getInput('sliderHref', null);
|
|
|
|
|
|
|
|
// Supprime les points devant les extensions des clés à cause du système de BDD
|
|
|
|
foreach ($inputs as $keyinputs => $valuesinputs) {
|
|
|
|
foreach ($valuesinputs as $keyinput => $valueinput) {
|
|
|
|
$datas[$keyinputs][str_replace('.', '', $keyinput)] = $valueinput;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->setData([
|
|
|
|
'module',
|
|
|
|
$this->getUrl(0),
|
|
|
|
[
|
|
|
|
'directory' => $this->getData(['module', $this->getUrl(0), 'directory']),
|
|
|
|
'theme' => $this->getData(['module', $this->getUrl(0), 'theme']),
|
|
|
|
'legends' => $datas['legends'],
|
|
|
|
'uri' => $datas['uri']
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
$this->addOutput([
|
|
|
|
'redirect' => helper::baseUrl() . $this->getUrl(0) . '/config',
|
|
|
|
'notification' => 'Modifications enregistrées',
|
|
|
|
'state' => true
|
|
|
|
]);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// Met en forme le tableau
|
|
|
|
$directory = $this->getData(['module', $this->getUrl(0), 'directory']);
|
|
|
|
if ($directory && is_dir($directory)) {
|
|
|
|
$iterator = new DirectoryIterator($directory);
|
|
|
|
foreach ($iterator as $fileInfos) {
|
|
|
|
if ($fileInfos->isDot() === false and $fileInfos->isFile() and @getimagesize($fileInfos->getPathname())) {
|
|
|
|
self::$pictures[$fileInfos->getFilename()] = [
|
|
|
|
$fileInfos->getFilename(),
|
|
|
|
template::text('legends[' . $fileInfos->getFilename() . ']', [
|
|
|
|
'value' => empty($this->getData(['module', $this->getUrl(0), 'legends', str_replace('.', '', $fileInfos->getFilename())]))
|
2023-11-02 15:07:29 +01:00
|
|
|
? ''
|
|
|
|
: $this->getData(['module', $this->getUrl(0), 'legends', str_replace('.', '', $fileInfos->getFilename())])
|
2023-07-24 21:18:56 +02:00
|
|
|
]),
|
|
|
|
template::select('sliderHref[' . $fileInfos->getFilename() . ']', self::$pageList, [
|
|
|
|
'selected' => empty($this->getData(['module', $this->getUrl(0), 'uri', str_replace('.', '', $fileInfos->getFilename())]))
|
2023-11-02 15:07:29 +01:00
|
|
|
? ''
|
|
|
|
: $this->getData(['module', $this->getUrl(0), 'uri', str_replace('.', '', $fileInfos->getFilename())])
|
2023-07-24 21:18:56 +02:00
|
|
|
]),
|
|
|
|
'<a href="' . str_replace('source', 'thumb', $directory) . '/' . self::THUMBS_SEPARATOR . $fileInfos->getFilename() . '" rel="data-lity" data-lity=""><img src="' . str_replace('source', 'thumb', $directory) . '/' . $fileInfos->getFilename() . '"></a>'
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
2024-08-19 15:46:45 +02:00
|
|
|
// Tri des images par ordre alphabétique, alphabétique inverse, aléatoire ou pas
|
|
|
|
switch ($this->getData(['module', $this->getUrl(0), 'theme', 'sort'])) {
|
|
|
|
case 'asc':
|
|
|
|
krsort(self::$pictures, SORT_NATURAL | SORT_FLAG_CASE);
|
|
|
|
break;
|
|
|
|
case 'dsc':
|
|
|
|
ksort(self::$pictures, SORT_NATURAL | SORT_FLAG_CASE);
|
|
|
|
break;
|
|
|
|
case 'rand':
|
|
|
|
// Récupérer les clés du tableau
|
|
|
|
$keys = array_keys(self::$pictures);
|
|
|
|
// Mélanger les clés
|
|
|
|
shuffle($keys);
|
|
|
|
// Créer un nouveau tableau avec les clés mélangées
|
|
|
|
$shuffledPictures = [];
|
|
|
|
foreach ($keys as $key) {
|
|
|
|
$shuffledPictures[$key] = self::$pictures[$key];
|
|
|
|
}
|
|
|
|
// Mettre à jour le tableau initial avec le nouveau tableau mélangé
|
|
|
|
self::$pictures = $shuffledPictures;
|
|
|
|
break;
|
|
|
|
case 'none':
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2023-07-24 21:18:56 +02:00
|
|
|
}
|
|
|
|
|
2024-08-19 15:46:45 +02:00
|
|
|
|
2023-07-24 21:18:56 +02:00
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'title' => 'Configuration du module',
|
|
|
|
'view' => 'config'
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Suppression
|
|
|
|
*/
|
|
|
|
public function delete()
|
|
|
|
{
|
|
|
|
// $url prend l'adresse sans le token
|
|
|
|
// La galerie n'existe pas
|
2023-11-15 09:23:41 +01:00
|
|
|
if (
|
|
|
|
$this->getUser('permission', __CLASS__, __FUNCTION__) !== true ||
|
|
|
|
$this->getData(['module', $this->getUrl(0), $this->getUrl(2)]) === null
|
|
|
|
) {
|
2023-07-24 21:18:56 +02:00
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'access' => false
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
// Suppression
|
|
|
|
else {
|
|
|
|
$this->deleteData(['module', $this->getUrl(0), $this->getUrl(2)]);
|
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'redirect' => helper::baseUrl() . $this->getUrl(0) . '/config',
|
|
|
|
'notification' => 'Galerie supprimée',
|
|
|
|
'state' => true
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Liste des dossiers
|
|
|
|
*/
|
|
|
|
public function dirs()
|
|
|
|
{
|
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'display' => self::DISPLAY_JSON,
|
|
|
|
'content' => $this->scanSubDir(self::FILE_DIR . 'source')
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Édition
|
|
|
|
*/
|
|
|
|
public function theme()
|
|
|
|
{
|
|
|
|
// Soumission du formulaire
|
2023-11-15 09:23:41 +01:00
|
|
|
if (
|
|
|
|
$this->getUser('permission', __CLASS__, __FUNCTION__) === true &&
|
|
|
|
$this->isPost()
|
|
|
|
) {
|
2023-07-24 21:18:56 +02:00
|
|
|
|
|
|
|
// Equilibrer les durées
|
|
|
|
$speed = $this->getInput('sliderThemespeed', helper::FILTER_INT);
|
|
|
|
$timeout = $this->getInput('sliderThemeDiapoTime', helper::FILTER_INT);
|
|
|
|
if ($speed >= $timeout) {
|
|
|
|
// Valeurs en sortie
|
2023-08-28 11:02:38 +02:00
|
|
|
$notification = 'La durée de transition doit inférieure à la durée de l`\'image fixe';
|
|
|
|
$state = false;
|
2023-07-24 21:18:56 +02:00
|
|
|
} else {
|
|
|
|
|
|
|
|
$this->setData([
|
|
|
|
'module',
|
|
|
|
$this->getUrl(0),
|
|
|
|
[
|
|
|
|
'theme' => [
|
|
|
|
'pager' => $this->getInput('sliderThemePager', helper::FILTER_BOOLEAN),
|
|
|
|
'auto' => $this->getInput('sliderThemeAuto', helper::FILTER_BOOLEAN),
|
2023-11-02 15:07:29 +01:00
|
|
|
'maxWidth' => $this->getInput('sliderThememaxWidth', helper::FILTER_INT),
|
2023-07-24 21:18:56 +02:00
|
|
|
'speed' => $speed,
|
|
|
|
'timeout' => $timeout,
|
|
|
|
'namespace' => $this->getInput('sliderThemeNameSpace', helper::FILTER_STRING_SHORT),
|
|
|
|
'sort' => $this->getInput('sliderThemeTri', helper::FILTER_STRING_SHORT),
|
|
|
|
],
|
|
|
|
'directory' => $this->getData(['module', $this->getUrl(0), 'directory']),
|
|
|
|
'legends' => $this->getData(['module', $this->getUrl(0), 'legends']),
|
|
|
|
'uri' => $this->getData(['module', $this->getUrl(0), 'uri']),
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
$notification = 'Modifications enregistrées';
|
|
|
|
$state = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'redirect' => helper::baseUrl() . $this->getUrl(0) . '/theme',
|
|
|
|
'notification' => $notification,
|
|
|
|
'state' => $state
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Sélection largeur de l'écran
|
|
|
|
self::$selectedMaxwidth = array_key_exists($this->getData(['module', $this->getUrl(0), 'theme', 'maxWidth']), self::$screenWidth)
|
|
|
|
? $this->getData(['module', $this->getUrl(0), 'theme', 'maxWidth'])
|
2024-08-19 10:11:29 +02:00
|
|
|
: 640;
|
2023-07-24 21:18:56 +02:00
|
|
|
|
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'title' => 'Thème',
|
|
|
|
'view' => 'theme'
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fonction index() modifiée par rapport au module Gallery
|
|
|
|
*/
|
|
|
|
public function index()
|
|
|
|
{
|
|
|
|
|
|
|
|
$galleryId = $this->getUrl(0);
|
|
|
|
$directory = $this->getData(['module', $galleryId, 'directory']);
|
|
|
|
|
|
|
|
// Images de la galerie
|
|
|
|
if ($directory && is_dir($directory)) {
|
|
|
|
$iterator = new DirectoryIterator($directory);
|
|
|
|
foreach ($iterator as $fileInfos) {
|
|
|
|
if ($fileInfos->isDot() === false and $fileInfos->isFile() and @getimagesize($fileInfos->getPathname())) {
|
|
|
|
self::$pictures[$directory . '/' . $fileInfos->getFilename()] = [
|
|
|
|
'legend' => $this->getData(['module', $galleryId, 'legends', str_replace('.', '', $fileInfos->getFilename())]),
|
|
|
|
'uri' => $this->getData(['module', $galleryId, 'uri', str_replace('.', '', $fileInfos->getFilename())]),
|
|
|
|
];
|
|
|
|
//self::$pictures['uri'][$directory . '/' . $fileInfos->getFilename()] = ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tri des images par ordre alphabétique, alphabétique inverse, aléatoire ou pas
|
2024-08-19 15:46:45 +02:00
|
|
|
switch ($this->getData(['module', $this->getUrl(0), 'theme', 'sort'])) {
|
2024-02-15 14:34:50 +01:00
|
|
|
case 'asc':
|
2024-08-19 15:46:45 +02:00
|
|
|
krsort(self::$pictures, SORT_NATURAL | SORT_FLAG_CASE);
|
|
|
|
break;
|
|
|
|
case 'dsc':
|
|
|
|
ksort(self::$pictures, SORT_NATURAL | SORT_FLAG_CASE);
|
2023-07-24 21:18:56 +02:00
|
|
|
break;
|
2024-02-15 14:34:50 +01:00
|
|
|
case 'rand':
|
|
|
|
// Récupérer les clés du tableau
|
|
|
|
$keys = array_keys(self::$pictures);
|
|
|
|
// Mélanger les clés
|
|
|
|
shuffle($keys);
|
|
|
|
// Créer un nouveau tableau avec les clés mélangées
|
|
|
|
$shuffledPictures = [];
|
|
|
|
foreach ($keys as $key) {
|
|
|
|
$shuffledPictures[$key] = self::$pictures[$key];
|
|
|
|
}
|
|
|
|
// Mettre à jour le tableau initial avec le nouveau tableau mélangé
|
|
|
|
self::$pictures = $shuffledPictures;
|
2023-07-24 21:18:56 +02:00
|
|
|
break;
|
2024-02-15 14:34:50 +01:00
|
|
|
case 'none':
|
2023-07-24 21:18:56 +02:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Valeurs en sortie
|
|
|
|
$this->addOutput([
|
|
|
|
'showBarEditButton' => true,
|
|
|
|
'showPageContent' => true,
|
|
|
|
'vendor' => [
|
|
|
|
'slider'
|
|
|
|
],
|
|
|
|
'view' => 'index'
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Scan le contenu d'un dossier et de ses sous-dossiers
|
|
|
|
* @param string $dir Dossier à scanner
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
private function scanSubDir($dir)
|
|
|
|
{
|
|
|
|
$dirContent = [];
|
|
|
|
$iterator = new DirectoryIterator($dir);
|
|
|
|
foreach ($iterator as $fileInfos) {
|
|
|
|
if ($fileInfos->isDot() === false and $fileInfos->isDir()) {
|
|
|
|
$dirContent[] = $dir . '/' . $fileInfos->getBasename();
|
|
|
|
$dirContent = array_merge($dirContent, $this->scanSubDir($dir . '/' . $fileInfos->getBasename()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $dirContent;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function init()
|
|
|
|
{
|
|
|
|
if (is_null($this->getData(['module', $this->getUrl(0), 'theme']))) {
|
|
|
|
$this->setData([
|
|
|
|
'module',
|
|
|
|
$this->getUrl(0),
|
|
|
|
[
|
|
|
|
'theme' => [
|
|
|
|
'pager' => true,
|
|
|
|
'auto' => true,
|
|
|
|
'maxWidth' => '1280',
|
|
|
|
'speed' => 1000,
|
|
|
|
'timeout' => 3000,
|
|
|
|
'namespace' => 'centered-btns',
|
2024-02-14 15:43:08 +01:00
|
|
|
'sort' => 'RAND',
|
2023-07-24 21:18:56 +02:00
|
|
|
],
|
|
|
|
'directory' => null,
|
|
|
|
'legends' => [],
|
|
|
|
'uri' => [],
|
|
|
|
]
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|