Locale

Change the locale of the datepicker, schedule and client side validation messages.

Language
English
French
German
Italian
Korean
Spanish
Catalan
Dutch
Portuguese
Portuguese
Arabic
Czech
Greek
Persian
Hindi
Indonesian
Croatian
Japanese
Hungarian
Hebrew
Georgian
Lithuanian
Latvian
Norwegian
Polish
Romanian
Russian
Slovak
Slovenian
Serbian
Swedish
Turkish
Ukrainian
Vietnamese
Chinese
Chinese

Input Style

Free Themes

Built-in component themes created by the PrimeFaces Theme Designer.

PrimeOne Design

Saga Saga
Vela Vela
Arya Arya

Premium Themes

Premium themes are only available exclusively for PrimeFaces Theme Designer subscribers and therefore not included in PrimeFaces core.

Bootstrap light blue and dark blue themes are also included in PrimeFaces 10.x builds for Elite subscribers.

bootstrap4-blue-light Bootstrap Blue
bootstrap4-purple-light Bootstrap Purple
bootstrap4-blue-dark Bootstrap Blue
bootstrap4-purple-dark Bootstrap Purple

Legacy Free Themes

Luna Amber Luna Amber
Luna Blue Luna Blue
Luna Green Luna Green
Luna Pink Luna Pink
Nova Nova
Nova Nova Alt
Nova Nova Accent

PREMIUM TEMPLATES

Create awesome applications in no time using the premium templates and impress your users.

DataTable Scroll

Both vertical and horizontal scrolling of the data is supported with optional frozen rows-columns and on-demand loading features.

