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
Maria P AmigonSpainAsiya Javayant NEGOTIATION
Kaitlin G AlbaresBrazilStephen Shaw RENEWAL
James O MorascaCanadaStephen Shaw QUALIFIED
Chavez M SaylorsArgentinaAmy Elsner PROPOSAL
Misaki I InouyeUnited KingdomBernardo Dominic NEGOTIATION
Aditya G NestleIndiaIoni Bowcher PROPOSAL
Greenwood Q MarrierGermanyBernardo Dominic PROPOSAL
Jones I ChuiBrazilXuxue Feng UNQUALIFIED
Maria C SergiFranceBernardo Dominic UNQUALIFIED
Costa H TollnerAustraliaAsiya Javayant RENEWAL
Stacey Z PerinItalyIoni Bowcher UNQUALIFIED
Aditya S PerinGermanyStephen Shaw RENEWAL
Aditya N StensethRussiaBernardo Dominic NEW
Julie N VocelkaIndiaIoni Bowcher RENEWAL
Kaitlin G MorascaSpainXuxue Feng NEW
Julie C CaldareraFranceAmy Elsner UNQUALIFIED
Wickens S CaudyAustraliaBernardo Dominic RENEWAL
Rodrigues F TollnerJapanOnyama Limba RENEWAL
Johnson O FigeroaJapanAmy Elsner PROPOSAL
Smith U InouyeCanadaElwin Sharvill UNQUALIFIED
Faith R RoysterArgentinaAsiya Javayant NEW
Jennifer M CampainSpainOnyama Limba NEGOTIATION
Maisha O AlbaresItalyStephen Shaw PROPOSAL
Emily O IturbideIndiaAsiya Javayant QUALIFIED
Morrow J ChuiArgentinaIvan Magalhaes NEGOTIATION
Aruna F MorascaIndiaIoni Bowcher UNQUALIFIED
Mayumi U RulapaughRussiaIvan Magalhaes QUALIFIED
Octavia C WaycottCanadaAmy Elsner NEW
Murillo I SlusarskiBrazilElwin Sharvill NEW
Wickens G RutaFranceOnyama Limba UNQUALIFIED
Maisha S RulapaughRussiaAnna Fali RENEWAL
Juan O BriddickGermanyOnyama Limba NEGOTIATION
Clifford J MorascaItalyAnna Fali UNQUALIFIED
Darci D GlickGermanyAmy Elsner RENEWAL
David B BriddickFranceAsiya Javayant QUALIFIED
Jennifer V GlickBrazilOnyama Limba RENEWAL
Ricardo O WaycottBrazilElwin Sharvill NEGOTIATION
Adams M KuskoSpainAsiya Javayant PROPOSAL
Jefferson S VenereIndiaAsiya Javayant NEW
Izzy C AmigonItalyAsiya Javayant NEW
Mayumi E InouyeRussiaStephen Shaw PROPOSAL
James U StensethSpainElwin Sharvill UNQUALIFIED
Greenwood N BriddickBrazilAnna Fali RENEWAL
Julie W DoeCanadaBernardo Dominic NEW
Tony Y RoysterSpainElwin Sharvill RENEWAL
Maisha O MorascaSpainOnyama Limba RENEWAL
Mujtaba G SlusarskiItalyIvan Magalhaes RENEWAL
Mayumi U IturbideArgentinaAmy Elsner NEW
Kaitlin P AlbaresFranceBernardo Dominic RENEWAL
Clifford L PoquetteFranceAmy Elsner QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Mayumi P RutaArgentinaXuxue Feng NEW
Jeanfrancois P GarufiCanadaStephen Shaw NEW
Octavia W FollerArgentinaElwin Sharvill UNQUALIFIED
Rodrigues X GillianSpainIoni Bowcher QUALIFIED
Jeanfrancois H MorascaItalyAsiya Javayant NEW
Jefferson V RutaItalyIoni Bowcher QUALIFIED
Francesco V SergiFranceAmy Elsner RENEWAL
Kadeem Z IturbideCanadaBernardo Dominic RENEWAL
Francesco E FerenczCanadaAsiya Javayant UNQUALIFIED
Mujtaba Z TollnerIndiaOnyama Limba RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Izzy K MaletBrazil2024-04-08Rangoni Of Florence PROPOSAL68Ioni Bowcher
1001Salvatore S MaletItaly2024-03-27Feiner Bros UNQUALIFIED24Anna Fali
1002Smith N AmigonArgentina2024-04-02King, Christopher A Esq NEW75Anna Fali
1003Misaki B MaletRussia2024-04-18Chemel, James L Cpa PROPOSAL28Ioni Bowcher
1004Isabel Q WaycottAustralia2024-04-11Feiner Bros NEGOTIATION66Bernardo Dominic
1005Juan R MaletUnited Kingdom2024-04-14Buckley Miller Wright RENEWAL66Ioni Bowcher
1006Costa B MarrierSpain2024-04-18Benton, John B Jr NEW13Amy Elsner
1007Rodrigues I MaletFrance2024-04-13Buckley Miller Wright UNQUALIFIED2Xuxue Feng
1008Greenwood A CaudyIndia2024-04-10Printing Dimensions PROPOSAL38Elwin Sharvill
1009Misaki T FollerArgentina2024-04-04Feiner Bros NEW63Anna Fali
1010Julie X MaletSpain2024-04-05Truhlar And Truhlar Attys QUALIFIED55Ioni Bowcher
1011Greenwood V SergiSpain2024-03-30Chemel, James L Cpa NEGOTIATION47Onyama Limba
1012Isabel K WhobreyCanada2024-04-14Rangoni Of Florence PROPOSAL33Elwin Sharvill
1013Leon L ShinkoSpain2024-03-27Rangoni Of Florence NEW72Bernardo Dominic
1014Leon X ButtIndia2024-04-07Chemel, James L Cpa QUALIFIED1Anna Fali
1015Costa H PaprockiGermany2024-03-31Feltz Printing Service QUALIFIED10Ivan Magalhaes
1016Maria I GlickJapan2024-04-13Benton, John B Jr NEGOTIATION55Xuxue Feng
1017Emily G BowleyJapan2024-04-20Rousseaux, Michael Esq NEGOTIATION24Ivan Magalhaes
1018Octavia M RulapaughRussia2024-04-14Benton, John B Jr RENEWAL53Onyama Limba
1019Alejandro Z DilliardIndia2024-04-17Printing Dimensions RENEWAL77Stephen Shaw
1020Aruna R BowleyJapan2024-04-16Feltz Printing Service QUALIFIED80Anna Fali
1021Aika C FigeroaUnited Kingdom2024-04-19Rangoni Of Florence NEGOTIATION91Ivan Magalhaes
1022Stacey D CaldareraSpain2024-04-12Commercial Press UNQUALIFIED45Ivan Magalhaes
1023Isabel P OldroydArgentina2024-04-21Commercial Press RENEWAL88Ioni Bowcher
1024Sinclair Q KuskoIndia2024-03-28Feltz Printing Service PROPOSAL14Stephen Shaw
1025Juan P FlosiJapan2024-04-21Chanay, Jeffrey A Esq RENEWAL98Bernardo Dominic
1026Jeanfrancois F RutaIndia2024-04-14Benton, John B Jr PROPOSAL67Stephen Shaw
1027Izzy F ShinkoGermany2024-04-24Feltz Printing Service QUALIFIED98Xuxue Feng
1028Aruna G MarrierBrazil2024-04-16Rangoni Of Florence RENEWAL5Ivan Magalhaes
1029Cody E SlusarskiRussia2024-04-09Buckley Miller Wright NEGOTIATION69Anna Fali
1030Jennifer R OstroskyBrazil2024-04-24Rangoni Of Florence NEW31Onyama Limba
1031Antonio D RimJapan2024-04-11Dorl, James J Esq RENEWAL14Stephen Shaw
1032Francesco O WaycottIndia2024-03-30Benton, John B Jr RENEWAL99Ioni Bowcher
1033Octavia Z StockhamArgentina2024-04-01Truhlar And Truhlar Attys RENEWAL51Stephen Shaw
1034Octavia B MarrierRussia2024-03-28Buckley Miller Wright NEGOTIATION20Amy Elsner
1035Alejandro I OldroydJapan2024-03-28Commercial Press NEW67Xuxue Feng
1036Silvio H GillianJapan2024-04-18Chemel, James L Cpa NEW15Ioni Bowcher
1037Adams G GlickJapan2024-04-19Feiner Bros NEW15Anna Fali
1038Munro V GauchoUnited Kingdom2024-04-07Printing Dimensions UNQUALIFIED6Anna Fali
1039Kadeem O CampainFrance2024-04-22Printing Dimensions UNQUALIFIED22Onyama Limba
1040Aruna N AlbaresJapan2024-03-27Chapman, Ross E Esq QUALIFIED0Bernardo Dominic
1041Costa S PerinArgentina2024-04-09Commercial Press UNQUALIFIED97Onyama Limba
1042Claire P FigeroaItaly2024-04-14Truhlar And Truhlar Attys NEGOTIATION1Stephen Shaw
1043Ivar V MaletAustralia2024-04-07Benton, John B Jr PROPOSAL12Onyama Limba
1044James Y SergiBrazil2024-04-04Feltz Printing Service PROPOSAL32Onyama Limba
1045Kadeem P SaylorsAustralia2024-04-08Rangoni Of Florence PROPOSAL43Amy Elsner
1046Cody B BologniaJapan2024-04-25Morlong Associates NEW26Anna Fali
1047Claire F NickaGermany2024-04-13Truhlar And Truhlar Attys RENEWAL49Stephen Shaw
1048Jefferson A RulapaughGermany2024-04-19Rousseaux, Michael Esq PROPOSAL62Ioni Bowcher
1049Wickens K ChuiArgentina2024-03-29Printing Dimensions RENEWAL46Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Jennifer D CampainAustraliaBernardo Dominic RENEWAL
Johnson K GauchoRussiaAmy Elsner NEW
Johnson P NestleFranceAmy Elsner QUALIFIED
Deepesh Z GlickIndiaStephen Shaw NEGOTIATION
Costa W MacleadJapanAnna Fali RENEWAL
Murillo W BriddickFranceAmy Elsner QUALIFIED
Maisha H ButtCanadaOnyama Limba NEGOTIATION
Costa N GarufiIndiaAsiya Javayant PROPOSAL
Tony X PoquetteUnited KingdomIoni Bowcher NEGOTIATION
Faith Z ShinkoAustraliaIoni Bowcher QUALIFIED
Costa Y IturbideArgentinaStephen Shaw UNQUALIFIED
Chavez H NickaSpainXuxue Feng NEW
Kadeem P OldroydFranceXuxue Feng RENEWAL
Ashley G RoysterBrazilAnna Fali UNQUALIFIED
Wickens Q MarrierUnited KingdomBernardo Dominic NEGOTIATION
Isabel O PoquetteAustraliaAnna Fali UNQUALIFIED
Greenwood B RoysterSpainAmy Elsner NEGOTIATION
Antonio W TollnerItalyIoni Bowcher PROPOSAL
Aditya W IturbideArgentinaAmy Elsner NEGOTIATION
Smith R MorascaJapanBernardo Dominic QUALIFIED
Juan U KolmetzGermanyOnyama Limba RENEWAL
Darci S MarrierBrazilAsiya Javayant RENEWAL
Izzy G RimUnited KingdomAsiya Javayant PROPOSAL
Stacey A SlusarskiRussiaElwin Sharvill NEGOTIATION
Kaitlin Y WhobreyCanadaBernardo Dominic UNQUALIFIED
Octavia S DilliardCanadaAsiya Javayant QUALIFIED
Mayumi B AmigonJapanOnyama Limba NEW
Mayumi O RulapaughJapanIoni Bowcher NEW
Jeanfrancois P VenereSpainAsiya Javayant NEW
Leon V DoeSpainIoni Bowcher QUALIFIED
Greenwood O OstroskyIndiaXuxue Feng QUALIFIED
Tony M OstroskyRussiaXuxue Feng UNQUALIFIED
Faith P IturbideRussiaAmy Elsner NEGOTIATION
Kaitlin M KolmetzUnited KingdomIvan Magalhaes PROPOSAL
Silvio L BriddickBrazilAmy Elsner NEGOTIATION
Faith D AlbaresItalyElwin Sharvill RENEWAL
Silvio W BologniaCanadaAnna Fali RENEWAL
Ricardo Z MaletFranceElwin Sharvill RENEWAL
Stacey Q RutaUnited KingdomAsiya Javayant NEW
Cody R MarrierIndiaXuxue Feng NEGOTIATION
Stacey W MaletRussiaBernardo Dominic NEW
Maisha Q ShinkoFranceAnna Fali NEW
Ricardo H RulapaughIndiaAsiya Javayant QUALIFIED
Mayumi B MaletIndiaXuxue Feng QUALIFIED
Kadeem F WaycottSpainBernardo Dominic NEGOTIATION
Murillo R FlosiItalyAnna Fali QUALIFIED
Ashley C BriddickUnited KingdomIvan Magalhaes PROPOSAL
Greenwood O PerinItalyIvan Magalhaes QUALIFIED
Silvio P KuskoAustraliaAsiya Javayant QUALIFIED
Claire Q WaycottBrazilElwin Sharvill NEGOTIATION
Frozen Columns
Name
Aika L Poquette
Jeanfrancois J Maclead
Murillo U Poquette
Deepesh K Whobrey
Sinclair I Foller
Arvin W Malet
Deepesh R Oldroyd
Kaitlin W Albares
Emily U Marrier
Juan E Malet
Greenwood T Bolognia
Octavia A Schemmer
Munro Z Kusko
Francesco Z Chui
Deepesh V Malet
Aika P Perin
Antonio U Darakjy
Arvin Z Nicka
Maria I Maclead
Ivar N Stockham
Darci H Doe
Smith F Campain
Stacey H Morasca
Maisha H Ruta
Jefferson A Flosi
Octavia Q Stockham
Misaki M Ruta
Sinclair N Nestle
David S Kusko
Antonio X Gillian
Morrow H Figeroa
Tony D Wieser
Maisha K Rulapaugh
Aika T Inouye
Emily Y Doe
Aika B Waycott
Emily U Bolognia
Leon Q Ferencz
Ricardo Z Butt
Murillo Y Kolmetz
Sinclair V Gillian
Julie U Poquette
Aruna G Schemmer
Emily N Kusko
Jones J Perin
Kadeem B Tollner
Ashley J Briddick
Murillo B Poquette
Costa S Foller
Salvatore M Inouye
IdCountryDate
1000Argentina2024-03-27
1001India2024-04-14
1002Brazil2024-03-27
1003Russia2024-04-01
1004India2024-04-06
1005France2024-04-04
1006Brazil2024-04-01
1007India2024-03-29
1008India2024-03-30
1009Brazil2024-04-08
1010Australia2024-04-13
1011Argentina2024-04-06
1012Brazil2024-04-10
1013United Kingdom2024-04-11
1014Brazil2024-04-11
1015India2024-04-21
1016Brazil2024-04-14
1017Spain2024-04-04
1018Japan2024-04-15
1019Spain2024-04-22
1020Japan2024-03-29
1021Australia2024-04-08
1022Germany2024-04-16
1023Japan2024-04-25
1024Russia2024-03-31
1025France2024-03-27
1026Russia2024-04-07
1027Argentina2024-04-21
1028Australia2024-04-02
1029Italy2024-04-09
1030Canada2024-04-09
1031Canada2024-04-10
1032Brazil2024-04-07
1033Argentina2024-04-11
1034Russia2024-04-07
1035Brazil2024-03-27
1036Australia2024-04-13
1037Germany2024-03-27
1038Spain2024-04-23
1039Spain2024-04-23
1040Italy2024-04-14
1041Japan2024-04-08
1042Canada2024-03-28
1043United Kingdom2024-04-23
1044Spain2024-04-19
1045Brazil2024-04-24
1046Japan2024-04-16
1047Spain2024-04-05
1048Spain2024-03-29
1049Italy2024-04-01

