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
Aditya J FigeroaItalyAnna Fali NEW
Maisha O MaletBrazilElwin Sharvill RENEWAL
Murillo C MaletRussiaIoni Bowcher RENEWAL
Deepesh V PaprockiUnited KingdomAmy Elsner PROPOSAL
Aika Q CampainRussiaElwin Sharvill NEW
Isabel W RutaItalyIoni Bowcher QUALIFIED
Aruna I BowleyBrazilElwin Sharvill PROPOSAL
Faith L TollnerItalyIoni Bowcher PROPOSAL
Clifford Y RoysterArgentinaAsiya Javayant NEW
Silvio V AmigonGermanyAnna Fali NEW
Antonio X SchemmerIndiaStephen Shaw NEGOTIATION
Salvatore A MaletAustraliaIoni Bowcher PROPOSAL
Johnson K SlusarskiUnited KingdomAmy Elsner NEW
James D BowleyIndiaAmy Elsner UNQUALIFIED
Aika R MorascaArgentinaXuxue Feng NEW
Kadeem I FlosiFranceStephen Shaw NEW
David L CaudyJapanElwin Sharvill NEW
Cody V FerenczArgentinaAmy Elsner UNQUALIFIED
Kaitlin P CaudyItalyAmy Elsner PROPOSAL
Clifford W WieserBrazilAmy Elsner UNQUALIFIED
Smith C MarrierAustraliaXuxue Feng UNQUALIFIED
Jefferson U PaprockiAustraliaAmy Elsner NEGOTIATION
Aditya F FigeroaIndiaAmy Elsner RENEWAL
Greenwood P StensethBrazilAsiya Javayant UNQUALIFIED
Leon D IturbideCanadaIvan Magalhaes UNQUALIFIED
Costa G PoquetteFranceXuxue Feng UNQUALIFIED
Arvin P GillianUnited KingdomAnna Fali PROPOSAL
Isabel L AlbaresArgentinaElwin Sharvill NEW
Mujtaba K GauchoGermanyStephen Shaw NEGOTIATION
Silvio C VocelkaUnited KingdomIvan Magalhaes PROPOSAL
Ricardo G FerenczJapanXuxue Feng NEW
Morrow D SaylorsUnited KingdomAmy Elsner UNQUALIFIED
Aika W OldroydJapanAnna Fali PROPOSAL
Jones A OstroskyAustraliaAnna Fali UNQUALIFIED
Juan V PerinArgentinaElwin Sharvill RENEWAL
Claire F NickaUnited KingdomAnna Fali RENEWAL
Leja Q SaylorsBrazilAmy Elsner RENEWAL
Silvio N ShinkoAustraliaStephen Shaw PROPOSAL
Tony R WaycottFranceBernardo Dominic UNQUALIFIED
Tony E PerinBrazilStephen Shaw UNQUALIFIED
Costa F SaylorsArgentinaXuxue Feng QUALIFIED
Cody M AmigonJapanOnyama Limba QUALIFIED
Munro B AmigonItalyAmy Elsner UNQUALIFIED
Aditya L TollnerAustraliaXuxue Feng PROPOSAL
Wickens U ShinkoSpainIvan Magalhaes PROPOSAL
Mayumi U BowleyJapanStephen Shaw RENEWAL
Wickens G TollnerArgentinaStephen Shaw PROPOSAL
Chavez X WaycottUnited KingdomStephen Shaw RENEWAL
Costa L RulapaughIndiaIoni Bowcher NEW
Juan R InouyeUnited KingdomOnyama Limba NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Maria S CaudyRussiaElwin Sharvill PROPOSAL
Nicolas Y StockhamUnited KingdomIvan Magalhaes QUALIFIED
Morrow Q RutaFranceBernardo Dominic NEGOTIATION
Rodrigues F VenereItalyOnyama Limba RENEWAL
Cody W WieserItalyIvan Magalhaes PROPOSAL
Wickens O FollerAustraliaIvan Magalhaes UNQUALIFIED
Darci X SaylorsItalyOnyama Limba NEGOTIATION
Stacey Y MaletRussiaXuxue Feng UNQUALIFIED
Nicolas I SlusarskiGermanyAnna Fali UNQUALIFIED
Juan P MorascaUnited KingdomIvan Magalhaes NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Aruna Y MacleadFrance2024-03-27Feltz Printing Service UNQUALIFIED50Asiya Javayant
1001Leja Y OstroskyIndia2024-03-30Rangoni Of Florence RENEWAL44Stephen Shaw
1002Alejandro D FollerSpain2024-04-13Morlong Associates PROPOSAL4Bernardo Dominic
1003Ivar P SaylorsFrance2024-04-12Benton, John B Jr NEGOTIATION23Anna Fali
1004Alejandro U DoeBrazil2024-04-09Morlong Associates RENEWAL48Ivan Magalhaes
1005Murillo V GillianUnited Kingdom2024-04-01Benton, John B Jr PROPOSAL67Stephen Shaw
1006Tony O SlusarskiArgentina2024-03-26Printing Dimensions NEW65Anna Fali
1007Ricardo A WhobreyIndia2024-03-27Chanay, Jeffrey A Esq PROPOSAL36Ivan Magalhaes
1008Rodrigues I VenereUnited Kingdom2024-04-18Feiner Bros RENEWAL31Asiya Javayant
1009Sinclair T WieserSpain2024-04-24Chemel, James L Cpa UNQUALIFIED94Ivan Magalhaes
1010Mayumi X FerenczFrance2024-04-11Buckley Miller Wright UNQUALIFIED65Bernardo Dominic
1011Aruna D IturbideUnited Kingdom2024-04-18Feiner Bros UNQUALIFIED37Amy Elsner
1012Kadeem Y NickaSpain2024-03-30Chemel, James L Cpa NEGOTIATION20Amy Elsner
1013Wickens I GauchoArgentina2024-04-12Rangoni Of Florence RENEWAL64Ivan Magalhaes
1014James S IturbideArgentina2024-04-23Feiner Bros NEW31Ioni Bowcher
1015Julie D VenereUnited Kingdom2024-03-29Feiner Bros NEGOTIATION83Bernardo Dominic
1016Costa Y FigeroaGermany2024-04-08Dorl, James J Esq NEGOTIATION27Xuxue Feng
1017Julie L SergiItaly2024-04-01Chemel, James L Cpa NEW32Anna Fali
1018Murillo M MaletFrance2024-04-22Benton, John B Jr PROPOSAL68Onyama Limba
1019Maria K NickaJapan2024-04-05Buckley Miller Wright UNQUALIFIED83Onyama Limba
1020James E DilliardRussia2024-04-19Feiner Bros UNQUALIFIED81Amy Elsner
1021Munro R CaudyIndia2024-03-31Benton, John B Jr RENEWAL31Asiya Javayant
1022Tony V RoysterAustralia2024-03-27Feiner Bros PROPOSAL43Stephen Shaw
1023Morrow X StockhamBrazil2024-04-13Rousseaux, Michael Esq NEGOTIATION99Ivan Magalhaes
1024Ricardo N CaudyIndia2024-04-14King, Christopher A Esq UNQUALIFIED31Xuxue Feng
1025Isabel U SchemmerAustralia2024-04-04Printing Dimensions PROPOSAL11Stephen Shaw
1026Murillo P OldroydGermany2024-04-01Morlong Associates NEW85Asiya Javayant
1027Francesco T TollnerArgentina2024-04-14Rangoni Of Florence QUALIFIED67Bernardo Dominic
1028Rodrigues E AmigonIndia2024-04-16Chemel, James L Cpa UNQUALIFIED60Stephen Shaw
1029Wickens S CampainCanada2024-04-17Truhlar And Truhlar Attys UNQUALIFIED61Stephen Shaw
1030Murillo E AlbaresFrance2024-04-17Rousseaux, Michael Esq PROPOSAL19Amy Elsner
1031Aditya B KuskoBrazil2024-04-23Benton, John B Jr UNQUALIFIED36Amy Elsner
1032Nicolas H NickaRussia2024-04-20Dorl, James J Esq NEW34Amy Elsner
1033Jennifer D FerenczItaly2024-04-09Rangoni Of Florence RENEWAL36Asiya Javayant
1034Octavia U RutaArgentina2024-03-31Truhlar And Truhlar Attys RENEWAL58Stephen Shaw
1035Ricardo O KolmetzSpain2024-04-21Rangoni Of Florence UNQUALIFIED28Xuxue Feng
1036Nicolas V WaycottIndia2024-04-01Morlong Associates PROPOSAL84Anna Fali
1037Nicolas A SergiUnited Kingdom2024-04-08Rangoni Of Florence UNQUALIFIED85Stephen Shaw
1038Jefferson L AmigonSpain2024-04-05Chemel, James L Cpa NEW10Anna Fali
1039Smith B FollerBrazil2024-04-21Dorl, James J Esq NEW82Xuxue Feng
1040Tony B RoysterFrance2024-04-21Chapman, Ross E Esq NEGOTIATION68Bernardo Dominic
1041Adams K OstroskyFrance2024-04-23Buckley Miller Wright UNQUALIFIED7Ivan Magalhaes
1042Chavez M SchemmerArgentina2024-04-17Rangoni Of Florence UNQUALIFIED69Anna Fali
1043Smith Y OldroydAustralia2024-04-23Feiner Bros UNQUALIFIED13Ivan Magalhaes
1044Emily E ShinkoBrazil2024-04-20Printing Dimensions RENEWAL22Asiya Javayant
1045Claire E GauchoBrazil2024-04-03Chapman, Ross E Esq PROPOSAL66Bernardo Dominic
1046Jennifer A FlosiJapan2024-04-14Printing Dimensions UNQUALIFIED56Xuxue Feng
1047Sinclair J PaprockiUnited Kingdom2024-04-15Benton, John B Jr NEW13Ioni Bowcher
1048Smith H NickaIndia2024-04-08Truhlar And Truhlar Attys NEGOTIATION89Xuxue Feng
1049Jones H SlusarskiIndia2024-03-27Commercial Press RENEWAL17Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Aditya H WieserIndiaAmy Elsner NEW
Kadeem K FollerCanadaIoni Bowcher NEGOTIATION
David A DilliardItalyElwin Sharvill NEGOTIATION
Aditya J ButtIndiaIoni Bowcher UNQUALIFIED
Murillo D FollerGermanyAnna Fali RENEWAL
Greenwood R SchemmerGermanyBernardo Dominic QUALIFIED
Clifford U WhobreyArgentinaIoni Bowcher NEW
Faith L MacleadGermanyElwin Sharvill NEW
Cody Z DilliardBrazilAnna Fali QUALIFIED
Francesco D GarufiFranceStephen Shaw QUALIFIED
Misaki E BowleyCanadaAmy Elsner UNQUALIFIED
Jones K NickaArgentinaIoni Bowcher NEGOTIATION
Deepesh N CampainGermanyIoni Bowcher NEGOTIATION
David I PaprockiGermanyAnna Fali NEW
Jeanfrancois Y FerenczSpainStephen Shaw NEW
Smith U TollnerJapanAsiya Javayant UNQUALIFIED
Ashley A VocelkaRussiaOnyama Limba NEGOTIATION
Mujtaba X NestleIndiaAsiya Javayant NEGOTIATION
David F RutaArgentinaXuxue Feng PROPOSAL
Faith R NickaSpainAmy Elsner NEGOTIATION
David B PerinArgentinaBernardo Dominic PROPOSAL
Maisha B FollerUnited KingdomElwin Sharvill PROPOSAL
Chavez Y OstroskyJapanIoni Bowcher RENEWAL
Munro A VenereItalyOnyama Limba PROPOSAL
Cody Q FlosiIndiaAnna Fali NEGOTIATION
Izzy H DilliardFranceBernardo Dominic NEW
Cody X PerinItalyStephen Shaw RENEWAL
Antonio N SaylorsCanadaElwin Sharvill NEGOTIATION
Kadeem J StensethFranceAnna Fali QUALIFIED
James N PerinCanadaIvan Magalhaes NEGOTIATION
Aika O MaletArgentinaIvan Magalhaes QUALIFIED
Arvin G CampainSpainBernardo Dominic NEW
Juan B MorascaGermanyXuxue Feng NEW
Munro G OldroydItalyOnyama Limba UNQUALIFIED
Antonio N RutaArgentinaAmy Elsner RENEWAL
James X CaudyRussiaOnyama Limba NEW
Cody M PerinSpainIoni Bowcher NEGOTIATION
Leja R InouyeAustraliaAnna Fali PROPOSAL
Maria L MacleadGermanyAmy Elsner NEW
Johnson L InouyeUnited KingdomIoni Bowcher UNQUALIFIED
David X FigeroaJapanStephen Shaw QUALIFIED
Aika H WhobreyArgentinaBernardo Dominic NEW
Aditya I PoquetteUnited KingdomIoni Bowcher NEW
Munro B DilliardIndiaAsiya Javayant QUALIFIED
Faith H WhobreyJapanIvan Magalhaes NEGOTIATION
Maria U RoysterAustraliaBernardo Dominic NEGOTIATION
Jefferson X RoysterItalyAmy Elsner UNQUALIFIED
Jefferson V DoeUnited KingdomXuxue Feng NEW
Silvio H SaylorsGermanyAmy Elsner QUALIFIED
Jeanfrancois B BologniaJapanXuxue Feng NEW
Frozen Columns
Name
Mayumi S Stenseth
Adams K Glick
Octavia L Kusko
Kaitlin W Butt
Faith B Waycott
Francesco Y Paprocki
Rodrigues Z Stockham
Stacey B Perin
Munro O Malet
Rodrigues S Marrier
Octavia D Malet
Nicolas A Kusko
Ashley Q Bowley
Mayumi P Ruta
Octavia K Ferencz
Jefferson I Maclead
Jones R Caudy
Misaki K Gaucho
David M Whobrey
Aika Y Garufi
Wickens L Iturbide
Antonio S Darakjy
Jones K Figeroa
Kaitlin Q Malet
Stacey O Briddick
Faith A Iturbide
Misaki X Stenseth
Silvio Q Stenseth
Julie K Caldarera
Murillo N Slusarski
Murillo K Chui
Aika N Royster
Claire J Rulapaugh
Morrow H Amigon
Isabel C Foller
Nicolas H Kolmetz
Izzy B Whobrey
David H Royster
Deepesh F Venere
Jefferson C Caudy
Izzy B Marrier
Alejandro D Stenseth
Aruna O Inouye
Morrow I Albares
Deepesh Z Ostrosky
Greenwood E Shinko
Johnson N Bolognia
Ricardo O Ruta
David J Darakjy
Costa V Poquette
IdCountryDate
1000Canada2024-04-12
1001Spain2024-04-10
1002Brazil2024-04-02
1003India2024-04-11
1004Australia2024-04-09
1005Australia2024-04-12
1006Brazil2024-04-22
1007Italy2024-04-14
1008Japan2024-04-08
1009Italy2024-04-20
1010Japan2024-03-26
1011Russia2024-04-11
1012France2024-03-30
1013Argentina2024-04-13
1014Italy2024-03-27
1015Canada2024-03-31
1016France2024-04-12
1017Australia2024-04-03
1018Japan2024-04-14
1019France2024-04-17
1020United Kingdom2024-04-05
1021United Kingdom2024-04-02
1022Italy2024-03-29
1023France2024-04-13
1024Canada2024-04-11
1025United Kingdom2024-04-09
1026Russia2024-04-09
1027Australia2024-04-23
1028Japan2024-03-27
1029Spain2024-03-30
1030France2024-03-29
1031Germany2024-04-21
1032Germany2024-04-21
1033Australia2024-04-05
1034Spain2024-04-16
1035India2024-03-30
1036Argentina2024-04-23
1037Brazil2024-04-17
1038Australia2024-04-10
1039Australia2024-04-20
1040Canada2024-04-09
1041Argentina2024-04-13
1042Argentina2024-03-29
1043Australia2024-04-13
1044Australia2024-03-26
1045Russia2024-04-01
1046Australia2024-04-14
1047Argentina2024-03-27
1048Spain2024-03-28
1049Italy2024-04-04

