Gestione di campi aggiuntivi per la tabella articoli (SPIP 1.8.3 e 1.9B2)

Ceci est une ARCHIVE, peut-être périmée. Vérifiez bien les compatibilités !

Come è ben spiegato in questo articolo (fr), è possibile aggiungere dei campi alle tabelle SPIP dalla versione 1.8. In tal modo è possibile sostituire i campi extra ma non proprio del tutto. In effetti i campi extra hanno il vantaggio di poter essere direttamente gestiti dalla parte privata del sito, cosa non vera per i campi aggiunti.

Avevo bisogno di aggiungere dei campi nella tabella articoli per un sito in preparazione, quindi mi sono messo al lavoro su questo argomento, solo per la tabella articoli. Di seguito sono proposti dei file modificati per gestire i campi aggiuntivi direttamente dalla pagina di modifica degli articoli. Le modifiche proposte cercano di rispettare le modalità di funzionamento di SPIP.

Il principio è di utilizzare un file che descrive i campi aggiunti in modo da
predisporli opportunamente in base al tipo di dati da inserire.

Ecco le modifiche :

Per la V1.8.3 :

Add-ons pour /ecrire

e per la V1.9 beta2 del 03/06/06 :

add-ons V1.9 courante (03/06/06)

Ecco un esempio di file di configurazione, che descriverò seccessivamente.

<?php
$GLOBALS['champs_site'] = Array (
        'articles' => Array (
                        'inedit' => Array(
                                  'champ'    => 'inedit',
                                  'titre'    => 'Inédit ?',
                                  'style'    => Array( 'couleur' => '#FF0000' ),
                                  'secteur'  => 1,
                                  'type'     => 'choix',
                                  'multiple' => 'non',
                                  'modele'   => 'texte',
                                  'valeurs'  => Array (
                                             'Oui' => 'Inédit',
                                             'Non' => 'Réédition'
                                  )
                        ),
                        'isbn' => Array(
                                  'champ'    => 'isbn',
                                  'titre'    => 'Num.ISBN',
                                  'style'    => Array(),
                                  'secteur'  => 1,
                                  'type'     => 'texte',
                                  'taille'   => 20,
                                  'modele'   => 'texte'
                        ),
                        'essaicheck' => Array(
                                  'champ'    => 'essaicheck',
                                  'titre'    => 'Essai check',
                                  'style'    => Array(
                                               'aligne' => 'horizontal',
                                               'couleur' => '#0088CC'
                                  ),
                                  'secteur'  => 1,
                                  'type'     => 'choix',
                                  'multiple' => 'oui',
                                  'modele'   => 'texte',
                                  'valeurs'  => Array (
                                             'Oui' => 'Oui',
                                             'Non' => 'Non',
                                             'Ptèt' => 'Bof'
                                  ) 
                       ),
                        'project' => Array(
                                  'champ'    => 'project',
                                  'titre'    => 'Project',
                                  'style'    => Array(),
                                  'secteur'  => 1,
                                  'type'     => 'table',
                                  'table'    => 'site_proj',
                                  'colonne'  => 'name',
                                  'valeur'   => 'prjid',
                                  'multiple' => 'non',
                                  'modele'   => 'entier'
                        ),

         )
);
?>

Ogni campo è descritto grazie a degli elementi obbligatori:
’articles’ => Array (
’inedit’ => Array(
’champ’ => ’inedit’,
’titre’ => ’Inédit ?’,
’style’ => Array( ’couleur’ => ’#FF0000’ ),
’secteur’ => 1,
’type’ => ’choix’,
’multiple’ => ’non’,
’modele’ => ’texte’,
’valeurs’ => Array (
’Oui’ => ’Inédit’,
’Non’ => ’Réédition’
)
),
’isbn’ => Array(
’champ’ => ’isbn’,
’titre’ => ’Num.ISBN’,
’style’ => Array(),
’secteur’ => 1,
’type’ => ’texte’,
’taille’ => 20,
’modele’ => ’texte’
),
’essaicheck’ => Array(
’champ’ => ’essaicheck’,
’titre’ => ’Essai check’,
’style’ => Array(
’aligne’ => ’horizontal’,
’couleur’ => ’#0088CC’
),
’secteur’ => 1,
’type’ => ’choix’,
’multiple’ => ’oui’,
’modele’ => ’texte’,
’valeurs’ => Array (
’Oui’ => ’Oui’,
’Non’ => ’Non’,
’Ptèt’ => ’Bof’
)
),
’project’ => Array(
’champ’ => ’project’,
’titre’ => ’Project’,
’style’ => Array(),
’secteur’ => 1,
’type’ => ’table’,
’table’ => ’site_proj’,
’colonne’ => ’name’,
’valeur’ => ’prjid’,
’multiple’ => ’non’,
’modele’ => ’entier’
),

)
);
?>