On-Demand Data

NameIdCountryDate
Aruna G Tollner1000Italy2024-03-27
Leja S Wieser1001Australia2024-04-02
David V Caudy1002India2024-04-22
Jones M Bowley1003Germany2024-04-15
Francesco H Vocelka1004Russia2024-04-06
Jefferson Z Maclead1005Russia2024-04-20
Antonio C Foller1006Russia2024-04-19
Alejandro Y Kusko1007Argentina2024-04-21
Mayumi S Figeroa1008India2024-03-31
Kadeem Q Maclead1009France2024-04-07
Greenwood V Flosi1010Argentina2024-04-23
Salvatore I Campain1011Germany2024-04-24
Jeanfrancois Q Glick1012India2024-04-12
Munro K Slusarski1013France2024-04-08
Aruna O Marrier1014Russia2024-04-22
Silvio O Venere1015United Kingdom2024-04-18
Greenwood A Maclead1016India2024-04-21
Leon O Ostrosky1017Russia2024-03-27
Nicolas P Wieser1018Canada2024-04-09
Deepesh X Nicka1019Canada2024-03-27
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Izzy N OldroydJapanAmy Elsner NEGOTIATION
Sinclair I MarrierAustraliaAnna Fali NEGOTIATION
Leja R PoquetteGermanyIoni Bowcher UNQUALIFIED
Rodrigues X PaprockiRussiaElwin Sharvill QUALIFIED
Tony M PoquetteArgentinaAsiya Javayant QUALIFIED
Isabel X AmigonUnited KingdomAmy Elsner RENEWAL
Juan A VocelkaCanadaXuxue Feng PROPOSAL
Julie D ButtBrazilIoni Bowcher QUALIFIED
Isabel F MacleadFranceXuxue Feng NEGOTIATION
Alejandro M SaylorsFranceIoni Bowcher RENEWAL
Antonio M RoysterJapanIoni Bowcher NEW
Deepesh U BriddickRussiaBernardo Dominic NEGOTIATION
Antonio X NestleGermanyAnna Fali NEW
Mujtaba U FerenczArgentinaBernardo Dominic NEGOTIATION
Stacey X PerinAustraliaElwin Sharvill NEGOTIATION
Maisha J SaylorsIndiaIvan Magalhaes UNQUALIFIED
David P SaylorsGermanyOnyama Limba RENEWAL
Ricardo X StensethUnited KingdomAnna Fali PROPOSAL
Smith V OstroskySpainOnyama Limba RENEWAL
Salvatore S PoquetteItalyStephen Shaw PROPOSAL
Salvatore F PerinItalyBernardo Dominic PROPOSAL
Misaki Z NickaGermanyXuxue Feng NEW
Ashley A SaylorsJapanOnyama Limba NEGOTIATION
Jennifer G TollnerItalyIvan Magalhaes RENEWAL
Arvin X NestleUnited KingdomIoni Bowcher QUALIFIED
Nicolas B MacleadIndiaOnyama Limba UNQUALIFIED
Ashley P IturbideItalyXuxue Feng RENEWAL
Isabel I MaletRussiaAmy Elsner RENEWAL
Aruna J OstroskyBrazilIoni Bowcher NEGOTIATION
Deepesh M KuskoJapanAnna Fali UNQUALIFIED
Juan Y KolmetzIndiaIoni Bowcher NEW
Octavia P WieserBrazilBernardo Dominic NEW
David S SergiSpainStephen Shaw UNQUALIFIED
Jennifer Z PoquetteCanadaIoni Bowcher RENEWAL
Jeanfrancois X AlbaresAustraliaStephen Shaw PROPOSAL
Nicolas C CaldareraSpainOnyama Limba QUALIFIED
Clifford H NestleAustraliaIoni Bowcher RENEWAL
Misaki T BriddickItalyAsiya Javayant NEW
Cody T OldroydArgentinaStephen Shaw QUALIFIED
Nicolas C BriddickRussiaIoni Bowcher UNQUALIFIED

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