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
Kaitlin A MarrierAustraliaOnyama Limba PROPOSAL
Antonio N FigeroaIndiaStephen Shaw NEGOTIATION
Tony C BowleyBrazilOnyama Limba PROPOSAL
Rodrigues M GarufiGermanyBernardo Dominic UNQUALIFIED
Francesco B BriddickJapanAmy Elsner RENEWAL
Julie U MacleadFranceStephen Shaw QUALIFIED
Murillo Z BriddickUnited KingdomOnyama Limba RENEWAL
Kaitlin K DilliardFranceIoni Bowcher QUALIFIED
Aditya R NestleArgentinaAmy Elsner NEGOTIATION
Juan L AmigonItalyElwin Sharvill PROPOSAL
Costa Y PaprockiRussiaIoni Bowcher RENEWAL
Izzy U SaylorsArgentinaXuxue Feng QUALIFIED
Aika Q GarufiGermanyElwin Sharvill QUALIFIED
Deepesh O CaldareraRussiaElwin Sharvill NEGOTIATION
Mayumi V GarufiJapanStephen Shaw UNQUALIFIED
Aruna E RimRussiaOnyama Limba NEW
Greenwood U ButtJapanAnna Fali PROPOSAL
Mujtaba I WhobreyCanadaElwin Sharvill NEW
Aika M RutaUnited KingdomIvan Magalhaes RENEWAL
Nicolas W OldroydGermanyStephen Shaw UNQUALIFIED
Juan O TollnerAustraliaXuxue Feng NEGOTIATION
Nicolas F RulapaughAustraliaBernardo Dominic NEGOTIATION
Costa Q VocelkaUnited KingdomIoni Bowcher NEW
Costa Q FerenczCanadaBernardo Dominic QUALIFIED
Smith O StockhamRussiaIvan Magalhaes UNQUALIFIED
Morrow U MaletItalyOnyama Limba UNQUALIFIED
Clifford M FerenczJapanIoni Bowcher NEW
Mujtaba L MarrierUnited KingdomAmy Elsner PROPOSAL
Misaki I MaletSpainBernardo Dominic NEW
Murillo J WaycottIndiaAsiya Javayant QUALIFIED
Aditya W FollerFranceAsiya Javayant PROPOSAL
Silvio K OstroskyGermanyOnyama Limba QUALIFIED
Salvatore O FigeroaUnited KingdomBernardo Dominic RENEWAL
Kaitlin J AlbaresBrazilIoni Bowcher RENEWAL
Nicolas C FerenczItalyAnna Fali UNQUALIFIED
Chavez Q PoquetteGermanyStephen Shaw RENEWAL
Clifford A CaudyFranceAmy Elsner NEGOTIATION
Silvio L CaudySpainAnna Fali RENEWAL
Aditya Z InouyeRussiaIoni Bowcher NEGOTIATION
Aika L FerenczSpainAnna Fali UNQUALIFIED
Wickens L WhobreyJapanXuxue Feng PROPOSAL
Isabel I KolmetzItalyIoni Bowcher UNQUALIFIED
Costa D AmigonIndiaOnyama Limba RENEWAL
Chavez W RutaIndiaIoni Bowcher QUALIFIED
Salvatore R TollnerUnited KingdomStephen Shaw RENEWAL
Clifford T SchemmerRussiaAnna Fali PROPOSAL
Rodrigues E NestleGermanyElwin Sharvill NEGOTIATION
Salvatore E IturbideGermanyXuxue Feng UNQUALIFIED
Alejandro D ChuiIndiaXuxue Feng QUALIFIED
Maria K AlbaresSpainStephen Shaw UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Arvin B SchemmerArgentinaXuxue Feng PROPOSAL
Alejandro N GarufiJapanIoni Bowcher QUALIFIED
Smith P NestleBrazilOnyama Limba NEW
Faith U DilliardIndiaOnyama Limba NEW
Chavez A PerinGermanyAmy Elsner QUALIFIED
Kadeem R RutaGermanyOnyama Limba QUALIFIED
Chavez F FlosiIndiaAmy Elsner QUALIFIED
Emily Q WieserGermanyStephen Shaw RENEWAL
Jones F FlosiArgentinaIoni Bowcher QUALIFIED
Costa H RutaSpainIvan Magalhaes RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jefferson W ButtRussia2024-04-23Benton, John B Jr UNQUALIFIED46Bernardo Dominic
1001Juan G RimAustralia2024-04-07Morlong Associates PROPOSAL38Onyama Limba
1002Mujtaba H KolmetzUnited Kingdom2024-04-06Rangoni Of Florence PROPOSAL89Elwin Sharvill
1003Jeanfrancois W ChuiSpain2024-04-11Commercial Press RENEWAL57Ivan Magalhaes
1004Tony Y CampainCanada2024-04-07Feltz Printing Service NEGOTIATION73Xuxue Feng
1005Mujtaba Q DoeIndia2024-04-12Morlong Associates QUALIFIED20Ioni Bowcher
1006Francesco L BologniaArgentina2024-04-05Dorl, James J Esq PROPOSAL94Onyama Limba
1007Maria N FigeroaJapan2024-04-27Buckley Miller Wright PROPOSAL42Bernardo Dominic
1008Rodrigues P RoysterIndia2024-04-01Buckley Miller Wright RENEWAL92Xuxue Feng
1009Leja Y OldroydUnited Kingdom2024-04-24Printing Dimensions NEGOTIATION93Asiya Javayant
1010Sinclair N PerinAustralia2024-04-17Chanay, Jeffrey A Esq UNQUALIFIED10Bernardo Dominic
1011Murillo W RoysterRussia2024-04-21Chapman, Ross E Esq RENEWAL29Xuxue Feng
1012Darci S BriddickItaly2024-04-07Feiner Bros NEW29Ioni Bowcher
1013Deepesh F DarakjyRussia2024-03-30Buckley Miller Wright RENEWAL94Ivan Magalhaes
1014Jefferson P KolmetzCanada2024-04-08Dorl, James J Esq NEGOTIATION32Bernardo Dominic
1015Jefferson F MaletAustralia2024-04-12Printing Dimensions RENEWAL58Asiya Javayant
1016Maria C PerinArgentina2024-04-08Rousseaux, Michael Esq RENEWAL93Ioni Bowcher
1017Leon O FlosiSpain2024-04-13Feiner Bros RENEWAL20Amy Elsner
1018Clifford Z GarufiFrance2024-04-05Rangoni Of Florence UNQUALIFIED94Elwin Sharvill
1019Silvio Z FlosiAustralia2024-03-30Truhlar And Truhlar Attys PROPOSAL70Ioni Bowcher
1020Maisha W MaletRussia2024-04-26Chanay, Jeffrey A Esq NEW82Ioni Bowcher
1021Leon P PerinJapan2024-04-20Chemel, James L Cpa NEGOTIATION86Asiya Javayant
1022Smith Y SergiIndia2024-04-02Commercial Press UNQUALIFIED79Ivan Magalhaes
1023Faith E MorascaIndia2024-04-17Benton, John B Jr PROPOSAL72Anna Fali
1024Arvin U ShinkoCanada2024-04-21Rousseaux, Michael Esq RENEWAL54Xuxue Feng
1025Mujtaba X OldroydGermany2024-03-29Rousseaux, Michael Esq NEGOTIATION75Asiya Javayant
1026Clifford D PerinItaly2024-03-30Benton, John B Jr QUALIFIED47Ioni Bowcher
1027Leja M SaylorsJapan2024-04-05Rousseaux, Michael Esq NEW27Anna Fali
1028Arvin G PerinItaly2024-04-17Dorl, James J Esq NEGOTIATION62Anna Fali
1029Isabel G RimSpain2024-04-17Truhlar And Truhlar Attys UNQUALIFIED88Elwin Sharvill
1030Ashley N VocelkaFrance2024-04-03Morlong Associates NEGOTIATION18Amy Elsner
1031Aika Z WieserArgentina2024-04-21Dorl, James J Esq NEGOTIATION96Ivan Magalhaes
1032Murillo K VenereArgentina2024-04-06Chemel, James L Cpa RENEWAL60Xuxue Feng
1033Faith D MaletBrazil2024-03-30Chapman, Ross E Esq PROPOSAL56Amy Elsner
1034Aruna C RimItaly2024-04-21Feiner Bros NEW89Onyama Limba
1035Alejandro Y AmigonRussia2024-04-01Buckley Miller Wright UNQUALIFIED76Ivan Magalhaes
1036Mayumi L MorascaJapan2024-04-25King, Christopher A Esq NEW11Onyama Limba
1037Costa X MaletBrazil2024-04-14Feiner Bros PROPOSAL49Anna Fali
1038Kadeem P StockhamGermany2024-04-11Benton, John B Jr QUALIFIED99Elwin Sharvill
1039Leja Y DarakjyAustralia2024-04-11Feltz Printing Service NEGOTIATION21Anna Fali
1040Tony S InouyeBrazil2024-04-06Commercial Press UNQUALIFIED69Xuxue Feng
1041Misaki E MaletSpain2024-04-01Chanay, Jeffrey A Esq NEGOTIATION43Bernardo Dominic
1042Aditya G OldroydJapan2024-04-08Rangoni Of Florence NEW3Amy Elsner
1043Jennifer T WhobreyAustralia2024-03-31Feltz Printing Service NEGOTIATION77Ioni Bowcher
1044Stacey V MaletFrance2024-04-11Commercial Press NEGOTIATION71Ivan Magalhaes
1045Maisha B SaylorsJapan2024-04-11Rangoni Of Florence QUALIFIED53Bernardo Dominic
1046Isabel J WieserBrazil2024-04-11Feltz Printing Service QUALIFIED94Onyama Limba
1047Clifford J CaldareraFrance2024-04-06Truhlar And Truhlar Attys NEW12Bernardo Dominic
1048James E WhobreyUnited Kingdom2024-04-11Feltz Printing Service RENEWAL64Onyama Limba
1049Nicolas J VocelkaAustralia2024-03-29Buckley Miller Wright RENEWAL6Asiya Javayant
Frozen Rows
NameCountryRepresentativeStatus
Murillo W ButtAustraliaIoni Bowcher RENEWAL
Rodrigues F RoysterIndiaStephen Shaw RENEWAL
David M NestleAustraliaXuxue Feng RENEWAL
Francesco Y ChuiGermanyIvan Magalhaes NEGOTIATION
Leon I StensethCanadaElwin Sharvill PROPOSAL
Maria N DilliardFranceBernardo Dominic UNQUALIFIED
Julie Q NestleUnited KingdomIvan Magalhaes NEW
Salvatore X VocelkaCanadaBernardo Dominic QUALIFIED
Antonio D RutaJapanIoni Bowcher RENEWAL
Greenwood F KuskoCanadaXuxue Feng UNQUALIFIED
Morrow U GlickGermanyOnyama Limba UNQUALIFIED
Sinclair M GarufiJapanAsiya Javayant NEW
Aditya X NickaRussiaAmy Elsner NEGOTIATION
Nicolas M MorascaJapanBernardo Dominic QUALIFIED
Clifford R DarakjyGermanyAsiya Javayant NEW
Alejandro H BologniaRussiaIvan Magalhaes NEGOTIATION
Arvin C GlickAustraliaIoni Bowcher UNQUALIFIED
Cody V DilliardRussiaOnyama Limba PROPOSAL
Francesco X MaletAustraliaAsiya Javayant QUALIFIED
Isabel X OstroskyFranceXuxue Feng UNQUALIFIED
Maria F SchemmerBrazilElwin Sharvill RENEWAL
Misaki Z RoysterIndiaOnyama Limba PROPOSAL
Munro A SlusarskiRussiaXuxue Feng PROPOSAL
Salvatore P BologniaRussiaBernardo Dominic PROPOSAL
Francesco X BologniaRussiaStephen Shaw RENEWAL
Costa Q VenereUnited KingdomBernardo Dominic NEW
Cody O MaletUnited KingdomXuxue Feng PROPOSAL
Antonio A DilliardJapanBernardo Dominic RENEWAL
Darci Y VocelkaItalyStephen Shaw UNQUALIFIED
Clifford G RoysterSpainIoni Bowcher QUALIFIED
Jones R RimUnited KingdomIvan Magalhaes NEW
Smith L ShinkoIndiaAnna Fali NEGOTIATION
Emily G DarakjyGermanyXuxue Feng RENEWAL
Emily G MacleadGermanyOnyama Limba NEW
Nicolas B StockhamFranceAsiya Javayant QUALIFIED
Francesco L DoeBrazilOnyama Limba PROPOSAL
Jefferson O ButtArgentinaXuxue Feng UNQUALIFIED
Maisha K KolmetzSpainXuxue Feng QUALIFIED
Morrow K WaycottGermanyAnna Fali RENEWAL
Aruna E PoquetteRussiaXuxue Feng NEW
Kaitlin D ShinkoArgentinaIvan Magalhaes QUALIFIED
Salvatore B BriddickIndiaAmy Elsner QUALIFIED
Claire A BologniaFranceIvan Magalhaes UNQUALIFIED
Juan H StockhamFranceBernardo Dominic QUALIFIED
Ivar R StockhamFranceAsiya Javayant QUALIFIED
Arvin L OstroskyAustraliaAsiya Javayant NEGOTIATION
Izzy B SlusarskiFranceOnyama Limba NEGOTIATION
Francesco I KuskoSpainAnna Fali NEW
Francesco O SchemmerCanadaAmy Elsner UNQUALIFIED
Isabel H RutaUnited KingdomOnyama Limba RENEWAL
Frozen Columns
Name
Nicolas M Doe
Aditya S Foller
Mayumi C Dilliard
Murillo Q Dilliard
Wickens V Briddick
Chavez F Slusarski
Aruna T Butt
Ricardo F Campain
Aruna Z Darakjy
Greenwood J Shinko
Misaki N Sergi
Greenwood G Kolmetz
Ivar U Kolmetz
Darci D Gaucho
Leon X Dilliard
Chavez H Darakjy
Aruna M Dilliard
Tony E Venere
Jennifer S Stockham
Izzy V Sergi
Sinclair S Foller
Salvatore C Gaucho
Claire J Rim
Maisha A Ruta
Morrow C Stockham
Sinclair I Flosi
Maisha N Albares
Mujtaba T Stenseth
Ricardo I Tollner
Kadeem R Shinko
Julie W Slusarski
Aika G Nicka
Mayumi K Tollner
Chavez C Ruta
James N Campain
Jennifer T Poquette
Aruna W Gaucho
Darci G Foller
Darci Z Bolognia
Leon J Ruta
Alejandro F Gaucho
Jones U Amigon
Kaitlin Y Waycott
Nicolas W Dilliard
Arvin O Rim
Adams X Ruta
Faith A Kolmetz
Francesco B Nicka
Chavez S Ostrosky
Cody W Albares
IdCountryDate
1000India2024-04-20
1001Russia2024-04-01
1002Australia2024-04-24
1003Australia2024-04-26
1004United Kingdom2024-04-22
1005Russia2024-04-21
1006Japan2024-04-17
1007India2024-04-15
1008India2024-04-23
1009Japan2024-04-08
1010Argentina2024-04-04
1011Australia2024-04-11
1012Argentina2024-04-03
1013Australia2024-04-14
1014Brazil2024-04-06
1015France2024-04-08
1016Italy2024-04-18
1017Japan2024-04-03
1018Canada2024-04-14
1019Australia2024-04-13
1020France2024-04-26
1021Argentina2024-04-06
1022Brazil2024-04-03
1023Germany2024-04-09
1024Russia2024-04-17
1025France2024-04-05
1026Italy2024-04-20
1027Germany2024-04-12
1028Australia2024-04-04
1029Argentina2024-04-13
1030Spain2024-04-12
1031Italy2024-04-19
1032Germany2024-04-14
1033Spain2024-04-17
1034India2024-04-19
1035India2024-03-31
1036Spain2024-04-23
1037India2024-04-22
1038Japan2024-04-20
1039Brazil2024-03-30
1040India2024-04-01
1041Australia2024-04-01
1042France2024-04-26
1043Brazil2024-04-24
1044United Kingdom2024-04-07
1045Argentina2024-04-04
1046Germany2024-04-07
1047Russia2024-04-09
1048Canada2024-04-22
1049Argentina2024-03-31

