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
Jefferson A CaudySpainBernardo Dominic RENEWAL
Darci K CaldareraUnited KingdomAnna Fali PROPOSAL
Ashley R DarakjyBrazilIvan Magalhaes PROPOSAL
Aruna Q NickaRussiaAmy Elsner RENEWAL
David L VocelkaAustraliaAmy Elsner PROPOSAL
Faith I NickaAustraliaOnyama Limba UNQUALIFIED
Arvin E SchemmerCanadaElwin Sharvill NEW
Arvin X CaudyFranceAsiya Javayant RENEWAL
Clifford G CampainSpainElwin Sharvill NEGOTIATION
Johnson Z ChuiBrazilElwin Sharvill QUALIFIED
Ashley I NestleFranceIoni Bowcher QUALIFIED
Jones G FollerJapanAsiya Javayant RENEWAL
Misaki F DilliardCanadaOnyama Limba NEGOTIATION
Jennifer C ShinkoArgentinaElwin Sharvill NEW
Kadeem W MaletBrazilIvan Magalhaes QUALIFIED
David P GlickFranceElwin Sharvill RENEWAL
David X GillianCanadaStephen Shaw UNQUALIFIED
Adams Z MaletSpainElwin Sharvill PROPOSAL
Tony O VocelkaSpainIvan Magalhaes NEW
Nicolas F KolmetzArgentinaBernardo Dominic UNQUALIFIED
Aika Q CaudyItalyIoni Bowcher UNQUALIFIED
Murillo Z StockhamUnited KingdomElwin Sharvill RENEWAL
Adams C DilliardGermanyBernardo Dominic RENEWAL
Kaitlin I FigeroaItalyAmy Elsner UNQUALIFIED
Mujtaba T GlickJapanAnna Fali QUALIFIED
Morrow D NickaAustraliaStephen Shaw NEGOTIATION
Johnson O VocelkaJapanAsiya Javayant QUALIFIED
Aruna S KolmetzItalyBernardo Dominic NEGOTIATION
Ivar Y BriddickArgentinaAnna Fali PROPOSAL
Ivar F AlbaresGermanyAsiya Javayant PROPOSAL
Jennifer J GillianJapanOnyama Limba NEGOTIATION
Maisha T CaldareraCanadaStephen Shaw NEGOTIATION
Cody D OstroskySpainIoni Bowcher UNQUALIFIED
Claire K PerinFranceElwin Sharvill NEW
Wickens B RoysterUnited KingdomIoni Bowcher PROPOSAL
Costa N GarufiUnited KingdomAnna Fali QUALIFIED
Sinclair B GarufiGermanyIoni Bowcher NEGOTIATION
Kadeem B ButtGermanyIoni Bowcher QUALIFIED
Greenwood L IturbideBrazilXuxue Feng PROPOSAL
Aruna X MaletCanadaElwin Sharvill RENEWAL
Jeanfrancois S FerenczCanadaAmy Elsner QUALIFIED
Izzy V SchemmerCanadaIoni Bowcher RENEWAL
Kadeem E InouyeItalyIvan Magalhaes RENEWAL
Sinclair J SaylorsAustraliaIvan Magalhaes PROPOSAL
Francesco B RutaAustraliaOnyama Limba RENEWAL
Adams D MorascaArgentinaAsiya Javayant UNQUALIFIED
Rodrigues O InouyeSpainElwin Sharvill NEGOTIATION
Wickens G RutaArgentinaBernardo Dominic NEGOTIATION
Clifford Y ShinkoArgentinaIvan Magalhaes RENEWAL
James K WaycottGermanyAsiya Javayant NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Alejandro M GillianIndiaBernardo Dominic NEGOTIATION
Silvio C KuskoBrazilAnna Fali UNQUALIFIED
James Q MarrierArgentinaIoni Bowcher UNQUALIFIED
Aika P SchemmerAustraliaIvan Magalhaes QUALIFIED
Arvin S AmigonSpainStephen Shaw RENEWAL
Morrow Z BriddickCanadaIvan Magalhaes NEGOTIATION
Smith U BologniaCanadaXuxue Feng PROPOSAL
Isabel Y GarufiSpainElwin Sharvill QUALIFIED
Chavez M ButtCanadaIvan Magalhaes NEGOTIATION
Jennifer O SaylorsIndiaIoni Bowcher RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Antonio B MorascaItaly2024-03-21Chapman, Ross E Esq NEW54Amy Elsner
1001Juan I WaycottRussia2024-04-10Rangoni Of Florence NEGOTIATION94Bernardo Dominic
1002Misaki Q VenereRussia2024-04-01Rousseaux, Michael Esq UNQUALIFIED86Amy Elsner
1003Cody K NickaUnited Kingdom2024-04-08Rousseaux, Michael Esq NEGOTIATION36Amy Elsner
1004Tony S OstroskyIndia2024-04-05Benton, John B Jr NEGOTIATION10Ivan Magalhaes
1005Stacey O CampainUnited Kingdom2024-03-27Rangoni Of Florence NEW1Onyama Limba
1006Isabel Q SchemmerUnited Kingdom2024-04-13Morlong Associates RENEWAL74Ivan Magalhaes
1007Silvio X RutaCanada2024-04-04Chemel, James L Cpa RENEWAL2Ioni Bowcher
1008Ivar G SergiArgentina2024-03-25Benton, John B Jr RENEWAL28Onyama Limba
1009Greenwood M AmigonItaly2024-03-30Rangoni Of Florence QUALIFIED45Asiya Javayant
1010Wickens W PaprockiCanada2024-04-12Commercial Press NEGOTIATION88Ioni Bowcher
1011Greenwood K IturbideGermany2024-03-26Truhlar And Truhlar Attys QUALIFIED41Ivan Magalhaes
1012Jeanfrancois W MarrierAustralia2024-04-06Dorl, James J Esq RENEWAL79Ioni Bowcher
1013Misaki D MarrierJapan2024-04-02Printing Dimensions UNQUALIFIED71Onyama Limba
1014Francesco J NickaCanada2024-04-17Rangoni Of Florence QUALIFIED60Onyama Limba
1015Jefferson G FlosiAustralia2024-03-24Chanay, Jeffrey A Esq UNQUALIFIED23Onyama Limba
1016Mayumi P AmigonUnited Kingdom2024-04-15Commercial Press PROPOSAL82Asiya Javayant
1017Maisha D GlickAustralia2024-03-21Rangoni Of Florence PROPOSAL20Amy Elsner
1018Julie U PaprockiArgentina2024-04-04Buckley Miller Wright PROPOSAL84Ioni Bowcher
1019Julie J WieserCanada2024-03-30Buckley Miller Wright QUALIFIED38Asiya Javayant
1020Murillo Y MaletIndia2024-03-27Chemel, James L Cpa RENEWAL94Stephen Shaw
1021Costa Q RulapaughFrance2024-04-01Printing Dimensions UNQUALIFIED12Asiya Javayant
1022Jennifer E OldroydIndia2024-04-08Feltz Printing Service PROPOSAL73Onyama Limba
1023Munro N StensethGermany2024-03-21Truhlar And Truhlar Attys NEGOTIATION40Onyama Limba
1024Morrow Q DoeJapan2024-04-15Feltz Printing Service NEGOTIATION79Asiya Javayant
1025Johnson M SergiIndia2024-04-19Feltz Printing Service RENEWAL79Ioni Bowcher
1026Darci K MarrierCanada2024-03-25Commercial Press NEGOTIATION24Ivan Magalhaes
1027Chavez A MarrierFrance2024-03-25Commercial Press PROPOSAL65Ivan Magalhaes
1028Francesco Y StensethArgentina2024-04-08Rangoni Of Florence UNQUALIFIED31Bernardo Dominic
1029Murillo L RulapaughCanada2024-04-13Buckley Miller Wright NEW94Onyama Limba
1030Costa J MarrierFrance2024-04-11King, Christopher A Esq NEW99Xuxue Feng
1031Cody H CaldareraItaly2024-04-12Dorl, James J Esq QUALIFIED49Xuxue Feng
1032Johnson L KolmetzFrance2024-04-18Chemel, James L Cpa NEGOTIATION82Anna Fali
1033Aditya Y SergiIndia2024-03-30Chanay, Jeffrey A Esq QUALIFIED0Amy Elsner
1034Mayumi N IturbideFrance2024-04-14Chanay, Jeffrey A Esq NEGOTIATION34Amy Elsner
1035Smith Z DoeIndia2024-03-28Rangoni Of Florence PROPOSAL4Anna Fali
1036Wickens T MaletSpain2024-04-06Feiner Bros UNQUALIFIED71Asiya Javayant
1037Sinclair E SchemmerIndia2024-03-25Chapman, Ross E Esq PROPOSAL35Amy Elsner
1038Ivar F OstroskyRussia2024-04-05Morlong Associates NEGOTIATION29Ivan Magalhaes
1039Sinclair M RimIndia2024-04-16Chanay, Jeffrey A Esq NEW84Stephen Shaw
1040Deepesh U BologniaArgentina2024-04-16Benton, John B Jr NEW17Bernardo Dominic
1041Rodrigues Y MacleadItaly2024-03-25Truhlar And Truhlar Attys QUALIFIED51Ivan Magalhaes
1042Cody T OldroydBrazil2024-04-12Chanay, Jeffrey A Esq NEGOTIATION76Bernardo Dominic
1043Leja U PerinBrazil2024-04-16Buckley Miller Wright QUALIFIED97Anna Fali
1044Claire Q ShinkoGermany2024-04-07Benton, John B Jr RENEWAL19Elwin Sharvill
1045Deepesh F DilliardUnited Kingdom2024-04-09Chanay, Jeffrey A Esq RENEWAL20Xuxue Feng
1046Chavez A CaudyBrazil2024-04-06Chanay, Jeffrey A Esq RENEWAL61Ivan Magalhaes
1047Darci Y WhobreyIndia2024-04-17Printing Dimensions RENEWAL17Xuxue Feng
1048Costa T RimRussia2024-04-06Feltz Printing Service RENEWAL25Anna Fali
1049Faith E SaylorsGermany2024-04-01Chapman, Ross E Esq RENEWAL12Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
David N BriddickArgentinaAsiya Javayant PROPOSAL
Murillo M RulapaughGermanyAmy Elsner NEGOTIATION
Juan O WieserCanadaElwin Sharvill NEGOTIATION
Darci A PaprockiItalyBernardo Dominic NEGOTIATION
Aditya O StensethFranceIvan Magalhaes NEGOTIATION
Claire Z GauchoBrazilAsiya Javayant UNQUALIFIED
Mayumi M FlosiAustraliaStephen Shaw PROPOSAL
Adams S DarakjySpainElwin Sharvill UNQUALIFIED
Nicolas T KolmetzArgentinaOnyama Limba PROPOSAL
Ivar D FollerArgentinaXuxue Feng UNQUALIFIED
Clifford K ShinkoAustraliaAnna Fali RENEWAL
Ashley G CaudyGermanyStephen Shaw NEGOTIATION
Ashley A MaletGermanyAsiya Javayant NEW
Ivar M VocelkaItalyXuxue Feng QUALIFIED
Kadeem H FerenczBrazilAsiya Javayant QUALIFIED
Arvin J BowleySpainAnna Fali NEGOTIATION
Juan O DilliardIndiaElwin Sharvill NEGOTIATION
Kadeem H MarrierAustraliaIoni Bowcher QUALIFIED
Juan P FollerArgentinaElwin Sharvill PROPOSAL
Kaitlin W ShinkoRussiaXuxue Feng RENEWAL
Silvio Y RimCanadaStephen Shaw RENEWAL
Arvin I CampainItalyXuxue Feng QUALIFIED
Rodrigues G ChuiRussiaAsiya Javayant NEGOTIATION
Johnson E FlosiUnited KingdomAmy Elsner NEW
James H DilliardIndiaStephen Shaw PROPOSAL
Adams R IturbideIndiaAmy Elsner PROPOSAL
Julie B WhobreyFranceOnyama Limba RENEWAL
Francesco V DoeGermanyBernardo Dominic NEW
Francesco S PaprockiCanadaElwin Sharvill RENEWAL
Francesco M WaycottCanadaIvan Magalhaes NEGOTIATION
Kadeem F IturbideGermanyAsiya Javayant RENEWAL
Leja Q PerinJapanAsiya Javayant NEGOTIATION
Mujtaba D AlbaresAustraliaBernardo Dominic NEW
Aika F ShinkoUnited KingdomOnyama Limba NEW
Tony J FollerFranceAsiya Javayant UNQUALIFIED
Jennifer M InouyeItalyIvan Magalhaes NEGOTIATION
Leja E RoysterItalyXuxue Feng PROPOSAL
Juan H WieserIndiaIoni Bowcher NEW
Costa N SlusarskiCanadaAnna Fali RENEWAL
Octavia C AlbaresItalyAnna Fali NEGOTIATION
Rodrigues W ChuiItalyIoni Bowcher NEW
Arvin M AlbaresItalyStephen Shaw NEGOTIATION
Rodrigues G CaldareraCanadaOnyama Limba UNQUALIFIED
Maisha A SchemmerArgentinaIvan Magalhaes RENEWAL
Salvatore Y GlickSpainOnyama Limba NEW
Jones H PoquetteGermanyElwin Sharvill PROPOSAL
Francesco A MacleadArgentinaXuxue Feng PROPOSAL
Aditya D GillianCanadaOnyama Limba NEGOTIATION
Darci J GauchoGermanyOnyama Limba RENEWAL
Kaitlin D RutaIndiaIoni Bowcher PROPOSAL
Frozen Columns
Name
Aruna E Rim
Aika R Malet
Claire M Morasca
Mujtaba S Caldarera
Alejandro R Amigon
Aika L Marrier
Juan K Nestle
Mayumi O Slusarski
Jefferson I Whobrey
Costa P Wieser
Chavez T Amigon
Isabel T Waycott
Jennifer H Butt
Munro S Kusko
Wickens D Doe
Aditya P Inouye
Leja R Whobrey
Jennifer R Briddick
Isabel I Figeroa
Salvatore S Ruta
Aditya C Albares
James S Morasca
Maisha K Bowley
Wickens O Malet
Munro N Rulapaugh
Deepesh W Bowley
Rodrigues R Rulapaugh
Darci V Waycott
Costa D Royster
Stacey H Marrier
Octavia Z Stockham
Aditya B Inouye
Morrow W Tollner
Sinclair D Oldroyd
Greenwood X Ferencz
Darci T Nestle
Maisha J Slusarski
Antonio X Kolmetz
Cody D Butt
Chavez L Saylors
Misaki Q Dilliard
Maria V Figeroa
Claire H Royster
Aruna T Gaucho
James H Foller
Greenwood U Marrier
Julie C Kolmetz
Darci G Kolmetz
Chavez A Marrier
Mujtaba N Morasca
IdCountryDate
1000United Kingdom2024-03-24
1001India2024-04-10
1002Japan2024-03-21
1003Germany2024-03-29
1004Japan2024-04-10
1005Australia2024-04-19
1006France2024-04-17
1007France2024-04-08
1008France2024-03-21
1009Japan2024-04-12
1010Brazil2024-03-23
1011Japan2024-04-13
1012Spain2024-03-25
1013United Kingdom2024-04-05
1014India2024-03-21
1015Italy2024-04-16
1016United Kingdom2024-03-25
1017Russia2024-04-16
1018Argentina2024-04-18
1019Brazil2024-03-24
1020France2024-04-14
1021Brazil2024-04-07
1022Spain2024-04-12
1023Spain2024-03-30
1024Australia2024-04-17
1025Spain2024-04-12
1026Brazil2024-04-16
1027Spain2024-04-13
1028Canada2024-04-16
1029France2024-03-22
1030Russia2024-04-06
1031Canada2024-03-24
1032India2024-03-24
1033France2024-03-21
1034India2024-03-31
1035Canada2024-04-17
1036Brazil2024-04-07
1037Argentina2024-04-15
1038Canada2024-04-10
1039France2024-04-10
1040India2024-03-28
1041Brazil2024-04-15
1042India2024-04-17
1043France2024-04-17
1044Russia2024-04-02
1045Brazil2024-04-04
1046France2024-03-24
1047Japan2024-04-01
1048Japan2024-04-17
1049India2024-04-12

