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
Jones D SlusarskiUnited KingdomIoni Bowcher NEGOTIATION
Silvio N WhobreyCanadaXuxue Feng NEGOTIATION
Cody E AlbaresUnited KingdomAnna Fali RENEWAL
David I SaylorsCanadaIoni Bowcher QUALIFIED
Francesco N MorascaRussiaAsiya Javayant UNQUALIFIED
Leon P MorascaBrazilAsiya Javayant NEGOTIATION
Maisha K ChuiItalyAmy Elsner QUALIFIED
Leja H SaylorsAustraliaAsiya Javayant RENEWAL
Claire C WhobreyCanadaElwin Sharvill NEW
Kadeem C WhobreyGermanyAnna Fali QUALIFIED
Aruna O DarakjyBrazilAnna Fali RENEWAL
Izzy I TollnerFranceStephen Shaw NEGOTIATION
Deepesh S TollnerArgentinaAsiya Javayant PROPOSAL
Salvatore H IturbideFranceBernardo Dominic UNQUALIFIED
Ricardo T SchemmerIndiaAsiya Javayant PROPOSAL
Aika M SchemmerRussiaStephen Shaw NEW
Ricardo R FigeroaSpainXuxue Feng NEW
Juan U GillianJapanBernardo Dominic UNQUALIFIED
Wickens V GillianAustraliaAmy Elsner UNQUALIFIED
Arvin Z CaudyFranceAnna Fali NEW
Kaitlin P OstroskyArgentinaXuxue Feng NEW
Francesco V SaylorsAustraliaElwin Sharvill NEW
Murillo X VenereIndiaAnna Fali QUALIFIED
Misaki V RoysterItalyAmy Elsner PROPOSAL
Cody S BriddickFranceStephen Shaw QUALIFIED
Costa T OldroydCanadaIoni Bowcher RENEWAL
James F MacleadSpainStephen Shaw QUALIFIED
Maria L GarufiArgentinaAsiya Javayant UNQUALIFIED
Silvio K FlosiBrazilStephen Shaw QUALIFIED
Silvio A GauchoCanadaXuxue Feng QUALIFIED
Clifford M GillianSpainAmy Elsner NEGOTIATION
Mujtaba Z GauchoCanadaAnna Fali QUALIFIED
Wickens E DarakjyArgentinaAsiya Javayant PROPOSAL
Stacey J VocelkaUnited KingdomElwin Sharvill RENEWAL
James V CaudyFranceIvan Magalhaes NEW
Smith S PoquetteBrazilElwin Sharvill QUALIFIED
Adams Y ShinkoBrazilAsiya Javayant NEGOTIATION
Jefferson D KuskoJapanStephen Shaw RENEWAL
Izzy B RimAustraliaAsiya Javayant PROPOSAL
Ashley E KuskoSpainAsiya Javayant RENEWAL
Ivar I WaycottRussiaAmy Elsner UNQUALIFIED
Cody D PerinCanadaBernardo Dominic QUALIFIED
Izzy R NickaRussiaStephen Shaw QUALIFIED
Antonio N PaprockiAustraliaStephen Shaw NEW
Adams V StensethAustraliaAsiya Javayant PROPOSAL
Leon L PerinFranceOnyama Limba PROPOSAL
Adams B OldroydBrazilOnyama Limba QUALIFIED
Adams U FlosiItalyIvan Magalhaes RENEWAL
Francesco N BologniaItalyXuxue Feng QUALIFIED
Chavez T SlusarskiAustraliaBernardo Dominic QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Aditya X RimBrazilBernardo Dominic NEW
Darci Q DarakjySpainIoni Bowcher NEGOTIATION
Greenwood T DarakjyAustraliaElwin Sharvill RENEWAL
Antonio E BowleyJapanAnna Fali UNQUALIFIED
Aika I KolmetzCanadaStephen Shaw UNQUALIFIED
Jones S PoquetteRussiaAsiya Javayant NEGOTIATION
Aika L NickaRussiaIoni Bowcher NEGOTIATION
Maria F OldroydJapanStephen Shaw RENEWAL
Leja B RoysterJapanElwin Sharvill NEW
Morrow Z KolmetzRussiaStephen Shaw QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Wickens N RoysterGermany2024-04-18Buckley Miller Wright NEGOTIATION90Amy Elsner
1001Francesco G RulapaughBrazil2024-04-13Chanay, Jeffrey A Esq UNQUALIFIED11Xuxue Feng
1002Arvin B PerinFrance2024-04-16Rangoni Of Florence RENEWAL70Ioni Bowcher
1003Munro X VenereBrazil2024-04-10Feltz Printing Service NEW93Ivan Magalhaes
1004Chavez W DarakjyFrance2024-04-28Printing Dimensions RENEWAL62Elwin Sharvill
1005Smith H OldroydSpain2024-04-11Feiner Bros RENEWAL70Amy Elsner
1006David G AlbaresGermany2024-04-13Printing Dimensions UNQUALIFIED53Ioni Bowcher
1007Johnson L RulapaughAustralia2024-04-27Rousseaux, Michael Esq RENEWAL91Xuxue Feng
1008Cody O NickaAustralia2024-04-20Dorl, James J Esq PROPOSAL53Ivan Magalhaes
1009Darci T PoquetteItaly2024-04-16Morlong Associates PROPOSAL20Xuxue Feng
1010Murillo J PoquetteGermany2024-04-14Chapman, Ross E Esq NEW40Xuxue Feng
1011Leja Y GauchoRussia2024-04-03Buckley Miller Wright PROPOSAL24Ioni Bowcher
1012Ivar M StensethAustralia2024-04-11Rousseaux, Michael Esq UNQUALIFIED89Anna Fali
1013Octavia H BowleyRussia2024-04-24Chanay, Jeffrey A Esq UNQUALIFIED45Xuxue Feng
1014Jennifer T WhobreyRussia2024-04-10Feiner Bros QUALIFIED51Asiya Javayant
1015Costa U FerenczCanada2024-04-04Printing Dimensions PROPOSAL50Elwin Sharvill
1016Mayumi K RoysterIndia2024-04-28Chapman, Ross E Esq PROPOSAL23Ioni Bowcher
1017Ricardo A GillianItaly2024-04-13Feiner Bros RENEWAL82Ioni Bowcher
1018Chavez W GlickJapan2024-04-09Morlong Associates RENEWAL63Amy Elsner
1019Faith U NickaRussia2024-04-18Truhlar And Truhlar Attys PROPOSAL51Ivan Magalhaes
1020Munro O GarufiJapan2024-04-25Rousseaux, Michael Esq QUALIFIED90Anna Fali
1021Maisha F PaprockiRussia2024-04-04Benton, John B Jr NEW73Amy Elsner
1022Kadeem W FlosiArgentina2024-04-02Chemel, James L Cpa PROPOSAL31Elwin Sharvill
1023Julie B KolmetzUnited Kingdom2024-04-18Benton, John B Jr QUALIFIED89Stephen Shaw
1024Wickens N CaudyJapan2024-04-18Benton, John B Jr NEGOTIATION0Anna Fali
1025Chavez J StockhamItaly2024-04-04Benton, John B Jr NEGOTIATION97Bernardo Dominic
1026Francesco S AmigonFrance2024-04-27Buckley Miller Wright PROPOSAL64Elwin Sharvill
1027Stacey Y AlbaresBrazil2024-05-01Buckley Miller Wright NEGOTIATION52Xuxue Feng
1028Aditya A ChuiIndia2024-04-27Feiner Bros UNQUALIFIED61Xuxue Feng
1029Ivar P ButtJapan2024-05-01Chanay, Jeffrey A Esq QUALIFIED51Xuxue Feng
1030Jeanfrancois Q CaudySpain2024-04-15Chapman, Ross E Esq NEGOTIATION4Ioni Bowcher
1031Francesco J GauchoJapan2024-04-24Morlong Associates PROPOSAL16Stephen Shaw
1032Julie B SergiAustralia2024-04-16King, Christopher A Esq QUALIFIED0Amy Elsner
1033Sinclair I BriddickUnited Kingdom2024-04-10Buckley Miller Wright NEW66Elwin Sharvill
1034Wickens M WhobreyGermany2024-04-23Rangoni Of Florence NEGOTIATION66Onyama Limba
1035Nicolas B StockhamFrance2024-04-13Rousseaux, Michael Esq RENEWAL67Bernardo Dominic
1036Leja W WieserFrance2024-04-16Dorl, James J Esq PROPOSAL98Anna Fali
1037Clifford S CaldareraItaly2024-04-11King, Christopher A Esq QUALIFIED56Stephen Shaw
1038Adams C MarrierJapan2024-04-20King, Christopher A Esq NEGOTIATION93Bernardo Dominic
1039Jones C CampainCanada2024-04-25Chemel, James L Cpa QUALIFIED68Ioni Bowcher
1040Maria B DilliardSpain2024-04-09Feiner Bros QUALIFIED75Xuxue Feng
1041Aruna W VocelkaRussia2024-04-26Buckley Miller Wright NEW56Amy Elsner
1042Stacey C TollnerUnited Kingdom2024-04-23Morlong Associates NEGOTIATION64Bernardo Dominic
1043Darci K BriddickArgentina2024-05-01Chapman, Ross E Esq RENEWAL55Onyama Limba
1044Munro U ChuiBrazil2024-04-26Rousseaux, Michael Esq RENEWAL85Onyama Limba
1045Maria E GauchoSpain2024-05-01Benton, John B Jr UNQUALIFIED99Elwin Sharvill
1046Aruna S ShinkoGermany2024-04-23Chemel, James L Cpa NEGOTIATION87Asiya Javayant
1047Adams F VenereArgentina2024-04-15Commercial Press RENEWAL50Amy Elsner
1048Darci B PoquetteFrance2024-04-24Feltz Printing Service QUALIFIED37Xuxue Feng
1049Munro L InouyeBrazil2024-04-20Feiner Bros QUALIFIED31Asiya Javayant
Frozen Rows
NameCountryRepresentativeStatus
Ricardo L NestleIndiaAmy Elsner RENEWAL
Aruna F VenereFranceAsiya Javayant UNQUALIFIED
Isabel S FollerRussiaElwin Sharvill QUALIFIED
Maria S MacleadSpainAnna Fali PROPOSAL
Stacey R DoeBrazilAsiya Javayant NEW
Octavia S RoysterArgentinaIoni Bowcher NEW
Ivar X NestleSpainIvan Magalhaes NEGOTIATION
Ivar Y PerinSpainAnna Fali PROPOSAL
Kaitlin E PerinBrazilAmy Elsner RENEWAL
Stacey Z InouyeRussiaBernardo Dominic RENEWAL
Salvatore V DarakjyItalyBernardo Dominic UNQUALIFIED
Isabel Y MaletArgentinaOnyama Limba NEW
Juan E AlbaresCanadaOnyama Limba NEGOTIATION
Nicolas N CampainIndiaStephen Shaw QUALIFIED
Isabel Q BriddickSpainXuxue Feng PROPOSAL
Rodrigues E BologniaJapanAnna Fali QUALIFIED
Salvatore Y StockhamSpainAnna Fali UNQUALIFIED
Smith G ChuiAustraliaBernardo Dominic QUALIFIED
Tony G WieserUnited KingdomStephen Shaw QUALIFIED
Izzy J SergiFranceBernardo Dominic UNQUALIFIED
Izzy O MacleadUnited KingdomIoni Bowcher PROPOSAL
Greenwood Q FlosiFranceAnna Fali NEW
Cody H GillianSpainIvan Magalhaes PROPOSAL
Juan U DarakjyJapanAmy Elsner UNQUALIFIED
Claire W MaletGermanyAsiya Javayant QUALIFIED
David R StensethAustraliaElwin Sharvill NEGOTIATION
Octavia D PaprockiRussiaIoni Bowcher RENEWAL
Alejandro G NickaFranceXuxue Feng QUALIFIED
Jefferson K WhobreyBrazilElwin Sharvill QUALIFIED
Aditya U GillianArgentinaIoni Bowcher UNQUALIFIED
Izzy S DarakjyRussiaOnyama Limba QUALIFIED
Morrow C GillianSpainOnyama Limba QUALIFIED
Johnson P SchemmerItalyXuxue Feng UNQUALIFIED
Francesco O KolmetzJapanIoni Bowcher RENEWAL
Costa T DarakjyRussiaElwin Sharvill PROPOSAL
Francesco X MacleadBrazilAsiya Javayant QUALIFIED
Mayumi K AmigonIndiaAmy Elsner NEW
Arvin Q ShinkoUnited KingdomXuxue Feng QUALIFIED
Emily T KolmetzGermanyAsiya Javayant UNQUALIFIED
Clifford I CaudyBrazilBernardo Dominic QUALIFIED
Kadeem A AmigonBrazilAnna Fali UNQUALIFIED
Aruna S TollnerBrazilIoni Bowcher RENEWAL
Claire Q CaudyItalyIoni Bowcher NEW
Maisha Z BologniaBrazilXuxue Feng NEW
Ricardo J InouyeBrazilOnyama Limba UNQUALIFIED
Maria L MorascaArgentinaXuxue Feng PROPOSAL
Faith O ChuiRussiaBernardo Dominic PROPOSAL
Deepesh B DoeCanadaOnyama Limba UNQUALIFIED
Arvin F AmigonUnited KingdomAsiya Javayant NEGOTIATION
Maria F GarufiBrazilBernardo Dominic NEW
Frozen Columns
Name
Rodrigues L Whobrey
Tony K Albares
Juan S Kolmetz
Francesco C Albares
Wickens W Venere
Misaki C Nicka
Aika W Royster
Misaki Y Dilliard
Smith N Shinko
Johnson E Butt
Leja E Ferencz
Deepesh A Iturbide
Johnson Q Figeroa
Greenwood B Royster
Salvatore M Slusarski
Deepesh K Foller
Jefferson J Venere
Arvin E Gaucho
Alejandro O Doe
Adams I Perin
Leon R Kolmetz
Salvatore S Morasca
Juan F Malet
Francesco M Ruta
Johnson M Inouye
Mayumi Z Chui
Maisha N Paprocki
Francesco L Vocelka
Ricardo X Sergi
David T Malet
David N Gillian
Antonio S Stenseth
Cody B Vocelka
Darci B Caldarera
Isabel G Albares
Maria O Malet
Francesco Z Ostrosky
Cody K Malet
Octavia J Stockham
Ivar P Wieser
Jeanfrancois H Rim
Rodrigues L Campain
Isabel U Garufi
Jefferson B Dilliard
Maisha S Inouye
Jeanfrancois V Inouye
Claire W Garufi
Mujtaba M Royster
Maria D Wieser
Julie U Glick
IdCountryDate
1000United Kingdom2024-04-22
1001Russia2024-04-07
1002United Kingdom2024-04-27
1003Canada2024-04-24
1004Argentina2024-04-09
1005Japan2024-04-26
1006Russia2024-04-02
1007Spain2024-04-11
1008Spain2024-04-26
1009Australia2024-04-18
1010Russia2024-04-26
1011Australia2024-04-21
1012Brazil2024-04-03
1013United Kingdom2024-04-13
1014Brazil2024-04-11
1015Japan2024-04-28
1016Brazil2024-04-29
1017France2024-04-21
1018Japan2024-04-27
1019India2024-04-10
1020Canada2024-05-01
1021India2024-04-21
1022India2024-04-02
1023France2024-04-22
1024Spain2024-04-09
1025Brazil2024-04-05
1026Argentina2024-04-23
1027Germany2024-04-06
1028Germany2024-04-08
1029Australia2024-04-22
1030Argentina2024-04-27
1031United Kingdom2024-04-02
1032Italy2024-04-04
1033United Kingdom2024-04-30
1034United Kingdom2024-04-24
1035Argentina2024-04-05
1036Canada2024-04-06
1037India2024-04-25
1038Russia2024-04-27
1039France2024-05-01
1040Spain2024-04-03
1041Russia2024-04-21
1042Brazil2024-04-07
1043Spain2024-04-29
1044Brazil2024-04-07
1045India2024-04-26
1046Canada2024-04-24
1047Japan2024-04-10
1048Argentina2024-04-05
1049India2024-04-09

