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
Greenwood K SlusarskiJapanAsiya Javayant PROPOSAL
Costa Q FlosiItalyStephen Shaw RENEWAL
Sinclair A RoysterArgentinaAsiya Javayant NEGOTIATION
Arvin K GillianCanadaAsiya Javayant QUALIFIED
Claire I KuskoArgentinaAmy Elsner NEGOTIATION
Octavia K DoeIndiaAsiya Javayant RENEWAL
Silvio T MacleadBrazilXuxue Feng RENEWAL
Ashley R NestleFranceIvan Magalhaes RENEWAL
Isabel E SchemmerFranceStephen Shaw UNQUALIFIED
Cody D NestleArgentinaIoni Bowcher NEW
Isabel I VocelkaFranceIoni Bowcher UNQUALIFIED
Smith A BriddickArgentinaAsiya Javayant RENEWAL
Aditya B VocelkaRussiaBernardo Dominic NEGOTIATION
Rodrigues W StockhamGermanyOnyama Limba UNQUALIFIED
Kadeem D CampainArgentinaStephen Shaw RENEWAL
Darci S PoquetteCanadaIoni Bowcher NEGOTIATION
Misaki H PerinArgentinaAsiya Javayant PROPOSAL
Aika C NestleSpainStephen Shaw NEW
Kadeem D InouyeCanadaIvan Magalhaes QUALIFIED
Murillo R ShinkoAustraliaAnna Fali NEW
Kadeem L WaycottUnited KingdomStephen Shaw UNQUALIFIED
Misaki Y MaletJapanElwin Sharvill NEGOTIATION
Morrow F SlusarskiIndiaOnyama Limba PROPOSAL
Antonio C FollerBrazilAnna Fali UNQUALIFIED
Cody W DarakjyIndiaIoni Bowcher QUALIFIED
Octavia B ShinkoGermanyIoni Bowcher NEW
Salvatore X CaldareraUnited KingdomIoni Bowcher RENEWAL
Adams T OldroydJapanOnyama Limba QUALIFIED
David J AlbaresItalyBernardo Dominic NEW
Ashley B CaldareraItalyAmy Elsner NEGOTIATION
Aruna C RutaBrazilStephen Shaw NEGOTIATION
Sinclair H MaletUnited KingdomElwin Sharvill RENEWAL
Isabel I KuskoArgentinaElwin Sharvill PROPOSAL
Tony B SaylorsIndiaAnna Fali QUALIFIED
Wickens J ButtGermanyOnyama Limba RENEWAL
Leja R NickaItalyOnyama Limba NEGOTIATION
Smith S WieserRussiaIoni Bowcher UNQUALIFIED
Ashley V VocelkaUnited KingdomStephen Shaw RENEWAL
Nicolas D DoeUnited KingdomAnna Fali UNQUALIFIED
Maria H RoysterCanadaAnna Fali NEW
Deepesh C WaycottArgentinaIoni Bowcher NEW
Munro J CampainIndiaAnna Fali NEGOTIATION
Ashley V StensethRussiaIvan Magalhaes NEW
Maria V DilliardSpainElwin Sharvill NEGOTIATION
Maria K PoquetteFranceOnyama Limba NEGOTIATION
Francesco J IturbideJapanIoni Bowcher QUALIFIED
Clifford A CampainUnited KingdomElwin Sharvill UNQUALIFIED
Maria B MaletItalyStephen Shaw NEGOTIATION
Adams E WaycottFranceBernardo Dominic UNQUALIFIED
Greenwood Q ChuiJapanIvan Magalhaes RENEWAL
Horizontal
NameCountryRepresentativeStatus
David E KuskoItalyAmy Elsner RENEWAL
Antonio Q ButtJapanElwin Sharvill UNQUALIFIED
Deepesh D RutaCanadaAmy Elsner UNQUALIFIED
Emily J PerinAustraliaAsiya Javayant RENEWAL
Munro F NestleJapanOnyama Limba QUALIFIED
Leon R RulapaughJapanBernardo Dominic RENEWAL
Antonio O RulapaughRussiaOnyama Limba PROPOSAL
Darci O CaudyUnited KingdomXuxue Feng NEW
Juan H DilliardArgentinaAsiya Javayant NEGOTIATION
Aditya O ButtJapanElwin Sharvill QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Arvin X KuskoBrazil2024-04-23Printing Dimensions QUALIFIED66Ivan Magalhaes
1001Jefferson F SaylorsFrance2024-04-22Commercial Press QUALIFIED94Stephen Shaw
1002Morrow Y GillianArgentina2024-04-23Chapman, Ross E Esq NEGOTIATION76Elwin Sharvill
1003Greenwood Y KolmetzAustralia2024-04-06Commercial Press NEGOTIATION74Xuxue Feng
1004Kaitlin K SchemmerArgentina2024-04-12Feiner Bros UNQUALIFIED85Asiya Javayant
1005Mayumi K FlosiFrance2024-04-16Feiner Bros NEGOTIATION13Xuxue Feng
1006Kadeem K ChuiUnited Kingdom2024-04-14King, Christopher A Esq NEGOTIATION53Onyama Limba
1007Izzy C AlbaresGermany2024-04-06Dorl, James J Esq UNQUALIFIED47Stephen Shaw
1008Maisha S KuskoFrance2024-04-01Commercial Press PROPOSAL90Elwin Sharvill
1009Silvio J GlickItaly2024-04-10Truhlar And Truhlar Attys PROPOSAL41Onyama Limba
1010Deepesh G VenereIndia2024-03-30Morlong Associates QUALIFIED10Bernardo Dominic
1011Francesco Y PerinGermany2024-04-22King, Christopher A Esq PROPOSAL62Bernardo Dominic
1012Cody D KolmetzFrance2024-03-30Chemel, James L Cpa UNQUALIFIED47Xuxue Feng
1013Emily D DoeFrance2024-04-17King, Christopher A Esq UNQUALIFIED15Elwin Sharvill
1014Izzy Y VenereArgentina2024-03-27Buckley Miller Wright QUALIFIED78Ivan Magalhaes
1015Silvio Q AmigonArgentina2024-04-09King, Christopher A Esq NEGOTIATION5Anna Fali
1016Francesco Q DarakjyArgentina2024-04-10King, Christopher A Esq NEGOTIATION35Ivan Magalhaes
1017Aditya H OstroskyRussia2024-04-05Dorl, James J Esq QUALIFIED47Elwin Sharvill
1018Darci N DoeGermany2024-04-24Morlong Associates RENEWAL78Xuxue Feng
1019Adams S MacleadArgentina2024-04-08Feltz Printing Service QUALIFIED5Amy Elsner
1020Alejandro G FollerUnited Kingdom2024-04-01Rangoni Of Florence NEGOTIATION43Ioni Bowcher
1021Salvatore C CaldareraGermany2024-04-22Commercial Press NEW69Elwin Sharvill
1022Faith A ButtCanada2024-03-31Rangoni Of Florence UNQUALIFIED42Asiya Javayant
1023Aruna V PoquetteItaly2024-04-12Morlong Associates NEW67Onyama Limba
1024Maria E VenereArgentina2024-04-16Chemel, James L Cpa UNQUALIFIED16Onyama Limba
1025Izzy H VenereJapan2024-03-27Buckley Miller Wright PROPOSAL48Elwin Sharvill
1026Silvio X AlbaresUnited Kingdom2024-04-20Rousseaux, Michael Esq RENEWAL84Ioni Bowcher
1027Ashley P PerinFrance2024-03-29Truhlar And Truhlar Attys PROPOSAL70Ioni Bowcher
1028Leja A RoysterAustralia2024-04-14Dorl, James J Esq PROPOSAL92Anna Fali
1029Adams R TollnerJapan2024-04-18Chapman, Ross E Esq UNQUALIFIED77Ivan Magalhaes
1030Murillo Y NestleGermany2024-04-21Printing Dimensions NEGOTIATION69Onyama Limba
1031Faith J RulapaughBrazil2024-04-24Dorl, James J Esq PROPOSAL6Ioni Bowcher
1032Cody I ChuiIndia2024-04-14Buckley Miller Wright NEW22Amy Elsner
1033Claire H FollerAustralia2024-04-15Buckley Miller Wright RENEWAL23Xuxue Feng
1034Munro P PaprockiSpain2024-04-20Buckley Miller Wright NEW50Ivan Magalhaes
1035Costa P WieserFrance2024-04-22Feiner Bros RENEWAL32Amy Elsner
1036Maisha G AlbaresFrance2024-04-06Dorl, James J Esq NEGOTIATION14Onyama Limba
1037James O PaprockiAustralia2024-04-06Benton, John B Jr UNQUALIFIED85Stephen Shaw
1038Munro E DarakjyFrance2024-04-10Feltz Printing Service QUALIFIED57Bernardo Dominic
1039Adams K MaletGermany2024-04-24Commercial Press UNQUALIFIED38Bernardo Dominic
1040Antonio Q DilliardArgentina2024-04-18Chanay, Jeffrey A Esq PROPOSAL3Asiya Javayant
1041Murillo Z FlosiArgentina2024-04-10Rangoni Of Florence NEGOTIATION66Onyama Limba
1042Greenwood H MarrierBrazil2024-04-07King, Christopher A Esq NEW36Ivan Magalhaes
1043Isabel Q MacleadCanada2024-04-11Printing Dimensions QUALIFIED92Ioni Bowcher
1044Claire U NickaSpain2024-04-08Dorl, James J Esq PROPOSAL80Onyama Limba
1045Leja F ShinkoJapan2024-04-18Buckley Miller Wright RENEWAL51Xuxue Feng
1046Chavez L FerenczAustralia2024-04-01Chapman, Ross E Esq UNQUALIFIED8Onyama Limba
1047Aruna I InouyeGermany2024-03-26Feltz Printing Service QUALIFIED51Onyama Limba
1048Izzy C RoysterArgentina2024-03-29Commercial Press NEGOTIATION67Ioni Bowcher
1049Jones T NickaIndia2024-03-28Buckley Miller Wright RENEWAL72Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Octavia R RulapaughJapanXuxue Feng NEGOTIATION
Izzy K StockhamSpainAsiya Javayant UNQUALIFIED
Mujtaba F WieserUnited KingdomAnna Fali NEW
Juan W NickaUnited KingdomAmy Elsner PROPOSAL
Antonio P SergiAustraliaOnyama Limba UNQUALIFIED
Johnson J FerenczArgentinaXuxue Feng NEW
David N RulapaughRussiaOnyama Limba NEGOTIATION
Costa G MarrierArgentinaStephen Shaw RENEWAL
Tony Q RimJapanAsiya Javayant QUALIFIED
Salvatore A OldroydSpainElwin Sharvill QUALIFIED
Munro V VocelkaItalyAsiya Javayant RENEWAL
Claire S BowleyIndiaAnna Fali NEGOTIATION
Mayumi H RutaUnited KingdomIoni Bowcher QUALIFIED
Jeanfrancois H VocelkaArgentinaOnyama Limba UNQUALIFIED
Smith H OldroydUnited KingdomOnyama Limba RENEWAL
Kadeem Y PerinRussiaXuxue Feng NEGOTIATION
Leon P CaldareraRussiaIoni Bowcher NEW
Leja Z FerenczRussiaElwin Sharvill NEGOTIATION
Rodrigues B GillianIndiaOnyama Limba NEW
Arvin G GarufiUnited KingdomElwin Sharvill RENEWAL
Isabel N CampainGermanyIoni Bowcher UNQUALIFIED
Maria X FollerJapanOnyama Limba UNQUALIFIED
Stacey K SchemmerCanadaXuxue Feng RENEWAL
Arvin O TollnerUnited KingdomStephen Shaw RENEWAL
Aruna O GarufiRussiaXuxue Feng NEGOTIATION
Juan P GlickJapanIvan Magalhaes UNQUALIFIED
Wickens F MorascaAustraliaElwin Sharvill PROPOSAL
Octavia S FollerUnited KingdomIvan Magalhaes NEGOTIATION
Maria V SlusarskiIndiaAnna Fali PROPOSAL
Ivar U GauchoBrazilIvan Magalhaes PROPOSAL
Izzy N MarrierArgentinaBernardo Dominic NEGOTIATION
Ashley K NestleRussiaStephen Shaw NEGOTIATION
Chavez I TollnerRussiaIoni Bowcher NEGOTIATION
Nicolas G StockhamGermanyStephen Shaw RENEWAL
Costa P OldroydCanadaIoni Bowcher NEGOTIATION
Salvatore O WaycottItalyBernardo Dominic NEGOTIATION
Sinclair J FigeroaItalyOnyama Limba NEGOTIATION
Jones P MacleadJapanIvan Magalhaes PROPOSAL
Johnson R PoquetteIndiaAnna Fali RENEWAL
Emily T SchemmerRussiaStephen Shaw NEGOTIATION
Silvio V BowleyArgentinaElwin Sharvill PROPOSAL
David J PerinArgentinaIvan Magalhaes QUALIFIED
Greenwood Z RutaFranceAnna Fali NEGOTIATION
Darci Y PerinBrazilOnyama Limba UNQUALIFIED
Johnson J GillianIndiaElwin Sharvill QUALIFIED
Sinclair I AlbaresArgentinaIoni Bowcher NEW
Silvio Q RutaJapanAsiya Javayant UNQUALIFIED
Nicolas C FerenczSpainOnyama Limba UNQUALIFIED
Nicolas G CaudyAustraliaAmy Elsner QUALIFIED
Clifford D PoquetteAustraliaElwin Sharvill PROPOSAL
Frozen Columns
Name
Tony Q Poquette
Ivar Z Gaucho
Leja W Garufi
Aika L Vocelka
Isabel V Kolmetz
Maria U Gaucho
Alejandro E Sergi
Salvatore H Nicka
Izzy V Caudy
Jennifer T Stenseth
Silvio J Perin
Costa A Flosi
Maria Q Ostrosky
Morrow W Gillian
James X Kusko
Faith X Darakjy
Aditya T Nicka
Julie V Darakjy
Julie H Morasca
Costa L Venere
Maisha I Wieser
Jones N Paprocki
Johnson A Rim
Alejandro R Flosi
Darci T Vocelka
Salvatore J Whobrey
Munro H Tollner
Ivar Q Sergi
Jefferson C Shinko
Emily Y Bolognia
Darci E Ostrosky
Rodrigues Y Foller
Darci V Perin
Julie H Nestle
Kadeem Q Bowley
Claire A Maclead
Stacey Y Poquette
Johnson V Briddick
Aika G Venere
Arvin Z Campain
Aruna A Poquette
Kaitlin M Doe
Murillo W Rim
Ivar S Amigon
Darci C Chui
Leja Q Malet
Clifford Z Waycott
Arvin G Malet
Tony S Gillian
Francesco G Nicka
IdCountryDate
1000India2024-04-10
1001Canada2024-04-18
1002Italy2024-04-07
1003Germany2024-03-29
1004Russia2024-04-13
1005Japan2024-04-15
1006Germany2024-04-19
1007Argentina2024-04-02
1008Spain2024-04-19
1009India2024-03-29
1010India2024-03-27
1011France2024-04-19
1012India2024-03-27
1013Japan2024-04-24
1014Canada2024-04-16
1015India2024-04-16
1016India2024-03-26
1017Canada2024-04-11
1018Japan2024-04-16
1019Canada2024-03-30
1020Japan2024-04-02
1021Argentina2024-04-22
1022India2024-03-31
1023Germany2024-04-22
1024Brazil2024-03-31
1025United Kingdom2024-04-16
1026Australia2024-04-05
1027India2024-04-15
1028Brazil2024-04-04
1029Canada2024-04-11
1030France2024-03-30
1031United Kingdom2024-04-20
1032Italy2024-04-09
1033Canada2024-04-19
1034France2024-04-18
1035Argentina2024-04-18
1036Canada2024-04-10
1037France2024-04-01
1038France2024-03-28
1039United Kingdom2024-04-09
1040Spain2024-04-23
1041Italy2024-04-11
1042Spain2024-04-08
1043India2024-03-31
1044Germany2024-04-19
1045United Kingdom2024-04-01
1046Argentina2024-04-15
1047Australia2024-04-14
1048Russia2024-04-16
1049Spain2024-04-10

