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
Ivar R StockhamJapanAnna Fali RENEWAL
Maisha Z CaudyJapanAmy Elsner NEW
Aika A MarrierUnited KingdomAnna Fali NEGOTIATION
Ivar F FerenczItalyAnna Fali QUALIFIED
David A CaldareraIndiaAsiya Javayant NEGOTIATION
Greenwood P AlbaresBrazilAmy Elsner QUALIFIED
Kadeem Y DilliardUnited KingdomStephen Shaw UNQUALIFIED
Jeanfrancois O PerinUnited KingdomAmy Elsner UNQUALIFIED
Ivar Z GlickIndiaIvan Magalhaes PROPOSAL
Chavez T ButtSpainXuxue Feng QUALIFIED
Rodrigues Q RutaCanadaIvan Magalhaes RENEWAL
Ivar A SchemmerFranceAmy Elsner QUALIFIED
Isabel U RulapaughFranceStephen Shaw PROPOSAL
Jennifer Z NickaGermanyIvan Magalhaes NEW
Leon Z OstroskyRussiaStephen Shaw UNQUALIFIED
Jefferson Z DarakjySpainBernardo Dominic PROPOSAL
Nicolas J MaletSpainIoni Bowcher RENEWAL
Nicolas Q AmigonIndiaElwin Sharvill PROPOSAL
Ashley X StensethGermanyElwin Sharvill PROPOSAL
Jones W DoeArgentinaAsiya Javayant QUALIFIED
Munro S PerinFranceXuxue Feng NEGOTIATION
Maria U DarakjyArgentinaIvan Magalhaes RENEWAL
Stacey N WhobreyGermanyXuxue Feng PROPOSAL
Juan S KuskoSpainOnyama Limba PROPOSAL
Nicolas V FigeroaItalyAsiya Javayant NEW
Cody B GauchoSpainStephen Shaw UNQUALIFIED
Leja X PoquetteRussiaAsiya Javayant UNQUALIFIED
Greenwood D PaprockiArgentinaXuxue Feng QUALIFIED
Silvio S SchemmerItalyElwin Sharvill RENEWAL
Aika Z SaylorsFranceElwin Sharvill NEGOTIATION
Jefferson F WieserIndiaAnna Fali RENEWAL
James Z CaldareraIndiaElwin Sharvill RENEWAL
Mujtaba F FerenczFranceIoni Bowcher NEW
Aika R DarakjyBrazilStephen Shaw QUALIFIED
Faith I BriddickBrazilOnyama Limba UNQUALIFIED
Chavez N GauchoIndiaAmy Elsner UNQUALIFIED
James I TollnerIndiaAmy Elsner RENEWAL
Faith P IturbideGermanyIoni Bowcher QUALIFIED
Octavia U CampainSpainIoni Bowcher QUALIFIED
Stacey U FollerGermanyElwin Sharvill RENEWAL
Smith C InouyeItalyAmy Elsner NEW
Faith L TollnerJapanXuxue Feng NEW
Smith W CampainAustraliaOnyama Limba RENEWAL
Murillo P RutaSpainOnyama Limba NEGOTIATION
Kadeem N TollnerBrazilAnna Fali NEGOTIATION
Mayumi H RulapaughAustraliaBernardo Dominic QUALIFIED
Antonio M OstroskySpainAmy Elsner PROPOSAL
Johnson H BowleyItalyXuxue Feng UNQUALIFIED
Johnson Y ShinkoFranceIoni Bowcher NEGOTIATION
Murillo V RoysterRussiaAnna Fali UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Jeanfrancois B RulapaughUnited KingdomAmy Elsner NEGOTIATION
Claire A SaylorsArgentinaBernardo Dominic NEW
Nicolas V KuskoRussiaIvan Magalhaes PROPOSAL
Leon W WhobreyAustraliaAnna Fali NEGOTIATION
Jones D VocelkaGermanyXuxue Feng UNQUALIFIED
Arvin Q MorascaSpainOnyama Limba QUALIFIED
Adams S PoquetteUnited KingdomAsiya Javayant PROPOSAL
Jeanfrancois O WaycottIndiaAnna Fali QUALIFIED
Munro G MaletItalyAsiya Javayant RENEWAL
Tony K GauchoBrazilAsiya Javayant NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Ashley R RulapaughIndia2024-04-20Chapman, Ross E Esq PROPOSAL95Xuxue Feng
1001Ashley B CampainArgentina2024-04-24Buckley Miller Wright PROPOSAL40Ivan Magalhaes
1002Leon H SergiIndia2024-04-04King, Christopher A Esq QUALIFIED32Ivan Magalhaes
1003Silvio K NestleItaly2024-04-10Rousseaux, Michael Esq RENEWAL56Elwin Sharvill
1004Antonio U CaldareraBrazil2024-04-10Chemel, James L Cpa NEW2Elwin Sharvill
1005Izzy O RoysterRussia2024-04-10Dorl, James J Esq NEW1Elwin Sharvill
1006Ivar H AmigonGermany2024-04-21Printing Dimensions RENEWAL36Asiya Javayant
1007Leon M FollerUnited Kingdom2024-04-13Chemel, James L Cpa NEGOTIATION89Ioni Bowcher
1008Wickens A FlosiArgentina2024-04-11Dorl, James J Esq NEW45Onyama Limba
1009Ricardo A FigeroaGermany2024-04-10Feiner Bros RENEWAL21Onyama Limba
1010Johnson X StensethCanada2024-04-22Chemel, James L Cpa QUALIFIED54Xuxue Feng
1011Clifford M StensethBrazil2024-04-18Feiner Bros NEGOTIATION86Stephen Shaw
1012Nicolas O DarakjyGermany2024-04-15Printing Dimensions PROPOSAL61Amy Elsner
1013Darci D MarrierJapan2024-04-04Truhlar And Truhlar Attys NEW76Ivan Magalhaes
1014Francesco H DoeRussia2024-04-19Chanay, Jeffrey A Esq NEGOTIATION21Asiya Javayant
1015Kaitlin Y SergiArgentina2024-03-30Dorl, James J Esq QUALIFIED42Ioni Bowcher
1016Darci S StensethIndia2024-04-22Truhlar And Truhlar Attys NEGOTIATION82Xuxue Feng
1017Ricardo R PaprockiArgentina2024-04-21Buckley Miller Wright QUALIFIED85Asiya Javayant
1018Julie R VocelkaItaly2024-04-18Rangoni Of Florence NEW51Asiya Javayant
1019Ashley K GarufiRussia2024-04-28Printing Dimensions RENEWAL41Asiya Javayant
1020Morrow J GillianGermany2024-04-20Printing Dimensions QUALIFIED62Bernardo Dominic
1021Alejandro Q MaletCanada2024-04-22Dorl, James J Esq RENEWAL15Asiya Javayant
1022Ricardo K SergiJapan2024-04-04King, Christopher A Esq RENEWAL35Onyama Limba
1023Murillo B SlusarskiItaly2024-04-12Feiner Bros UNQUALIFIED89Amy Elsner
1024Adams S PoquetteFrance2024-04-02Commercial Press RENEWAL38Asiya Javayant
1025Ricardo B AlbaresCanada2024-04-15King, Christopher A Esq RENEWAL93Onyama Limba
1026James Y WieserJapan2024-04-10Truhlar And Truhlar Attys QUALIFIED52Onyama Limba
1027Morrow I PoquetteSpain2024-04-01Feiner Bros PROPOSAL55Ioni Bowcher
1028Cody G PoquetteIndia2024-04-03Benton, John B Jr NEGOTIATION7Anna Fali
1029Darci H IturbideCanada2024-04-04Chemel, James L Cpa PROPOSAL88Xuxue Feng
1030Isabel N WaycottJapan2024-04-07Rangoni Of Florence UNQUALIFIED31Stephen Shaw
1031Salvatore D StockhamRussia2024-04-19Feiner Bros PROPOSAL58Anna Fali
1032Francesco Z SchemmerRussia2024-04-15Morlong Associates PROPOSAL78Ivan Magalhaes
1033Darci O RutaItaly2024-04-14Morlong Associates NEW26Stephen Shaw
1034Adams C CampainSpain2024-04-19Benton, John B Jr NEGOTIATION73Ivan Magalhaes
1035Misaki R SaylorsUnited Kingdom2024-04-22Buckley Miller Wright NEW72Anna Fali
1036Salvatore Z ButtCanada2024-04-26Rousseaux, Michael Esq NEGOTIATION70Ioni Bowcher
1037Antonio R ChuiSpain2024-04-10Feltz Printing Service NEGOTIATION16Elwin Sharvill
1038Claire A VocelkaCanada2024-04-28Feltz Printing Service UNQUALIFIED7Xuxue Feng
1039Munro R OldroydSpain2024-04-02Benton, John B Jr NEW59Ioni Bowcher
1040Misaki B SergiRussia2024-03-30Chapman, Ross E Esq UNQUALIFIED18Anna Fali
1041Nicolas O CaudyIndia2024-04-04Feiner Bros NEW92Amy Elsner
1042Clifford A AlbaresFrance2024-04-03Chemel, James L Cpa UNQUALIFIED71Ivan Magalhaes
1043Maria L IturbideUnited Kingdom2024-04-06Rangoni Of Florence UNQUALIFIED23Ivan Magalhaes
1044Smith I AlbaresUnited Kingdom2024-04-04Commercial Press NEGOTIATION24Stephen Shaw
1045Rodrigues F CaudyBrazil2024-04-20Chanay, Jeffrey A Esq RENEWAL4Amy Elsner
1046Ivar M OstroskyFrance2024-04-08King, Christopher A Esq NEGOTIATION40Stephen Shaw
1047Clifford U RimIndia2024-04-19Printing Dimensions NEGOTIATION92Amy Elsner
1048Morrow X RimBrazil2024-03-30Feltz Printing Service PROPOSAL28Ivan Magalhaes
1049Munro P CaudyArgentina2024-04-10Rangoni Of Florence NEW47Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Nicolas S RulapaughJapanStephen Shaw NEW
Aditya A WhobreyFranceElwin Sharvill QUALIFIED
Stacey D BologniaCanadaAmy Elsner NEGOTIATION
Ivar D CaudyGermanyStephen Shaw QUALIFIED
Aditya O FollerCanadaXuxue Feng QUALIFIED
Greenwood I NestleUnited KingdomIvan Magalhaes RENEWAL
Stacey X GauchoCanadaOnyama Limba RENEWAL
Morrow M CaudySpainElwin Sharvill NEW
Julie B WhobreyItalyAnna Fali NEW
Nicolas Q MarrierArgentinaAsiya Javayant QUALIFIED
Aika V VocelkaIndiaOnyama Limba PROPOSAL
Jeanfrancois S WieserJapanAmy Elsner NEGOTIATION
Isabel I DoeItalyAsiya Javayant RENEWAL
Ashley V WhobreyCanadaIoni Bowcher NEGOTIATION
Francesco F KolmetzUnited KingdomBernardo Dominic QUALIFIED
Isabel V BriddickFranceOnyama Limba UNQUALIFIED
Sinclair E MarrierCanadaElwin Sharvill NEW
Maria M StockhamAustraliaAmy Elsner NEGOTIATION
Chavez E MarrierAustraliaAsiya Javayant PROPOSAL
Rodrigues J NestleRussiaStephen Shaw UNQUALIFIED
Octavia L ButtRussiaBernardo Dominic NEW
Isabel M FollerItalyAsiya Javayant RENEWAL
Johnson E RulapaughGermanyAmy Elsner UNQUALIFIED
Misaki N TollnerJapanIvan Magalhaes UNQUALIFIED
Greenwood U GarufiJapanAnna Fali PROPOSAL
Kaitlin R RimJapanIvan Magalhaes QUALIFIED
Alejandro P FlosiRussiaBernardo Dominic RENEWAL
Chavez A CampainGermanyAnna Fali QUALIFIED
Rodrigues M KuskoRussiaIoni Bowcher NEW
Kadeem W MaletGermanyIoni Bowcher PROPOSAL
Cody Y FerenczSpainIoni Bowcher NEW
Clifford E GlickSpainStephen Shaw PROPOSAL
Alejandro L BriddickCanadaIoni Bowcher UNQUALIFIED
Jeanfrancois U SaylorsUnited KingdomStephen Shaw NEGOTIATION
Octavia P BriddickGermanyAmy Elsner NEW
Deepesh S SergiItalyOnyama Limba UNQUALIFIED
Ricardo M CampainItalyElwin Sharvill PROPOSAL
Johnson O MacleadBrazilAmy Elsner UNQUALIFIED
Smith K GlickArgentinaAsiya Javayant UNQUALIFIED
Maria O KuskoFranceAnna Fali RENEWAL
Izzy L CampainJapanStephen Shaw QUALIFIED
Jefferson E GauchoIndiaAnna Fali PROPOSAL
Ashley V ChuiIndiaIoni Bowcher UNQUALIFIED
Aika Z DoeAustraliaElwin Sharvill NEW
Ashley K StockhamItalyXuxue Feng NEW
Octavia W FollerIndiaIvan Magalhaes UNQUALIFIED
Jefferson F WhobreyJapanAmy Elsner UNQUALIFIED
Mujtaba T WaycottGermanyStephen Shaw NEW
James T TollnerRussiaAmy Elsner PROPOSAL
Arvin K SchemmerUnited KingdomStephen Shaw NEW
Frozen Columns
Name
Kadeem H Gillian
Silvio T Sergi
Greenwood Q Poquette
Kaitlin A Amigon
Nicolas P Saylors
Francesco P Nicka
Rodrigues J Briddick
Maria F Schemmer
Francesco B Perin
Aika H Poquette
Deepesh M Darakjy
Cody C Paprocki
Jeanfrancois H Saylors
Kaitlin H Doe
Aditya U Gillian
Costa D Kusko
Francesco J Ferencz
Chavez F Iturbide
Chavez U Caudy
Ivar F Amigon
Sinclair Z Ferencz
Antonio C Morasca
Clifford Q Garufi
Salvatore H Glick
Clifford R Bowley
Deepesh G Gillian
Costa R Ruta
Smith B Whobrey
Misaki L Ostrosky
Jefferson O Poquette
Ricardo D Rulapaugh
Misaki E Figeroa
Arvin Q Tollner
Sinclair S Rim
Chavez O Nicka
Kadeem D Malet
Nicolas G Garufi
Aruna L Tollner
Julie K Waycott
Smith O Stockham
Misaki O Ferencz
Chavez D Perin
Clifford X Marrier
Silvio K Nestle
Rodrigues D Butt
Costa R Shinko
Misaki H Doe
Juan Y Slusarski
Claire E Figeroa
Juan S Slusarski
IdCountryDate
1000Spain2024-04-16
1001Australia2024-04-23
1002Spain2024-04-25
1003India2024-04-10
1004Canada2024-04-18
1005France2024-04-19
1006Italy2024-04-13
1007United Kingdom2024-04-12
1008Australia2024-04-20
1009France2024-04-26
1010Germany2024-04-16
1011Argentina2024-04-12
1012Canada2024-04-02
1013Germany2024-03-30
1014Canada2024-04-21
1015Japan2024-04-16
1016Italy2024-04-04
1017Brazil2024-04-01
1018Russia2024-04-26
1019Argentina2024-04-14
1020Brazil2024-04-09
1021France2024-04-21
1022France2024-04-26
1023Spain2024-04-14
1024Spain2024-04-18
1025Russia2024-04-23
1026Canada2024-04-15
1027Brazil2024-04-07
1028Canada2024-04-06
1029Spain2024-04-22
1030Argentina2024-04-05
1031Italy2024-04-15
1032Japan2024-04-18
1033Italy2024-04-16
1034Russia2024-04-23
1035Italy2024-04-18
1036Australia2024-04-14
1037India2024-04-20
1038Australia2024-04-28
1039Russia2024-04-06
1040Australia2024-04-11
1041Argentina2024-04-15
1042Australia2024-04-08
1043France2024-04-19
1044Canada2024-04-03
1045France2024-04-24
1046Italy2024-04-22
1047Argentina2024-03-30
1048Brazil2024-04-18
1049Spain2024-04-04