On-Demand Data

NameIdCountryDate
Clifford S Caldarera1000Germany2024-03-25
Smith W Whobrey1001Brazil2024-04-15
Kadeem F Stockham1002Russia2024-03-26
Leon K Ostrosky1003Brazil2024-04-04
Adams R Kolmetz1004Germany2024-03-31
Chavez O Maclead1005Japan2024-03-22
Stacey F Slusarski1006Italy2024-03-31
Kaitlin R Figeroa1007Japan2024-04-12
Chavez D Dilliard1008Spain2024-03-22
Adams K Morasca1009Australia2024-04-05
Julie V Bowley1010Germany2024-04-14
Aditya U Flosi1011Argentina2024-03-22
Darci F Tollner1012India2024-03-25
Leon S Bolognia1013France2024-03-30
Juan V Rulapaugh1014Brazil2024-04-15
Misaki T Venere1015India2024-04-10
Julie W Malet1016Germany2024-04-18
Jones Z Rim1017Spain2024-03-28
Jefferson Z Kusko1018Germany2024-04-13
Costa B Dilliard1019Germany2024-04-16
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Alejandro L FlosiCanadaAsiya Javayant RENEWAL
Munro S ButtSpainOnyama Limba RENEWAL
Jefferson A OstroskySpainIvan Magalhaes UNQUALIFIED
Isabel K WieserJapanAmy Elsner NEGOTIATION
Misaki F SchemmerJapanXuxue Feng UNQUALIFIED
Kaitlin L ChuiFranceBernardo Dominic PROPOSAL
Juan O BologniaAustraliaIvan Magalhaes RENEWAL
Isabel V CaldareraRussiaOnyama Limba QUALIFIED
Darci O FerenczSpainAnna Fali UNQUALIFIED
Johnson K SaylorsItalyIvan Magalhaes QUALIFIED
Silvio O ShinkoRussiaElwin Sharvill QUALIFIED
Faith D WaycottArgentinaXuxue Feng QUALIFIED
Faith N FigeroaJapanIvan Magalhaes RENEWAL
Jefferson U DarakjyIndiaAmy Elsner NEGOTIATION
Jones D IturbideFranceOnyama Limba PROPOSAL
Ashley G FigeroaArgentinaAsiya Javayant NEW
Sinclair C CaudyUnited KingdomAmy Elsner UNQUALIFIED
Aruna S CaldareraItalyElwin Sharvill PROPOSAL
Cody B DilliardUnited KingdomXuxue Feng NEGOTIATION
Chavez G WaycottItalyIvan Magalhaes PROPOSAL
Juan R MaletFranceElwin Sharvill NEGOTIATION
Salvatore O TollnerArgentinaAmy Elsner NEW
Greenwood K FerenczSpainIvan Magalhaes QUALIFIED
Jefferson G AmigonCanadaAsiya Javayant NEGOTIATION
Julie G KuskoUnited KingdomAmy Elsner RENEWAL
Costa K NestleCanadaOnyama Limba RENEWAL
Chavez T PoquetteSpainIoni Bowcher NEW
Isabel Q BowleyFranceStephen Shaw NEGOTIATION
Kadeem J RoysterGermanyIoni Bowcher QUALIFIED
Julie L NickaSpainIoni Bowcher NEW
Maria M CampainSpainBernardo Dominic NEGOTIATION
David W ChuiItalyIvan Magalhaes UNQUALIFIED
Salvatore B DilliardAustraliaOnyama Limba PROPOSAL
Isabel J DoeIndiaOnyama Limba RENEWAL
Nicolas V ButtFranceAsiya Javayant QUALIFIED
Wickens I PaprockiAustraliaAnna Fali UNQUALIFIED
Salvatore R MaletCanadaElwin Sharvill RENEWAL
Sinclair T SaylorsSpainAmy Elsner QUALIFIED
Chavez K MacleadRussiaAsiya Javayant QUALIFIED
Aruna K SergiUnited KingdomOnyama Limba 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>