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
David O MaletBrazilXuxue Feng NEGOTIATION
Aika P DilliardItalyAsiya Javayant NEW
Ivar M RutaJapanAmy Elsner UNQUALIFIED
Antonio F WaycottItalyAmy Elsner RENEWAL
Leon C VocelkaAustraliaBernardo Dominic QUALIFIED
Mayumi J WieserFranceAmy Elsner NEGOTIATION
Adams S VenereSpainIvan Magalhaes NEGOTIATION
Faith K WaycottRussiaAnna Fali NEGOTIATION
Julie B RutaFranceIvan Magalhaes RENEWAL
Smith W RoysterGermanyOnyama Limba RENEWAL
Aruna U MaletGermanyOnyama Limba PROPOSAL
Kaitlin S SaylorsItalyAnna Fali UNQUALIFIED
Jones S MacleadJapanAnna Fali RENEWAL
Maisha M VenereAustraliaAmy Elsner NEW
Ivar B ChuiIndiaBernardo Dominic NEW
Johnson Z FerenczArgentinaAnna Fali RENEWAL
Izzy J MacleadRussiaIoni Bowcher NEGOTIATION
Adams D NickaUnited KingdomAsiya Javayant QUALIFIED
Mujtaba A InouyeAustraliaIoni Bowcher NEGOTIATION
Ricardo T SaylorsUnited KingdomOnyama Limba UNQUALIFIED
Izzy N RoysterBrazilAsiya Javayant NEGOTIATION
Isabel F DarakjyBrazilOnyama Limba PROPOSAL
Nicolas E NestleAustraliaOnyama Limba UNQUALIFIED
Julie A MaletArgentinaIvan Magalhaes NEGOTIATION
Aruna M GillianCanadaElwin Sharvill RENEWAL
Leon A DarakjyJapanXuxue Feng RENEWAL
Jefferson S SchemmerAustraliaStephen Shaw NEW
Cody S ShinkoFranceIoni Bowcher RENEWAL
Morrow K KuskoBrazilElwin Sharvill QUALIFIED
Morrow P PerinBrazilStephen Shaw UNQUALIFIED
Rodrigues O BriddickArgentinaIoni Bowcher UNQUALIFIED
Arvin Z PerinArgentinaIoni Bowcher UNQUALIFIED
Darci H MaletGermanyAnna Fali QUALIFIED
Arvin M BriddickArgentinaIoni Bowcher QUALIFIED
Faith O SaylorsSpainAmy Elsner UNQUALIFIED
Julie O WaycottItalyIoni Bowcher QUALIFIED
David Y IturbideGermanyIvan Magalhaes PROPOSAL
Cody L NestleFranceAmy Elsner UNQUALIFIED
Leon R CaudyUnited KingdomXuxue Feng QUALIFIED
Jefferson G FerenczRussiaOnyama Limba NEGOTIATION
Mayumi V GillianCanadaOnyama Limba RENEWAL
Faith F FlosiArgentinaOnyama Limba NEGOTIATION
Tony B GlickGermanyStephen Shaw NEW
Munro P GillianSpainAmy Elsner NEW
Kadeem A FlosiGermanyIoni Bowcher NEGOTIATION
Mujtaba K WieserSpainIvan Magalhaes QUALIFIED
Smith M AlbaresSpainIoni Bowcher PROPOSAL
Costa X PerinArgentinaBernardo Dominic RENEWAL
Mayumi I PoquetteGermanyIvan Magalhaes RENEWAL
Misaki B DilliardArgentinaBernardo Dominic NEW
Horizontal
NameCountryRepresentativeStatus
Ivar G RimAustraliaAnna Fali UNQUALIFIED
Jeanfrancois X PerinRussiaAsiya Javayant QUALIFIED
Jennifer W GillianGermanyElwin Sharvill NEGOTIATION
Jennifer E CampainSpainOnyama Limba QUALIFIED
Darci S MarrierRussiaAnna Fali PROPOSAL
Leja D RulapaughIndiaAmy Elsner RENEWAL
Aruna G InouyeJapanXuxue Feng NEW
Stacey O ChuiItalyStephen Shaw QUALIFIED
Jefferson Z KolmetzItalyBernardo Dominic NEW
Morrow A DilliardItalyOnyama Limba RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Isabel P RimAustralia2024-04-13Rangoni Of Florence PROPOSAL97Xuxue Feng
1001Aditya B InouyeArgentina2024-03-28Chemel, James L Cpa UNQUALIFIED44Onyama Limba
1002Smith A NickaArgentina2024-04-17Feltz Printing Service NEW1Xuxue Feng
1003Jefferson V DilliardBrazil2024-03-29Chapman, Ross E Esq PROPOSAL3Stephen Shaw
1004Isabel R BologniaUnited Kingdom2024-04-16Feltz Printing Service NEGOTIATION52Ioni Bowcher
1005Chavez O FollerItaly2024-04-02Benton, John B Jr UNQUALIFIED47Elwin Sharvill
1006Smith V BologniaArgentina2024-04-11Rousseaux, Michael Esq NEGOTIATION73Ioni Bowcher
1007David U GlickGermany2024-04-15King, Christopher A Esq RENEWAL92Bernardo Dominic
1008Aika Q RoysterAustralia2024-04-02Rangoni Of Florence UNQUALIFIED58Ioni Bowcher
1009Maisha S AmigonIndia2024-04-04Printing Dimensions NEGOTIATION24Xuxue Feng
1010Ricardo L IturbideItaly2024-03-27Chanay, Jeffrey A Esq NEW63Ivan Magalhaes
1011Ashley R TollnerJapan2024-03-27Rousseaux, Michael Esq PROPOSAL47Onyama Limba
1012Jeanfrancois Y StensethJapan2024-04-21Feiner Bros NEGOTIATION94Ioni Bowcher
1013Wickens W BriddickFrance2024-04-04Buckley Miller Wright RENEWAL57Bernardo Dominic
1014Ivar E CaudyAustralia2024-04-09Chapman, Ross E Esq NEGOTIATION35Stephen Shaw
1015Murillo W DilliardBrazil2024-04-09Rangoni Of Florence RENEWAL43Bernardo Dominic
1016Leon L StockhamCanada2024-03-30Truhlar And Truhlar Attys QUALIFIED97Onyama Limba
1017Juan E PaprockiJapan2024-04-14Morlong Associates NEGOTIATION76Onyama Limba
1018Maria Y BriddickFrance2024-04-10Rangoni Of Florence PROPOSAL67Ioni Bowcher
1019Julie O ShinkoFrance2024-03-25Morlong Associates NEGOTIATION11Bernardo Dominic
1020Aika J KolmetzBrazil2024-04-05Chapman, Ross E Esq RENEWAL38Ioni Bowcher
1021Alejandro V CampainCanada2024-04-03Feiner Bros NEGOTIATION59Amy Elsner
1022Tony Q BowleyIndia2024-04-22Morlong Associates QUALIFIED16Stephen Shaw
1023Sinclair C PoquetteIndia2024-03-30Chanay, Jeffrey A Esq RENEWAL75Xuxue Feng
1024Claire U TollnerIndia2024-04-17Chanay, Jeffrey A Esq QUALIFIED54Onyama Limba
1025Ashley A RutaBrazil2024-04-17Feiner Bros UNQUALIFIED74Amy Elsner
1026Rodrigues G MaletIndia2024-03-26Buckley Miller Wright NEGOTIATION15Xuxue Feng
1027Maisha G SergiIndia2024-04-19Rangoni Of Florence RENEWAL51Anna Fali
1028Ashley I WaycottCanada2024-04-22Benton, John B Jr UNQUALIFIED75Bernardo Dominic
1029Cody L FerenczRussia2024-04-15Commercial Press NEW28Amy Elsner
1030Wickens L RimSpain2024-04-07Feltz Printing Service RENEWAL27Elwin Sharvill
1031Mayumi G RimJapan2024-03-31Chemel, James L Cpa PROPOSAL36Stephen Shaw
1032Octavia C ShinkoSpain2024-03-31Rangoni Of Florence NEW66Asiya Javayant
1033Jefferson G CampainIndia2024-04-08Chanay, Jeffrey A Esq QUALIFIED90Elwin Sharvill
1034Alejandro R SergiCanada2024-04-08King, Christopher A Esq UNQUALIFIED15Elwin Sharvill
1035Octavia L ChuiJapan2024-04-12Rangoni Of Florence RENEWAL42Ivan Magalhaes
1036Costa Z AlbaresAustralia2024-04-12Morlong Associates NEGOTIATION88Stephen Shaw
1037Murillo Y RutaAustralia2024-04-11Feltz Printing Service QUALIFIED62Bernardo Dominic
1038Stacey M ShinkoAustralia2024-03-27Benton, John B Jr UNQUALIFIED2Anna Fali
1039Mujtaba O WieserIndia2024-04-05Printing Dimensions NEW65Bernardo Dominic
1040Silvio Z FerenczAustralia2024-04-16Dorl, James J Esq NEW57Ioni Bowcher
1041Darci A RulapaughRussia2024-03-29King, Christopher A Esq PROPOSAL2Onyama Limba
1042Deepesh Q OldroydRussia2024-04-12Feltz Printing Service UNQUALIFIED41Elwin Sharvill
1043Emily H BriddickBrazil2024-04-21Chanay, Jeffrey A Esq NEGOTIATION67Amy Elsner
1044Silvio G DarakjyItaly2024-03-29Feltz Printing Service UNQUALIFIED43Elwin Sharvill
1045Ivar K WaycottIndia2024-04-18Truhlar And Truhlar Attys RENEWAL63Amy Elsner
1046Salvatore S DilliardArgentina2024-04-02Benton, John B Jr UNQUALIFIED3Ioni Bowcher
1047Jennifer U SchemmerRussia2024-04-17Feiner Bros RENEWAL48Xuxue Feng
1048Cody F RoysterSpain2024-03-30King, Christopher A Esq UNQUALIFIED81Bernardo Dominic
1049Greenwood U FerenczSpain2024-04-02Dorl, James J Esq UNQUALIFIED53Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Tony T DarakjyGermanyAsiya Javayant NEW
Juan J InouyeFranceAmy Elsner NEW
Isabel B DoeItalyAmy Elsner PROPOSAL
Greenwood E KuskoJapanIvan Magalhaes QUALIFIED
Chavez S WaycottRussiaIoni Bowcher NEW
Maria C WaycottUnited KingdomIoni Bowcher NEGOTIATION
Jennifer Y DarakjyUnited KingdomAnna Fali QUALIFIED
Adams Y BowleySpainElwin Sharvill NEW
Jones M DoeJapanStephen Shaw NEW
Tony M VocelkaArgentinaOnyama Limba PROPOSAL
Ricardo X GillianIndiaOnyama Limba QUALIFIED
Izzy N InouyeItalyAmy Elsner QUALIFIED
Jennifer H RimArgentinaXuxue Feng QUALIFIED
Claire O GlickUnited KingdomIvan Magalhaes PROPOSAL
Izzy L AlbaresIndiaIvan Magalhaes PROPOSAL
Smith V BologniaRussiaAsiya Javayant NEGOTIATION
Maisha Q SaylorsJapanAmy Elsner UNQUALIFIED
Johnson X AlbaresFranceIvan Magalhaes RENEWAL
Salvatore N ShinkoArgentinaAnna Fali QUALIFIED
Nicolas U InouyeRussiaXuxue Feng PROPOSAL
Claire G PaprockiArgentinaXuxue Feng PROPOSAL
Nicolas Y BriddickCanadaBernardo Dominic UNQUALIFIED
David J WieserArgentinaAsiya Javayant RENEWAL
Leon Z FollerRussiaIoni Bowcher PROPOSAL
Tony Z PaprockiBrazilAmy Elsner UNQUALIFIED
Antonio S ShinkoBrazilBernardo Dominic UNQUALIFIED
Juan A AmigonSpainAsiya Javayant PROPOSAL
Claire Y KolmetzIndiaIvan Magalhaes UNQUALIFIED
Tony S MaletGermanyElwin Sharvill QUALIFIED
Munro Z VocelkaFranceStephen Shaw PROPOSAL
Sinclair S RulapaughArgentinaIvan Magalhaes RENEWAL
Costa I SaylorsFranceStephen Shaw UNQUALIFIED
Arvin N MarrierCanadaAsiya Javayant QUALIFIED
Leon W CaudyCanadaIvan Magalhaes RENEWAL
Ivar V MarrierArgentinaStephen Shaw UNQUALIFIED
Ivar J OldroydGermanyBernardo Dominic NEGOTIATION
Morrow U SchemmerCanadaAsiya Javayant NEW
Tony H MorascaIndiaXuxue Feng RENEWAL
Aditya R VenereCanadaOnyama Limba QUALIFIED
Deepesh O DilliardGermanyAnna Fali PROPOSAL
Mujtaba D KolmetzSpainIvan Magalhaes NEGOTIATION
Rodrigues C StensethSpainIoni Bowcher NEW
Tony P StockhamItalyBernardo Dominic NEGOTIATION
Jennifer A SergiCanadaIvan Magalhaes NEW
Leon N MacleadFranceBernardo Dominic NEW
Aruna Z ChuiIndiaElwin Sharvill QUALIFIED
Alejandro Y CaldareraJapanOnyama Limba QUALIFIED
Costa T SergiAustraliaXuxue Feng NEW
Mujtaba V PerinUnited KingdomIoni Bowcher PROPOSAL
Juan K NestleRussiaAnna Fali RENEWAL
Frozen Columns
Name
Francesco K Dilliard
Alejandro K Waycott
Nicolas W Perin
Leon H Sergi
Ricardo J Nestle
Murillo U Darakjy
Octavia M Poquette
Jeanfrancois I Kusko
Emily F Ostrosky
Octavia T Marrier
David H Maclead
Costa Q Kusko
Stacey M Sergi
Jefferson T Schemmer
Ricardo W Caldarera
Adams J Bowley
Octavia I Caldarera
Maria V Gillian
David V Foller
Munro J Campain
Isabel L Saylors
Deepesh Y Iturbide
Nicolas N Gillian
Jeanfrancois W Chui
Julie D Albares
Silvio Y Maclead
Johnson J Ruta
Darci B Caudy
Johnson H Nicka
Francesco C Chui
Kadeem H Glick
Octavia V Gaucho
Francesco P Glick
Greenwood R Ferencz
Morrow N Tollner
Kadeem J Inouye
Faith M Ostrosky
Tony A Shinko
Alejandro U Gillian
Mayumi M Kusko
Salvatore Q Campain
Faith C Malet
Antonio B Briddick
Ashley U Doe
Julie V Inouye
Johnson D Chui
Aruna F Gaucho
Jeanfrancois C Morasca
James F Marrier
Ivar C Doe
IdCountryDate
1000Brazil2024-04-20
1001Italy2024-03-25
1002United Kingdom2024-03-24
1003Japan2024-03-26
1004Australia2024-03-28
1005Canada2024-04-14
1006Japan2024-04-05
1007Germany2024-04-04
1008Russia2024-04-07
1009Russia2024-04-11
1010Argentina2024-04-04
1011Russia2024-04-02
1012Japan2024-03-30
1013Italy2024-04-22
1014Spain2024-04-19
1015Italy2024-04-17
1016Canada2024-03-31
1017Argentina2024-03-30
1018France2024-04-14
1019India2024-04-06
1020Brazil2024-04-09
1021Japan2024-04-16
1022Russia2024-04-04
1023United Kingdom2024-04-21
1024Canada2024-03-27
1025Australia2024-04-08
1026Germany2024-04-07
1027Japan2024-04-09
1028United Kingdom2024-04-02
1029Brazil2024-04-08
1030Russia2024-04-21
1031Japan2024-04-12
1032Australia2024-04-13
1033Italy2024-04-03
1034France2024-04-09
1035Canada2024-04-21
1036India2024-04-04
1037Australia2024-04-14
1038Germany2024-03-26
1039United Kingdom2024-04-12
1040Canada2024-04-03
1041Australia2024-04-19
1042Italy2024-04-01
1043Spain2024-04-05
1044Argentina2024-04-09
1045Argentina2024-04-04
1046Spain2024-03-25
1047Russia2024-03-31
1048Japan2024-04-19
1049Spain2024-03-24

On-Demand Data

NameIdCountryDate
Leja T Wieser1000France2024-04-03
Costa Y Glick1001Japan2024-03-31
Johnson D Caldarera1002Germany2024-04-03
Mayumi R Ostrosky1003Australia2024-04-07
Ivar D Waycott1004Russia2024-03-28
Rodrigues O Maclead1005Russia2024-04-17
Chavez L Marrier1006Brazil2024-04-03
Leja B Maclead1007United Kingdom2024-03-30
Mayumi G Maclead1008France2024-03-25
Ivar W Venere1009Japan2024-04-15
Silvio A Poquette1010Argentina2024-04-16
Silvio F Foller1011Argentina2024-04-14
Cody E Nicka1012Brazil2024-03-29
Cody F Kusko1013Australia2024-03-24
Nicolas F Foller1014France2024-04-18
Salvatore O Flosi1015Canada2024-04-07
Tony D Albares1016Brazil2024-03-24
Alejandro J Saylors1017India2024-04-21
Deepesh F Nestle1018Brazil2024-03-30
Sinclair T Ferencz1019Japan2024-03-31
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Sinclair N SergiIndiaElwin Sharvill QUALIFIED
Jennifer J VenereUnited KingdomIoni Bowcher NEGOTIATION
Rodrigues X StockhamFranceAmy Elsner QUALIFIED
Jennifer D CaldareraAustraliaElwin Sharvill NEW
Jeanfrancois C ChuiItalyBernardo Dominic PROPOSAL
Isabel Z FollerGermanyOnyama Limba UNQUALIFIED
Francesco Y MarrierGermanyIoni Bowcher UNQUALIFIED
Francesco M GarufiAustraliaOnyama Limba NEW
Ricardo N DarakjyJapanAsiya Javayant NEW
Cody K FigeroaJapanBernardo Dominic QUALIFIED
Silvio I RulapaughRussiaAsiya Javayant RENEWAL
Clifford N VenereUnited KingdomAsiya Javayant NEGOTIATION
Salvatore K VocelkaSpainBernardo Dominic QUALIFIED
Sinclair W RulapaughGermanyOnyama Limba NEGOTIATION
Murillo V InouyeRussiaBernardo Dominic QUALIFIED
Smith K DoeUnited KingdomXuxue Feng PROPOSAL
Rodrigues I AlbaresAustraliaOnyama Limba UNQUALIFIED
Costa U SchemmerSpainElwin Sharvill PROPOSAL
Wickens H SchemmerSpainAmy Elsner NEW
Stacey H RutaRussiaBernardo Dominic QUALIFIED
Isabel B StensethArgentinaElwin Sharvill NEGOTIATION
David P CaudyItalyAsiya Javayant RENEWAL
Julie E VenereJapanAsiya Javayant RENEWAL
Jones N InouyeItalyBernardo Dominic QUALIFIED
Jeanfrancois E DoeFranceXuxue Feng NEW
Silvio M OldroydFranceStephen Shaw PROPOSAL
Adams X FerenczCanadaBernardo Dominic RENEWAL
Chavez X PoquetteRussiaIoni Bowcher PROPOSAL
Silvio C FlosiGermanyAsiya Javayant PROPOSAL
Maisha P RulapaughRussiaElwin Sharvill UNQUALIFIED
Aika A InouyeGermanyIoni Bowcher PROPOSAL
Morrow A RoysterSpainAnna Fali PROPOSAL
Alejandro H ShinkoJapanBernardo Dominic RENEWAL
Chavez Y NestleGermanyXuxue Feng QUALIFIED
Mayumi Y RimRussiaAmy Elsner QUALIFIED
Sinclair A StockhamSpainBernardo Dominic NEGOTIATION
Sinclair I CaudyRussiaElwin Sharvill NEW
Johnson A BriddickRussiaIvan Magalhaes NEW
Rodrigues T MaletJapanBernardo Dominic QUALIFIED
Jeanfrancois U DarakjyUnited KingdomXuxue Feng 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>