<div class="rtds-top-bar rtds-py-1 md:rtds-py-2 rtds-px-4">
    <div class="rtds-top-bar__container rtds-container">

        <nav class="rtds-primary-navigation rtds-flex lg:rtds-justify-end rtds-ml-auto lg:rtds-ml-0 is-top-nav-positioned" aria-label="Principale" id="siteNavWrapper">
            <button type="button" class="rtds-btn rtds-btn--only-text rtds-rounded-0 lg:rtds-hidden rtds-ml-auto rtds-btn--icon rtds-group" aria-expanded="false" aria-controls="mainNavPanel" id="mobileNavToggle">
                <svg class="rtds-icon rtds-fill-current rtds-w-6 rtds-h-6 rtds-m-0 rtds-p-0
    rtds-transition-all rtds-duration-200 rtds-ease-out rtds-transform
    group-hover:rtds-translate-none is-show-menu
    group-aria-expanded:rtds-hidden" aria-hidden="true" focusable="false" role="img">
                    <use href="../../icons.svg#mini--bars-3" />
                </svg>

                <svg class="rtds-icon rtds-fill-current rtds-w-6 rtds-h-6 rtds-m-0 rtds-p-0 rtds-transition-all
    rtds-duration-200 rtds-ease-out rtds-transform
    group-hover:rtds-translate-none is-close-menu rtds-hidden
    group-aria-expanded:rtds-inline-block" aria-hidden="true" focusable="false" role="img">
                    <use href="../../icons.svg#mini--x-mark" />
                </svg>

                <span class="rtds-sr-only is-show-menu">
                    Menu
                </span>
            </button>
            <!-- Mobile panel -->
            <div class="rtds-primary-navigation__panel rtds-flex-col rtds-transition-all rtds-invisible rtds-w-[88%] lg:rtds-w-auto rtds-fixed lg:rtds-static lg:rtds-visible rtds-top-[--header-height] rtds-bottom-0 rtds-left-[12%] lg:rtds-left-0 rtds-border-l rtds-border-primary lg:rtds-border-l-0 rtds-overflow-y-auto" id="mainNavPanel">
                <!-- Main nav -->
                <div class="rtds-primary-navigation__module is-main lg:rtds-border-b-0">
                    <ul class="rtds-primary-navigation__list  rtds-gap-2 lg:rtds-gap-2.5">

                        <li class="rtds-primary-navigation__item">
                            <a href="" class="rtds-primary-navigation__first-level rtds-primary-navigation__link rtds-group rtds-text-sm">
                                Item
                            </a>
                        </li>

                        <li class="rtds-primary-navigation__item">
                            <a href="" class="rtds-primary-navigation__first-level rtds-primary-navigation__link rtds-group rtds-text-sm is-current" aria-current="page">
                                Current page
                            </a>
                        </li>

                        <li class="rtds-dropdown-menu has-dropdown-menu rtds-primary-navigation__item">
                            <button class="rtds-dropdown-menu__trigger rtds-dropdown-trigger rtds-group rtds-w-full rtds-flex rtds-items-center  hover:rtds-content-primary aria-expanded:rtds-bg-white lg:aria-expanded:rtds-bg-transparent aria-expanded:rtds-content-primary aria-expanded:rtds-relative rtds-p-3 rtds-gap-2 rtds-text-sm rtds-primary-navigation__first-level rtds-primary-navigation__link" aria-expanded="false" aria-controls="submenumenu-3">

                                Dropdown

                                <svg class="rtds-icon rtds-fill-current rtds-w-5 rtds-h-5 rtds-ml-auto rtds-transition-all rtds-dropdown-menu__trigger-icon group-aria-expanded:-rtds-rotate-180" aria-hidden="true" focusable="false" role="img">
                                    <use href="../../icons.svg#mini--chevron-down" />
                                </svg>

                            </button>

                            <ul class="rtds-dropdown-menu__list rtds-hidden rtds-border rtds-border-t-0 lg:rtds-w-52 lg:rtds-border-t lg:rtds-rounded lg:rtds-shadow-md lg:rtds-absolute rtds-border-r-0 rtds-border-l-0 lg:rtds-border-r lg:rtds-border-l" id="submenumenu-3">

                                <li class="rtds-dropdown-menu__item rtds-group/menu-item">
                                    <a class="rtds-dropdown-menu__link rtds-block rtds-transition rtds-text-sm group-first/menu-item:rtds-rounded-t group-last/menu-item:rtds-rounded-b" href="">
                                        <div class="rtds-flex rtds-gap-2 rtds-items-center">

                                            <span class="rtds-grow">List item</span>

                                        </div>

                                    </a>
                                </li>

                                <li class="rtds-dropdown-menu__item rtds-group/menu-item">
                                    <a class="rtds-dropdown-menu__link rtds-block rtds-transition rtds-text-sm group-first/menu-item:rtds-rounded-t group-last/menu-item:rtds-rounded-b" href="">
                                        <div class="rtds-flex rtds-gap-2 rtds-items-center">

                                            <span class="rtds-grow">List item</span>

                                        </div>

                                    </a>
                                </li>

                                <li class="rtds-dropdown-menu__item rtds-group/menu-item">
                                    <a class="rtds-dropdown-menu__link rtds-block rtds-transition rtds-text-sm group-first/menu-item:rtds-rounded-t group-last/menu-item:rtds-rounded-b" href="">
                                        <div class="rtds-flex rtds-gap-2 rtds-items-center">

                                            <span class="rtds-grow">List item</span>

                                        </div>

                                    </a>
                                </li>

                                <li class="rtds-dropdown-menu__item rtds-group/menu-item">
                                    <a class="rtds-dropdown-menu__link rtds-block rtds-transition rtds-text-sm group-first/menu-item:rtds-rounded-t group-last/menu-item:rtds-rounded-b" href="">
                                        <div class="rtds-flex rtds-gap-2 rtds-items-center">

                                            <span class="rtds-grow">List item</span>

                                        </div>

                                    </a>
                                </li>

                            </ul>

                        </li>

                    </ul>
                </div>

            </div>
            <div class="rtds-primary-navigation__backdrop rtds-bg-black/25 rtds-top-[--header-height] lg:rtds-hidden"></div>
        </nav>

        <div class="rtds-top-bar__utilities-area rtds-flex lg:rtds-gap-4 xl:rtds-gap-6 rtds-ml-auto">

            <!-- Social links component -->

            <div class="rtds-social-links rtds-grid rtds-gap-1 md:rtds-flex md:rtds-gap-6 ">

                <ul id="headerSocial" class="rtds-flex rtds-items-center rtds-gap-4 lg:rtds-gap-2 xl:rtds-gap-4 rtds-flex-wrap rtds-p-2 lg:rtds-p-0">

                    <li class="rtds-flex rtds-items-center">
                        <a href="" class="rtds-link rtds-text-2xl rtds-content-05 rtds-p-2 xl:rtds-p-1 undefined rtds-link--lg">
                            <span class="rtds-sr-only">Vai al profilo Facebook di Regione Toscana</span>

                            <svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8 lg:rtds-w-5 lg:rtds-h-5 xl:rtds-w-6 xl:rtds-h-6" aria-hidden="true" focusable="false" role="img">
                                <use href="../../icons.svg#solid--facebook" />
                            </svg>

                        </a>
                    </li>

                    <li class="rtds-flex rtds-items-center">
                        <a href="" class="rtds-link rtds-text-2xl rtds-content-05 rtds-p-2 xl:rtds-p-1 undefined rtds-link--lg">
                            <span class="rtds-sr-only">Vai al profilo X di Regione Toscana</span>

                            <svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8 lg:rtds-w-5 lg:rtds-h-5 xl:rtds-w-6 xl:rtds-h-6" aria-hidden="true" focusable="false" role="img">
                                <use href="../../icons.svg#solid--x" />
                            </svg>

                        </a>
                    </li>

                    <li class="rtds-flex rtds-items-center">
                        <a href="" class="rtds-link rtds-text-2xl rtds-content-05 rtds-p-2 xl:rtds-p-1 undefined rtds-link--lg">
                            <span class="rtds-sr-only">Vai al canale Telegram di Regione Toscana</span>

                            <svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8 lg:rtds-w-5 lg:rtds-h-5 xl:rtds-w-6 xl:rtds-h-6" aria-hidden="true" focusable="false" role="img">
                                <use href="../../icons.svg#solid--telegram" />
                            </svg>

                        </a>
                    </li>

                    <li class="rtds-flex rtds-items-center">
                        <a href="" class="rtds-link rtds-text-2xl rtds-content-05 rtds-p-2 xl:rtds-p-1 undefined rtds-link--lg">
                            <span class="rtds-sr-only">Vai al canale Youtube di Regione Toscana</span>

                            <svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8 lg:rtds-w-5 lg:rtds-h-5 xl:rtds-w-6 xl:rtds-h-6" aria-hidden="true" focusable="false" role="img">
                                <use href="../../icons.svg#solid--youtube" />
                            </svg>

                        </a>
                    </li>

                    <li class="rtds-flex rtds-items-center">
                        <a href="" class="rtds-link rtds-text-2xl rtds-content-05 rtds-p-2 xl:rtds-p-1 undefined rtds-link--lg">
                            <span class="rtds-sr-only">Vai al canale Instagram di Regione Toscana</span>

                            <svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8 lg:rtds-w-5 lg:rtds-h-5 xl:rtds-w-6 xl:rtds-h-6" aria-hidden="true" focusable="false" role="img">
                                <use href="../../icons.svg#solid--instagram" />
                            </svg>

                        </a>
                    </li>

                    <li class="rtds-flex rtds-items-center">
                        <a href="" class="rtds-link rtds-text-2xl rtds-content-05 rtds-p-2 xl:rtds-p-1 undefined rtds-link--lg">
                            <span class="rtds-sr-only">Vai al profilo Flickr di Regione Toscana</span>

                            <svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8 lg:rtds-w-5 lg:rtds-h-5 xl:rtds-w-6 xl:rtds-h-6" aria-hidden="true" focusable="false" role="img">
                                <use href="../../icons.svg#solid--flickr" />
                            </svg>

                        </a>
                    </li>

                </ul>

            </div>

            <div class="rtds-vertical-divider rtds-w-1e rtds-flex">
                <img class="rtds-w-full rtds-h-auto" src="/images/vertical-divider.svg" alt="">
            </div>

            <!-- Search Modal Desktop -->

            <!-- Desktop Search Modal -->
            <div class="rtds-search-modal-desktop__wrapper rtds-hidden lg:rtds-block">
                <button type="button" aria-haspopup="dialog" aria-controls="searchModal" aria-expanded="false" id="searchModalTrigger" class="rtds-btn rtds-btn--outline rtds-btn--icon rtds-w-6 rtds-h-6 md:rtds-w-10 md:rtds-h-10 rtds-border-gray-03 hover:rtds-button-primary-hover focus:rtds-button-primary-hover active:rtds-button-primary-hover hover:rtds-text-white focus:rtds-text-white active:rtds-text-white">
                    <span class="rtds-sr-only">Cerca nel sito - apri la modale</span>
                    <svg class="rtds-icon rtds-fill-current rtds-w-4 rtds-h-4 md:rtds-w-5 md:rtds-h-5" aria-hidden="true" focusable="false" role="img">
                        <use href="../../icons.svg#mini--magnifying-glass" />
                    </svg>

                </button>

                <!-- Search Modal -->
                <div id="searchModal" class="rtds-search-modal-desktop rtds-fixed rtds-items-center rtds-content-center rtds-inset-0 rtds-bg-black rtds-bg-opacity-50 rtds-overflow-y-auto rtds-h-full rtds-w-full" style="display:none;" aria-hidden="true" role="dialog" aria-modal="true" aria-labelledby="modalTitle" data-trigger-id="searchModalTrigger" data-close-button-id="closeModal">

                    <div class="rtds-relative rtds-h-full lg:rtds-h-full lg:rtds-w-full rtds-mx-auto rtds-p-6 lg:rtds-p-16 rtds-shadow-lg rtds-bg-white">
                        <div class="rtds-modal-content rtds-container rtds-px-16 rtds-grid rtds-gap-14">
                            <div class="rtds-flex rtds-justify-between rtds-items-center">
                                <h2 id="modalTitle" class="rtds-text-3xl md:rtds-text-5xl lg:rtds-text-6xl">Cerca nel sito</h2>
                                <button type="button" class="rtds-btn 
    rtds-btn--icon rtds-btn--icon-square rtds-btn--icon rtds-border-0 hover:rtds-background-primary hover:rtds-text-white" id="closeModal"><svg class="rtds-icon rtds-fill-current rtds-w-8 rtds-h-8" aria-hidden="true" focusable="false" role="img">
                                        <use href="../../icons.svg#mini--x-mark" />
                                    </svg>
                                    <span class="rtds-sr-only">

                                        Chiudi
                                    </span>

                                </button>

                            </div>

                            <form role="search" class="rtds-flex rtds-gap-2">
                                <div class="rtds-input-field rtds-gap-1 rtds-flex-1 rtds-search-modal-desktop__input ">
                                    <label for="inputSearch" class="rtds-input-field__label">
                                        Cerca servizi, informazioni, aiuti...

                                    </label>

                                    <div class="rtds-input has-icon">

                                        <svg class="rtds-icon rtds-fill-current rtds-input__icon" aria-hidden="true" focusable="false" role="img">
                                            <use href="../../icons.svg#mini--magnifying-glass" />
                                        </svg>

                                        <input id="inputSearch" class="rtds-text-sm rtds-input-placeholder" type="search" placeholder="Cerca">
                                    </div>

                                </div>
                                <button type="button" class="rtds-btn 
    rtds-btn--icon-right rtds-group/button rtds-btn--primary rtds-self-end">

                                    Cerca nel sito

                                    <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 group-hover/button:rtds-translate-x-1" aria-hidden="true" focusable="false" role="img">
                                        <use href="../../icons.svg#mini--chevron-right" />
                                    </svg>

                                </button>

                            </form>

                        </div><!-- /END MODAL CONTENT -->
                    </div>
                </div>
            </div>

        </div>
        <!--/ END TOP BAR UTILITIES -->

    </div>