On-Demand Data

NameIdCountryDate
Adams S Gaucho1000Italy2024-04-09
Salvatore H Saylors1001Spain2024-04-03
Smith E Paprocki1002Russia2024-03-30
Ivar P Butt1003Australia2024-04-06
Leja X Schemmer1004France2024-04-15
Costa P Rulapaugh1005Italy2024-04-07
Wickens B Maclead1006Russia2024-04-17
Maisha W Flosi1007France2024-04-12
Faith T Iturbide1008Russia2024-04-23
Leon B Bowley1009United Kingdom2024-04-16
Aditya T Marrier1010Japan2024-04-19
Jennifer Z Sergi1011India2024-04-20
Smith U Flosi1012France2024-04-15
Wickens R Garufi1013Japan2024-04-14
Mujtaba W Poquette1014Canada2024-03-26
Francesco A Chui1015Italy2024-04-03
James M Campain1016Argentina2024-04-09
Ricardo R Figeroa1017India2024-04-14
Isabel V Amigon1018United Kingdom2024-04-01
Rodrigues G Marrier1019Spain2024-04-01
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aditya J SchemmerUnited KingdomElwin Sharvill PROPOSAL
Mujtaba U NestleItalyXuxue Feng RENEWAL
Morrow N StensethJapanAnna Fali UNQUALIFIED
Aruna X GauchoSpainElwin Sharvill QUALIFIED
Murillo B CaldareraItalyXuxue Feng NEW
Francesco Y GauchoJapanElwin Sharvill QUALIFIED
Isabel X AlbaresFranceAmy Elsner QUALIFIED
David Q SaylorsFranceElwin Sharvill UNQUALIFIED
Isabel U SchemmerGermanyAsiya Javayant RENEWAL
Kaitlin B DarakjyBrazilBernardo Dominic UNQUALIFIED
David L IturbideAustraliaAmy Elsner QUALIFIED
Sinclair M OldroydItalyOnyama Limba NEW
Ashley W ShinkoJapanOnyama Limba NEW
Sinclair Z BologniaIndiaOnyama Limba NEGOTIATION
Leja W ButtCanadaXuxue Feng QUALIFIED
Kaitlin R DilliardItalyElwin Sharvill PROPOSAL
Cody T CampainJapanElwin Sharvill QUALIFIED
Maisha V VenereBrazilBernardo Dominic NEGOTIATION
Maria G VocelkaBrazilIoni Bowcher NEW
Jefferson L GlickItalyAmy Elsner PROPOSAL
Misaki G OstroskyFranceStephen Shaw PROPOSAL
Murillo K PerinArgentinaBernardo Dominic NEGOTIATION
Nicolas U MarrierUnited KingdomAnna Fali QUALIFIED
Antonio H GarufiSpainOnyama Limba NEGOTIATION
Smith A TollnerBrazilAmy Elsner PROPOSAL
Sinclair J VenereArgentinaIoni Bowcher RENEWAL
Ashley F TollnerUnited KingdomAmy Elsner QUALIFIED
Leja N KolmetzFranceIoni Bowcher PROPOSAL
Johnson G BologniaAustraliaXuxue Feng NEW
Jones D DarakjyFranceStephen Shaw NEW
Morrow A InouyeFranceAmy Elsner QUALIFIED
Antonio C RutaItalyIvan Magalhaes RENEWAL
Clifford P SlusarskiArgentinaAnna Fali NEGOTIATION
Kaitlin N MorascaSpainBernardo Dominic PROPOSAL
Deepesh T GlickJapanOnyama Limba QUALIFIED
James K InouyeBrazilBernardo Dominic UNQUALIFIED
Francesco B PerinGermanyAnna Fali NEW
Deepesh F WieserCanadaIvan Magalhaes RENEWAL
Murillo Y CampainGermanyStephen Shaw NEW
Arvin L MorascaSpainIoni Bowcher NEGOTIATION

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