Skip to main content

DesignItalia contenty types

Project description

Design Plone Content-types

Pacchetto per la gestione dei content-type per un sito Agid con Plone.

Features

Installando questo pacchetto, si rendono disponibili diversi content-type per la gestione di un sito Agid con Plone e Volto.

Tipi di contenuto

Elenco tipi implementati

  • Cartella Modulistica

    • Definizione campi
    • Ordine campi
    • Vista su Volto completata
  • Collegamento

    • Definizione campi
    • Ordine campi
    • Indicizzazione testo
    • Vista su Volto completata
    • Selezione link interno
  • Dataset

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Documento

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Documento Personale

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Evento

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Messaggio

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Modulo

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Vista su Volto completata
  • Notizia

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Luogo

    • Definizione campi
    • Abilitare behavior collective.address.address
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
    • gestione di "è sede di"
  • Pagina Argomento

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Persona

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Pratica

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Ricevuta Pagamento

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Servizio

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata
  • Unità Organizzativa

    • Definizione campi
    • Ordine campi
    • Ordine fieldsets
    • Indicizzazione testo
    • Vista su Volto completata

Bando

Proveniente da redturtle.bandi_.

Sono state fatte alcune modifiche ai campi e in più:

  • La vista di default nel backend è la base_view, in modo da non dare problemi con i campi a blocchi
  • Rimosso l'ente di default
  • Le cartelle approfondimento possono contenere anche Moduli

.. _redturtle.bandi: https://github.com/RedTurtle/redturtle.bandi

Cartella Modulistica

Contenuto folderish (come la Pagina) che serve a raggruppare dei Documenti.

Questo content-type ha sia i blocchi attivati che una vista ad hoc che mostra i Documenti al suo interno con già i link ai file da scaricare.

Se i Documenti vengono raggruppati in Pagine, nella vista verrà mostrato il testo delle pagine contenitori come separatore tra i vari gruppi (solo nella parte Volto).

Nella proprietà @components dell'oggetto CartellaModulistica, viene sempre inviato nella prop modulistica-items l'url dell'endpoint per avere la struttura dati degli elementi da mostrare nella vista della cartella modulistica. Quell'url ritorna sempre una oggetto del tipo {items:[]} dove l'array contiene gli elementi.

Documento

Ha i campi definiti da Agid (senza quelli specifici per i Bandi, perché li gestiamo con un content-type ad hoc).

Al suo interno può contenere degli oggetti di tipo Modulo (che sono i file scaricabili veri e propri).

I Moduli che vengono inseriti dentro al Documento, verranno mostrati nel frontend come lista di documenti scaricabili. E' presente una customizzazione del serializer per poter mostrare di default più di 25 risultati (200), perché può essere necessario mostrare più moduli.

Se si prova a fare un caricamento massivo di file dalla vista "contents" di un Documento, c'è una personalizzazione di restapi che converte il tipo da File (il default che imposta Volto per la POST) a Modulo. In questo modo si può fare il caricamento massivo di Moduli dentro ad un Documento.

Campi indicizzati nel SearchableText

  • blocchi Volto

Evento di creazione

Alla creazione di un Documento, un evento genera in automatico una cartella "Multimedia" dove andare ad inserire delle eventuali immagini.

L'evento imposta anche come unico contenuto aggiungibile dentro al Documento, il Modulo.

Luogo

Esiste un deserializer per plone.restapi per il campo di tipo "GeolocationField" che si occupa di trasformare le coordinate in input, in un oggetto corretto per quel campo.

Accetta un valore del tipo::

{
  "latitude": 10.0000,
  "longitude": 20.0000,
}

Alcuni campi della geolocalizzazione hanno dei valori predefiniti quando viene richiesto lo schema mediante plone.restapi:

  • city
  • street
  • geolocation
  • country

Sono pre-popolati con la sede di AGID a Roma.

Il campo "sede_di" ritornato da restapi è calcolato in base alle Unità Operative che lo referenziano come sede principale o secondaria.

Modulo

