<article class="rtds-card rtds-card--information rtds-card--information-02 is-card-fullclickable rtds-group/card">
<div class="rtds-card__content rtds-gap-3">
<div class="rtds-card__heading">
<div class="rtds-flex rtds-items-center rtds-justify-between rtds-w-full">
<h3 class="rtds-card__title">
<div class="rtds-flex rtds-items-center rtds-gap-2">
<svg class="rtds-icon rtds-fill-current rtds-w-4 rtds-h-4 rtds-content-02" aria-hidden="true" focusable="false" role="img">
<use href="../../icons.svg#solid--circle" />
</svg>
<span>Istanza approvata</span>
</div>
</h3>
</div>
</div>
<div class="rtds-card__description rtds-ml-6 lg:rtds-pr-[280px] !rtds-text-sm">
<p>
Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et. Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et. Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et.
</p>
</div>
<div class="rtds-ml-6 rtds-space-y-2 md:rtds-space-y-0 md:rtds-flex md:rtds-items-baseline md:rtds-justify-between md:rtds-gap-2">
<ul class="rtds-card__tags rtds-items-center" aria-label="Categorie">
<li class="rtds-text-xs rtds-font-bold rtds-content-03">10.01.2025</li>
<div class="rtds-vertical-divider rtds-w-2 md:rtds-w-4 rtds-hidden md:rtds-block">
<img class="rtds-w-full rtds-h-auto" src="/images/vertical-divider.svg" alt="">
</div>
<li class="rtds-text-xs rtds-uppercase rtds-font-semibold rtds-content-primary">Avanzamento istanza</li>
</ul>
<div class="rtds-flex rtds-justify-end rtds-w-full sm:rtds-w-auto">
<div class="rtds-flex-shrink-0">
<a href="#" class="rtds-btn
rtds-btn--icon rtds-action-link--has-icon rtds-content-01 hover:rtds-text-white hover:rtds-bg-black focus:rtds-content-03"><svg class="rtds-icon rtds-fill-current rtds-w-4 rtds-h-4 md:rtds-w-5 md:rtds-h-5 lg:rtds-w-6 lg:rtds-h-6" aria-hidden="true" focusable="false" role="img">
<use href="../../icons.svg#outline--chevron-right" />
</svg>
<span class="rtds-sr-only">
Visualizza dettagli
</span>
</a>
</div>
</div>
</div>
</div>
</article>
{% extends "@card" %}
{% block classes %}{{ super() }} rtds-card--information rtds-card--information-02{% endblock classes %}
{% block headingTitle %}
<div class="rtds-flex rtds-items-center rtds-justify-between rtds-w-full">
<{% if h2 %}h2{% else %}h3{% endif %} class="rtds-card__title{% if headingClasses %} {{ headingClasses }}{% endif %}">
<div class="rtds-flex rtds-items-center rtds-gap-2">
{% render '@icon', {id: 'solid--circle', size: 'rtds-w-4 rtds-h-4', classes: 'rtds-content-02'}, true %}
<span>Istanza approvata</span>
</div>
</{% if h2 %}h2{% else %}h3{% endif %}>
</div>
{% endblock headingTitle %}
{% block content %}
{% if 'is-empty' not in excerpt %}
<div class="rtds-card__description rtds-ml-6 lg:rtds-pr-[280px]{% if excerptClasses %} {{ excerptClasses }}{% endif %}{% if headingLinkIcon %} rtds-pr-8 md:rtds-pr-12{% endif %}">
<p>
{% if excerpt %}{{ excerpt | safe }}{% else %}Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et.{% endif %}
</p>
</div>
{% endif %}
{% endblock %}
{% block tags %}
<div class="rtds-ml-6 rtds-space-y-2 md:rtds-space-y-0 md:rtds-flex md:rtds-items-baseline md:rtds-justify-between md:rtds-gap-2">
{% if tags %}
<ul class="rtds-card__tags rtds-items-center" aria-label="Categorie">
<li class="rtds-text-xs rtds-font-bold rtds-content-03">10.01.2025</li>
{% render '@vertical-divider', { width: 'rtds-w-2 md:rtds-w-4', classes: 'rtds-hidden md:rtds-block' }, true %}
<li class="rtds-text-xs rtds-uppercase rtds-font-semibold rtds-content-primary">Avanzamento istanza</li>
</ul>
{% endif %}
<div class="rtds-flex rtds-justify-end rtds-w-full sm:rtds-w-auto">
<div class="rtds-flex-shrink-0">
{% render '@button--icon', {
classes: 'rtds-action-link--has-icon rtds-content-01 hover:rtds-text-white hover:rtds-bg-black focus:rtds-content-03',
hasIcon: 'true',
icon: 'outline--chevron-right',
label: "Visualizza dettagli",
href: '#',
iconClasses: 'rtds-transition-all hover:rtds-translate-x-1'
}, true %}
</div>
</div>
</div>
{% endblock tags %}
{
"article": true,
"categoryText": "Categoria",
"heading": "Nunc aliquam phasellus molestie blandit. Nisi, amet, id maecenas diam",
"text": "Testo",
"excerpt": "Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et. Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et. Neque blandit pellentesque nunc sed amet. Nisl, semper sed aliquam amet proin purus augue et.",
"ctaIcon": "mini--chevron-right",
"ctaLinkLabel": "Leggi di più",
"categoryVariant": "",
"img": {
"path": "/images/card-image.jpg",
"alt": ""
},
"fullClick": true,
"tags": true,
"scadenza": true,
"contentGap": "rtds-gap-3",
"excerptClasses": "!rtds-text-sm",
"dataScadenza": "2024-07-23",
"dataFormattata": "23.07.2024"
}
/**
* CARD SMART
* Extends @card component styles for CARD SMART COMPONENTS
*
*/
@layer components {
/* CARD SMART */
:where(.rtds-card--smart-scadenza.rtds-card--event:not(.rtds-card--event-small)) .rtds-card__content {
@apply rtds-grid-flow-col md:rtds-grid-flow-row;
}
:where(.rtds-card--smart-scadenza.rtds-card--event) .rtds-card__date {
@apply rtds-border-r rtds-border-b-0 rtds-pr-4 rtds-pb-0;
}
.rtds-card--smart-trascinabile {
/* Custom properties private con fallback tripli */
--_card-smart-bg: var(--card-smart-bg, var(--color-background-01, var(--color-neutral-50)));
--_card-smart-border: var(--card-smart-border, var(--color-border-gray-01, var(--color-neutral-300)));
--_card-smart-shadow: var(--card-smart-shadow, 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1));
background-color: var(--_card-smart-bg);
box-shadow: var(--_card-smart-shadow);
border-color: var(--_card-smart-border);
@apply rtds-border rtds-border-solid;
}
.rtds-card--smart-trascinabile.is-selected {
/* Override solo delle custom properties pubbliche */
--card-smart-bg: #ffffff;
--card-smart-border: var(--color-brand-00, var(--color-primary-500));
--card-smart-shadow: none;
}
}
Documentazione WORK IN PROGRESS
I componenti Card Smart sono una collezione specializzata di card progettate specificamente per applicazioni di servizi digitali. Questi componenti estendono il sistema base delle card (@card) con funzionalità avanzate per gestire dati strutturati, interazioni complesse e flussi di lavoro specifici dei servizi pubblici.
Le Card Smart sono state spostate dalla sezione generale delle card alla sezione servizi per una migliore organizzazione e specializzazione funzionale.
Tutte le Card Smart estendono il componente base @card, mantenendo:
card-smart--complete)Card completa per la visualizzazione di istanze o pratiche con informazioni dettagliate.
Caratteristiche:
card-smart--accordion)Card espandibile con contenuto collassabile per gestire informazioni complesse.
Caratteristiche:
card-smart--agenda)Card specializzata per la gestione di scadenze e appuntamenti.
Caratteristiche:
card-smart--scadenza)Card per scadenze urgenti con layout ad alta visibilità.
Caratteristiche:
card-smart--notifiche)Card per notifiche di sistema e aggiornamenti di stato.
Caratteristiche:
card-smart--shortcut)Card di accesso rapido per azioni frequenti.
Caratteristiche:
card-smart--trascinabile)Card per interfacce drag-and-drop con stati di selezione.
Caratteristiche:
card-smart--trascinabile-selected)Variante selezionata della card trascinabile.
Un sistema completo di card per form e selezioni multiple:
card-smart--selezione)Card base per input di selezione con controlli form integrati.
card-smart--selezione-selected - Stato selezionatocard-smart--selezione-checkbox - Con checkboxcard-smart--selezione-large - Versione grande con azionicard-smart--selezione-large-checkbox - Grande con checkboxcard-smart--selezione-large-selected - Grande selezionatacard-smart--selezione-procedimento - Per gestione procedimenticard-smart--selezione-procedimento-checkbox - Con checkboxcard-smart--selezione-procedimento-radio - Con radio buttoncard-smart--selezione-procedimento-checkbox-selected - Checkbox selezionataOltre ai parametri base delle card standard, le Card Smart supportano:
dataScadenza: Data di scadenza in formato ISOdataFormattata: Data formattata per visualizzazionedescrizione: Testo descrittivo aggiuntivoeditId: ID univoco per componenti con menuprofileDialogId: ID per modal di profilohasActionMenu: Attiva menu azionihasActionDelete: Attiva opzione eliminazioneinput: Configurazione per controlli form integratiLe Card Smart utilizzano classi CSS specifiche:
.rtds-card--smart-trascinabile /* Card trascinabili */
.rtds-card--smart-scadenza /* Card scadenze */
.rtds-card--smart-shortcut /* Card shortcut */
.rtds-card--compact-header /* Header compatto */Sistema di stati avanzato con CSS custom properties:
.rtds-card--smart-trascinabile.is-selected {
--card-smart-bg: #ffffff;
--card-smart-border: var(--color-brand-00);
--card-smart-shadow: none;
}aria-expanded per controlli accordionaria-controls per associazioni elementiaria-haspopup per menu contestualirole="region" per aree espandibiliaria-labelledby per associazioni semantichertds-sr-only per contesto aggiuntivo// Auto-inizializzazione per elementi con classe
.rtds-js-accordion-toggle
// Gestione stati ARIA
aria-expanded="true/false"
// Animazioni CSS coordinate
.rtds-hidden / .rtds-transition-allEredita il sistema JavaScript delle card base per area cliccabile estesa.
is-selected per feedback visivoDocumentazione aggiornata per la versione corrente del Design System RT-UI-Kit