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

All contributions published for previous SPIP versions

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
exemple

ed in visualizzazione (nello spazio redazionale):

exemple2
exemple2

updated on 28 September 2018

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

    Reply to this message

Comment on this article

Who are you?
  • [Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom