Correction : erreur zip download et libellés

This commit is contained in:
fredtempez 2019-01-17 17:48:58 +01:00
parent 252546848b
commit 1a2238ff02
2 changed files with 31 additions and 42 deletions

View File

@ -480,25 +480,8 @@ class theme extends common {
* Export du thème
*/
public function export() {
// Creation du dossier
$zipFilename = 'theme-'.date('dmYhms').'-'.rand(100,999).'.zip';
$zip = new ZipArchive();
if ($zip->open('site/tmp/' . $zipFilename, ZipArchive::CREATE | ZipArchive::OVERWRITE ) === TRUE) {
$zip->addFile('site/data/theme.json','site/data/theme.json');
$zip->addFile('site/data/theme.json','site/data/theme.css');
$zip->addFile('site/data/theme.json','site/data/custom.css');
if ($this->getData(['theme','body','image']) !== '' ) {
$zip->addFile('site/file/source/'.$this->getData(['theme','body','image']),
'site/file/source/'.$this->getData(['theme','body','image'])
);
}
if ($this->getData(['theme','header','image']) !== '' ) {
$zip->addFile('site/file/source/'.$this->getData(['theme','header','image']),
'site/file/source/'.$this->getData(['theme','header','image'])
);
}
$ret = $zip->close();
}
// Make zip
$zipFilename = $this->makezip();
// Téléchargement du ZIP
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
@ -508,35 +491,15 @@ class theme extends common {
readfile('site/tmp/' . $zipFilename);
// Nettoyage du dossier
unlink ('site/tmp/' . $zipFilename);
// Valeurs en sortie
$this->addOutput([
'display' => self::DISPLAY_RAW
]);
die();
}
/**
* Export du thème
*/
public function save() {
// Creation du dossier
$zipFilename = 'theme-'.date('dmYhms').'-'.rand(100,999).'.zip';
$zip = new ZipArchive();
if ($zip->open('site/tmp/' . $zipFilename, ZipArchive::CREATE | ZipArchive::OVERWRITE ) === TRUE) {
$zip->addFile('site/data/theme.json','site/data/theme.json');
$zip->addFile('site/data/theme.json','site/data/theme.css');
$zip->addFile('site/data/theme.json','site/data/custom.css');
if ($this->getData(['theme','body','image']) !== '' ) {
$zip->addFile('site/file/source/'.$this->getData(['theme','body','image']),
'site/file/source/'.$this->getData(['theme','body','image'])
);
}
if ($this->getData(['theme','header','image']) !== '' ) {
$zip->addFile('site/file/source/'.$this->getData(['theme','header','image']),
'site/file/source/'.$this->getData(['theme','header','image'])
);
}
$ret = $zip->close();
}
// Make zip
$zipFilename = $this->makezip();
// Téléchargement du ZIP
copy ('site/tmp/' . $zipFilename , 'site/file/source/' . $zipFilename);
// Nettoyage du dossier
@ -549,4 +512,30 @@ class theme extends common {
]);
}
/**
* construction du zip
*/
public function makezip() {
// Creation du dossier
$zipFilename = 'theme-'.date('dmY').'-'.date('hm').'-'.rand(10,99).'.zip';
$zip = new ZipArchive();
if ($zip->open('site/tmp/' . $zipFilename, ZipArchive::CREATE | ZipArchive::OVERWRITE ) === TRUE) {
$zip->addFile('site/data/theme.json','site/data/theme.json');
$zip->addFile('site/data/theme.json','site/data/theme.css');
$zip->addFile('site/data/theme.json','site/data/custom.css');
if ($this->getData(['theme','body','image']) !== '' ) {
$zip->addFile('site/file/source/'.$this->getData(['theme','body','image']),
'site/file/source/'.$this->getData(['theme','body','image'])
);
}
if ($this->getData(['theme','header','image']) !== '' ) {
$zip->addFile('site/file/source/'.$this->getData(['theme','header','image']),
'site/file/source/'.$this->getData(['theme','header','image'])
);
}
$ret = $zip->close();
}
return ($zipFilename);
}
}

View File

@ -12,9 +12,9 @@
<div class="row">
<div class="col6">
<div class="block">
<h4>Importer les données du thème</h4>
<h4>Importer</h4>
<?php echo template::file('themeManageImport', [
'label' => 'Archive à importer',
'label' => 'Archive',
'type' => 2
]); ?>
<div class="col5 offset3">
@ -26,23 +26,23 @@
</div>
<div class="col6">
<div class="block">
<h4>Enregistrer les données du thème</h4>
<h4>Exporter</h4>
<div class="row">
<div class="col5 offset1">
<?php echo template::button('themeSave', [
'href' => helper::baseUrl() . 'theme/save',
'value' => 'Sauvegarder le thème dans les fichiers'
'value' => 'Sauvegarder'
]); ?>
</div>
<div class="col5">
<?php echo template::button('themeExport', [
'href' => helper::baseUrl() . 'theme/export',
'value' => 'Télécharger une archive du thème'
'value' => 'Télécharger'
]); ?>
</div>
</div>
L'archive ZIP contient la structure du thème avec l'arborescence complète à copier dans le dossier site. Les images sont comprises dans l'archive.
<p \>Le nom du thème est généré à partir du groupe date heure et d'un nombre aléatoire.
L'archive ZIP contient un dossier "site" à copier à la racine du répertoire d'installation de ZwiiCMS. Il comprend les données du thème et les images qu'il utilise le cas échéant.
<p \>Le nom du thème est généré automatiquement à partir de la date et de l'heure de son enregistrement et d'un nombre aléatoire.
</div>
</div>
</div>