Vertical
NameCountryRepresentativeStatus
Sinclair C TollnerUnited KingdomOnyama Limba UNQUALIFIED
Wickens N TollnerGermanyOnyama Limba UNQUALIFIED
Maisha W OldroydRussiaOnyama Limba NEW
Alejandro K KolmetzCanadaElwin Sharvill RENEWAL
Alejandro B PoquetteCanadaElwin Sharvill NEGOTIATION
Izzy Q ButtCanadaAsiya Javayant RENEWAL
Jeanfrancois Q GlickArgentinaStephen Shaw QUALIFIED
Julie G PaprockiIndiaIoni Bowcher UNQUALIFIED
Antonio B MorascaAustraliaIoni Bowcher QUALIFIED
Mujtaba S FollerSpainIoni Bowcher QUALIFIED
Francesco I PoquetteBrazilAsiya Javayant NEGOTIATION
Mayumi X BriddickCanadaAsiya Javayant RENEWAL
Jones M OldroydJapanStephen Shaw NEGOTIATION
Jeanfrancois Q IturbideSpainBernardo Dominic RENEWAL
Faith C MacleadCanadaOnyama Limba NEGOTIATION
Tony V GillianIndiaAsiya Javayant UNQUALIFIED
Ashley U GlickIndiaBernardo Dominic UNQUALIFIED
Misaki J PaprockiCanadaAnna Fali UNQUALIFIED
Aruna O AlbaresBrazilIvan Magalhaes PROPOSAL
Wickens X MarrierJapanAmy Elsner PROPOSAL
Clifford M FigeroaArgentinaStephen Shaw NEGOTIATION
Alejandro T InouyeRussiaIvan Magalhaes NEW
Stacey F NickaRussiaAsiya Javayant RENEWAL
Juan V GillianBrazilXuxue Feng QUALIFIED
Aika L VocelkaFranceAmy Elsner PROPOSAL
Sinclair M StockhamSpainAnna Fali UNQUALIFIED
Leon O WieserAustraliaElwin Sharvill NEW
Francesco T GlickBrazilXuxue Feng NEGOTIATION
Ivar U KolmetzRussiaOnyama Limba PROPOSAL
Chavez Y OldroydRussiaStephen Shaw RENEWAL
Francesco H CampainRussiaElwin Sharvill QUALIFIED
Faith F StockhamSpainAsiya Javayant NEW
Jefferson G MaletIndiaBernardo Dominic QUALIFIED
Julie X GauchoJapanElwin Sharvill NEW
Costa W GillianFranceStephen Shaw NEGOTIATION
Juan R DilliardGermanyElwin Sharvill NEGOTIATION
Mujtaba O RulapaughFranceAmy Elsner NEGOTIATION
David Q KolmetzAustraliaAmy Elsner RENEWAL
Smith Q OstroskyFranceBernardo Dominic NEGOTIATION
Jennifer T RutaJapanIoni Bowcher NEGOTIATION
Wickens B SchemmerJapanOnyama Limba QUALIFIED
Cody B ButtSpainXuxue Feng RENEWAL
Maria K RulapaughArgentinaAnna Fali UNQUALIFIED
Mayumi K StockhamItalyAmy Elsner PROPOSAL
Johnson S DarakjyArgentinaBernardo Dominic QUALIFIED
Murillo I PaprockiItalyBernardo Dominic NEW
Claire Y GarufiUnited KingdomElwin Sharvill QUALIFIED
Aruna O CaldareraUnited KingdomElwin Sharvill RENEWAL
Cody X ShinkoAustraliaIvan Magalhaes QUALIFIED
Aika Q WaycottJapanElwin Sharvill UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Stacey M PaprockiUnited KingdomStephen Shaw RENEWAL
Clifford D RoysterSpainXuxue Feng RENEWAL
Johnson D GlickRussiaElwin Sharvill QUALIFIED
David Y PerinUnited KingdomIvan Magalhaes RENEWAL
Izzy U WaycottIndiaAsiya Javayant PROPOSAL
Juan N ChuiFranceOnyama Limba QUALIFIED
David M BriddickAustraliaOnyama Limba NEGOTIATION
Smith F MacleadArgentinaOnyama Limba UNQUALIFIED
Deepesh Y FerenczRussiaAmy Elsner NEGOTIATION
Murillo S MacleadArgentinaElwin Sharvill NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000James C VocelkaCanada2024-04-15Chanay, Jeffrey A Esq QUALIFIED75Stephen Shaw
1001Emily M RimArgentina2024-04-19Truhlar And Truhlar Attys UNQUALIFIED31Elwin Sharvill
1002Jones U StensethIndia2024-04-16King, Christopher A Esq UNQUALIFIED28Ivan Magalhaes
1003Salvatore J GauchoSpain2024-04-17Rangoni Of Florence NEGOTIATION56Onyama Limba
1004Costa G InouyeBrazil2024-04-03Feiner Bros PROPOSAL51Ioni Bowcher
1005Izzy D DilliardArgentina2024-04-21Rangoni Of Florence QUALIFIED15Stephen Shaw
1006Jefferson O CaudySpain2024-03-24Printing Dimensions RENEWAL35Anna Fali
1007Murillo Q AlbaresUnited Kingdom2024-04-13Chemel, James L Cpa RENEWAL19Asiya Javayant
1008Isabel V BriddickAustralia2024-03-30Feltz Printing Service PROPOSAL47Onyama Limba
1009Arvin U DarakjyJapan2024-04-22Rangoni Of Florence PROPOSAL12Ivan Magalhaes
1010Alejandro A DilliardGermany2024-04-01Dorl, James J Esq PROPOSAL20Asiya Javayant
1011Tony N RutaItaly2024-03-24Dorl, James J Esq NEGOTIATION65Ioni Bowcher
1012Aditya I FlosiArgentina2024-04-12Benton, John B Jr QUALIFIED94Anna Fali
1013Silvio W WieserFrance2024-04-12Chapman, Ross E Esq NEW94Ivan Magalhaes
1014Faith R MorascaUnited Kingdom2024-04-08Rousseaux, Michael Esq UNQUALIFIED16Xuxue Feng
1015Maisha Q RimCanada2024-04-08Truhlar And Truhlar Attys RENEWAL86Xuxue Feng
1016Maisha C RoysterAustralia2024-04-11Chanay, Jeffrey A Esq QUALIFIED69Bernardo Dominic
1017Silvio A MarrierArgentina2024-04-13Morlong Associates NEW67Bernardo Dominic
1018Misaki R RimBrazil2024-03-25Feiner Bros UNQUALIFIED14Xuxue Feng
1019Izzy B WaycottSpain2024-03-24Feltz Printing Service UNQUALIFIED78Stephen Shaw
1020Adams S VocelkaBrazil2024-04-07Feiner Bros NEGOTIATION51Stephen Shaw
1021Ivar A WieserIndia2024-03-27Feiner Bros UNQUALIFIED75Asiya Javayant
1022Ricardo S RulapaughGermany2024-04-07Rousseaux, Michael Esq UNQUALIFIED96Bernardo Dominic
1023Julie G BriddickBrazil2024-04-18Printing Dimensions PROPOSAL99Ivan Magalhaes
1024Rodrigues R PaprockiAustralia2024-03-27Chapman, Ross E Esq PROPOSAL96Amy Elsner
1025Maisha O GauchoBrazil2024-03-28Chanay, Jeffrey A Esq NEGOTIATION19Ivan Magalhaes
1026Ivar W SergiIndia2024-04-09Feiner Bros PROPOSAL72Ioni Bowcher
1027Alejandro G PoquetteCanada2024-04-18King, Christopher A Esq NEW38Ivan Magalhaes
1028Antonio G VocelkaJapan2024-04-17King, Christopher A Esq QUALIFIED98Onyama Limba
1029Jennifer Q SchemmerBrazil2024-04-07Chemel, James L Cpa NEGOTIATION41Stephen Shaw
1030Juan Q WieserIndia2024-04-06Rangoni Of Florence NEW10Elwin Sharvill
1031Clifford E FollerJapan2024-03-26Benton, John B Jr RENEWAL68Xuxue Feng
1032Isabel U RulapaughFrance2024-04-04Chanay, Jeffrey A Esq RENEWAL7Anna Fali
1033Ashley D AmigonJapan2024-04-16Morlong Associates NEGOTIATION87Xuxue Feng
1034Mayumi G AlbaresCanada2024-03-30Chemel, James L Cpa NEW16Asiya Javayant
1035Murillo C GlickGermany2024-03-27Truhlar And Truhlar Attys RENEWAL11Bernardo Dominic
1036Arvin Q PerinArgentina2024-04-03Feiner Bros NEW8Amy Elsner
1037Ashley O MaletSpain2024-04-15Commercial Press QUALIFIED11Stephen Shaw
1038Emily U MaletIndia2024-04-01Feiner Bros QUALIFIED14Ioni Bowcher
1039Smith B BologniaGermany2024-04-14King, Christopher A Esq QUALIFIED78Ioni Bowcher
1040Ricardo N SaylorsGermany2024-04-22Printing Dimensions UNQUALIFIED32Elwin Sharvill
1041Sinclair S PerinFrance2024-03-25Commercial Press RENEWAL75Elwin Sharvill
1042Aruna F NestleIndia2024-03-31Rousseaux, Michael Esq NEGOTIATION48Elwin Sharvill
1043Maria G GlickIndia2024-04-13Rangoni Of Florence NEW1Amy Elsner
1044Isabel C CaldareraUnited Kingdom2024-04-16Chapman, Ross E Esq UNQUALIFIED40Stephen Shaw
1045Leon M WhobreyIndia2024-04-21King, Christopher A Esq NEGOTIATION33Stephen Shaw
1046Adams F VenereGermany2024-03-29Truhlar And Truhlar Attys RENEWAL67Ioni Bowcher
1047James L MaletCanada2024-04-15Feltz Printing Service QUALIFIED87Ioni Bowcher
1048Johnson Y SchemmerItaly2024-04-10Chemel, James L Cpa RENEWAL76Elwin Sharvill
1049Emily K MaletUnited Kingdom2024-04-10Rangoni Of Florence UNQUALIFIED42Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Morrow Y RulapaughItalyOnyama Limba NEW
Maria B RulapaughBrazilAnna Fali RENEWAL
Kaitlin U WaycottSpainStephen Shaw UNQUALIFIED
Leja F ShinkoItalyXuxue Feng NEGOTIATION
Claire K IturbideSpainAmy Elsner RENEWAL
Silvio V IturbideArgentinaXuxue Feng NEW
Murillo V PaprockiIndiaIvan Magalhaes UNQUALIFIED
Julie T MaletFranceAnna Fali PROPOSAL
Greenwood M PaprockiIndiaXuxue Feng RENEWAL
Kaitlin K CaudyJapanBernardo Dominic PROPOSAL
Aika L NickaGermanyXuxue Feng NEGOTIATION
Deepesh G MaletArgentinaAnna Fali PROPOSAL
Octavia B MaletSpainXuxue Feng PROPOSAL
Deepesh A StockhamItalyElwin Sharvill NEW
Octavia S VocelkaIndiaIvan Magalhaes PROPOSAL
Emily K PaprockiSpainStephen Shaw QUALIFIED
Julie V DoeArgentinaAnna Fali PROPOSAL
Aditya D PaprockiFranceBernardo Dominic PROPOSAL
Mayumi V BriddickRussiaXuxue Feng NEGOTIATION
Clifford K SergiFranceIvan Magalhaes PROPOSAL
Leja K CaudyArgentinaIoni Bowcher PROPOSAL
Jones U OldroydFranceElwin Sharvill PROPOSAL
Salvatore S AlbaresAustraliaAmy Elsner NEW
Smith Y NestleSpainElwin Sharvill QUALIFIED
Izzy R FollerBrazilAnna Fali NEW
Tony V AmigonBrazilBernardo Dominic UNQUALIFIED
Julie P StensethGermanyElwin Sharvill NEGOTIATION
Deepesh H FerenczJapanAmy Elsner RENEWAL
James P PaprockiArgentinaAmy Elsner RENEWAL
Isabel J KolmetzFranceIoni Bowcher PROPOSAL
Mujtaba Q OldroydRussiaAnna Fali NEW
Claire P OstroskyBrazilElwin Sharvill NEGOTIATION
Deepesh K RutaAustraliaElwin Sharvill UNQUALIFIED
Faith B StensethJapanAmy Elsner NEGOTIATION
Adams T VenereItalyXuxue Feng NEW
Kadeem P DarakjyItalyBernardo Dominic NEW
Adams A VocelkaIndiaAnna Fali QUALIFIED
Deepesh J CaudyArgentinaBernardo Dominic UNQUALIFIED
Salvatore Z FerenczRussiaAsiya Javayant RENEWAL
Silvio V SergiBrazilStephen Shaw PROPOSAL
Aika M AlbaresItalyElwin Sharvill RENEWAL
Smith R OldroydFranceIoni Bowcher PROPOSAL
Jennifer U WaycottJapanIvan Magalhaes NEW
Arvin N MarrierRussiaAsiya Javayant NEGOTIATION
Isabel J DarakjyGermanyIvan Magalhaes QUALIFIED
Munro U BologniaUnited KingdomXuxue Feng QUALIFIED
Antonio B RulapaughGermanyElwin Sharvill NEW
Ivar T KolmetzCanadaAsiya Javayant QUALIFIED
Greenwood V SchemmerBrazilIoni Bowcher RENEWAL
Tony M FollerIndiaOnyama Limba RENEWAL
Frozen Columns
Name
Aruna X Nestle
Murillo S Butt
Izzy S Sergi
Isabel H Chui
Leja Q Perin
Wickens S Perin
Juan W Glick
Jefferson U Bolognia
Ricardo O Ferencz
Faith X Stockham
Johnson F Caldarera
Aditya I Caudy
Mujtaba N Schemmer
Wickens P Slusarski
Juan C Shinko
Ashley S Venere
Silvio H Shinko
Emily C Gillian
Emily S Darakjy
Johnson H Foller
Jefferson Q Glick
Clifford Y Ostrosky
Deepesh U Darakjy
Alejandro H Rim
Chavez M Maclead
Salvatore G Dilliard
Mayumi S Iturbide
Adams E Flosi
Juan C Shinko
Silvio W Amigon
Antonio A Bowley
Aika N Ostrosky
Adams I Nicka
Wickens X Slusarski
Morrow Q Ferencz
Jones K Kolmetz
Salvatore Y Slusarski
Greenwood C Wieser
Isabel M Figeroa
Kadeem G Gillian
Murillo P Rulapaugh
Nicolas C Doe
Chavez M Gaucho
Jeanfrancois Z Ostrosky
Nicolas N Stockham
Deepesh R Ferencz
Antonio V Bowley
Stacey M Vocelka
Smith V Iturbide
Johnson P Caudy
IdCountryDate
1000France2024-03-24
1001Brazil2024-04-03
1002United Kingdom2024-03-30
1003Canada2024-04-02
1004Argentina2024-04-01
1005India2024-04-01
1006Japan2024-04-13
1007Japan2024-04-22
1008Japan2024-04-03
1009Australia2024-03-25
1010Japan2024-04-13
1011Russia2024-04-14
1012France2024-04-09
1013Germany2024-04-12
1014Spain2024-04-12
1015Italy2024-04-19
1016Argentina2024-03-30
1017Argentina2024-03-29
1018Germany2024-04-11
1019Australia2024-04-05
1020Russia2024-04-04
1021Spain2024-04-22
1022Germany2024-03-29
1023Japan2024-03-30
1024Germany2024-03-25
1025Russia2024-04-20
1026Russia2024-04-16
1027Australia2024-03-28
1028Brazil2024-03-25
1029United Kingdom2024-03-28
1030Russia2024-03-29
1031Canada2024-04-21
1032Germany2024-04-04
1033Russia2024-03-31
1034Argentina2024-04-03
1035Russia2024-03-27
1036Italy2024-03-30
1037Australia2024-04-15
1038Argentina2024-04-03
1039Italy2024-03-27
1040Japan2024-04-18
1041India2024-03-26
1042Germany2024-03-24
1043Argentina2024-04-07
1044France2024-04-07
1045Germany2024-03-27
1046Germany2024-04-06
1047Brazil2024-04-08
1048France2024-03-29
1049Spain2024-04-02

