Di seguito sono riportati i criteri di conformità e le raccomandazioni verificabili tramite App di valutazione dell'adesione al modello Comuni.
Per il corretto funzionamento dell'App di valutazione, è necessario inserire dei data attribute all’interno dei tag HTML del sito. Questi vengono indicati separatamente per ognuno dei criteri. Alcuni data attribute valgono per più criteri.
La chiave generale dei data attribute è data-element=*
e va inserita all’interno dei tag HTML.
Note
I data attribute, dove possibile, sono già presenti nei materiali forniti da Designers Italia, sia all'interno dei template HTML che dei temi CMS messi a disposizione. Rimane tuttavia responsabilità dell'ente verificare che siano correttamente inseriti dove richiesto.
Note
Per tutto ciò che è un URL, per esempio FAQ o Segnalazione disservizio, l'App controlla anche che l’URL nell’href del componente non sia nullo e, per alcuni casi specifici, che sia in HTTPS e che riporti ad una pagina “funzionante”.
Note
Per tutto ciò che viene controllato sulla base di un vocabolario si utilizzano controlli non case-sensitive.
Important
I requisiti tecnici qui riportati sono necessari, oltre che per il funzionamento dell'App di valutazione, anche per lo svolgimento delle verifiche da parte del DTD per il rilascio dei fondi della misura 1.4.1. A questo proposito il sito comunale, una volta pubblicato, deve anche essere funzionante durante gli orari notturni e raggiungibile dagli indirizzi IP 15.160.11.200, 15.160.250.158 e 18.102.41.229 (è necessario che questi indirizzi non vengano bloccati da un eventuale firewall).
Condizioni di successo: per superare il test effettuato dall'app, tutti i titoli (heading) e tutti i paragrafi delle pagine del sito in lingua italiana utilizzano esclusivamente i font Titillium Web, Lora o Roboto Mono come font di default. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: tramite ricerca di specifici attributi data-element, nelle pagine analizzate viene verificato che i font di default siano quelli richiesti all'interno di tutti gli <h> e <p>. La verifica viene svolta sulla homepage, N pagine di primo livello, N pagine di secondo livello, N pagine di terzo livello “Scheda servizio” e nella pagina di accesso all’area riservata.
Requisiti tecnici:
Caricamento pagina di accesso all’area riservata:
In homepage, se è presente un link alla pagina di accesso all'area riservata, questo deve contenere il data-element="personal-area-login"
nel tag <a> contenente il link alla pagina.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-a.html
Caricamento pagine primo livello:
In homepage, per poter identificare i link alle pagine di primo livello, nel menù principale identificato dal tag <div class="navbar"> i link alle pagine di primo livello devono contenere all'interno del tag <a class="nav-link"> i seguenti attributi:
- "Amministrazione":
data-element="management"
- "Novità":
data-element="news"
- "Servizi":
data-element="all-services"
- "Vivere il Comune":
data-element="live"
- Eventuali voci aggiuntive:
data-element=”custom-submenu”
L'assenza di uno dei data-element (ad eccezione di quelli relativi a eventuali voci aggiuntive) porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-b.html
Caricamento pagine di secondo livello:
Per il caricamento delle pagine di secondo livello è necessario che i data-element alle pagine di primo livello siano correttamente posizionati all'interno dei link delle pagine di primo livello nel menù principale.
La pagina di primo livello "Amministrazione", identificata grazie al data-element="management"
, dovrà contenere il data-element="management-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Novità", identificata grazie al data-element="news"
, dovrà contenere il data-element="news-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Vivere il comune", identificata grazie al data-element="live"
, dovrà contenere due bottoni. Il bottone che porta alla pagina di secondo livello "Eventi" dovrà contenere data-element="live-button-events"
e il bottone che porta alla pagina di secondo livello "Luoghi" dovrà contenere data-element="live-button-locations"
. Per entrambi i bottoni il data-element dovrà essere posizionato sul tag <button> e il link alla pagina di secondo livello dovrà essere presente o all’interno dell’attributo «onclick» o all'interno di un attributo «href». La mancata individuazione di almeno un link attraverso questi data-element porta all'impossibilità di esecuzione dell'audit.
Nel caso fossero presenti delle voci aggiuntive di primo livello esse vengono identificate attraverso il data-element=”custom-submenu”
. In ognuna di queste pagine è necessaria la presenza del data-element=”custom-category-link”
all’interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-c.html
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-d.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Condizioni di successo: per superare il test effettuato dall'app, in ogni pagina deve essere presente e in uso la libreria Bootstrap Italia in una versione uguale o superiore alla 2.0 e almeno il 30% delle classi CSS usate deve appartenere alle classi CSS di Bootstrap Italia. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi data-element, in ogni pagina analizzata viene verificata la presenza della libreria Bootstrap Italia e la versione in uso, individuando la proprietà CSS --bootstrap-italia-version all’interno del selettore :root o la variabile globale window.BOOTSTRAP_ITALIA_VERSION. Inoltre, viene verificato che almeno il 30% delle classi CSS uniche trovate nella pagina appartiene all'elenco delle classi CSS di Bootstrap Italia. La verifica viene svolta sulla homepage, N pagine di primo livello, N pagine di secondo livello, N pagine di terzo livello “Scheda servizio”, nella pagina di accesso all’area riservata e nella pagina della funzionalità di prenotazione appuntamento.
Requisiti tecnici:
Note
Qualora il test dovesse fallire e tutti i data-element necessari sono presenti, riprova la verifica disabilitando il post processing del CSS (minificazione o inlining).
Caricamento pagina di accesso all’area riservata:
In homepage, se è presente un link alla pagina di accesso all'area riservata, questo deve contenere il data-element="personal-area-login"
nel tag <a> contenete il link alla pagina.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-2-a.html
Caricamento pagina di prenotazione appuntamenti:
Per caricare la pagina prenotazione appuntamenti è necessario che il data-element=”all-service”
sia posizionato in homepage nel link della pagina di primo livello “Servizi”. In questa pagina di primo livello il link alla pagina di prenotazione appuntamenti deve contenere il data-element="appointment-booking"
nel tag <a> contenente il link alla pagina.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-2-b.html
Caricamento pagine primo livello:
In homepage, per poter identificare i link alle pagine di primo livello, nel menù principale identificato dal tag <div class="navbar"> i link alle pagine di primo livello devono contenere all'interno del tag <a class="nav-link"> i seguenti attributi:
- "Amministrazione":
data-element="management"
- "Novità":
data-element="news"
- "Servizi":
data-element="all-services"
- "Vivere il Comune":
data-element="live"
- Eventuali voci aggiuntive:
data-element=”custom-submenu”
L'assenza di uno dei data-element (ad eccezione di quelli relativi a eventuali voci aggiuntive) porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-2-c.html
Caricamento pagine di secondo livello:
Per il caricamento delle pagine di secondo livello è necessario che i data-element alle pagine di primo livello siano correttamente posizionati all'interno dei link delle pagine di primo livello nel menù principale.
La pagina di primo livello "Amministrazione", identificata grazie al data-element="management"
, dovrà contenere il data-element="management-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Novità", identificata grazie al data-element="news"
, dovrà contenere il data-element="news-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Vivere il comune", identificata grazie al data-element="live"
, dovrà contenere due bottoni. Il bottone che porta alla pagina di secondo livello "Eventi" dovrà contenere data-element="live-button-events"
e il bottone che porta alla pagina di secondo livello "Luoghi" dovrà contenere data-element="live-button-locations"
. Per entrambi i bottoni il data-element dovrà essere posizionato sul tag <button> e il link alla pagina di secondo livello dovrà essere presente o all’interno dell’attributo «onclick» o all'interno di un attributo «href». La mancata individuazione di almeno un link attraverso questi data-element porta all'impossibilità di esecuzione dell'audit.
Nel caso fossero presenti delle voci aggiuntive di primo livello esse vengono identificate attraverso il data-element=”custom-submenu”. In ognuna di queste pagine è necessaria la presenza del data-element=”custom-category-link” all’interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-2-d.html
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-2-e.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Condizioni di successo: per superare il test effettuato dall'app, devono essere presenti almeno 10 schede informative di servizio e in queste le voci obbligatorie e i relativi contenuti sono presenti e, dove richiesto, sono nell'ordine corretto. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: viene verificata la presenza e l'ordine delle voci richieste ricercandole all'interno della pagina e dell'indice tramite specifici data-element. Per essere ritenute valide, le voci devono avere contenuti associati della tipologia indicata all'interno del documento di architettura dell'informazione. La verifica viene effettuata su N pagine di terzo livello “Scheda servizio”.
Requisiti tecnici:
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards".
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-3-a.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Controllo della presenza e ordine delle voci nelle “Schede servizio”:
Per le pagine di terzo livello di servizi è necessaria la presenza del data-element="page-index"
nell'indice della pagina identificato dal tag <ul>. Da questo indice vengono caricate le voci che si trovano dentro i tag <a> di ogni riga dell'indice indicata dal tag <li>. Le voci per le quali viene controllata la presenza nell'indice e il loro ordinamento sono:
- "A chi è rivolto"
- "Come fare"
- "Cosa serve"
- "Cosa si ottiene"
- "Tempi e scadenze"
- "Accedi al servizio",
- "Condizioni di servizio"
- "Contatti"
Per queste voci viene anche controllata la presenza di contenuto nella relativa sezione in pagina. Se la sezione non viene individuata la relativa voce risulterà mancante nella reportistica. In particolare:
- "A chi è rivolto": viene controllata la presenza di un tag <p> contenuto nel <div> con
data-element="service-addressed"
e che questo abbia almeno 3 caratteri; - "Come fare": viene controllata la presenza di un tag <p> contenuto nel <div> con
data-element="service-how-to"
e che questo abbia almeno 3 caratteri; - "Cosa serve": viene controllata la presenza di un tag <p> contenuto nel <div> con
data-element="service-needed"
e che questo abbia almeno 3 caratteri; - "Cosa si ottiene": viene controllata la presenza di un tag <p> contenuto nel <div> con
data-element="service-achieved"
e che questo abbia almeno 3 caratteri; - "Tempi e scadenze": per confermare la presenza in pagina della relativa sezione è sufficiente sia presente uno di questi 2 componenti: "Testo"(è necessario un <p> contenuto nel <div> con data-element="service-calendar-text" e che questo abbia almeno 3 caratteri in un testo al di fuori del componente calendario) e/o "Calendario" (un componente calendario contenuto in un tag <div> con data-element="service-calendar-list");
- "Accedi al servizio": per confermare la presenza in pagina della relativa sezione è sufficiente sia presente uno di questi 3 componenti: "Prenota appuntamento" (un tag <button> con
data-element="service-booking-access"
per il bottone che porta alla pagina di prenotazione appuntamenti), "Accesso online" (un tag <button> condata-element="service-online-access"
per il bottone che porta alla pagina di accesso online) e/o "Accesso generico" (un tag HTML condata-element="service-generic-access"
per un componente diverso da quelli sopra identificati); - "Condizioni di servizio": viene controllata la presenza di un tag <a> con
data-element="service-file"
; - "Contatti": viene controllata la presenza di un tag <div> con
data-element="service-area"
che identifica i contatti.
Viene inoltre controllata la presenza di altri componenti al di fuori dell'indice:
- "Categoria del servizio": viene controllata la presenza di un tag HTML con
data-element="breadcrumb"
che identifica la breadcrumb. In questo componente vengono individuati i testi relativi ai vari <li> e viene controllata la presenza di almeno 3 caratteri nel testo successivo a "Servizi"; - "Titolo": viene controllata la presenza di un tag HTML con
data-element="service-title"
che identifica il titolo del servizio e che questo abbia almeno 3 caratteri; - "Stato": viene controllata la presenza di un tag HTML con
data-element="service-status"
che identifica lo stato del servizio; - "Descrizione breve": viene controllata la presenza di un tag HTML con
data-element="service-description"
che identifica la descrizione del servizio e che questo abbia almeno 3 caratteri; - "Unità organizzativa responsabile": viene controllata la presenza di un tag HTML con
data-element="service-area"
che identifica l'area responsabile del servizio e che questo abbia almeno 3 caratteri; - "Argomenti": viene controllata la presenza di almeno un tag <a> con
data-element="service-topic"
che identificano gli argomenti del servizio (es. Turismo).
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-3-b.html
Note
Le voci controllate in questo criterio sono case sensitive, cioè devono coincidere anche nella distinzione tra maiuscole e minuscole.
Condizioni di successo: per superare il test effettuato dall'app, se è in uso il tema CMS del modello per i Comuni, la versione utilizzata è uguale o superiore alla 1.0. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: viene verificato l'uso del tema CMS del modello e la versione in uso ricercando uno specifico testo all'interno di tutti i file .CSS presenti in pagina.
Il testo ricercato nei file .css è:
.. literalinclude:: esempi-codice-comuni/c-si-1-4.html
Note
Qualora il test non dovesse identificare correttamente il tema CMS e la versione in uso, riprova la verifica disabilitando il post processing del CSS (minificazione o inlining).
Condizioni di successo: per superare il test effettuato dall'app, gli argomenti utilizzati appartengono alla lista indicata all'interno del documento di architettura dell'informazione del modello Comuni alla voce "Tassonomia argomenti" o al vocabolario controllato EuroVoc ed è presente un link in homepage (chiamato ad esempio, "Tutti gli argomenti") che porta a una pagina con l’elenco completo degli argomenti. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: gli argomenti identificati all'interno della pagina contenente l'elenco degli argomenti vengono confrontati con l'elenco di voci presente nel documento di architettura dell'informazione e con il vocabolario controllato EuroVoc, ricercandoli usando specifici attributi "data-element".
Requisiti tecnici: In homepage, all’interno di un tag <a>, deve esserci l’attributo data-element="all-topics"
che riporta alla pagina template-argomenti.html. In template-argomenti deve esserci una lista di argomenti (tag <a>) con l’attributo data-element="topic-element"
che contengono del testo con il nome dell’argomento.
Esempi:
.. literalinclude:: esempi-codice-comuni/c-si-1-5-a.html
.. literalinclude:: esempi-codice-comuni/c-si-1-5-b.html
Condizioni di successo: per superare il test effettuato dall'app, le voci del menù di primo livello del sito sono esattamente quelle indicate nel documento di architettura dell'informazione e sono nell'ordine indicato (ovvero "Amministrazione", "Novità", "Servizi", "Vivere il Comune" oppure "Vivere [nome del Comune]") e tutte le pagine raggiungibili dal menu di primo livello portano a pagine interne al dominio del Comune. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando uno specifico attributo data-element, vengono identificate le voci presenti nel menù del sito e il loro ordine, confrontandole con quanto indicato nella Documentazione del modello Comuni.
Viene verificata la presenza e la sequenzialità delle seguenti voci:
- Amministrazione
- Novità
- Servizi
- Vivere il Comune o Vivere {nome_Comune}
Inoltre, viene verificato che tutte le pagine raggiungibili dal menu di primo livello portino a pagine interne al dominio del Comune.
Requisiti tecnici: In template-homepage deve esserci un <ul> con l’attributo data-element=”main-navigation”
che contenga degli <li> e degli <a> in cui ci sono le label (può contenere altri tag).
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-6.html
Condizioni di successo: per superare il test effettuato dall'app, i titoli delle pagine di secondo livello corrispondono a quelli indicati nel capitolo "Conformità al modello Comuni" della Documentazione del Modello Comuni. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi data-element, viene verificato che i titoli delle card usate per rimandare alle pagine di secondo livello siano corretti e presenti sulle rispettive pagine genitore di primo livello. Nel caso della pagina di primo livello "Vivere il Comune", viene verificato che i titoli delle pagine di secondo livello raggiungibili da questa siano corretti. Nel conteggio vengono incluse anche le pagine di secondo livello raggiungibili da pagine di primo livello non indicate nella documentazione.
I titoli che vengono verificati sono:
- Per la sezione Amministrazione, “Organi di governo”, “Aree amministrative”, “Uffici”, “Enti e fondazioni”, “Politici”, “Personale amministrativo”, “Documenti e dati”;
- Per la sezione Novità, “Notizie”, “Comunicati”, “Avvisi”
- Per la sezione Servizi, “Educazione e formazione”, “Salute, benessere e assistenza”, “Vita lavorativa”, “Mobilità e trasporti”, “Catasto e urbanistica”, “Anagrafe e stato civile”, “Turismo”, “Giustizia e sicurezza pubblica”, “Tributi, finanze e contravvenzioni”, “Cultura e tempo libero”, “Ambiente”, “Imprese e commercio”, “Autorizzazioni”, “Appalti pubblici”, “Agricoltura e pesca”;
- Per la sezione Vivere il Comune o Vivere {nome_comune}, “Luoghi”, “Eventi”.
Requisiti tecnici:
Caricamento pagine primo livello:
In homepage, per poter identificare i link alle pagine di primo livello, nel menù principale identificato dal tag <div class="navbar"> i link alle pagine di primo livello devono contenere all'interno del tag <a class="nav-link"> i seguenti attributi:
- "Amministrazione":
data-element="management"
- "Novità":
data-element="news"
- "Servizi":
data-element="all-services"
- "Vivere il Comune":
data-element="live"
- Eventuali voci aggiuntive:
data-element=”custom-submenu”
L'assenza di uno dei data-element (ad eccezione di quelli relativi a eventuali voci aggiuntive) porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-7-a.html
Caricamento voci di secondo livello:
- "Amministrazione": nella pagina di primo livello, le card sotto la voce “Categoria” dovranno contenere un tag <a> con
data-element=”management-category-link”
dal quale verrà prelevato il testo. La mancata individuazione di almeno una voce attraverso questo data-element porta all’impossibilità di esecuzione dell’audit; - "Novità": nella pagina di primo livello, le card sotto la voce “Categoria” dovranno contenere un tag <a> con
data-element=”news-category-link”
dal quale verrà prelevato il testo. La mancata individuazione di almeno una voce attraverso questo data-element porta all’impossibilità di esecuzione dell’audit; - "Servizi": nella pagina di primo livello, le card sotto la voce “Categoria” dovranno contenere un tag <a> con
data-element=”service-category-link”
dal quale verrà prelevato il testo. La mancata individuazione di almeno una voce attraverso questo data-element porta all’impossibilità di esecuzione dell’audit; - "Vivere il Comune": la pagina di primo livello dovrà contenere due bottoni. Il bottone che porta alla pagina di secondo livello "Eventi" dovrà contenere
data-element="live-button-events"
e il bottone che porta alla pagina di secondo livello "Luoghi" dovrà conteneredata-element="live-button-locations"
. Per entrambi i bottoni il data-element dovrà essere posizionato sul tag <button> e il link alla pagina di secondo livello dovrà essere presente o all’interno dell’attributo «onclick» o all'interno di un attributo «href». In queste pagine di secondo livello dovrà essere presente un tag HTML condata-element=”page-name”
che identifica il titolo della pagina. La mancata individuazione di almeno una voce attraverso questo data-element porta all’impossibilità di esecuzione dell’audit; - Eventuali voci aggiuntive: nel caso il sito avesse voci di menù di primo livello aggiuntive esse dovranno contenere il
data-element=”custom-submenu”
. In queste pagine è necessario inserire ildata-element=”custom-category-link”
per le card sotto la voce “Categoria”.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-7-b.html
Condizioni di successo: per superare il test effettuato dall'app, la funzionalità di prenotazione di un appuntamento è accessibile dalla sezione di funzionalità trasversali delle schede servizio e della pagina di primo livello "Servizi", permette al cittadino di indicare/fornire le informazioni richieste, e, se è presente il pulsante di Prenotazione appuntamento come modalità di accesso al servizio all’interno di una scheda servizio, la funzionalità circoscrive la scelta degli uffici disponibili a quelli competenti per il servizio selezionato e la funzionalità indica come argomento pre-selezionato il titolo del servizio. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi "data-element", viene verificata la presenza del componente "Prenota appuntamento" all'interno della sezione di funzionalità trasversali delle schede servizio analizzate e della pagina di primo livello "Servizi". Viene inoltre indicato se è stato rilevato il pulsante di accesso alla funzionalità di prenotazione appuntamento all'interno della sezione "Accedi al servizio" delle schede servizio. La verifica viene eseguita sulla pagina di primo livello “Servizi” e su N pagine di terzo livello “Scheda servizio”.
Requisiti tecnici:
Caricamento pagina primo livello:
In homepage, per poter identificare il link alla pagina di primo livello "Servizi", nel menù principale identificato dal tag <div class="navbar"> il link alla pagina deve contenere, all'interno del tag <a class="nav-link">, il data-element="all-services"
.
L'assenza del data-element porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-1-a.html
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-1-b.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Controllo presenza prenotazione appuntamenti:
Nella pagina di primo livello “Servizi”, identificata grazie al data-element="all-services"
, dovrà contenere un tag <a> con data-element="appointment-booking"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-1-c.html
Ogni “Scheda servizio”, identificata dal data-element="service-link"
, dovrà contenere un tag <a> con data-element="appointment-booking"
e in aggiunta può contenere un bottone con data-element="service-booking-access"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-1-d.html
Condizioni di successo: per superare il test effettuato dall'app, i contatti dell'ufficio preposto all'erogazione del servizio sono presenti in tutte le schede servizio. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi data-element, viene verificata la presenza della voce "Contatti" all'interno dell'indice e nel corpo della pagina delle schede servizio analizzate, ricercando specifici attributi "data-element". La verifica viene eseguita su N pagine di primo livello “Scheda servizio”.
Requisiti tecnici:
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-2-a.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Controllo sui contatti:
All’interno della pagina di terzo livello “Scheda servizio” deve esserci tag <ul> con data-element="page-index"
contenente altri tags <li> con la label “Contatti”. All’interno della pagina la sezione che identifica i contatti deve contenere un componente che abbia l’attributo data-element=”service-area”
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-2-b.html
Condizioni di successo: per superare il test effettuato dall'app, nel footer del sito è presente un link contenente le espressioni «FAQ» oppure «domande frequenti» che invia a una pagina che contiene le domande frequenti. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: tramite ricerca di uno specifico attributo data-element, viene verificata la presenza del link nel footer dell'homepage che invii ad una pagina esistente e che il testo del link contenga almeno una delle espressioni richieste, senza fare distinzione tra caratteri minuscoli o maiuscoli.
Requisiti tecnici: All’interno del footer della pagina (tag <footer>) deve esserci un tag <a> che contiene l’href alla sezione FAQ. Il tag <a> deve avere l’attributo data-element="faq"
. (L’<a> può essere contenuto in altri tag, esempio <li>)
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-3.html
Condizioni di successo: per superare il test effettuato dall'app, nel footer del sito è presente un link contenente le espressioni "disservizio" oppure "segnala disservizio" oppure "segnalazione disservizio" che permette di segnalare un disservizio tramite email o funzionalità dedicato. Se viene usata una funzionalità dedicata di segnalazione disservizio, devono essere presenti i campi richiesti nella Documentazione del modello. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando uno specifico attributo data-element, viene verificata la presenza del link nel footer dell'homepage che invii ad una pagina esistente e che il testo del link contenga almeno una delle espressioni richieste, senza fare distinzione tra caratteri minuscoli o maiuscoli.
Requisiti tecnici: All’interno del footer della pagina (tag <footer>) deve esserci un tag <a> che contiene l’href alla Segnalazione disservizio. Il tag <a> deve avere l’attributo data-element="report-inefficiency"
. (L’<a> può essere contenuto in altri tag, esempio <li>)
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-4.html
Condizioni di successo: per superare il test effettuato dall'app, la funzionalità per valutare la chiarezza informativa è presente su tutte le pagine di primo e secondo livello del sito e rispetta tutte le caratteristiche e i passaggi richiesti. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi data-element, viene verificata la presenza del componente di valutazione nelle pagine di primo e di secondo livello, controllando che la funzionalità abbia le caratteristiche richieste nella documentazione. La verifica viene eseguita su N pagine di primo livello e su N pagine di secondo livello.
Requisiti tecnici:
Caricamento pagine primo livello:
In homepage, per poter identificare i link alle pagine di primo livello, nel menù principale identificato dal tag <div class="navbar"> i link alle pagine di primo livello devono contenere all'interno del tag <a class="nav-link"> i seguenti attributi:
- "Amministrazione": data-element="management"
- "Novità": data-element="news"
- "Servizi": data-element="all-services"
- "Vivere il Comune": data-element="live"
- Eventuali voci aggiuntive:
data-element=”custom-submenu”
L'assenza di uno dei data-element (ad eccezione di quelli relativi a eventuali voci aggiuntive) porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-5-a.html
Caricamento pagine di secondo livello:
Per il caricamento delle pagine di secondo livello è necessario che i data-element alle pagine di primo livello siano correttamente posizionati all'interno dei link delle pagine di primo livello nel menù principale.
La pagina di primo livello "Amministrazione", identificata grazie al data-element="management"
, dovrà contenere il data-element="management-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Novità", identificata grazie al data-element="news"
, dovrà contenere il data-element="news-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Vivere il comune", identificata grazie al data-element="live"
, dovrà contenere due bottoni. Il bottone che porta alla pagina di secondo livello "Eventi" dovrà contenere data-element="live-button-events"
e il bottone che porta alla pagina di secondo livello "Luoghi" dovrà contenere data-element="live-button-locations"
. Per entrambi i bottoni il data-element dovrà essere posizionato sul tag <button> e il link alla pagina di secondo livello dovrà essere presente o all’interno dell’attributo «onclick» o all'interno di un attributo «href». La mancata individuazione di almeno un link attraverso questi data-element porta all'impossibilità di esecuzione dell'audit.
Nel caso fossero presenti delle voci aggiuntive di primo livello esse vengono identificate attraverso il data-element=”custom-submenu”
. In ognuna di queste pagine è necessaria la presenza del data-element=”custom-category-link”
all’interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-5-b.html
Controllo componente di valutazione:
All’interno delle pagine di primo e secondo livello verrà analizzato il componente che contiene l’attributo data-element=”feedback”
. La presenza di questo componente è obbligatoria per il risultato positivo di questo audit.
Di questo componente con data-element=”feedback”
vengono analizzate le sue parti:
- Domanda iniziale: individuato attraverso l’attributo
data-element=”feedback-title”
. Questo è da inserire all’interno dell’<h2> che contiene la domanda iniziale; - Scala di valutazione: individuati attraverso l’attributo
data-element=”feedback-rate-{N}”
nella <label> del input. {N} viene sostituito con il valore di quel input. (es: data-element= “feedback-rate-1”, associato al valore minimo “1”); - Componente di follow up positivo: questo componente comprende tutte le parti per permettere all’utente di fornire un feedback positivo. Esso viene individuato attraverso l’attributo
data-element=”feedback-rating-positive”
nel <fieldset> che contiene domanda e risposte. Per la domanda viene inserito l’attributodata-element=”feedback-rating-question”
nella <legend> contente la domanda. Per le risposte viene inserito l’attributodata-element=”feedback-rating-answer”
nella <label> contenente ogni risposta. - Componente di follow up negativo: questo componente comprende tutte le parti per permettere all’utente di fornire un feedback negativo. Esso viene individuato attraverso l’attributo
data-element=”feedback-rating-negative”
nel <fieldset> che contiene domanda e risposte. Per la domanda viene inserito l’attributodata-element=”feedback-rating-question”
nella <legend> contente la domanda. Per le risposte viene inserito l’attributodata-element=”feedback-rating-answer”
nella <label> contenente ogni risposta; - Campo di testo libero: individuato attraverso l’attributo
data-element=”feedback-input-text”
dentro <input> della casella di testo per fornire una risposta libera alla fine del feedback.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-5-c.html
Criterio C.SI.2.6 - Valutazione dell'esperienza d'uso, chiarezza informativa della scheda di servizio
Condizioni di successo: per superare il test effettuato dall'app, la funzionalità per valutare la chiarezza informativa è presente su tutte le schede servizio e rispetta tutte le caratteristiche e passaggi richiesti. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi data-element, viene verificata la presenza del componente di valutazione all'interno delle schede servizio, controllando che la funzionalità abbia le caratteristiche richieste nella documentazione. La verifica viene eseguita su N pagine di terzo livello “Scheda servizio”.
Requisiti tecnici:
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link alla pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio". Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-6-a.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Controllo componente di valutazione:
All’interno delle pagine di primo e secondo livello verrà analizzato il componente che contiene l’attributo data-element=”feedback”
. La presenza di questo componente è obbligatoria per il risultato positivo di questo audit.
Di questo componente con data-element=”feedback”
vengono analizzate le sue parti:
- Domanda iniziale: individuato attraverso l’attributo
data-element=”feedback-title”
. Questo è da inserire all’interno dell’<h2> che contiene la domanda iniziale. - Scala di valutazione: individuati attraverso l’attributo
data-element=”feedback-rate-{N}”
nella <label> del input. {N} viene sostituito con il valore di quel input. (es: data-element= “feedback-rate-1”, associato al valore “1”); - Componente di follow up positivo: questo componente comprende tutte le parti per permettere all’utente di fornire un feedback positivo. Esso viene individuato attraverso l’attributo
data-element=”feedback-rating-positive”
nel <fieldset> che contiene domanda e risposte. Per la domanda viene inserito l’attributodata-element=”feedback-rating-question”
nella <legend> contente la domanda. Per le risposte viene inserito l’attributodata-element=”feedback-rating-answer”
nella <label> contenente ogni risposta; - Componente di follow up negativo: questo componente comprende tutte le parti per permettere all’utente di fornire un feedback negativo. Esso viene individuato attraverso l’attributo
data-element=”feedback-rating-negative”
nel <fieldset> che contiene domanda e risposte. Per la domanda viene inserito l’attributodata-element=”feedback-rating-question”
nella <legend> contente la domanda. Per le risposte viene inserito l’attributodata-element=”feedback-rating-answer”
nella <label> contenente ogni risposta; - Campo di testo libero: individuato attraverso l’attributo
data-element=”feedback-input-text”
dentro <input> della casella di testo per fornire una risposta libera alla fine del feedback.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-2-6-b.html
Condizioni di successo: per superare il test effettuato dall'app, il dominio di tutti i cookie già presenti nel sito, ovvero senza che sia stata espressa una preferenza da parte dell’utente riguardo il loro uso, è corrispondente al dominio del sito web del Comune. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando specifici attributi data-element, viene verificato che al caricamento di ogni pagina analizzata il dominio dei cookie identificati sia corrispondente al dominio del sito web. La verifica viene eseguita sull’homepage, sulla pagina di accesso all’area riservata, sulla pagina della funzionalità di prenotazione appuntamento, su N pagine di primo livello, su N pagine di secondo livello, su N pagine di terzo livello “Scheda servizio” e su N pagine di quarto livello “Evento”.
Requisiti tecnici:
Caricamento pagina di accesso all’area riservata:
In homepage, se è presente un link alla pagina di accesso all'area riservata, questo deve contenere il data-element="personal-area-login"
nel tag <a> contenete il link alla pagina.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-1-a.html
Caricamento pagina di prenotazione appuntamenti:
Per caricare la pagina prenotazione appuntamenti è necessario che il data-element=”all-services”
sia posizionato in homepage nel link della pagina di primo livello “Servizi”. In questa pagina di primo livello il link alla pagina di prenotazione appuntamenti deve contenere il data-element="appointment-booking"
nel tag <a> contenente il link alla pagina.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-1-b.html
Caricamento pagine primo livello:
In homepage, per poter identificare i link alle pagine di primo livello, nel menù principale identificato dal tag <div class="navbar"> i link alle pagine principali devono contenere all'interno del tag <a class="nav-link"> i seguenti attributi:
- "Amministrazione":
data-element="management"
- "Novità":
data-element="news"
- "Servizi":
data-element="all-services"
- "Vivere il Comune":
data-element="live"
- Eventuali voci aggiuntive:
data-element=”custom-submenu”
L'assenza di uno dei data-element (ad eccezione di quelli relativi a eventuali voci aggiuntive) porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-1-c.html
Caricamento pagine di secondo livello:
Per il caricamento delle pagine di secondo livello è necessario che i data-element alle pagine di primo livello siano correttamente posizionati all'interno dei link delle pagine di primo livello nel menù principale.
La pagina di primo livello "Amministrazione", identificata grazie al data-element="management"
, dovrà contenere il data-element="management-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Novità", identificata grazie al data-element="news"
, dovrà contenere il data-element="news-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Vivere il comune", identificata grazie al data-element="live"
, dovrà contenere due bottoni. Il bottone che porta alla pagina di secondo livello "Eventi" dovrà contenere data-element="live-button-events"
e il bottone che porta alla pagina di secondo livello "Luoghi" dovrà contenere data-element="live-button-locations"
. Per entrambi i bottoni il data-element dovrà essere posizionato sul tag <button> e il link alla pagina di secondo livello dovrà essere presente o all’interno dell’attributo «onclick» o all'interno di un attributo «href». La mancata individuazione di almeno un link attraverso questi data-element porta all'impossibilità di esecuzione dell'audit.
Nel caso fossero presenti delle voci aggiuntive di primo livello esse vengono identificate attraverso il data-element=”custom-submenu”
. In ognuna di queste pagine è necessaria la presenza del data-element=”custom-category-link”
all’interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-1-d.html
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-1-e.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Caricamento pagine di quarto livello "Evento":
Per il caricamento di queste pagine di quarto livello è necessario che il data-element=”live”
della pagina di primo livello "Vivere il Comune" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale e che il data-element="live-button-events"
sia correttamente posizionato nel bottone che porta alla pagina di secondo livello “Eventi”.
La pagina di secondo livello "Eventi", dovrà contenere il data-element="event-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di quarto livello degli eventi. Se nella pagina è presente un bottone che permette di caricare altri link agli eventi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-1-f.html
Condizioni di successo: per superare il test effettuato dall'app, il sito presenta una voce nel footer che riporta a una dichiarazione di accessibilità AgID valida per il sito. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando uno specifico attributo data-element, viene verificata la presenza di un link nel footer dell'homepage che riporti a una pagina esistente, che l'url della pagina di destinazione inizi con "https://form.agid.gov.it/view/" e che la pagina contenga l'url del sito del Comune.
Requisiti tecnici: All’interno del footer della pagina (tag <footer>) deve esserci un tag <a> che contiene l’href alla dichiarazione di accessibilità. Il tag <a> deve avere l’attributo data-element="accessibility-link"
. (L’<a> può essere contenuto in altri tag, esempio <li>)
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-2.html
Condizioni di successo: per superare il test effettuato dall'app, il sito presenta una voce nel footer che riporta a una pagina sicura riguardante l'informativa sulla privacy. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando uno specifico attributo data-element, viene verificata la presenza di un link nel footer dell'homepage che riporti a una pagina esistente e con certificato HTTPS valido e attivo.
Requisiti tecnici: All’interno del footer della pagina (tag <footer>) deve esserci un tag <a> che contiene l’href alla privacy policy. Il tag <a> deve avere l’attributo data-element="privacy-policy-link"
. (L’<a> può essere contenuto in altri tag, esempio <li>)
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-3.html
Condizioni di successo: per superare il test effettuato dall'app, il sito del Comune pubblica dati, documenti o informazioni con licenza aperta CC-BY 4.0, la licenza viene comunicata nella pagina delle “note legali“ raggiungibile da un link nel footer del sito e all’interno della pagina delle “note legali” è presente la sezione “Licenza dei contenuti” con la dicitura richiesta. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: ricercando uno specifico attributo data-element, viene verificato che la pagina delle note legali sia raggiungibile dal footer dell’homepage e che questa contenga una sezione intitolata "Licenza dei contenuti" riportante la seguente dicitura
“In applicazione del principio open by default ai sensi dell’articolo 52 del decreto legislativo 7 marzo 2005, n. 82 (CAD) e salvo dove diversamente specificato (compresi i contenuti incorporati di terzi), i dati, i documenti e le informazioni pubblicati sul sito sono rilasciati con licenza CC-BY 4.0. Gli utenti sono quindi liberi di condividere (riprodurre, distribuire, comunicare al pubblico, esporre in pubblico), rappresentare, eseguire e recitare questo materiale con qualsiasi mezzo e formato e modificare (trasformare il materiale e utilizzarlo per opere derivate) per qualsiasi fine, anche commerciale con il solo onere di attribuzione, senza apporre restrizioni aggiuntive.”
Requisiti tecnici:
All’interno del footer della homepage (tag <footer>) deve esserci un tag <a> che contiene l’href alla pagina delle note legali. Il tag <a> deve avere l’attributo data-element="legal-notes"
. L’<a> può essere contenuto in altri tag, esempio <li>.
All’interno della pagina individuata da questo link dovrà essere presente un tag HTML con l’attributo data-element=”legal-notes-section”
da inserire nell’<h> contenente il titolo della sezione da analizzare e uno o più tag <p> con attributo data-element=”legal-notes-body”
inseriti in ogni <p> contenente il testo della sezione da analizzare.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-3-4.html
Condizioni di successo: per superare il test effettuato dall'app, tutte le pagine del sito presentano almeno un punteggio di prestazioni pari a 50 quando testate in modalità “mobile” con Lighthouse. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: l’homepage del sito viene testata in modalità “mobile” con Lighthouse.
Condizioni di successo: per superare il test effettuato dall'app, il sito utilizza un certificato https valido e non obsoleto. Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: viene verificato che il certificato https dell’homepage sia valido e attivo.
Condizioni di successo: per superare il test effettuato dall'app, il sito comunale è raggiungibile senza necessità di inserimento del sottodominio “www.” e utilizza il sottodominio "comune." seguito da uno dei possibili domini utilizzabili, secondo la seguente struttura: (1) per i Comuni non capoluogo di provincia, comune.[nome comune].[sigla provincia].it o comune.[nome comune].[nome esteso provincia].it (Esempi: comune.anzio.rm.it o comune.anzio.roma.it) o (2) per i Comuni capoluogo di provincia, comune.[nome capoluogo].it o comune.[nome capoluogo].[sigla della provincia].it (Esempi: comune.roma.it o comune.roma.rm.it). Le condizioni complete di successo, tolleranza e fallimento per il superamento del criterio di conformità sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: tramite ricerca di specifici attributi "data-element", viene verificato che il dominio utilizzato nelle pagine analizzate rispetti la struttura richiesta dal criterio di conformità e che le pagine siano raggiungibili senza necessità di inserimento del sottodominio "www.". La verifica viene svolta sulla homepage, N pagine di primo livello, N pagine di secondo livello, N pagine di terzo livello “Scheda servizio” e nella pagina di accesso all’area riservata.
Nello specifico, le pagine di secondo livello analizzate sono:
- Per la sezione Amministrazione, “Organi di governo”, “Aree amministrative”, “Uffici”, “Enti e fondazioni”, “Politici”, “Personale amministrativo”, “Documenti e dati”;
- Per la sezione Novità, “Notizie”, “Comunicati”, “Avvisi”
- Per la sezione Servizi, “Educazione e formazione”, “Salute, benessere e assistenza”, “Vita lavorativa”, “Mobilità e trasporti”, “Catasto e urbanistica”, “Anagrafe e stato civile”, “Turismo”, “Giustizia e sicurezza pubblica”, “Tributi, finanze e contravvenzioni”, “Cultura e tempo libero”, “Ambiente”, “Imprese e commercio”, “Autorizzazioni”, “Appalti pubblici”, “Agricoltura e pesca”;
- Per la sezione Vivere il Comune o Vivere {nome_comune}, “Luoghi”, “Eventi”.
Requisiti tecnici:
Caricamento pagina di accesso all’area riservata:
In homepage, se è presente un link alla pagina di accesso all'area riservata, questo deve contenere il data-element="personal-area-login"
nel tag <a> contenente il link alla pagina.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-a.html
Caricamento pagine primo livello:
In homepage, per poter identificare i link alle pagine di primo livello, nel menù principale identificato dal tag <div class="navbar"> i link alle pagine di primo livello devono contenere all'interno del tag <a class="nav-link"> i seguenti attributi:
- "Amministrazione":
data-element="management"
- "Novità":
data-element="news"
- "Servizi":
data-element="all-services"
- "Vivere il Comune":
data-element="live"
- Eventuali voci aggiuntive:
data-element=”custom-submenu”
L'assenza di uno dei data-element (ad eccezione di quelli relativi a eventuali voci aggiuntive) porta all'impossibilità di esecuzione dell'audit in quanto non sarà possibile recuperare il link.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-b.html
Caricamento pagine di secondo livello:
Per il caricamento delle pagine di secondo livello è necessario che i data-element alle pagine di primo livello siano correttamente posizionati all'interno dei link delle pagine di primo livello nel menù principale.
La pagina di primo livello "Amministrazione", identificata grazie al data-element="management"
, dovrà contenere il data-element="management-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Novità", identificata grazie al data-element="news"
, dovrà contenere il data-element="news-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-category-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello. La mancata individuazione di almeno un link attraverso questo data-element porta all'impossibilità di esecuzione dell'audit.
La pagina di primo livello "Vivere il comune", identificata grazie al data-element="live"
, dovrà contenere due bottoni. Il bottone che porta alla pagina di secondo livello "Eventi" dovrà contenere data-element="live-button-events"
e il bottone che porta alla pagina di secondo livello "Luoghi" dovrà contenere data-element="live-button-locations"
. Per entrambi i bottoni il data-element dovrà essere posizionato sul tag <button> e il link alla pagina di secondo livello dovrà essere presente o all’interno dell’attributo «onclick» o all'interno di un attributo «href». La mancata individuazione di almeno un link attraverso questi data-element porta all'impossibilità di esecuzione dell'audit.
Nel caso fossero presenti delle voci aggiuntive di primo livello esse vengono identificate attraverso il data-element=”custom-submenu”
. In ognuna di queste pagine è necessaria la presenza del data-element=”custom-category-link”
all’interno dei tag <a> contenenti i link di atterraggio alle pagine di secondo livello.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-c.html
Caricamento pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/c-si-1-1-d.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Condizioni di successo: per superare il test effettuato dall'app, le voci delle schede servizio presentano tutti i metatag richiesti dal modello. Le condizioni complete di successo, tolleranza e fallimento per il superamento della raccomandazione sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: tramite ricerca di specifici attributi data-element, viene verificata la presenza e correttezza dei metatag su N pagine di terzo livello “Scheda servizio”.
I metatag ricercati sono i seguenti:
- il titolo del servizio nell’attributo json
name
; - il l’attributo materie del servizio nell’attributo json
serviceType
; - il nome del comune nell’attributo json
serviceOperator>name
; - l’attributo copertura geografica nell’attributo json
areaServed>name
; - il testo a chi è rivolto nell’attributo json
audience>audienceType
; - il link canale digitale nell’attributo json
availableChannel>serviceUrl
; - l’attributo titolo dell’unità organizzativa (es ufficio o area) responsabile del servizio (attributo Struttura responsabile del servizio) nell’attributo json
availableChannel>serviceLocation>name
; - l’attributo indirizzo dell’oggetto luogo associato al’attributo canale fisico del servizio nell’attributo json
availableChannel>serviceLocation>address>streetAdress
; - l’attributo CAP dell’oggetto luogo associato al’attributo canale fisico del servizio nell’attributo json
availableChannel>serviceLocation>address>postalCode
; - il nome del comune nell’attributo json
availableChannel>serviceLocation>address>addressLocality
.
Requisiti tecnici:
Caricamento e verifica nelle pagine di terzo livello "Scheda servizio":
Per il caricamento di queste pagine di terzo livello è necessario che il data-element alla pagina di primo livello "Servizi" sia correttamente posizionato all'interno del link della pagina di primo livello nel menù principale.
La pagina di primo livello "Servizi", identificata grazie al data-element="all-services"
, dovrà contenere il data-element="service-link"
all'interno dei tag <a> contenenti i link di atterraggio alle pagine di terzo livello “Scheda servizio”. Se nella pagina è presente un bottone che permette di caricare altri link ai servizi attraverso una chiamata AJAX esso dovrà contenere il data-element="load-other-cards"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/r-si-1-1-a.html
All’interno dell’HTML delle pagine “Scheda servizio” deve esserci un attributo <script> che contiene come valore un JSON di metatag. Il tag <script> deve avere l'attributo data-element="metatag"
.
Esempio:
.. literalinclude:: esempi-codice-comuni/r-si-1-1-b.html
Se invece i link ai servizi sono organizzati tramite paginazione è necessario inserire il data-element="pager-link"
in tutti i link <a> per cambiare pagina, incluso quello per caricare i link successivi.
Esempio:
.. literalinclude:: esempi-codice-comuni/servizi-con-paginazione.html
La paginazione dei servizi può essere fatta anche su una pagina dedicata, diversa dalla pagina di primo livello "Servizi". In questo caso la pagina di primo livello "Servizi" deve avere un link con data-element="pager-link"
che punta alla pagina con i link ai servizi.
La mancata individuazione di almeno un link attraverso il data-element="service-link"
porta all'impossibilità di esecuzione dell'audit.
Condizioni di successo: per superare il test effettuato dall'app, l'indirizzo IP fa riferimento a un datacenter localizzato su territorio europeo. Le condizioni complete di successo, tolleranza e fallimento per il superamento della raccomandazione sono dettagliate nella documentazione del modello sui criteri di conformità per la misura 1.4.1.
Modalità di verifica: viene verificato che la localizzazione dell'IP rientri all'interno di uno dei confini degli stati membri dell'UE