</div><!-- /END TOPBAR -->
{% extends '@top-bar' %}
{% block leftArea %}
    {% render '@primary-navigation', {classes: 'rtds-flex lg:rtds-justify-end rtds-ml-auto lg:rtds-ml-0 is-top-nav-positioned', navPanelClasses: 'rtds-flex-col rtds-transition-all rtds-invisible rtds-w-[88%] lg:rtds-w-auto rtds-fixed lg:rtds-static lg:rtds-visible rtds-top-[--header-height] rtds-bottom-0 rtds-left-[12%] lg:rtds-left-0 rtds-border-l rtds-border-primary lg:rtds-border-l-0 rtds-overflow-y-auto', listGap: 'rtds-gap-2 lg:rtds-gap-2.5',itemFontSize: 'rtds-text-sm', itemDropdownFontSize: 'rtds-text-sm'}, true %}
{% endblock %}
{
  "hasSecondaryNav": true,
  "hasTopBarSocial": true,
  "hasSearchButton": true,
  "mobileHidden": false,
  "spacing": "rtds-py-1 md:rtds-py-2 rtds-px-4",
  "hasVerticalDivider": true,
  "searchButtonBorderColor": "rtds-border-gray-03",
  "searchModalVariant": null,
  "hasLanguageSelector": false
}
  • Content:
    /**
     * SIDE NAVIGATION
     *
    */
    @layer components {
        .rtds-top-bar {
            @apply rtds-flex rtds-items-center rtds-background-01;
        }
    
        .rtds-top-bar__container {
            @apply rtds-flex rtds-items-center lg:rtds-flex-1;
        }
    
        /*.rtds-top-bar__navigation {
        }*/
    
        /*.rtds-top-bar__utilities-area {
            @apply rtds-flex rtds-ml-auto;
        }*/
    }
  • URL: /components/raw/top-bar/top-bar.css
  • Filesystem Path: components/04-organisms/top-bar/top-bar.css
  • Size: 365 Bytes