On-Demand Data

NameIdCountryDate
Jefferson I Malet1000Canada2024-04-20
Salvatore O Doe1001Canada2024-03-30
Morrow D Royster1002Italy2024-04-02
Arvin C Rulapaugh1003Russia2024-04-06
James P Ferencz1004Brazil2024-04-17
Kaitlin U Kusko1005Italy2024-03-30
Johnson L Morasca1006Italy2024-03-24
Antonio Q Rim1007Canada2024-04-19
Octavia F Rulapaugh1008Spain2024-04-01
Leon G Poquette1009Argentina2024-04-11
Johnson X Inouye1010Brazil2024-04-04
Aruna H Stenseth1011United Kingdom2024-03-29
Tony K Nicka1012Canada2024-04-21
Ashley E Waycott1013Argentina2024-04-05
Ricardo K Ferencz1014Germany2024-04-08
Mayumi C Malet1015Canada2024-03-26
James T Sergi1016Japan2024-04-01
Antonio H Nestle1017Australia2024-04-20
Adams R Garufi1018Argentina2024-04-17
Salvatore D Wieser1019Japan2024-03-26
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Ivar D BologniaGermanyAmy Elsner QUALIFIED
Rodrigues V ChuiFranceAmy Elsner NEGOTIATION
Mujtaba A PoquetteUnited KingdomIvan Magalhaes NEGOTIATION
James W FigeroaJapanIoni Bowcher PROPOSAL
Octavia I AmigonFranceOnyama Limba QUALIFIED
Arvin E GillianSpainOnyama Limba NEW
Mayumi B MacleadItalyBernardo Dominic NEGOTIATION
Isabel H RulapaughAustraliaIoni Bowcher RENEWAL
Aruna T PaprockiBrazilStephen Shaw QUALIFIED
Leja V VocelkaSpainIoni Bowcher NEW
Misaki V DoeArgentinaAnna Fali UNQUALIFIED
Jones Y SchemmerItalyBernardo Dominic NEW
Faith S PaprockiItalyBernardo Dominic NEGOTIATION
Ashley Y InouyeUnited KingdomXuxue Feng RENEWAL
Johnson M OldroydAustraliaStephen Shaw QUALIFIED
Julie O AmigonGermanyAmy Elsner NEGOTIATION
Julie I SchemmerArgentinaAsiya Javayant RENEWAL
Tony S DarakjyAustraliaStephen Shaw NEW
Ashley K GlickCanadaBernardo Dominic PROPOSAL
Chavez J GarufiRussiaOnyama Limba QUALIFIED
Emily T FollerAustraliaAnna Fali UNQUALIFIED
Aditya T PoquetteItalyAnna Fali UNQUALIFIED
Jefferson C GauchoUnited KingdomOnyama Limba NEW
Aditya A AmigonGermanyStephen Shaw RENEWAL
Smith T BologniaCanadaStephen Shaw RENEWAL
Deepesh P OstroskyIndiaXuxue Feng QUALIFIED
Jefferson I GlickGermanyXuxue Feng NEGOTIATION
Morrow C OstroskySpainIvan Magalhaes QUALIFIED
James L MaletArgentinaAsiya Javayant UNQUALIFIED
Alejandro E TollnerIndiaBernardo Dominic QUALIFIED
Smith X FerenczRussiaOnyama Limba NEW
Isabel W VocelkaItalyOnyama Limba NEW
Leja T StensethBrazilOnyama Limba UNQUALIFIED
Cody C NickaArgentinaOnyama Limba UNQUALIFIED
Emily C WaycottItalyIvan Magalhaes QUALIFIED
James V PaprockiArgentinaBernardo Dominic UNQUALIFIED
Stacey R FigeroaJapanBernardo Dominic UNQUALIFIED
Leon Z FerenczUnited KingdomIvan Magalhaes NEGOTIATION
Rodrigues Q KolmetzGermanyAmy Elsner QUALIFIED
Jeanfrancois B MaletBrazilIvan Magalhaes PROPOSAL

