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
Maisha N TollnerCanadaAnna Fali NEGOTIATION
Faith T GarufiIndiaOnyama Limba NEGOTIATION
Juan Y SergiSpainAnna Fali QUALIFIED
Darci Y CampainSpainXuxue Feng QUALIFIED
Jennifer N VenereArgentinaIvan Magalhaes QUALIFIED
Murillo N GauchoIndiaIoni Bowcher PROPOSAL
Jefferson K VocelkaGermanyIoni Bowcher UNQUALIFIED
Leon Y GlickCanadaAnna Fali QUALIFIED
Arvin K GauchoFranceXuxue Feng NEW
Johnson Y NickaFranceAsiya Javayant PROPOSAL
Jeanfrancois O SaylorsRussiaBernardo Dominic UNQUALIFIED
Jeanfrancois N BologniaGermanyStephen Shaw NEGOTIATION
Arvin D RutaAustraliaOnyama Limba UNQUALIFIED
Adams H PerinJapanAsiya Javayant RENEWAL
Murillo Y OldroydSpainStephen Shaw QUALIFIED
Antonio H StockhamJapanAnna Fali UNQUALIFIED
Deepesh T VenereBrazilAnna Fali PROPOSAL
Mujtaba I TollnerCanadaXuxue Feng NEGOTIATION
Munro F SergiCanadaAnna Fali NEW
Darci D RulapaughIndiaIvan Magalhaes QUALIFIED
James L KolmetzUnited KingdomElwin Sharvill PROPOSAL
Greenwood U NestleJapanIoni Bowcher UNQUALIFIED
Jeanfrancois Q FerenczCanadaStephen Shaw UNQUALIFIED
Francesco W PaprockiJapanXuxue Feng RENEWAL
Jeanfrancois U OldroydItalyIoni Bowcher NEW
Salvatore A StensethUnited KingdomOnyama Limba QUALIFIED
Kadeem X ButtJapanAsiya Javayant QUALIFIED
Kadeem H ChuiRussiaAsiya Javayant NEW
Francesco Z MarrierFranceAnna Fali PROPOSAL
Alejandro F DilliardFranceBernardo Dominic NEW
Cody U NestleUnited KingdomElwin Sharvill QUALIFIED
Francesco P SchemmerSpainBernardo Dominic NEW
Aditya T IturbideCanadaAnna Fali NEW
Aruna A SergiItalyStephen Shaw QUALIFIED
Jefferson A MaletCanadaXuxue Feng PROPOSAL
Francesco I InouyeAustraliaIoni Bowcher PROPOSAL
Maria K GlickItalyAnna Fali NEW
Smith Y RimFranceStephen Shaw RENEWAL
James J FollerSpainXuxue Feng NEGOTIATION
Kaitlin P CampainRussiaAnna Fali QUALIFIED
David K AlbaresIndiaStephen Shaw NEGOTIATION
Kadeem B KuskoSpainIoni Bowcher PROPOSAL
Johnson Q MaletRussiaElwin Sharvill PROPOSAL
Octavia D TollnerFranceBernardo Dominic NEW
Aruna L RimBrazilAmy Elsner RENEWAL
Wickens N PaprockiGermanyStephen Shaw NEGOTIATION
Francesco H AlbaresCanadaXuxue Feng PROPOSAL
Darci K PoquetteFranceAnna Fali QUALIFIED
James U MaletBrazilAmy Elsner UNQUALIFIED
Aditya N ButtCanadaAnna Fali NEW
Horizontal
NameCountryRepresentativeStatus
Stacey Z MorascaRussiaElwin Sharvill PROPOSAL
Costa X MaletRussiaAmy Elsner NEW
Ivar B GillianJapanAsiya Javayant PROPOSAL
Sinclair E KuskoIndiaAnna Fali RENEWAL
Salvatore B RimBrazilXuxue Feng NEW
Leon F FlosiIndiaOnyama Limba PROPOSAL
Clifford U BologniaCanadaXuxue Feng QUALIFIED
Maria R GarufiJapanBernardo Dominic QUALIFIED
Jefferson K StensethUnited KingdomAmy Elsner PROPOSAL
Wickens V IturbideFranceXuxue Feng QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Murillo R WhobreySpain2024-04-13Truhlar And Truhlar Attys QUALIFIED34Bernardo Dominic
1001Misaki V SergiJapan2024-04-11Morlong Associates NEW96Bernardo Dominic
1002Arvin X GauchoIndia2024-04-05Morlong Associates UNQUALIFIED73Asiya Javayant
1003Kaitlin E ShinkoAustralia2024-04-02Feiner Bros NEW95Amy Elsner
1004Octavia Y RoysterCanada2024-03-31Feiner Bros RENEWAL18Asiya Javayant
1005Deepesh R PaprockiJapan2024-04-01Chemel, James L Cpa NEGOTIATION73Ivan Magalhaes
1006Costa X FerenczArgentina2024-04-15Rangoni Of Florence UNQUALIFIED64Elwin Sharvill
1007Jefferson L BowleyBrazil2024-03-24King, Christopher A Esq UNQUALIFIED25Ioni Bowcher
1008Juan A CaldareraArgentina2024-04-13Buckley Miller Wright NEW63Anna Fali
1009Clifford F ShinkoIndia2024-04-21Chemel, James L Cpa RENEWAL72Elwin Sharvill
1010Ivar X BriddickIndia2024-04-03Chanay, Jeffrey A Esq NEGOTIATION92Xuxue Feng
1011Arvin V DarakjyArgentina2024-04-14Truhlar And Truhlar Attys UNQUALIFIED20Onyama Limba
1012Isabel C DoeFrance2024-03-24Feltz Printing Service QUALIFIED44Onyama Limba
1013Costa W WhobreyCanada2024-03-29Printing Dimensions NEW9Amy Elsner
1014Adams S PaprockiIndia2024-03-29Benton, John B Jr UNQUALIFIED12Ivan Magalhaes
1015Leja A BologniaGermany2024-03-29Rousseaux, Michael Esq UNQUALIFIED85Anna Fali
1016Tony X SergiSpain2024-04-17Feiner Bros NEGOTIATION81Asiya Javayant
1017Emily B GarufiItaly2024-04-11Dorl, James J Esq RENEWAL25Asiya Javayant
1018Munro Z ButtRussia2024-04-17Buckley Miller Wright QUALIFIED27Ivan Magalhaes
1019Rodrigues L OldroydSpain2024-04-11Chemel, James L Cpa NEW74Asiya Javayant
1020Stacey L BriddickJapan2024-04-11Rangoni Of Florence UNQUALIFIED53Asiya Javayant
1021Deepesh R DoeBrazil2024-04-18Rangoni Of Florence NEGOTIATION6Ioni Bowcher
1022Nicolas L AmigonAustralia2024-04-10Buckley Miller Wright RENEWAL11Stephen Shaw
1023Deepesh I DarakjyFrance2024-04-18Chapman, Ross E Esq PROPOSAL16Xuxue Feng
1024Silvio M FollerGermany2024-03-25Morlong Associates UNQUALIFIED97Ivan Magalhaes
1025Maisha Z RimJapan2024-04-12Rangoni Of Florence NEW29Amy Elsner
1026Darci S GillianCanada2024-04-08Rousseaux, Michael Esq NEGOTIATION99Bernardo Dominic
1027Murillo O FlosiCanada2024-04-21Printing Dimensions QUALIFIED54Asiya Javayant
1028Munro O DarakjySpain2024-04-11Rousseaux, Michael Esq NEGOTIATION50Elwin Sharvill
1029Chavez Y KuskoIndia2024-04-08Printing Dimensions NEGOTIATION18Ioni Bowcher
1030Greenwood R PoquetteFrance2024-03-29Dorl, James J Esq QUALIFIED90Elwin Sharvill
1031Deepesh Y ShinkoFrance2024-03-28Feltz Printing Service PROPOSAL44Onyama Limba
1032Leon E GauchoGermany2024-04-20King, Christopher A Esq NEW39Anna Fali
1033Adams B KuskoItaly2024-04-03Feltz Printing Service PROPOSAL76Asiya Javayant
1034Claire A TollnerJapan2024-03-30Chanay, Jeffrey A Esq UNQUALIFIED68Anna Fali
1035Clifford E DoeFrance2024-03-27Buckley Miller Wright NEGOTIATION71Ioni Bowcher
1036Faith E FollerGermany2024-04-14Chanay, Jeffrey A Esq PROPOSAL98Amy Elsner
1037Smith C ShinkoArgentina2024-03-30Dorl, James J Esq UNQUALIFIED95Xuxue Feng
1038Aika I KuskoFrance2024-04-21Rangoni Of Florence QUALIFIED71Anna Fali
1039Julie E AmigonIndia2024-04-06Chapman, Ross E Esq NEW4Stephen Shaw
1040Mayumi G StockhamArgentina2024-03-27Benton, John B Jr UNQUALIFIED10Elwin Sharvill
1041Silvio S MacleadArgentina2024-03-31Printing Dimensions NEGOTIATION89Amy Elsner
1042Smith O OldroydBrazil2024-03-31Feiner Bros PROPOSAL74Elwin Sharvill
1043Salvatore K DilliardItaly2024-04-10Buckley Miller Wright NEW82Elwin Sharvill
1044Faith M OstroskySpain2024-04-06Chemel, James L Cpa NEGOTIATION4Stephen Shaw
1045Jefferson N WhobreyGermany2024-04-01Rangoni Of Florence RENEWAL18Onyama Limba
1046Jones Y NickaArgentina2024-04-06Chapman, Ross E Esq NEGOTIATION32Ivan Magalhaes
1047Munro K BologniaGermany2024-04-10Printing Dimensions NEGOTIATION82Onyama Limba
1048Ricardo R PaprockiFrance2024-04-21King, Christopher A Esq NEGOTIATION12Ioni Bowcher
1049Leja E GlickUnited Kingdom2024-04-04Chapman, Ross E Esq UNQUALIFIED8Asiya Javayant
Frozen Rows
NameCountryRepresentativeStatus
Maria X BowleyCanadaAsiya Javayant QUALIFIED
Adams H GlickGermanyOnyama Limba UNQUALIFIED
Greenwood S MacleadArgentinaAmy Elsner RENEWAL
Salvatore J DoeSpainXuxue Feng NEW
Munro C MorascaSpainOnyama Limba QUALIFIED
Isabel F WhobreyAustraliaElwin Sharvill NEW
Costa I NickaFranceElwin Sharvill NEW
Ivar V CaldareraUnited KingdomOnyama Limba QUALIFIED
Morrow U InouyeItalyAsiya Javayant NEGOTIATION
Alejandro X DoeAustraliaAnna Fali NEW
Silvio C MacleadArgentinaIvan Magalhaes NEGOTIATION
Jones X BriddickJapanIvan Magalhaes NEW
Ricardo R PoquetteFranceAmy Elsner NEGOTIATION
Mayumi U ShinkoIndiaElwin Sharvill PROPOSAL
Jeanfrancois A GarufiItalyOnyama Limba NEW
Stacey D PaprockiBrazilAsiya Javayant NEGOTIATION
Jones F SaylorsJapanAsiya Javayant RENEWAL
Jones M CaldareraRussiaAnna Fali QUALIFIED
Francesco B CampainGermanyAsiya Javayant UNQUALIFIED
Leon D AlbaresRussiaStephen Shaw RENEWAL
Octavia T BriddickJapanAnna Fali NEW
Maisha M VocelkaCanadaElwin Sharvill QUALIFIED
Greenwood W SaylorsItalyAmy Elsner UNQUALIFIED
Emily A RulapaughSpainAsiya Javayant RENEWAL
Ashley L FigeroaCanadaIoni Bowcher QUALIFIED
Kaitlin I MacleadJapanOnyama Limba NEW
Misaki W ChuiBrazilOnyama Limba UNQUALIFIED
Ricardo Q IturbideJapanOnyama Limba NEGOTIATION
Jones E GlickAustraliaAnna Fali NEW
Maria E MaletRussiaBernardo Dominic PROPOSAL
Julie J ButtRussiaIvan Magalhaes UNQUALIFIED
Chavez R VocelkaAustraliaAmy Elsner UNQUALIFIED
Nicolas D MarrierIndiaElwin Sharvill NEW
Alejandro K GillianUnited KingdomIvan Magalhaes NEW
Nicolas Z SlusarskiCanadaIoni Bowcher RENEWAL
Aruna M ButtJapanAmy Elsner QUALIFIED
Rodrigues X MorascaFranceStephen Shaw RENEWAL
Murillo F KuskoBrazilAsiya Javayant RENEWAL
Ivar Y OldroydArgentinaXuxue Feng UNQUALIFIED
Ivar N RimArgentinaAnna Fali PROPOSAL
Ricardo K WaycottFranceAnna Fali NEW
Isabel B FerenczFranceIoni Bowcher QUALIFIED
Greenwood G CampainCanadaStephen Shaw NEGOTIATION
Alejandro L VenereGermanyAmy Elsner QUALIFIED
Mayumi C CaudyJapanIvan Magalhaes RENEWAL
Maisha U RoysterRussiaXuxue Feng NEGOTIATION
Ricardo Z RoysterUnited KingdomOnyama Limba NEW
Salvatore C FlosiJapanAsiya Javayant NEGOTIATION
Silvio F CaudyIndiaBernardo Dominic UNQUALIFIED
Rodrigues E GillianAustraliaIvan Magalhaes NEGOTIATION
Frozen Columns
Name
Ricardo R Stockham
Stacey T Caudy
Ivar M Figeroa
Chavez S Perin
James H Poquette
Jones M Rim
Octavia Q Vocelka
Smith X Oldroyd
Kaitlin H Dilliard
Julie Q Nestle
Cody Q Ferencz
Chavez H Campain
Darci A Schemmer
Misaki H Figeroa
Arvin J Ostrosky
Salvatore I Gillian
Rodrigues X Gillian
Julie G Inouye
Aika G Kusko
James L Gaucho
Adams P Venere
Misaki B Schemmer
David E Kusko
Stacey F Kolmetz
Greenwood D Slusarski
Misaki U Dilliard
Chavez C Briddick
Leja C Vocelka
Leja Y Briddick
Smith A Glick
Smith Q Malet
Jennifer U Sergi
Adams Q Iturbide
Darci W Waycott
Smith M Oldroyd
Darci N Sergi
Cody C Shinko
Aditya E Schemmer
Tony D Rulapaugh
Wickens L Iturbide
Kadeem V Sergi
Ashley P Flosi
Izzy R Wieser
Darci C Stenseth
Misaki I Rim
Silvio X Schemmer
Aditya X Gillian
Juan O Inouye
Jones I Rim
Jeanfrancois D Ruta
IdCountryDate
1000United Kingdom2024-03-27
1001Germany2024-04-01
1002Brazil2024-03-26
1003India2024-04-03
1004Australia2024-03-25
1005Australia2024-03-27
1006Japan2024-04-15
1007Italy2024-04-02
1008Germany2024-03-30
1009Italy2024-03-28
1010Italy2024-04-01
1011India2024-04-11
1012India2024-04-20
1013United Kingdom2024-04-20
1014France2024-04-15
1015India2024-04-11
1016Russia2024-03-26
1017Argentina2024-04-04
1018Australia2024-04-11
1019United Kingdom2024-04-10
1020Argentina2024-04-18
1021Australia2024-03-25
1022India2024-04-11
1023Italy2024-04-02
1024Brazil2024-04-08
1025United Kingdom2024-04-06
1026India2024-04-03
1027Japan2024-04-15
1028India2024-04-22
1029Spain2024-04-08
1030France2024-04-01
1031Argentina2024-04-01
1032France2024-03-30
1033Argentina2024-04-04
1034Japan2024-04-22
1035Spain2024-04-16
1036Australia2024-04-13
1037Spain2024-04-13
1038Canada2024-03-27
1039Russia2024-04-01
1040Brazil2024-04-01
1041Russia2024-04-13
1042Brazil2024-04-14
1043Italy2024-04-09
1044Australia2024-04-05
1045Japan2024-04-01
1046Russia2024-04-16
1047Canada2024-03-29
1048Canada2024-04-21
1049Russia2024-03-26