Top bar component

Configurations:

  • classes: value - top bar classes
  • bgColor: value - background color classes
  • spacing: values - spacing classes
  • topBarLinkLeft: array - manage top bar link in left area
    • alt: value - link alt attribute
    • link: value - link url
    • width: value - link width
    • height: value - link height
    • image: value - link image
    • imageSrcset: value - link image srcset
  • topBarLinkRight: array - manage top bar link in right area
    • alt: value - link alt attribute
    • link: value - link url
    • width: value - link width
    • height: value - link height
    • image: value - link image
    • imageSrcset: value - link image srcset
  • hasSecondaryNav: true - manage secondary navigation
  • hasTopBarSocial: true - manage social bar
  • hasLanguageSelector: true - manage language selector
  • hasSearchButton: true - manage top bar search and modal
  • searchModalVariant: value - variante della modale di ricerca desktop:
    • null o non specificato: usa la variante default con form semplice (@input-field--search + @button--icon-right)
    • "with-search-bar": usa la variante con componente @search-bar completo con autocomplete
  • searchButtonBorderColor: value - classe CSS per il colore del bordo del trigger button (default: “rtds-border-gray-03”)
  • searchButtonTextColor: value - classe CSS per il colore del testo del trigger button (opzionale)

Accessibilità

Quando hasSearchButton è abilitato, il trigger button per la modale di ricerca include:

  • aria-haspopup="dialog": Indica che il bottone apre una modale
  • aria-controls="searchModal": Riferimento all’ID della modale controllata
  • aria-expanded: Attributo gestito dinamicamente da JavaScript:
    • aria-expanded="false" quando la modale è chiusa (valore iniziale)
    • aria-expanded="true" quando la modale è aperta
  • Label nascosta per screen reader: “Cerca nel sito - apri la modale”

La gestione JavaScript dell’attributo aria-expanded è implementata nel componente search-modal-desktop.js.

Varianti della Modale Desktop di Ricerca

Quando hasSearchButton è abilitato, è possibile scegliere tra due varianti della modale desktop:

Variante Default (searchModalVariant: null)

Utilizza un form semplice con:

  • @input-field--search per il campo di ricerca
  • @button--icon-right per il bottone submit

Utilizza il componente @search-bar completo con:

  • Autocomplete accessibile
  • Bottone clear per cancellare l’input
  • Link “Tutti i risultati” nel dropdown
  • Supporto per opzioni di ricerca personalizzate

Esempio con variante search-bar: Utilizzare @top-bar con i parametri: hasSearchButton: true, searchModalVariant: 'with-search-bar', searchId: 'desktopSearchBar', searchLabel: 'Cerca servizi, informazioni, aiuti...', placeholder: 'Search', allResultsHref: '/search?q=', allResultsLabel: 'Tutti i risultati'.

Blocks:

  • leftArea
  • hasTopBarLinkLeft
  • rightArea
  • hasTopBarLinkRight