<style>
    .ui-datatable-frozenlayout-left {
        width: 20%;
    }

    .ui-datatable-frozenlayout-right {
        width: 80%;
    }
</style>


<h:form>
    <div class="card">
        <h5 style="margin-top:0">Vertical</h5>
        <p:dataTable var="customer" value="#{dtScrollView.customers1}" scrollable="true" scrollHeight="250">
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Representative" footerText="Representative">
                <h:outputText value="#{customer.representative.name}"/>
            </p:column>
            <p:column headerText="Status" footerText="Status">
                <span class="customer-badge status-#{customer.status.name().toLowerCase()}">#{customer.status}</span>
            </p:column>
        </p:dataTable>
    </div>

    <div class="card">
        <h5>Horizontal</h5>
        <p:dataTable var="customer" value="#{dtScrollView.customers2}" scrollable="true" scrollWidth="600">
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Representative" footerText="Representative">
                <h:outputText value="#{customer.representative.name}"/>
            </p:column>
            <p:column headerText="Status" footerText="Status">
                <span class="customer-badge status-#{customer.status.name().toLowerCase()}">#{customer.status}</span>
            </p:column>
        </p:dataTable>
    </div>

    <div class="card">
        <h5>Horizontal and Vertical</h5>
        <p:dataTable var="customer" value="#{dtScrollView.customers3}" scrollable="true" scrollWidth="50%" scrollHeight="250">
            <p:column headerText="Id" footerText="Id">
                <h:outputText value="#{customer.id}"/>
            </p:column>
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Date" footerText="Date">
                <h:outputText value="#{customer.date}"/>
            </p:column>
            <p:column headerText="Company" footerText="Company">
                <h:outputText value="#{customer.company}"/>
            </p:column>
            <p:column headerText="Status" footerText="Status">
                <span class="customer-badge status-#{customer.status.name().toLowerCase()}">#{customer.status}</span>
            </p:column>
            <p:column headerText="Activity" footerText="Activity">
                <h:outputText value="#{customer.activity}"/>
            </p:column>
            <p:column headerText="Representative" footerText="Representative">
                <h:outputText value="#{customer.representative.name}"/>
            </p:column>
        </p:dataTable>
    </div>

    <div class="card">
        <h5>Frozen Rows</h5>
        <p:dataTable var="customer" value="#{dtScrollView.customers4}" scrollable="true" scrollHeight="250"
                     frozenRows="2">
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Representative" footerText="Representative">
                <h:outputText value="#{customer.representative.name}"/>
            </p:column>
            <p:column headerText="Status" footerText="Status">
                <span class="customer-badge status-#{customer.status.name().toLowerCase()}">#{customer.status}</span>
            </p:column>
        </p:dataTable>
    </div>

    <div class="card">
        <h5>Frozen Columns</h5>
        <p:dataTable var="customer" value="#{dtScrollView.customers5}" scrollable="true" scrollHeight="250"
                     scrollWidth="300" frozenColumns="1">
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Id" footerText="Id">
                <h:outputText value="#{customer.id}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Date" footerText="Date">
                <h:outputText value="#{customer.date}"/>
            </p:column>
        </p:dataTable>
    </div>

    <div class="card">
        <h3>On-Demand Data</h3>
        <p:dataTable var="customer" value="#{dtScrollView.customers6}" scrollRows="20" scrollable="true" liveScroll="true" scrollHeight="150">
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Id" footerText="Id">
                <h:outputText value="#{customer.id}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Date" footerText="Date">
                <h:outputText value="#{customer.date}"/>
            </p:column>
        </p:dataTable>
    </div>

    <div class="card">
        <h5>Virtual Scrolling - 20000 Rows</h5>
        <p:dataTable var="customer" value="#{dtScrollView.lazyModel}" scrollRows="20" scrollable="true"
                     virtualScroll="true" scrollHeight="200" rows="40" style="margin-bottom:0">
            <p:column headerText="Name" footerText="Name">
                <h:outputText value="#{customer.name}"/>
            </p:column>
            <p:column headerText="Country" footerText="Country">
                <h:outputText value="#{customer.country}"/>
            </p:column>
            <p:column headerText="Representative" footerText="Representative">
                <h:outputText value="#{customer.representative.name}"/>
            </p:column>
            <p:column headerText="Status" footerText="Status">
                <span class="customer-badge status-#{customer.status.name().toLowerCase()}">#{customer.status}</span>
            </p:column>
        </p:dataTable>
    </div>

</h:form>