Merge branch 'gallery_stock_v2' into dev10_gallery_stock_v2
This commit is contained in:
commit
779a864761
@ -475,7 +475,7 @@ class common {
|
||||
// La clef est une chaine
|
||||
else {
|
||||
foreach($this->input as $type => $values) {
|
||||
// Champ obligatoire
|
||||
// Champ obligatoire
|
||||
if($required) {
|
||||
$this->addRequiredInputNotices($key);
|
||||
}
|
||||
@ -1111,6 +1111,36 @@ class common {
|
||||
if (file_exists(self::DATA_DIR.'theme.css') === false) {
|
||||
unlink (self::DATA_DIR.'theme.css');
|
||||
}
|
||||
// Numérotation des galeries
|
||||
// Lire toutes les pages et trouver celle avec le module gallery
|
||||
// Parcourir les galeries du modules
|
||||
// Verifier la présence des champs : sort et postion
|
||||
|
||||
// Tableau avec les pages
|
||||
$pageList = array();
|
||||
foreach ($this->getHierarchy(null,null,null) as $parentKey=>$parentValue) {
|
||||
$pageList [] = $parentKey;
|
||||
foreach ($parentValue as $childKey) {
|
||||
$pageList [] = $childKey;
|
||||
}
|
||||
}
|
||||
// Parcourir toutes les pages
|
||||
foreach ($pageList as $parentKey => $parent) {
|
||||
//La page a une galerie
|
||||
if ($this->getData(['page',$parent,'moduleId']) === 'gallery' ) {
|
||||
// Parcourir les dossiers de la galerie
|
||||
$tempData = $this->getData(['module', $parent]);
|
||||
$i = 1;
|
||||
foreach ($tempData as $galleryKey => $galleryItem) {
|
||||
if ( $this->getdata(['module',$parent,$galleryKey,'config','sort']) === NULL) {
|
||||
$this->setdata(['module',$parent,$galleryKey,'config','sort','SORT_ASC']);
|
||||
}
|
||||
if ( $this->getdata(['module',$parent,$galleryKey,'config','position']) === NULL) {
|
||||
$this->setdata(['module',$parent,$galleryKey,'config','position',$i++]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
$this->setData(['core', 'dataVersion', 9227]);
|
||||
}
|
||||
// Version 10.0.00
|
||||
@ -1118,6 +1148,7 @@ class common {
|
||||
$this->setData(['config', 'faviconDark','faviconDark.ico']);
|
||||
$this->setData(['core', 'dataVersion', 10000]);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@ -2372,4 +2403,4 @@ class layout extends common {
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
@ -15,6 +15,7 @@
|
||||
<link rel="stylesheet" href="<?php echo helper::baseUrl(false); ?>core/layout/light.css">
|
||||
<link rel="stylesheet" href="<?php echo helper::baseUrl(false) . self::DATA_DIR; ?>theme.css?<?php echo md5_file(self::DATA_DIR.'theme.css'); ?>">
|
||||
<link rel="stylesheet" href="<?php echo helper::baseUrl(false) . self::DATA_DIR; ?>custom.css?<?php echo md5_file(self::DATA_DIR.'custom.css'); ?>">
|
||||
<?php $layout->showStyle(); ?>
|
||||
</head>
|
||||
<body>
|
||||
<?php $layout->showNotification(); ?>
|
||||
|
1
module/form/vendor/html-sortable/lisezmoi.txt
vendored
Normal file
1
module/form/vendor/html-sortable/lisezmoi.txt
vendored
Normal file
@ -0,0 +1 @@
|
||||
https://github.com/lukasoppermann/html5sortable
|
@ -19,7 +19,8 @@ class gallery extends common {
|
||||
'delete' => self::GROUP_MODERATOR,
|
||||
'dirs' => self::GROUP_MODERATOR,
|
||||
'edit' => self::GROUP_MODERATOR,
|
||||
'index' => self::GROUP_VISITOR
|
||||
'filter' => self::GROUP_MODERATOR,
|
||||
'index' => self::GROUP_VISITOR
|
||||
];
|
||||
|
||||
public static $sort = [
|
||||
@ -34,16 +35,49 @@ class gallery extends common {
|
||||
|
||||
public static $galleries = [];
|
||||
|
||||
public static $galleriesId = [];
|
||||
|
||||
public static $pictures = [];
|
||||
|
||||
const GALLERY_VERSION = '1.3';
|
||||
const GALLERY_VERSION = '2.0';
|
||||
|
||||
|
||||
|
||||
public function filter() {
|
||||
// Traitement du tri
|
||||
$data = explode('&',($this->getInput('galleryConfigFilterResponse')));
|
||||
$data = str_replace('galleryTable%5B%5D=','',$data);
|
||||
for($i=0;$i<count($data);$i++) {
|
||||
$this->setData(['module', $this->getUrl(0), $data[$i], [
|
||||
'config' => [
|
||||
'name' => $this->getData(['module',$this->getUrl(0),$data[$i],'config','name']),
|
||||
'directory' => $this->getData(['module',$this->getUrl(0),$data[$i],'config','directory']),
|
||||
'homePicture' => $this->getData(['module',$this->getUrl(0),$data[$i],'config','homePicture']),
|
||||
'sort' => $this->getData(['module',$this->getUrl(0),$data[$i],'config','sort']),
|
||||
'position' => $i + 1
|
||||
],
|
||||
'legend' => $this->getData(['module',$this->getUrl(0),$data[$i],'legend'])
|
||||
]]);
|
||||
}
|
||||
$this->saveData();
|
||||
// Valeurs en sortie
|
||||
// Recharge la page
|
||||
header('Refresh: 0;url='. helper::baseUrl() . $this->getUrl() );
|
||||
}
|
||||
|
||||
/**
|
||||
* Configuration
|
||||
*/
|
||||
public function config() {
|
||||
// Liste des galeries
|
||||
$galleries = $this->getData(['module', $this->getUrl(0)]);
|
||||
// Tri des galeries
|
||||
$g = $this->getData(['module', $this->getUrl(0)]);
|
||||
$p = helper::arrayCollumn(helper::arrayCollumn($g,'config'),'position');
|
||||
asort($p,SORT_NUMERIC);
|
||||
$galleries = [];
|
||||
foreach ($p as $positionId => $item) {
|
||||
$galleries [$positionId] = $g[$positionId];
|
||||
}
|
||||
// Traitement de l'affichage
|
||||
if($galleries) {
|
||||
foreach($galleries as $galleryId => $gallery) {
|
||||
// Erreur dossier vide
|
||||
@ -57,7 +91,8 @@ class gallery extends common {
|
||||
$gallery['config']['directory'] = '<span class="galleryConfigError">' . $gallery['config']['directory'] . ' (dossier introuvable)</span>';
|
||||
}
|
||||
// Met en forme le tableau
|
||||
self::$galleries[] = [
|
||||
self::$galleries[] = [
|
||||
template::ico('sort'),
|
||||
$gallery['config']['name'],
|
||||
$gallery['config']['directory'],
|
||||
//$gallery['config']['order'],
|
||||
@ -77,31 +112,41 @@ class gallery extends common {
|
||||
'value' => template::ico('cancel')
|
||||
])
|
||||
];
|
||||
// Tableau des id des galleries pour le drag and drop
|
||||
self::$galleriesId[] = $galleryId;
|
||||
}
|
||||
}
|
||||
// Soumission du formulaire
|
||||
|
||||
if($this->isPost()) {
|
||||
$galleryId = helper::increment($this->getInput('galleryConfigName', helper::FILTER_ID, true), (array) $this->getData(['module', $this->getUrl(0)]));
|
||||
$this->setData(['module', $this->getUrl(0), $galleryId, [
|
||||
'config' => [
|
||||
'name' => $this->getInput('galleryConfigName'),
|
||||
'directory' => $this->getInput('galleryConfigDirectory', helper::FILTER_STRING_SHORT, true),
|
||||
'sort' => $this->getInput('galleryConfigSort'),
|
||||
'order' => count($this->getData(['module',$this->getUrl(0)])) + 1
|
||||
],
|
||||
'legend' => []
|
||||
]]);
|
||||
// Valeurs en sortie
|
||||
$this->addOutput([
|
||||
'redirect' => helper::baseUrl() . $this->getUrl(),
|
||||
'notification' => 'Modifications enregistrées',
|
||||
'state' => true
|
||||
]);
|
||||
if ($this->getInput('galleryConfigFilterResponse')) {
|
||||
self::filter();
|
||||
} else {
|
||||
$galleryId = helper::increment($this->getInput('galleryConfigName', helper::FILTER_ID, true), (array) $this->getData(['module', $this->getUrl(0)]));
|
||||
$this->setData(['module', $this->getUrl(0), $galleryId, [
|
||||
'config' => [
|
||||
'name' => $this->getInput('galleryConfigName'),
|
||||
'directory' => $this->getInput('galleryConfigDirectory', helper::FILTER_STRING_SHORT, true),
|
||||
'sort' => $this->getInput('galleryConfigSort'),
|
||||
'order' => count($this->getData(['module',$this->getUrl(0)])) + 1
|
||||
],
|
||||
'legend' => []
|
||||
]]);
|
||||
// Valeurs en sortie
|
||||
$this->addOutput([
|
||||
'redirect' => helper::baseUrl() . $this->getUrl(),
|
||||
'notification' => 'Modifications enregistrées',
|
||||
'state' => true
|
||||
]);
|
||||
}
|
||||
}
|
||||
// Valeurs en sortie
|
||||
$this->addOutput([
|
||||
'title' => 'Configuration du module',
|
||||
'view' => 'config'
|
||||
'view' => 'config',
|
||||
'vendor' => [
|
||||
'tablednd'
|
||||
]
|
||||
]);
|
||||
}
|
||||
|
||||
@ -308,8 +353,16 @@ class gallery extends common {
|
||||
|
||||
}
|
||||
// Liste des galeries
|
||||
else {
|
||||
foreach((array) $this->getData(['module', $this->getUrl(0)]) as $galleryId => $gallery) {
|
||||
else {
|
||||
// Tri des galeries
|
||||
$g = $this->getData(['module', $this->getUrl(0)]);
|
||||
$p = helper::arrayCollumn(helper::arrayCollumn($g,'config'),'position');
|
||||
asort($p,SORT_NUMERIC);
|
||||
$galleries = [];
|
||||
foreach ($p as $positionId => $item) {
|
||||
$galleries [$positionId] = $g[$positionId];
|
||||
}
|
||||
foreach((array) $galleries as $galleryId => $gallery) {
|
||||
if(is_dir($gallery['config']['directory'])) {
|
||||
$iterator = new DirectoryIterator($gallery['config']['directory']);
|
||||
foreach($iterator as $fileInfos) {
|
||||
|
3
module/gallery/vendor/tablednd/inc.json
vendored
Normal file
3
module/gallery/vendor/tablednd/inc.json
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
[
|
||||
"tablednd.min.js"
|
||||
]
|
1
module/gallery/vendor/tablednd/lisez-moi.txt
vendored
Normal file
1
module/gallery/vendor/tablednd/lisez-moi.txt
vendored
Normal file
@ -0,0 +1 @@
|
||||
https://github.com/isocra/TableDnD
|
2
module/gallery/vendor/tablednd/tablednd.min.js
vendored
Normal file
2
module/gallery/vendor/tablednd/tablednd.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -12,6 +12,24 @@
|
||||
* @link http://zwiicms.com/
|
||||
*/
|
||||
|
||||
/**
|
||||
* Tri dynamique de la galerie
|
||||
*/
|
||||
$( document ).ready(function() {
|
||||
$("#galleryTable").tableDnD({
|
||||
onDrop: function(table, row) {
|
||||
$("#galleryConfigFilterResponse").val($.tableDnD.serialize());
|
||||
},
|
||||
serializeRegexp: "[^\_]*$"
|
||||
});
|
||||
});
|
||||
|
||||
// Activer le bouton de tri uniquement après un tri
|
||||
$("#galleryTable").mouseup(function(e) {
|
||||
e.preventDefault();
|
||||
$(":input[type='submit']").prop('disabled', false);
|
||||
});
|
||||
|
||||
/**
|
||||
* Confirmation de suppression
|
||||
*/
|
||||
@ -22,6 +40,8 @@ $(".galleryConfigDelete").on("click", function() {
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Liste des dossiers
|
||||
*/
|
||||
@ -62,4 +82,3 @@ directoryDOM.on("change", function() {
|
||||
directoryOldDOM.val($(this).val());
|
||||
});
|
||||
|
||||
|
||||
|
@ -44,11 +44,25 @@
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<?php echo template::formClose(); ?>
|
||||
<?php echo template::formOpen('galleryConfigFilterForm'); ?>
|
||||
<?php if($module::$galleries): ?>
|
||||
<?php echo template::table([4, 6, 1, 1], $module::$galleries, ['Nom', 'Dossier cible', '', ''], ['id' => 'galleryTable']); ?>
|
||||
<?php echo template::table([1, 4, 5, 1, 1], $module::$galleries, ['','Nom', 'Dossier cible', '', ''], ['id' => 'galleryTable'],$module::$galleriesId); ?>
|
||||
<?php echo template::hidden('galleryConfigFilterResponse'); ?>
|
||||
<?php echo template::hidden('galleryConfigFilterSubmit',[
|
||||
'value' => false
|
||||
]); ?>
|
||||
<?php else: ?>
|
||||
<?php echo template::speech('Aucune galerie.'); ?>
|
||||
<?php endif; ?>
|
||||
<div class="row">
|
||||
<div class="col2 offset10">
|
||||
<?php echo template::submit('galleryConfigFilterSubmit', [
|
||||
'value' => 'Trier',
|
||||
'disabled' => true
|
||||
]); ?>
|
||||
</div>
|
||||
</div>
|
||||
<?php echo template::formClose(); ?>
|
||||
<div class="moduleVersion">Version n°
|
||||
<?php echo $module::GALLERY_VERSION; ?>
|
||||
|
Loading…
Reference in New Issue
Block a user