Compare commits

..

1 commit

22 changed files with 159 additions and 477 deletions

View file

@ -1,67 +1,27 @@
# Plugin bigform # Plugin bigform
> plugin proposant un formulaire CVT pour le plugin bigup > plugin proposant un formulaire CVT pour le plugin bigup
## Usage 1 : en formulaire autonome (comme html5_upload) ## Usage 1 : en formulaire autonome (comme html5_upload)
> ATTENTION : il n'y a pas de vérification sur le type des fichiers envoyés en PHP. > ATTENTION : il n'y a pas de vérification sur le type des fichiers envoyés en PHP.
> Ne pas hésiter à surcharger la fonction de vérification : formulaires_bigform_verifier() > Ne pas hésiter à surcharger la fonction de vérification : formulaires_bigform_verifier()
> en fonction des besoins ! > en fonction des besoins !
```html ```html
#FORMULAIRE_BIGFORM{objet, id_objet, mode, args (array)} #FORMULAIRE_BIGFORM{objet, id_objet, mode}
```
- `mode` (facultatif) : le type d'image si besoin. Valeurs possibles : `auto | logoon | logooff`
- `args` (facultatif) : un array d'options.
- `redirect` qui permet de renvoyer sur la page passée en argument.
- `obfusquer`
- `proteger`
- `charger_js_titre` oui par defaut => permet de ne pas charger le js d'ajout de l'input titre
- `ajaxReload` le nom d'un bloc ajax à recharger via ajaxReload. dans ce cas, charger_js_titre = non
- `ajaxCallback` le nom d'une fonction JS qui sera appellée en callback de l'ajaxReload (/!\ le JS de cette fonction doit être dans le bloc rechargé)
- `boutonSubmit` non par défaut (= bouton masqué) => oui permet d'afficher le bouton submit du FORMULAIRE_BIGFORM
- `id_document` l'ID du document pour lequel le fichier chargé va remplacer le fichier existant (/!\ non pris en compte avec les modes `logoon | logooff` puisque dans ce cas le document est supprimé puis recréé)
Exemple pour revenir à la page principale "equipe" avec un bigform appelé dans une popin :
```
#FORMULAIRE_BIGFORM{article, #ID_ARTICLE, logoon, #ARRAY{redirect, #URL_PAGE{equipe}, obfusquer, oui}}
``` ```
## Usage 2 : en inclure dans un formulaire ## Usage 2 : en inclure dans un formulaire
> Ajoute dynamiquement un champ **titre** pour chaque image > Ajoute dynamiquement un champ **titre** pour chaque image
1. dans le formulaire html: 1. dans le formulaire html:
```html ```html
<INCLURE{fond=inclure/bigform,env}> <INCLURE{fond=inclure/bigform,env}>
ou
<INCLURE{fond=inclure/bigform, env, id_document, charger_js_titre=non}>
``` ```
Cet inclure peut accepter les arguments facultatifs : cet inclure peut accepter 3 arguments facultatifs :
* `accept=#LISTE{image/*, application/pdf}` ou `accept="image/*"` par défaut tous les fichiers
- `accept=#LISTE{image/*, application/pdf}` ou `accept="image/*"` par défaut tous les fichiers * `previsualiser=non` (par défaut = oui)
- `previsualiser=non` (par défaut = oui) * `multiple=non` (par défaut = oui)
- `multiple=non` (par défaut = oui)
- `suffix_liste_fichiers=toto` : permet de charger le fichier : `inc-bigup_liste_fichiers_toto.html`
Les autres arguments de **l'usage 1** utiles ici sont :
- `charger_js_titre=non` : pour ne pas charger/afficher le js d'ajout de l'input titre
- `id_document=#ID_DOCUMENT` : pour que le fichier chargé remplace celui du document `#ID_DOCUMENT` (ou autre `#ENV{id_document}`)
/!\ cet argument nécessite que le `..._traiter` du formulaire récupère l'id_document lui aussi :
```php
$bigform = charger_fonction('bigform_traiter','inc');
$bigform($id_article, 'article', 'auto', ['id_document' => intval($id_document)]);
```
(ici `id_article` et `id_document` sont des arguments du CVT)
1. dans le formulaire php
2. dans le formulaire php
```php ```php
// dans le charger : // dans le charger :
$valeurs['_bigup_rechercher_fichiers'] = true; $valeurs['_bigup_rechercher_fichiers'] = true;
@ -72,19 +32,6 @@ $valeurs['_bigup_rechercher_fichiers'] = true;
// https://git.spip.net/plugin/verifier/src/branch/master/verifier/fichiers.php // https://git.spip.net/plugin/verifier/src/branch/master/verifier/fichiers.php
$bigform = charger_fonction('bigform_verifier','inc'); $bigform = charger_fonction('bigform_verifier','inc');
$options = ['mime' => 'image_web']; $options = ['mime' => 'image_web'];
// si on veut redimensionner les images a 2048 et limiter a 10000 le televersement
// 1. dans options, définir la constante
define('_IMG_MAX_WIDTH', 2048);
// 2. ajouter dans l'appel de verifier des dimension_max
$options = [
'mime' => 'tout_mime',
'dimension_max' => [
'largeur' => 10000,
'hauteur' => 10000,
]
];
$bigform($options,$erreurs); $bigform($options,$erreurs);
/* /*
@ -98,26 +45,9 @@ $bigform($options,$erreurs);
$bigform = charger_fonction('bigform_traiter','inc'); $bigform = charger_fonction('bigform_traiter','inc');
$bigform($id_objet, $objet); $bigform($id_objet, $objet);
// Options de protection des documents : // Ou pour proteger les documents
// - deplacer dans un sous repertoire PROTECTED
// - obfusquer le nom du fichier
//
$secu = [
'proteger' => false,
'obfusquer' => false
];
$bigform = charger_fonction('bigform_traiter','inc'); $bigform = charger_fonction('bigform_traiter','inc');
$bigform($id_objet, $objet, $mode, $secu); $bigform($id_objet, $objet, $mode, true);
// ou definir la constante pour l'avoir dans tous les formulaires:
define('_BIGFORM_OBFUSQUER', true);
``` ```
> **ATTENTION** > **ATTENTION**
> Il faut ajouter les vérifications pour les différents types de fichiers > Il faut ajouter les vérifications pour les différents types de fichiers
> **ATTENTION pour les documents protégés**
> Il faut activer les urls propres : URLs Propres+.html

View file

@ -1,15 +1,12 @@
<?php <?php
if (!defined('_ECRIRE_INC_VERSION')) return; if (!defined('_ECRIRE_INC_VERSION')) return;
function action_bigform_supprimer_doc_dist($arg = null){ function action_bigform_supprimer_doc_dist(){
if ($arg === null) {
$securiser_action = charger_fonction('securiser_action', 'inc'); $securiser_action = charger_fonction('securiser_action', 'inc');
$arg = $securiser_action(); $arg = $securiser_action();
list($id_document, $id_objet, $objet) = explode('-', $arg); list($id_document, $id_objet, $objet) = explode('-', $arg);
} else {
list($id_document, $id_objet, $objet) = $arg;
}
include_spip('inc/autoriser'); include_spip('inc/autoriser');

View file

@ -3,8 +3,17 @@ if (!defined('_ECRIRE_INC_VERSION')) return;
function action_charger_document_dist($arg=null){ function action_charger_document_dist($arg=null){
if (is_null($arg)) {
// DEMI sécurité : s'il y a un hash, on teste la sécurité
if (_request('hash')) {
$securiser_action = charger_fonction('securiser_action', 'inc'); $securiser_action = charger_fonction('securiser_action', 'inc');
$arg = $securiser_action(); $arg = $securiser_action();
}
// Sinon, on prend l'arg direct
else {
$arg = _request('arg');
}
}
include_spip('inc/autoriser'); include_spip('inc/autoriser');
if (! autoriser("charger","document")) { if (! autoriser("charger","document")) {

View file

@ -7,7 +7,6 @@ if (!defined('_ECRIRE_INC_VERSION')){
function bigform_declarer_tables_principales($tables_principales){ function bigform_declarer_tables_principales($tables_principales){
$tables_principales['spip_documents']['field']['protected'] = 'varchar(5) NOT NULL'; $tables_principales['spip_documents']['field']['protected'] = 'varchar(5) NOT NULL';
$tables_principales['spip_documents']['field']['fichier_origine'] = 'varchar(255) NOT NULL';
return $tables_principales; return $tables_principales;
} }

View file

@ -31,11 +31,9 @@ function bigform_upgrade($nom_meta_base_version, $version_cible) {
'charger_public' => 1 'charger_public' => 1
]; ];
$maj['create'] = [ $maj['create'] = [['ecrire_meta', 'bigup', serialize($config_defaut)]];
['maj_tables', ['spip_documents']],
['ecrire_meta', 'bigup', serialize($config_defaut)]];
$maj['1.0.1'] = [['ecrire_meta', 'bigup', serialize($config_defaut)]]; $maj['1.0.1'] = [['ecrire_meta', 'bigup', serialize($config_defaut)]];
$maj['1.0.5'] = [['maj_tables', ['spip_documents']]]; $maj['1.0.4'] = [['maj_tables', ['spip_documents']]];
include_spip('base/upgrade'); include_spip('base/upgrade');
maj_plugin($nom_meta_base_version, $version_cible, $maj); maj_plugin($nom_meta_base_version, $version_cible, $maj);

View file

@ -26,7 +26,9 @@ function autoriser_document_charger_dist($faire, $type, $id, $qui, $opt) {
} }
function autoriser_document_dissociersupprimer_dist($faire, $type, $id, $qui, $opt) { function autoriser_document_dissociersupprimer_dist($faire, $type, $id, $qui, $opt) {
if (!intval($id) or !intval($qui['id_auteur'])) { if (!intval($id)
or !$qui['id_auteur']
) {
return false; return false;
} }

View file

@ -13,10 +13,6 @@ if (!defined('_ECRIRE_INC_VERSION')) {
return; return;
} }
function urls_generer_url_document($id_document, $args = '', $ancre = '', $public = null, $connect = '') {
$f = charger_fonction('bigform_generer_url_document', 'inc');
return $f($id_document, $args, $ancre, $public, $connect);
}
// https://code.spip.net/@urls_propres2_dist // https://code.spip.net/@urls_propres2_dist
function urls_propres2($i, &$entite, $args = '', $ancre = '') { function urls_propres2($i, &$entite, $args = '', $ancre = '') {

View file

@ -12,41 +12,3 @@
if (!defined('_ECRIRE_INC_VERSION')) { if (!defined('_ECRIRE_INC_VERSION')) {
return; return;
} }
/**
* Branchement sur l'insertion de document pour generer le cache des images
* a la sortie du formualire
* Extensions utilisées :
* - jpg
* - png
* - webm
*
* @param Array $flux
*
* @return Array $flux
*/
function bigform_post_edition($flux){
if (isset($flux['args']['table'])
and $flux['args']['table'] === 'spip_documents'
and $id_document = intval($flux['args']['id_objet'])
and $flux['args']['action'] === 'ajouter_document'
and in_array($flux['data']['extension'], ['jpg', 'png', 'webm'])
and lire_config('bigform/retailler_image') === 'oui'
) {
$url = generer_url_public("retailler_img", [
"id_document" => intval($id_document),
"largeur" => $flux['data']['largeur'],
"hauteur" => $flux['data']['hauteur'],
"taille" => $flux['data']['taille'],
"id_auteur" => session_get('id_auteur')
], true, false);
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1 );
curl_exec($ch);
curl_close($ch);
}
return $flux;
}