Ogni campo è descritto grazie a degli elementi obbligatori:
-  ’champ’ per indicare il nome della colonna nella tabella
-  ’titre’ per specificare il nome del campo per l’utente in redazione
-  ’style’ per modificare eventualmente l’aspetto tipografico
-  ’secteur’ per indicare in quale settore è utilizzabile il campo (un unico settore per campo per il momento)
-  ’type’ indica il tipo di rappresentazione adatta, che può essere ’choix’ (una scelta in un elenco preimpostato), ’texte’ (campo semplice) o ’table’ (scelta tra elementi di una tabella esterna)

Un campo opzionale ’modele’ => ’texte’ per indicare che il campo è di tipo testo all’interno della base dati (altrimenti il campo verrà considerato come un numero).

Quindi, in base al tipo di campo, ci sono altri elementi da specificare.

Per i campi di tipo ’texte’, deve essere fornita la dimensione (la lunghezza del campo)

Per il tipo ’choix’, bisogna indicare se la selezione degli elementi dell’elenco è multipla (’multiple’) o semplice, oltre alla lista dei valori e del testo da mostrare per ogni valore.

Per le tabelle esterne, bisogna indicare il nome della tabella (’table’), la colonna (’colonne’) da visualizzare oltre alla colonna contenente il valore (’valeur’) da inserire nel campo. Si possono avere anche scelte multiple.

Ecco come appare l’interfaccia in modifica:

exemple

ed in visualizzazione (nello spazio redazionale):
exemple2

Discussion

Une discussion

  • 1

    La cosa mi interessa molto, perchè permetterebbe di gestire contenuti differenti con la sola tabella articles.

    Qual è il vantaggio di usare la tua mod invece dei campi extra? anche questi non vengono indicizzati, o sbaglio?

    Ho dato un’occhiata al codice.
    per aggiungerli a tutte le sezioni non bast modificare gli if a linea 229 del file article_edit.php?
    [ if (($pluschamp[’secteur’] == $id_secteur) OR $pchamp[$keychamp]) ]

    Non sarebbe meglio cercare di fare lo stesso tramite un plugin, in modo da fare sì che si possa gestire la modifica anche su ogni nuova versione di spip?

    Ciao

    • Ciao mmmx,
      prima di tutto, l’articolo non è mio. L’ho tradotto. Se vuoi chiedere ulteriori info all’autore, fallo sulla versione in francese.

      Il vantaggio rispetto ai campi extra è che hai i campi separati in tabella e non un un unico campo con tutti i dati serializzati.
      I campi extra, inoltre, sono indicizzati dal motore di ricerca e, con un’opportuna configurazione, qualsiasi campo di qualsiasi tabella può essere indicizzato.

      Per quanto riguarda il plugin, si attendono volontari ;)
      Prova a dare un’occhiata su zone.spip.org

      Cap

    Rispondere al messaggio

Rispondere all’articolo

Chi sei?
  • [Connettersi]

Per mostrare qui il tuo avatar, registralo prima su gravatar.com (gratis e indolore). Non dimenticare di fornire il tuo indirizzo email.

Inserisci qui il tuo commento

Questo form accetta scorciatoie SPIP [->url] {{gras}} {italique} <quote> <code> et le code HTML <q> <del> <ins>. Per creare i paragrafi, lascia delle linee vuote.

Aggiungi un documento

Suivre les commentaires : RSS 2.0 | Atom

Dernière modification de cette page le 28 settembre 2018