On-Demand Data

NameIdCountryDate
Misaki K Venere1000Australia2024-03-26
Alejandro K Maclead1001Russia2024-04-14
Francesco K Inouye1002Brazil2024-04-24
Leon K Figeroa1003Canada2024-04-16
Emily V Ostrosky1004Australia2024-04-11
Jones G Dilliard1005Spain2024-04-17
James D Chui1006Argentina2024-04-24
Clifford F Caudy1007Australia2024-04-17
Aruna B Maclead1008Germany2024-04-16
Emily L Caldarera1009Italy2024-04-13
Chavez X Campain1010Japan2024-04-19
Maisha G Kusko1011France2024-04-01
Juan S Wieser1012United Kingdom2024-04-20
Leja B Slusarski1013Germany2024-04-23
Octavia D Kusko1014Italy2024-04-02
Jennifer H Campain1015Brazil2024-04-06
Julie H Stenseth1016France2024-04-05
Munro T Ruta1017Italy2024-04-07
Cody D Amigon1018India2024-04-14
Faith O Ruta1019Italy2024-04-14
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aika P TollnerArgentinaXuxue Feng NEGOTIATION
Stacey I AlbaresGermanyIvan Magalhaes UNQUALIFIED
Munro X GillianItalyIvan Magalhaes RENEWAL
Ashley O BriddickRussiaAmy Elsner PROPOSAL
Adams B FollerRussiaAnna Fali PROPOSAL
Antonio T OldroydRussiaOnyama Limba NEW
David K BowleyRussiaElwin Sharvill RENEWAL
Tony I IturbideCanadaAsiya Javayant PROPOSAL
Julie X AlbaresIndiaOnyama Limba UNQUALIFIED
David Q NestleFranceOnyama Limba NEGOTIATION
Mujtaba Q RutaAustraliaElwin Sharvill NEW
Mujtaba K OldroydBrazilAmy Elsner QUALIFIED
Johnson E WaycottJapanIoni Bowcher NEGOTIATION
Francesco K WhobreyGermanyOnyama Limba RENEWAL
Adams H VenereSpainOnyama Limba NEGOTIATION
Kaitlin L TollnerArgentinaAmy Elsner UNQUALIFIED
Salvatore E WhobreyBrazilXuxue Feng NEGOTIATION
Leja G GarufiRussiaStephen Shaw PROPOSAL
Smith R MaletItalyAsiya Javayant UNQUALIFIED
Jennifer K PoquetteGermanyXuxue Feng NEW
Stacey Q DarakjyCanadaBernardo Dominic QUALIFIED
Octavia W ButtBrazilAmy Elsner QUALIFIED
Jennifer W StensethGermanyIoni Bowcher NEW
Ricardo R InouyeUnited KingdomBernardo Dominic RENEWAL
Mayumi D GauchoSpainElwin Sharvill NEW
Faith N DarakjyUnited KingdomBernardo Dominic NEW
Francesco Z PoquetteFranceElwin Sharvill UNQUALIFIED
Aika N WaycottJapanAmy Elsner RENEWAL
Ivar N KuskoBrazilIoni Bowcher QUALIFIED
Aditya K VocelkaSpainAnna Fali PROPOSAL
Emily V RutaGermanyAmy Elsner NEGOTIATION
Kaitlin B SaylorsAustraliaBernardo Dominic QUALIFIED
Faith W MarrierBrazilOnyama Limba QUALIFIED
Darci M FigeroaBrazilElwin Sharvill UNQUALIFIED
Kadeem K DoeBrazilStephen Shaw PROPOSAL
Mayumi H WaycottIndiaAsiya Javayant NEGOTIATION
Leja V AmigonUnited KingdomXuxue Feng QUALIFIED
Deepesh M AlbaresRussiaIvan Magalhaes UNQUALIFIED
Antonio D AmigonAustraliaAnna Fali RENEWAL
Leja V CaldareraCanadaXuxue Feng 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>