On-Demand Data

NameIdCountryDate
Nicolas U Saylors1000United Kingdom2024-03-27
Costa M Caudy1001Germany2024-04-19
Kaitlin B Gaucho1002Germany2024-04-02
Jeanfrancois I Shinko1003Australia2024-04-03
Murillo T Waycott1004Russia2024-03-27
Antonio S Schemmer1005Russia2024-04-17
Sinclair D Campain1006Russia2024-04-18
Mujtaba W Bowley1007Italy2024-04-17
Murillo Q Figeroa1008India2024-03-29
Maria P Chui1009India2024-04-14
Juan X Garufi1010Australia2024-04-18
Julie P Wieser1011Japan2024-04-22
Sinclair S Paprocki1012Argentina2024-04-12
Emily G Bolognia1013Spain2024-04-09
Alejandro A Gillian1014United Kingdom2024-04-10
Isabel S Nicka1015Australia2024-04-16
Ricardo C Malet1016India2024-04-02
Arvin O Wieser1017Japan2024-03-27
Darci I Campain1018India2024-04-20
Francesco O Glick1019India2024-04-16
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Alejandro G NickaIndiaAmy Elsner NEGOTIATION
Aruna V TollnerIndiaIoni Bowcher PROPOSAL
Sinclair S GarufiGermanyBernardo Dominic NEW
Murillo Z StockhamUnited KingdomStephen Shaw RENEWAL
Jennifer G BriddickItalyAsiya Javayant QUALIFIED
Wickens N VocelkaItalyOnyama Limba NEGOTIATION
Morrow S PaprockiItalyIoni Bowcher RENEWAL
Sinclair Q BowleyFranceIoni Bowcher QUALIFIED
Emily B CaudyItalyBernardo Dominic QUALIFIED
Jeanfrancois C AlbaresUnited KingdomIoni Bowcher PROPOSAL
Wickens W SergiArgentinaElwin Sharvill QUALIFIED
Jennifer H BologniaBrazilXuxue Feng NEGOTIATION
Nicolas F MacleadItalyAmy Elsner UNQUALIFIED
Maria W InouyeBrazilXuxue Feng UNQUALIFIED
David H ShinkoItalyAnna Fali NEGOTIATION
Mujtaba V ChuiBrazilStephen Shaw NEGOTIATION
Johnson U TollnerJapanIoni Bowcher QUALIFIED
Jeanfrancois I InouyeJapanXuxue Feng RENEWAL
Darci D VocelkaFranceAnna Fali UNQUALIFIED
Ashley Z MaletIndiaXuxue Feng RENEWAL
Juan A MaletFranceIoni Bowcher PROPOSAL
Murillo P WhobreyRussiaStephen Shaw PROPOSAL
Juan Y CampainRussiaAsiya Javayant QUALIFIED
Greenwood T FerenczArgentinaStephen Shaw QUALIFIED
Misaki T VocelkaRussiaElwin Sharvill NEGOTIATION
Mujtaba V DoeCanadaXuxue Feng NEW
Kadeem C MorascaFranceAsiya Javayant NEW
Jeanfrancois V StensethFranceOnyama Limba PROPOSAL
Antonio H FigeroaIndiaOnyama Limba NEW
Ashley R MaletCanadaAsiya Javayant QUALIFIED
Leon W PoquetteUnited KingdomIvan Magalhaes PROPOSAL
Jefferson N FollerSpainIvan Magalhaes NEW
Octavia Q TollnerGermanyOnyama Limba NEGOTIATION
Antonio U BriddickGermanyIvan Magalhaes PROPOSAL
Salvatore S OstroskyBrazilAsiya Javayant QUALIFIED
Kaitlin H VocelkaJapanIoni Bowcher UNQUALIFIED
Rodrigues M MorascaGermanyBernardo Dominic QUALIFIED
Sinclair Q WhobreySpainOnyama Limba NEGOTIATION
Arvin O FollerRussiaIvan Magalhaes NEW
Juan O PerinItalyBernardo Dominic RENEWAL

<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>