View file

@ -1,58 +1,18 @@
[(#ENV{objet_ok}|oui) [(#ENV{objet_ok}|oui)
<div class="formulaire_spip formulaire_#FORM"> <div class="formulaire_spip formulaire_#FORM">
[<p class="reponse_formulaire reponse_formulaire_erreur">(#ENV*{message_erreur})</p>]
[(#ENV*{message_ok}|oui) [<p class="reponse_formulaire reponse_formulaire_erreur">(#ENV*{message_erreur})</p>]
<script> [<p class="reponse_formulaire reponse_formulaire_ok">(#ENV*{message_ok})</p>]
var aa = '#ENV*{message_ok}';
if (aa) {
try {
aa = JSON.parse(aa);
} catch (e) {
// utiliser le catch pour la compat descendante = lorsque ENV{message_ok} est une simple string avec le nom du bloc à recharger
ajaxReload(aa);
}
}
//console.log(aa);
if (aa.bloc_ajax !== undefined) {
let bb = '';
if (aa.callback_ajax !== undefined) {
bb = aa.callback_ajax;
}
ajaxReload(
aa.bloc_ajax,
{
callback: eval(bb)
}
);
}
</script>
]
<form class="form_bigform" id="form_bigform[_(#ENV{objet})][_(#ENV{id_objet})]" name="formulaire_#FORM" action="#ENV{action}" method="post" enctype="multipart/form-data"><div> <form class="form_bigform" id="form_bigform[_(#ENV{objet})][_(#ENV{id_objet})]" name="formulaire_#FORM" action="#ENV{action}" method="post" enctype="multipart/form-data"><div>
#ACTION_FORMULAIRE{#ENV{action}} #ACTION_FORMULAIRE{#ENV{action}}
[(#ENV{ajaxReload}|non)
<INCLURE{fond=inclure/bigform_doc,env,ajax}> <INCLURE{fond=inclure/bigform_doc,env,ajax}>
]
<INCLURE{fond=inclure/bigform,env}> <INCLURE{fond=inclure/bigform,env}>
<div class="boutons"><input id="valider_bigup" type="submit" class="submit valider_bigup" value="<:bigform:envoyer:>" ></div> <div class="boutons"><input id="valider_bigup" type="submit" class="submit valider_bigup" value="Envoyer" ></div>
</div></form> </div></form>
</div> </div>
] ]
[(#ENV{boutonSubmit}|non)
<style type="text/css">
.valider_bigup { display: none; }
</style>
]
<script type="text/javascript">
jQuery(function() {
//$('.valider_bigup').css('display','none');
$('input.bigup').bigup({}, {
complete: function(){
$(this).parents('form').submit();
},
});
});
</script>

View file

@ -3,24 +3,15 @@ if (!defined('_ECRIRE_INC_VERSION')){
return; return;
} }
include_spip('inc/cvtupload');
function formulaires_bigform_charger_dist($objet, $id_objet, $mode = 'auto', $args = []) {
if (!empty($args['ajaxReload'])) {
$ajaxReload = $args['ajaxReload'];
$charger_js_titre = 'non';
} else {
$charger_js_titre = $args['charger_js_titre'] ?? 'oui';
$ajaxReload = null;
}
$boutonSubmit = !empty($args['boutonSubmit']) ? $args['boutonSubmit'] : null;
function formulaires_bigform_charger_dist($objet, $id_objet, $mode = 'auto', $args = array()) {
$valeurs = [ $valeurs = [
'_bigup_rechercher_fichiers' => true, '_bigup_rechercher_fichiers' => true,
'id_objet' => $id_objet, 'id_objet' => $id_objet,
'objet' => $objet, 'objet' => $objet,
'ajaxReload' => $ajaxReload, 'mode' => $mode
'charger_js_titre' => $charger_js_titre === 'oui' ? 'oui' : 'non',
'boutonSubmit' => $boutonSubmit,
]; ];
$valeurs['objet_ok'] = ''; $valeurs['objet_ok'] = '';
@ -32,63 +23,16 @@ function formulaires_bigform_charger_dist($objet, $id_objet, $mode = 'auto', $ar
return $valeurs; return $valeurs;
} }
function formulaires_bigform_verifier_dist($objet, $id_objet, $mode = 'auto', $args = []) { function formulaires_bigform_verifier_dist($objet, $id_objet, $mode = 'auto', $args = array()) {
$erreurs = [];
$options = pipeline('bigform_verifier', [
'args' => [
'id_objet' => $id_objet,
'objet' => $objet,
'mode' => $mode,
'args' => $args
],
'data' => []
]);
$bigform = charger_fonction('bigform_verifier','inc');
$bigform($options,$erreurs);
$erreurs = array();
return $erreurs; return $erreurs;
} }
function formulaires_bigform_traiter_dist($objet = 'article', $id_objet = 0, $mode = 'auto', $args = []) { function formulaires_bigform_traiter_dist($objet = 'article', $id_objet = 0, $mode = 'auto', $args = array()) {
$options = [];
if (array_key_exists('proteger', $args)) {
$options['proteger'] = true;
}
if (array_key_exists('obfusquer', $args)) {
$options['obfusquer'] = true;
}
// passer l'id_document à remplacer seulement si ce n'est pas un logo (en cas de logo SPIP supprime puis recrée le doc)
if (array_key_exists('id_document', $args) && intval($args['id_document']) && !in_array($mode, ['logoon', 'logooff'])) {
$options['id_document'] = intval($args['id_document']);
}
$bigform = charger_fonction('bigform_traiter','inc'); $bigform = charger_fonction('bigform_traiter','inc');
$T = $bigform($id_objet,$objet,$mode, $options);
pipeline('bigform_post_insertion', [ //return [];
'args' => [ return $bigform($id_objet,$objet,$mode);
'id_objet' => $id_objet,
'objet' => $objet,
'mode' => $mode,
'args' => $args,
'tId_doc' => $T
]
]);
$retour = [];
if (!empty($args['redirect'])) {
$retour['redirect'] = $args['redirect'];
}
if (!empty($args['ajaxReload'])) {
//$retour['message_ok'] = $args['ajaxReload'];
$Tretour = ['bloc_ajax' => $args['ajaxReload']];
if (!empty($args['ajaxCallback'])) {
$Tretour['callback_ajax'] = $args['ajaxCallback'];
}
$retour['message_ok'] = json_encode($Tretour);
}
return $retour;
} }

View file

@ -9,22 +9,6 @@
<div> <div>
#ACTION_FORMULAIRE #ACTION_FORMULAIRE
<div class="editer_groupe">
#SET{name,retailler_image}
#SET{erreurs,#ENV**{erreurs}|table_valeur{#GET{name}}}
<div class="editer editer_[(#GET{name})][ (#GET{erreurs}|oui)erreur]">
<label>Activer la génération des adaptive_images lors du televersement</label>
<div class="choix">
<input type="radio" class="radio" name="#GET{name}" value="" id="#GET{name}_non"[ (#ENV{#GET{name}}|!={oui}|?{checked="checked"})] >
<label for="#GET{name}_non">Non</label>
</div>
<div class="choix">
<input type="radio" class="radio" name="#GET{name}" value="oui" id="#GET{name}_oui"[ (#ENV{#GET{name}}|=={oui}|?{checked="checked"})] >
<label for="#GET{name}_oui">Oui</label>
</div>
</div>
</div>
<input type="hidden" name="_meta_casier" value="bigform" /> <input type="hidden" name="_meta_casier" value="bigform" />
<p class="boutons"><span class="image_loading">&nbsp;</span><input type="submit" class="submit" value="<:bouton_enregistrer:>" /></p> <p class="boutons"><span class="image_loading">&nbsp;</span><input type="submit" class="submit" value="<:bouton_enregistrer:>" /></p>
</div> </div>

View file

@ -1,17 +0,0 @@
<?php
if (!defined('_ECRIRE_INC_VERSION')){
return;
}
function inc_bigform_generer_url_document_dist($id_document, $args = '', $ancre = '', $public = null, $connect = '') {
if (sql_countsel('spip_documents',['id_document='.$id_document, 'protected="oui"'])) {
//return generer_url_action('charger_document','id_document='.$id_document);
include_spip('inc/securiser_action');
return securiser_action_auteur('charger_document',$id_document);
}
include_spip('inc/documents');
return generer_url_document_dist($id_document, $args, $ancre);
}

View file

@ -1,39 +0,0 @@
<?php
if (!defined('_ECRIRE_INC_VERSION')){
return;
}
/**
* Permet d'obfusquer le nom d'un document
*
* @param array $Tid_doc
*
* @return void
*
*/
function bigform_obfusquer_doc($Tid_doc){
foreach ($Tid_doc as $id) {
if (intval($id)) {
$r = sql_fetsel('extension, fichier','spip_documents','id_document='.intval($id));
$ext = $r['extension'];
$fichier = $r['fichier'];
$fichier_ob = $fichier.uniqid(1);
$fichier_ob = $ext ."/". md5($fichier_ob) . ".".$ext;
if ($fichier) {
$source = _DIR_IMG . "/" . $fichier;
$dest = _DIR_IMG . "/" . $fichier_ob;
if (file_exists($source)) {
$d = deplacer_fichier_upload($source, $dest, true);
if ($d) {
sql_updateq('spip_documents',[
'fichier' => $fichier_ob,
'fichier_origine' => $fichier,
], 'id_document='.$id);
}
}
}
}
}
}

View file

@ -3,42 +3,15 @@ if (!defined('_ECRIRE_INC_VERSION')){
return; return;
} }
/** /**
* fonction de recuperation et liaison image / objet * fonction de recuperation et liaison image / objet
* *
* @param $id_objet * @param $id_objet
* @param $objet
* @param $mode * @param $mode
* @param array $options['secu' => false, 'obfusquer' => false, 'id_document' => ID du document pour lequel on va remplacer le fichier]
* @return array tableau des id_document $Tid_doc * @return array tableau des id_document $Tid_doc
*/ */
function inc_bigform_traiter_dist($id_objet, $objet = 'article', $mode = 'auto', $options = false) { function inc_bigform_traiter_dist($id_objet, $objet = 'article', $mode = 'auto', $secu = false) {
include_spip('inc/joindre_document'); include_spip('inc/joindre_document');
include_spip('inc/autoriser');
$proteger = false;
$obfusquer = false;
$id_document = 'new';
if (is_array($options)) {
if (array_key_exists('proteger', $options)) {
$proteger = $options['proteger'];
}
if (array_key_exists('obfusquer', $options)) {
$obfusquer = $options['obfusquer'];
}
if (array_key_exists('id_document', $options)
&& $options['id_document'] == intval($options['id_document'])
&& intval($options['id_document'])
) {
$id_document = $options['id_document'];
}
} else {
if ($options) {
$proteger = true;
}
}
set_request('joindre_upload','ok'); set_request('joindre_upload','ok');
$files = joindre_trouver_fichier_envoye(); $files = joindre_trouver_fichier_envoye();
@ -54,12 +27,6 @@ function inc_bigform_traiter_dist($id_objet, $objet = 'article', $mode = 'auto',
} }
} }
// en mode logoon, on va supprimer le (ou les) anciens logos. on récupère d'abord leurs id
//if ($mode == 'logoon'){
//$T_docs_objet = sql_allfetsel('id_document','spip_documents_liens',"id_objet=".intval($id_objet)." AND objet='" . $objet . "'");
//}
//
/* /*
* On peut utiliser une fonction SPIP * On peut utiliser une fonction SPIP
* pour supprimer les logos * pour supprimer les logos
@ -80,46 +47,40 @@ function inc_bigform_traiter_dist($id_objet, $objet = 'article', $mode = 'auto',
// si l'auteur n'a pas le droit d'associer un document à l'objet lui refiler une autorisation exceptionnelle // si l'auteur n'a pas le droit d'associer un document à l'objet lui refiler une autorisation exceptionnelle
// typiquement les 1comite ne peuvent associer un doc à un article de statut publie... // typiquement les 1comite ne peuvent associer un doc à un article de statut publie...
$autorisation_temp = false; $autorisation_temp = false;
if (!autoriser('associerdocuments', $objet, $id_objet)) {
include_spip('inc/autoriser'); include_spip('inc/autoriser');
// supprimer les _ du nom de l'objet pour que l'autorisation temporaire fonctionne autoriser_exception('associerdocuments', $objet, $id_objet);
$type = str_replace('_', '', strncmp($objet, '_', 1) == 0 ? $objet : objet_type($objet, false));
if (!autoriser('associerdocuments', $type, $id_objet)) {
autoriser_exception('associerdocuments', $type, $id_objet);
$autorisation_temp = true; $autorisation_temp = true;
} }
$ajouter_document = charger_fonction('ajouter_documents', 'action'); // traitement vignette (pompé sur medias/formulaires/illustrer_document.php)
$Tid_doc = $ajouter_document($id_document, $files, $objet, $id_objet, $mode); if ($mode === 'vignette') {
$id_vignette = sql_getfetsel('id_vignette', 'spip_documents', 'id_document=' . intval($id_objet));
$ajouter_documents = charger_fonction('ajouter_documents', 'action');
$ajoute = $ajouter_documents($id_vignette, $files, '', 0, 'vignette');
if ($autorisation_temp) { if (is_numeric(reset($ajoute))
autoriser_exception('associerdocuments', $type, $id_objet, false); and $id_vignette = reset($ajoute)
) {
include_spip('action/editer_document');
document_modifier($id_objet, array('id_vignette' => $id_vignette, 'mode' => 'document'));
}
}
// traitement doc ou logo
else {
$ajouter_document = charger_fonction('ajouter_documents', 'action');
$Tid_doc = $ajouter_document('new', $files, $objet, $id_objet, $mode);
} }
if (is_array($Tid_doc) and count($Tid_doc) and $proteger) { if ($autorisation_temp) {
autoriser_exception('associerdocuments', $objet, $id_objet, false);
}
if (is_array($Tid_doc) and count($Tid_doc) and $secu) {
include_spip('inc/bigform_securiser_doc'); include_spip('inc/bigform_securiser_doc');
bigform_securiser_doc($Tid_doc); bigform_securiser_doc($Tid_doc);
} }
if (is_array($Tid_doc) and count($Tid_doc) and $obfusquer) {
include_spip('inc/bigform_obfusquer_doc');
bigform_obfusquer_doc($Tid_doc);
} }
if (is_array($Tid_doc) and count($Tid_doc) and defined('_BIGFORM_OBFUSQUER')) {
include_spip('inc/bigform_obfusquer_doc');
bigform_obfusquer_doc($Tid_doc);
}
}
// si tout s'est bien passé, on supprime le/les anciens logos
//if ($mode == 'logoon'){
//foreach ($T_docs_objet as $i => $ligne) {
//$id_doc = $ligne['id_document'];
//if (sql_getfetsel('mode','spip_documents','id_document=' . intval($id_doc)) == 'logoon'){
//sql_delete('spip_documents', 'id_document='.intval($id_doc));
//sql_delete('spip_documents_liens', 'id_document='.intval($id_doc));
//}
//}
//}
if (!empty($html_titre) and count($Tid_doc)) { if (!empty($html_titre) and count($Tid_doc)) {
foreach ($Tid_doc as $i => $id_doc) { foreach ($Tid_doc as $i => $id_doc) {

View file

@ -4,29 +4,12 @@ if (!defined('_ECRIRE_INC_VERSION')){
} }
function inc_bigform_verifier_dist($options = [], &$erreurs = [] ){ function inc_bigform_verifier_dist($options = [], &$erreurs){
$options_defauts = [
'mime' => 'tout_mime',
'dimension_max' => [
'largeur' => 20000,
'hauteur' => 20000,
]
];
if (is_array($options)) {
$options = array_merge($options_defauts, $options);
} else {
$options = $options_defauts;
}
$er = []; $er = [];
$verifier = charger_fonction('verifier', 'inc/'); $verifier = charger_fonction('verifier', 'inc/');
$verifier($_FILES['fichiers'], 'fichiers',$options, $er);
if (!empty($_FILES)) {
foreach ($_FILES as $cle => $file) {
$verifier($file, 'fichiers', $options, $er);
if (count($er)) { if (count($er)) {
$erreurs[$cle] = implode('<br>', $er); $erreurs['fichiers'] = implode('<br>', $er);
}
}
} }
} }

View file

@ -14,11 +14,7 @@
[(#SET{multiple,#ENV{multiple,oui}})] [(#SET{multiple,#ENV{multiple,oui}})]
[(#SET{accept,#ENV{accept}|bigform_tab_accept})] [(#SET{accept,#ENV{accept}|bigform_tab_accept})]
[(#SET{inclure,inc-bigup_liste_fichiers})] <INCLURE{fond=inclure/inc-bigup_liste_fichiers,
[(#ENV{suffix_liste_fichiers}|oui)
[(#SET{inclure,#GET{inclure}|concat{_}|concat{#ENV{suffix_liste_fichiers}}})]
]
<INCLURE{fond=inclure/#GET{inclure},
nom=fichiers, nom=fichiers,
multiple=oui, multiple=oui,
fichiers=#ENV{_bigup_fichiers} fichiers=#ENV{_bigup_fichiers}
@ -30,7 +26,5 @@
{accept=#GET{accept}} {accept=#GET{accept}}
)] )]
[(#ENV{charger_js_titre}|!={non}|oui) <INCLURE{fond=js/bigform.js,env}>
<INCLURE{fond=js/bigform.js,env}>
]

View file

@ -13,20 +13,22 @@
.bloc_titres{ .bloc_titres{
flex-grow: 1; flex-grow: 1;
} }
.vignette_doc {
max-width: 200px;
}
</style> </style>
[(#REM)
affichage selon le mode : logoon logoff image vignette document
défaut = document
] #SET{mode, #ENV{mode,document}}
<div class="docs_ressource doc_rang" id="les_docs"> <div class="docs_ressource doc_rang" id="les_docs">
<BOUCLE_doc(DOCUMENTS){id_objet}{objet}{mode in image,logoon,vignette}{statut in prop,prepa,publie}{par rang_lien}> <BOUCLE_doc(DOCUMENTS){id_objet}{objet}{si #GET{mode}|in_array{#LISTE{image,logoon,logoff}}}{mode in image,logoon,logoff}{statut in prop,prepa,publie}{par rang_lien}{doublons}>
<div id="id-#ID_DOCUMENT" class="doc_article doc_objet[ (#MODE|=={logoon}|oui)logo_objet]"> <div id="id-#ID_DOCUMENT" class="doc_article doc_objet[ (#MODE|=={logoon}|oui)logo_objet]">
<div class="vignette_doc"> <div class="vignette_doc">
[(#EXTENSION|match{jpg|png|gif}|oui) [(#EXTENSION|match{jpg|png|gif}|oui)
<a href="[(#URL_DOCUMENT)]" title="Ouvrir le document" class="mediabox"> <a href="#URL_DOCUMENT" title="Ouvrir le document" class="mediabox">
][(#EXTENSION|match{jpg|png|gif}|non) ][(#EXTENSION|match{jpg|png|gif}|non)
<a href="[(#URL_DOCUMENT)]" title="Ouvrir le document" class="" download="[(#FICHIER|basename)]"> <a href="#URL_DOCUMENT" title="Ouvrir le document" class="" download="[(#FICHIER|basename)]">
] ]
<img class="spip_logo spip_logos" src="[(#LOGO_DOCUMENT{apercu}|extraire_attribut{src})]" alt=""> #LOGO_DOCUMENT{apercu}
</a> </a>
</div> </div>
<div class="infos_doc"> <div class="infos_doc">
@ -49,13 +51,37 @@
</div> </div>
</div> </div>
</BOUCLE_doc> </BOUCLE_doc>
<BOUCLE_doc_vignette(DOCUMENTS){id_vignette!=''}{id_document=#ENV{id_objet}}{si #GET{mode}|=={vignette}}>
<B_pdf> <BOUCLE_vignette(DOCUMENTS){mode=vignette}{id_document=#ID_VIGNETTE}{tout}{extension IN jpg,png,gif}{doublons}>
<BOUCLE_pdf(DOCUMENTS){id_objet}{objet}{mode=document}{extension=pdf}{statut in prop,prepa,publie}{par rang_lien}> <div id="id-#ID_DOCUMENT" class="doc_article doc_objet">
<div id="id-#ID_DOCUMENT" class="doc_article doc_objet doc_pdf]">
<div class="vignette_doc"> <div class="vignette_doc">
<a href="[(#URL_DOCUMENT)]" title="Ouvrir le document" class="" download="[(#FICHIER|basename)]"> <a href="#URL_DOCUMENT" title="Ouvrir la vignette" class="mediabox">
[(#LOGO_DOCUMENT{apercu})] #LOGO_DOCUMENT{apercu}
</a>
</div>
<div class="infos_doc">
<div class="icones_doc">
[(#AUTORISER{modifier, #ENV{objet}, #ENV{id_objet}})
<div class="icone-doc">
<a class="ajax nocache nohistory btn btn_poubelle"
href="[(#URL_ACTION_AUTEUR{bigform_supprimer_doc, [(#ID_DOCUMENT)]-[(#ENV{id_objet})]-[(#ENV{objet})], #SELF})]"
onClick="return confirm('Confirmer la suppression de cette vignette ?');"
title="Supprimer la vignette">
<i class="fa fa-trash red"></i>
</a>
</div>
]
</div>
</div>
</div>
</BOUCLE_vignette>
</BOUCLE_doc_vignette>
<BOUCLE_pdf(DOCUMENTS){id_objet}{objet}{mode=document}{extension=pdf}{statut in prop,prepa,publie}{par rang_lien}{doublons}>
<div id="id-#ID_DOCUMENT" class="doc_article doc_objet doc_pdf">
<div class="vignette_doc">
<a href="#URL_DOCUMENT" title="Ouvrir le document" class="" download="[(#FICHIER|basename)]">
#LOGO_DOCUMENT{apercu}
</a> </a>
</div> </div>
<div class="infos_doc"> <div class="infos_doc">
@ -74,5 +100,40 @@
</div> </div>
</div> </div>
</BOUCLE_pdf> </BOUCLE_pdf>
<BOUCLE_autres(DOCUMENTS){id_objet}{objet}{mode=document}{statut in prop,prepa,publie}{par rang_lien}{doublons}>mode2: #MODE
<div id="id-#ID_DOCUMENT" class="doc_article doc_objet">
<div class="vignette_doc">
<a href="#URL_DOCUMENT" title="Ouvrir le document" class="" download="[(#FICHIER|basename)]">
#LOGO_DOCUMENT{apercu}
</a>
</div>
<div class="infos_doc">
<div class="bloc_titres">
[<div class="titre_doc #EDIT{titre}" title="Editer le titre">(#TITRE|sinon{[(#AUTORISER{modifier, #ENV{objet}, #ENV{id_objet}})<i class="fa fa-edit"></i>]})</div>]
<div class="fichier_doc">[(#FICHIER|basename)]</div>
</div>
[(#AUTORISER{modifier, #ENV{objet}, #ENV{id_objet}})
<a class="fr ajax nocache nohistory btn btn_poubelle"
href="[(#URL_ACTION_AUTEUR{bigform_supprimer_doc, [(#ID_DOCUMENT)]-[(#ENV{id_objet})]-[(#ENV{objet})], #SELF})]"
onClick="return confirm('Confirmer la suppression de ce document ?');"
title="Supprimer le document">
<i class="fa fa-trash red"></i>
</a>
]
</div>
</div>
</BOUCLE_autres>
</div> </div>
<script type="text/javascript">
jQuery(function() {
$('.valider_bigup').css('display','none');
$('input.bigup').bigup({}, {
complete: function(){
console.log("on valide [(#ENV{objet})]_[(#ENV{id_objet})]");
$(this).parents('form').submit();
},
});
});
</script>

View file

@ -23,7 +23,7 @@
] ]
<B_fichiers> <B_fichiers>
<div class='bigup_fichiers fichiers_[(#ENV{nom}|concat{#ENV{multiple}|=={oui}|?{\[\]}}|bigup_nom2classe)]'> <div class='bigup_fichiers fichiers_[(#ENV{nom}|concat{#ENV{multiple}|=={oui}|?{\[\]}}|bigup_nom2classe)]'>
<BOUCLE_fichiers(DATA){source table, #FICHIERS|bigup_lister_fichiers{#ENV{nom},#ENV{multiple}}}> <BOUCLE_fichiers(DATA){source tableau, #FICHIERS|bigup_lister_fichiers{#ENV{nom},#ENV{multiple}}}>
<div class='fichier'> <div class='fichier'>
<div class='description'> <div class='description'>
[(#VALEUR{bigup/vignette/data}|oui) [(#VALEUR{bigup/vignette/data}|oui)
@ -36,21 +36,20 @@
<span class='name'><strong>#NAME</strong></span> <span class='name'><strong>#NAME</strong></span>
<span class='size'>[(#SIZE|taille_en_octets)]</span> <span class='size'>[(#SIZE|taille_en_octets)]</span>
</div> </div>
[(#ENV{mode}|=={liste}|non)
<div class="html_titre"> <div class="html_titre">
<label><:bigform:html_titre:> <input type="text" value="" name="html_titre\[\]"/></label> <label><:bigform:html_titre:><input type="text" value="" name="html_titre\[\]"/></label>
<input type="hidden" value="#NAME" name="html_ordre\[\]"/> <input type="hidden" value="#NAME" name="html_ordre\[\]"/>
</div> </div>
<div class='actions'> <div class='actions'>
<button class='submit' type='submit' <button class='submit' type='submit'
name='bigup_enlever_fichier' value="#VALEUR{bigup/identifiant}" name='bigup_enlever_fichier' value="#VALEUR{bigup/identifiant}"
onclick="jQuery(this).parents('form').find('input,textarea,select').filter('\[required\]').prop('required', false); return true;"> onclick="jQuery(this).parents('form').find('input,textarea,select').filter('[required]').prop('required', false); return true;">
<:bigup:bouton_enlever:> <:bigup:bouton_enlever:>
</button> </button>
</div> </div>
]
</div> </div>
</div> </div>
</BOUCLE_fichiers> </BOUCLE_fichiers>
</div> </div>
</B_fichiers> </B_fichiers>

View file

@ -1,23 +0,0 @@
<?php
// This is a SPIP language file -- Ceci est un fichier langue de SPIP
if (!defined('_ECRIRE_INC_VERSION')) {
return;
}
$GLOBALS[$GLOBALS['idx_lang']] = array(
// B
'bigform_titre' => 'BigForm',
// C
// E
'envoyer' => 'Submit',
//H
'html_titre' => 'Title',
// T
'titre_page_configurer_bigform' => 'Configure BigForm',
);

View file

@ -11,13 +11,13 @@ $GLOBALS[$GLOBALS['idx_lang']] = array(
'bigform_titre' => 'BigForm', 'bigform_titre' => 'BigForm',
// C // C
'cfg_exemple' => 'Exemple',
// E 'cfg_exemple_explication' => 'Explication de cet exemple',
'envoyer' => 'Envoyer', 'cfg_titre_parametrages' => 'Paramétrages',
//H //H
'html_titre' => 'Titre', 'html_titre' => 'Titre',
// T // T
'titre_page_configurer_bigform' => 'Configurer BigForm', 'titre_page_configurer_bigform' => 'BigForm',
); );

View file

@ -1,12 +1,12 @@
<paquet <paquet
prefix="bigform" prefix="bigform"
categorie="edition" categorie="edition"
version="1.4.5" version="1.1.4"
etat="dev" etat="dev"
compatibilite="[4.1.0;4.*]" compatibilite="[3.2.5;3.3.*]"
logo="prive/themes/spip/images/bigform-64.png" logo="prive/themes/spip/images/bigform-64.png"
documentation="" documentation=""
schema="1.0.5" schema="1.0.4"
> >
<nom>BigForm</nom> <nom>BigForm</nom>
@ -17,14 +17,9 @@
<licence>GNU/GPL</licence> <licence>GNU/GPL</licence>
<necessite nom="bigup" compatibilite="[1.0.0;[" /> <necessite nom="bigup" compatibilite="[1.0.0;[" />
<necessite nom="verifier" compatibilite="[3.1.0;[" />
<pipeline nom="autoriser" inclure="bigform_autorisations.php" /> <pipeline nom="autoriser" inclure="bigform_autorisations.php" />
<pipeline nom="declarer_tables_principales" inclure="base/bigform.php" /> <pipeline nom="declarer_tables_principales" inclure="base/bigform.php" />
<pipeline nom="post_edition" inclure="bigform_pipelines.php" />
<pipeline nom="bigform_verifier" action='' />
<pipeline nom="bigform_post_insertion" action='' />
</paquet> </paquet>

View file

@ -1,13 +0,0 @@
<BOUCLE_documents(DOCUMENTS)
{si #CONFIG{bigform/retailler_image}|=={oui}}
{si #SESSION{id_auteur}}
{si #ENV{id_auteur}|=={#SESSION{id_auteur}}}
{protected=""}
{id_document}
{largeur}{hauteur}{taille}
{tout}>
[(#FICHIER|image_recadre{3072:1800,-,focus}|adaptive_images{3072})]
[(#FICHIER|image_recadre{2048:1200,-,focus}|adaptive_images{2048})]
[(#FICHIER|image_recadre{1024:600,-,focus}|adaptive_images{1024})]
[(#FICHIER|image_recadre{512:300,-,focus}|adaptive_images{512})]
</BOUCLE_documents>