Content-type creabile solo all'interno del Documento. Questo è un File "evoluto". Ha 3 campi file: uno per il modulo principale, e gli altri due per eventuali formati alternativi.

Notizie e comunicati stampa

  • Tipo base "Notizia" di Plone con alcuni campi aggiuntivi.
  • Folderish (grazie a redturtle.volto)
  • Può contenere Immagini, Collegamenti, File, Documenti (utile per strutturare i contenuti al suo interno)
  • Alla creazione di una Notizia, vengono create automaticamente al suo interno due cartelle "Multimedia" e "Documenti allegati" per poter organizzare meglio i contenuti

Pagina

  • Può essere usata anche come pagina di disambiguazione. C'è una behavior attivata (design.plone.contenttypes.behavior.info_testata) per impostare informazioni aggiuntive per la testata delle pagine di disambiguazione.

Pagina Argomento

Le pagine argomento hanno i blocchi. plone.restapi ha un indexer per SearchableText per poter indicizzare i blocchi.

Questo va in conflitto con le personalizzazioni fatte con collective.dexteritytextindexer perché Plone prende come buono il primo adapter di SearchableText che trova. Per ovviare a questo problema, abbiamo messo la behavior "volto.blocks" come ultima, in modo che venisse ignorato il suo indexer, e poi abbiamo registrato un adapter per IDynamicTextIndexExtender per replicare l'indicizzazione dei blocchi anche per le pagine argomento.

Evento di modifica

Se si modifica il titolo dell'argomento, viene scatenato un event handler che cerca tutti i contenuti del sito che referenziano questa pagina, e reindicizza il loro indice tassonomia_argomenti per aggiornare il valore (perché ci si salva il titolo).

Campi indicizzati nel SearchableText

  • blocchi Volto
  • unita_amministrative_responsabili
  • ulteriori_informazioni

Persona

Il serializer della persona, ritorna anche i seguenti valori calcolati:

  • strutture_correlate: elenco di Unità Organizzative in cui la persona è stata aggiunta nel campo "Persone che compongono la struttura"
  • responsabile_di: elenco di Unità Organizzative in cui la persona è stata aggiunta nel campo "Responsabile"
  • assessore_di: elenco di Unità Organizzative in cui la persona è stata aggiunta nel campo "Assessore di riferimento"

Evento di creazione

Alla creazione di una Persona, viene creata anche una struttura predefinita per contenere diversi documenti:

  • Foto e attività politica
  • Compensi
  • Importi di viaggio e/o servizi
  • Situazione patrimoniale
  • Dichiarazione dei redditi
  • Spese elettorali
  • Variazione situazione patrimoniale
  • Altre cariche

Campi indicizzati nel SearchableText

  • ruolo
  • competenze
  • deleghe
  • tipologia_persona
  • telefono
  • email
  • informazioni_di_contatto

Servizio

Campi indicizzati nel SearchableText

  • descrizione_estesa
  • sottotitolo
  • descrizione_destinatari
  • chi_puo_presentare
  • come_si_fa
  • cosa_si_ottiene
  • cosa_serve
  • ulteriori_informazioni
  • tassonomia_argomenti
  • copertura_geografica
  • costi
  • life_event
  • servizi_collegati

Unità Organizzativa

La get di questo content-type, ritorna (nell'attributo "servizi_offerti") anche la lista di Servizi che la referenziano nei campi "ufficio_responsabile" e "area".

Campi indicizzati nel SearchableText

  • street
  • city
  • zip_code
  • country
  • quartiere
  • circoscrizione
  • descrizione_breve
  • orario_pubblico
  • identificativo_mibac

Pannello di controllo

Nel pannello di controllo "Impostazioni Design Plone" sono presenti diversi campi dove configurare valori di default per i vari contenuti:

  • Tipologie notizia
  • Tipologie persona
  • Tipologie unità organizzativa
  • Tipologie documento
  • Dimensioni leadimage
  • Sezioni ricerca
  • Mostra la data di modifica

A parte gli ultimi tre, gli altri campi sono tutti multilingua. I vocabolari che usano quei valori, ritornano solo i possibili valori a seconda della lingua selezionata dall'utente.

Gestione modulistica

Agid prevede un tipo di contenuto Documento per gestire i moduli scaricabili.

Abbiamo però sviluppato anche un contenuto chiamato Cartella Modulistica che ha il compito di raggruppare in modo logico più Documenti e mostrarli all'utente come faceva il vecchio prodotto cciaa.modulistica.

Data di modifica

Esiste una behavior (design.plone.contenttypes.behavior.show_modified) abilitata di default solo per i Document (Pagina) che indica al frontend se va mostrata o meno la data di modifica.

Nel pannello di controllo viene definito il default, mentre nel singolo contenuto è possibile cambiare il valore nel tab "Impostazioni".

Endpoint restapi

Customizzazione dati relation field

C'è una customizzazione dei dati ritornati dal serializer per i relation field (correlati) per ritornare oltre alle informazioni standard, anche la data di pubblicazione e l'inizio e fine evento.

Vengono ritornati solo i correlati che l'utente che li ha richiesti può vedere (a differenza dello standard, che li torna tutti).

Serializer summary

E' il serializer utilizzato dalla get di un contenuto per mostrare il dettaglio dei suoi figli quando non viene richiesta la fullobjects (ci sono sono le informazioni base quindi).

E' stato customizzato per ritornare sempre due informazioni utili visto che Volto ora non richiede più sempre la fullobjects:

  • has_children: ritorna True o False a seconda che il contenuto abbia o meno dei figli
  • id: l'id dell'oggetto

## @modulistica_items

Endpoint ed expansion per la modulistica.

Nei content-type CartellaModulistica, tra i vari expansion c'è anche @modulistica_items. Questo è utile per la vista di frontend, in quanto se richiamato, ritorna la struttura di dati da mostrare in visualizzazione.

Installazione

Questo prodotto non è stato pensato per funzionare da solo, ma fa parte della suite "design.plone".

Per utilizzare questo prodotto, fare riferimento a design.plone.policy_.

.. _design.plone.policy: https://github.com/RedTurtle/design.plone.policy

Traduzioni

Per aggiornare le traduzioni, basta usare lo script update_locales dentro alla cartella bin::

bin/update_locales

N.B.: lo script va chiamato due volte perché al primo giro non aggiorna i file.

Contribuisci

Licenza

Questo progetto è rilasciato con licenza GPLv2.

Autori

Questo progetto è stato sviluppato da RedTurtle Technology.

RedTurtle Technology Site

Contributors

Changelog

3.6.0 (2021-09-21)

  • Add link_siti_esterni to SearchableText index. [cekk]
  • showModifiedDefaultValue compatible with plone.restapi >= 8.9.1 [cekk]
  • All content-types extends IDesignPloneContentType marker interface. [cekk]
  • Register custom TextBlockSearchableText adapter to index all text blocks in IDesignPloneContentType contents. [cekk]
  • Customize some Bando and Bando Folder Deepenings fields and allowed types. [cekk]
  • Add ufficio_responsabile_bando and Subject_bando indexes to speedup @bandi-search-filters endpoint. [cekk]
  • Upgrade step to enable kitconcept.seo behavior on contents. [daniele]
  • Refactor @types endpoint to be more extensible. [cekk]
  • show_modified_default is True by default. [cekk]

3.5.0 (2021-08-24)

  • Add new index: uo_location. [cekk]
  • Add new fields to be indexed in SearchableText for UO: nome_sede, email, pec, web [cekk]
  • Do not break if there are extra fieldsets that comes from non standard addons: just append them to the default ordered list. [cekk]

3.4.2 (2021-08-03)

  • Remove required from ufficio_responsabile and area_responsabile in Documento contents. [cekk]

3.4.1 (2021-07-30)

  • You can now add "File" content type inside a CartellaModulistica. [arsenico13]

3.4.0 (2021-07-07)

  • Convert File into Modulo when trying to do a massive upload inside a Documento. [cekk]
  • Fix description for "a_cura_di_persone" field. [cekk]
  • Added "maximumSelectionSize" in RelatedItemsFieldWidget [giulia]
  • Add mostra_bottoni_condivisione field.
  • Change block @type: newsHome -> highlitedContent [cekk]

3.3.2 (2021-06-25)

  • Enabled "trasparenza" behavior. It's back! [arsenico13]

3.3.1 (2021-06-17)

  • Handle contents with old Richtext values in volto13 migration. [cekk]

3.3.0 (2021-06-17)

  • Volto 13 compatibility. [cekk]

3.2.0 (2021-06-08)

  • Add new behavior "design.plone.contenttypes.behavior.show_modified". [cekk]

3.1.1 (2021-05-28)

  • Removed field "Accedere al servizio" from Documento ct. [daniele]

3.1.0 (2021-05-26)

  • Add design.plone.contenttypes.behavior.argomenti_document behavior to Document. [cekk]
  • correlato_in_evidenza field now return also icon value in restapi calls. [cekk]
  • Add leadimage to CartellaModulistica. [cekk]

3.0.3 (2021-05-20)

  • Added criteria for ente bando and ufficio responsabile. [daniele]

3.0.2 (2021-05-17)

  • Added backreferences to Documento and Cartella Modulistica for related services. [daniele]
  • Documento now set b_size=200 by default to show more than 25 items when getting its data. [cekk]

3.0.1 (2021-05-04)

  • Fix upgrade-step. [cekk]

3.0.0 (2021-04-30)

  • Rename controlpanel. [cekk]
  • Now controlpanel settings entries can be multilanguage. [cekk]
  • organizzazione_riferimento field for Persona no more required. [cekk]
  • servizi_offerti in UO serializer now returns only related Servizi. [cekk]

2.0.6 (2021-04-16)

  • Fix Venue fields order. [cekk]

2.0.5 (2021-04-16)

  • Add plone.app.dexterity.behaviors.id.IShortNamebehavior to Venue content-type to allow renaming. [cekk]

2.0.4 (2021-04-15)

  • Fix typo. [cekk]

2.0.3 (2021-04-08)

  • Added behavior plone.translatable by default on almost all the content types. [arsenico13]

2.0.2 (2021-03-24)

  • Now you can customize tipologie_persona from the control panel. [arsenico13]

2.0.1 (2021-03-24)

  • Fix defaults for vocabularies. [cekk]
  • Add remoteUrl to summarize serialization for Link content-type. [cekk]

2.0.0 (2021-03-02)

  • BREAKING CHANGE: use blocks editor also in other "text" fields. [cekk]

1.0.9 (2021-02-25)

  • Add search_sections field in control panel. [cekk]
  • Can add Images into Cartella Modulistica (to be able to add image blocks in it). [cekk]
  • Customizable tipologie_documento. [cekk]

1.0.8 (2021-02-19)

  • Fix typo. [cekk]

1.0.7 (2021-02-19)

  • Do not run dependencies when upgrading plone.app.registry. [cekk]

1.0.6 (2021-02-15)

  • Handle Servizio tabs in both cases: with Trasparenza enabled or not. [cekk]

1.0.5 (2021-02-08)

  • Disable trasparenza behavior by default. [deodorhunter]
  • Remove reference limit in "persone_struttura" field. [cekk]

1.0.4 (2021-02-05)

  • Add upgrade-step to cleanup Bando behaviors. [cekk]

1.0.3 (2021-01-20)

  • BREAKING CHANGE Convert RichText fields into BlocksField.
  • Upgrade-step to fix unused listing block template. [cekk]

1.0.2 (2020-12-17)

  • Fix rolemap for new types. [cekk]
  • Do not break eventoCreateHandler when copying and event. [cekk]

1.0.1 (2020-12-14)

  • Add immagine_testata new field in design.plone.contenttypes.behavior.info_testata behavior. [cekk]
  • Add correlato_in_evidenza new field in design.plone.contenttypes.behavior.argomenti behavior. [cekk]

1.0.0 (2020-12-07)

  • Initial release. [RedTurtle]

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

design.plone.contenttypes-3.6.0.tar.gz (151.0 kB view hashes)

Uploaded Source

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page