On-Demand Data

NameIdCountryDate
Leon N Glick1000Russia2024-04-17
Juan R Gillian1001Russia2024-04-23
Mayumi D Slusarski1002Germany2024-04-13
Kadeem J Glick1003Canada2024-04-23
Julie L Poquette1004India2024-04-11
David E Caudy1005Germany2024-04-04
David I Bolognia1006United Kingdom2024-04-07
Costa D Glick1007Germany2024-04-25
Juan G Kusko1008Argentina2024-04-06
Misaki L Stenseth1009Argentina2024-04-28
Juan X Schemmer1010Italy2024-04-17
Adams A Gillian1011Canada2024-04-07
Ivar J Darakjy1012India2024-04-27
Misaki H Gillian1013Russia2024-04-02
Kadeem K Bowley1014Canada2024-04-26
Silvio J Garufi1015Germany2024-04-08
Mayumi D Vocelka1016Australia2024-04-22
Antonio F Stockham1017Russia2024-04-02
Tony K Gaucho1018Germany2024-04-12
David I Amigon1019Australia2024-03-31
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Maria C PerinArgentinaAmy Elsner RENEWAL
Misaki A InouyeGermanyXuxue Feng QUALIFIED
Emily L RimRussiaAnna Fali RENEWAL
Costa Z SergiJapanXuxue Feng NEW
Mayumi Z ChuiBrazilXuxue Feng PROPOSAL
Aditya K WaycottBrazilBernardo Dominic NEW
Smith Z OstroskyFranceElwin Sharvill NEW
Mayumi H FigeroaFranceAsiya Javayant NEGOTIATION
Stacey M PaprockiBrazilIvan Magalhaes NEGOTIATION
Murillo M FigeroaRussiaXuxue Feng RENEWAL
Cody S CaldareraJapanElwin Sharvill UNQUALIFIED
Jones E InouyeItalyOnyama Limba QUALIFIED
Jennifer M MorascaFranceAmy Elsner UNQUALIFIED
Leon U RimBrazilAmy Elsner NEW
Octavia N MorascaAustraliaAsiya Javayant QUALIFIED
Munro E FollerBrazilAnna Fali UNQUALIFIED
Tony Y IturbideItalyAmy Elsner UNQUALIFIED
Morrow G MarrierArgentinaElwin Sharvill RENEWAL
Adams Y ShinkoBrazilIoni Bowcher PROPOSAL
Morrow E MorascaArgentinaBernardo Dominic QUALIFIED
Izzy U PaprockiRussiaXuxue Feng NEGOTIATION
Antonio H MaletRussiaElwin Sharvill NEW
Kadeem W SlusarskiGermanyBernardo Dominic NEGOTIATION
Aruna A NestleRussiaOnyama Limba QUALIFIED
Morrow F WieserSpainAmy Elsner NEW
Kaitlin Q CaldareraIndiaOnyama Limba PROPOSAL
Wickens Y PaprockiUnited KingdomElwin Sharvill UNQUALIFIED
Maria F DarakjyUnited KingdomAsiya Javayant NEW
Morrow Q NestleJapanIoni Bowcher RENEWAL
Francesco A OstroskySpainAnna Fali UNQUALIFIED
Rodrigues R WieserAustraliaElwin Sharvill NEGOTIATION
Deepesh B KuskoSpainIoni Bowcher NEW
Faith K VenereArgentinaElwin Sharvill UNQUALIFIED
Stacey D ChuiFranceAnna Fali QUALIFIED
Adams L BriddickAustraliaElwin Sharvill NEGOTIATION
Munro M CampainIndiaElwin Sharvill PROPOSAL
Jefferson W MaletSpainStephen Shaw NEW
Rodrigues Z BologniaRussiaBernardo Dominic NEGOTIATION
Deepesh P MacleadItalyIoni Bowcher NEW
Cody L FollerGermanyIvan 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>