On-Demand Data

NameIdCountryDate
Ricardo P Tollner1000Russia2024-04-02
Alejandro P Ostrosky1001Australia2024-04-25
Misaki C Schemmer1002Spain2024-04-14
Sinclair J Rulapaugh1003France2024-03-31
Maisha E Amigon1004United Kingdom2024-04-14
Jefferson O Oldroyd1005Russia2024-04-18
Nicolas T Waycott1006Italy2024-04-22
Kadeem J Ferencz1007Argentina2024-04-21
Jennifer U Dilliard1008United Kingdom2024-04-14
Johnson E Waycott1009France2024-04-13
Greenwood I Darakjy1010France2024-03-30
Kaitlin R Ferencz1011Russia2024-04-20
Emily A Doe1012Australia2024-03-31
Emily R Darakjy1013Italy2024-04-27
David I Paprocki1014Germany2024-04-05
Clifford D Royster1015Argentina2024-04-24
Antonio G Doe1016Italy2024-04-02
Clifford F Shinko1017Italy2024-04-22
Cody R Shinko1018Canada2024-04-12
Mujtaba L Doe1019Russia2024-04-08
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Jennifer B MorascaIndiaElwin Sharvill QUALIFIED
Smith U GauchoCanadaIoni Bowcher NEGOTIATION
Tony C NickaGermanyAnna Fali UNQUALIFIED
Maisha T GarufiUnited KingdomIoni Bowcher RENEWAL
Costa R VocelkaJapanBernardo Dominic QUALIFIED
Julie F MaletJapanIoni Bowcher RENEWAL
Sinclair O AmigonJapanBernardo Dominic NEGOTIATION
Faith N BowleyFranceIvan Magalhaes QUALIFIED
Aika V FigeroaFranceXuxue Feng NEGOTIATION
Morrow B StockhamUnited KingdomStephen Shaw UNQUALIFIED
Cody B CampainIndiaAmy Elsner QUALIFIED
Kaitlin U WaycottSpainElwin Sharvill PROPOSAL
Jennifer G PoquetteGermanyStephen Shaw UNQUALIFIED
Nicolas I RimArgentinaAnna Fali QUALIFIED
Antonio H BriddickRussiaIoni Bowcher QUALIFIED
Aruna T SlusarskiGermanyBernardo Dominic UNQUALIFIED
Faith J GillianBrazilXuxue Feng RENEWAL
Mujtaba H RutaIndiaIoni Bowcher NEW
Jones R CaldareraAustraliaAmy Elsner QUALIFIED
Ivar J DarakjyIndiaStephen Shaw UNQUALIFIED
Johnson R FigeroaJapanOnyama Limba NEW
Ricardo Z ChuiArgentinaAmy Elsner PROPOSAL
Darci L FigeroaItalyBernardo Dominic NEGOTIATION
Sinclair C DilliardBrazilStephen Shaw NEW
Leja B RulapaughJapanElwin Sharvill UNQUALIFIED
Misaki V RutaBrazilIoni Bowcher RENEWAL
Greenwood K SlusarskiJapanStephen Shaw RENEWAL
James J WhobreyUnited KingdomAnna Fali NEGOTIATION
Nicolas O NickaRussiaBernardo Dominic UNQUALIFIED
Arvin N TollnerIndiaAnna Fali RENEWAL
Leja L RoysterBrazilAnna Fali NEGOTIATION
Chavez F StockhamBrazilIvan Magalhaes NEGOTIATION
Kaitlin H MaletCanadaXuxue Feng NEW
Jennifer R SlusarskiFranceIvan Magalhaes QUALIFIED
Izzy C OldroydBrazilAsiya Javayant NEGOTIATION
Cody G AlbaresGermanyAnna Fali UNQUALIFIED
Adams U GarufiJapanIvan Magalhaes PROPOSAL
Deepesh V AmigonItalyAnna Fali NEW
Rodrigues Z MaletGermanyIoni Bowcher NEGOTIATION
Leon T FigeroaCanadaIvan Magalhaes QUALIFIED

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