On-Demand Data

NameIdCountryDate
Sinclair L Slusarski1000Argentina2024-04-28
Ashley M Gillian1001Russia2024-04-07
Jennifer N Malet1002India2024-04-21
Isabel W Oldroyd1003Brazil2024-04-11
Ricardo Z Foller1004Russia2024-04-02
Chavez A Marrier1005Canada2024-04-21
Claire W Rim1006India2024-04-28
Nicolas K Caldarera1007Japan2024-04-25
Jefferson D Tollner1008Australia2024-04-05
Mujtaba A Slusarski1009Brazil2024-04-12
Deepesh W Amigon1010Italy2024-04-19
Julie C Royster1011Germany2024-04-15
Silvio K Tollner1012Japan2024-04-23
Smith F Rulapaugh1013France2024-04-29
Izzy E Gaucho1014India2024-04-09
Francesco G Kolmetz1015Canada2024-04-08
Stacey G Malet1016Russia2024-04-10
Johnson E Darakjy1017France2024-04-14
Leja R Caldarera1018Italy2024-04-27
Misaki A Rim1019Canada2024-04-23
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Kadeem Y MaletItalyAsiya Javayant NEGOTIATION
Maria S KuskoGermanyStephen Shaw QUALIFIED
Adams S GauchoSpainIoni Bowcher PROPOSAL
Costa X DoeRussiaIvan Magalhaes RENEWAL
Leon H PerinBrazilAmy Elsner QUALIFIED
Greenwood F FlosiCanadaIvan Magalhaes NEW
Costa C RulapaughUnited KingdomOnyama Limba NEGOTIATION
David V OldroydRussiaStephen Shaw NEGOTIATION
Izzy R RulapaughFranceBernardo Dominic NEGOTIATION
Cody M WieserUnited KingdomAnna Fali NEGOTIATION
Morrow N FollerIndiaAsiya Javayant NEGOTIATION
Costa E OstroskyRussiaOnyama Limba PROPOSAL
Greenwood C PerinFranceAsiya Javayant NEGOTIATION
Mujtaba F MacleadCanadaAsiya Javayant RENEWAL
Deepesh X BologniaCanadaAsiya Javayant NEW
Costa N SlusarskiJapanAnna Fali NEW
Aruna J KolmetzUnited KingdomOnyama Limba NEGOTIATION
Claire J GlickUnited KingdomStephen Shaw UNQUALIFIED
Aruna F MorascaJapanAmy Elsner NEGOTIATION
Claire Z RimUnited KingdomStephen Shaw QUALIFIED
Salvatore L PerinSpainElwin Sharvill QUALIFIED
Jeanfrancois M WieserGermanyAmy Elsner PROPOSAL
Adams X MacleadCanadaOnyama Limba NEW
Rodrigues A MaletAustraliaIvan Magalhaes QUALIFIED
Deepesh Y MarrierRussiaAmy Elsner QUALIFIED
Kaitlin G CaudyRussiaAnna Fali NEGOTIATION
Jeanfrancois T SlusarskiGermanyElwin Sharvill RENEWAL
Arvin S MaletSpainAnna Fali NEGOTIATION
Arvin K KuskoIndiaXuxue Feng NEGOTIATION
Isabel T NickaArgentinaXuxue Feng UNQUALIFIED
Johnson H GlickGermanyAnna Fali QUALIFIED
Arvin B VenereSpainElwin Sharvill UNQUALIFIED
Johnson V PaprockiBrazilIvan Magalhaes PROPOSAL
Adams E PerinGermanyIoni Bowcher NEW
Jeanfrancois L OstroskyAustraliaBernardo Dominic NEGOTIATION
Ricardo Q PoquetteAustraliaStephen Shaw QUALIFIED
Salvatore Y GlickArgentinaAnna Fali NEGOTIATION
Cody F ChuiAustraliaIoni Bowcher NEW
Jefferson A ButtIndiaElwin Sharvill UNQUALIFIED
Johnson A DoeBrazilAnna Fali RENEWAL

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