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
Aruna C WhobreyIndiaIoni Bowcher PROPOSAL
Morrow R KolmetzGermanyAnna Fali UNQUALIFIED
Aika X GlickAustraliaOnyama Limba QUALIFIED
Johnson S GillianAustraliaIvan Magalhaes NEGOTIATION
Leja X FollerBrazilStephen Shaw UNQUALIFIED
Izzy O OstroskyJapanAsiya Javayant PROPOSAL
Costa K OldroydRussiaBernardo Dominic PROPOSAL
Mujtaba V FollerJapanBernardo Dominic RENEWAL
Sinclair G CaldareraJapanStephen Shaw NEW
Emily P FollerBrazilStephen Shaw NEGOTIATION
Rodrigues F FlosiBrazilXuxue Feng QUALIFIED
Darci O FlosiIndiaBernardo Dominic NEGOTIATION
James Q KolmetzArgentinaStephen Shaw PROPOSAL
Emily Z CaldareraBrazilOnyama Limba PROPOSAL
Ricardo W OstroskyFranceBernardo Dominic QUALIFIED
Cody I CaudyUnited KingdomOnyama Limba RENEWAL
Salvatore R MaletJapanAsiya Javayant RENEWAL
Mayumi D CampainIndiaElwin Sharvill RENEWAL
Ricardo A GauchoJapanBernardo Dominic UNQUALIFIED
Aditya J SchemmerAustraliaAmy Elsner PROPOSAL
Misaki Z InouyeCanadaIvan Magalhaes PROPOSAL
Antonio C WaycottRussiaStephen Shaw PROPOSAL
Stacey X BologniaBrazilBernardo Dominic RENEWAL
Misaki C PaprockiFranceAsiya Javayant RENEWAL
Sinclair C VenereAustraliaAsiya Javayant QUALIFIED
Mujtaba E CaldareraJapanXuxue Feng NEW
Faith A SergiRussiaIvan Magalhaes PROPOSAL
Maisha N FerenczGermanyIoni Bowcher NEGOTIATION
James X OldroydCanadaAnna Fali NEW
Octavia F SlusarskiGermanyIvan Magalhaes NEW
Murillo S NestleCanadaIvan Magalhaes UNQUALIFIED
Deepesh N VocelkaItalyBernardo Dominic NEGOTIATION
Aditya O PoquetteBrazilStephen Shaw UNQUALIFIED
Deepesh F VenereRussiaIvan Magalhaes UNQUALIFIED
Deepesh N SlusarskiGermanyStephen Shaw PROPOSAL
Claire Q MacleadCanadaStephen Shaw NEGOTIATION
Salvatore Y BologniaItalyAnna Fali RENEWAL
Sinclair Z FlosiJapanAmy Elsner NEGOTIATION
Ricardo D OstroskyArgentinaIvan Magalhaes UNQUALIFIED
Murillo Y MaletCanadaXuxue Feng QUALIFIED
Isabel W WieserJapanOnyama Limba NEW
Juan O MaletArgentinaOnyama Limba NEGOTIATION
Stacey N VocelkaJapanAmy Elsner RENEWAL
Darci E KolmetzItalyStephen Shaw UNQUALIFIED
Johnson M FollerIndiaElwin Sharvill PROPOSAL
Leja B GillianArgentinaIoni Bowcher QUALIFIED
Juan B SergiGermanyIoni Bowcher NEW
Ivar B WieserUnited KingdomAnna Fali UNQUALIFIED
Ricardo B MaletJapanXuxue Feng RENEWAL
Sinclair M KuskoRussiaAsiya Javayant UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Leon V StensethIndiaAmy Elsner UNQUALIFIED
Deepesh O BriddickAustraliaIoni Bowcher NEW
Nicolas R IturbideArgentinaAnna Fali NEW
Silvio Q AlbaresIndiaElwin Sharvill UNQUALIFIED
Silvio F FlosiItalyStephen Shaw PROPOSAL
Octavia S BologniaFranceBernardo Dominic QUALIFIED
Faith C BologniaIndiaOnyama Limba UNQUALIFIED
Munro P AlbaresGermanyBernardo Dominic QUALIFIED
Aika X WieserArgentinaIoni Bowcher RENEWAL
Kaitlin H PaprockiIndiaBernardo Dominic UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Ivar I StensethArgentina2024-04-09Printing Dimensions UNQUALIFIED82Asiya Javayant
1001Mayumi N PaprockiBrazil2024-03-27Chanay, Jeffrey A Esq RENEWAL2Onyama Limba
1002Rodrigues P BologniaArgentina2024-04-24Feltz Printing Service NEGOTIATION67Elwin Sharvill
1003Johnson C ChuiArgentina2024-04-03Morlong Associates UNQUALIFIED49Anna Fali
1004Darci M FerenczItaly2024-04-17Rousseaux, Michael Esq UNQUALIFIED85Anna Fali
1005Aruna V SergiBrazil2024-04-05Dorl, James J Esq QUALIFIED86Xuxue Feng
1006Silvio S WhobreyBrazil2024-04-07Buckley Miller Wright QUALIFIED48Stephen Shaw
1007Maisha H KolmetzCanada2024-04-11Feiner Bros UNQUALIFIED89Ioni Bowcher
1008Francesco Y FollerArgentina2024-04-18Benton, John B Jr NEGOTIATION6Onyama Limba
1009Alejandro X MaletIndia2024-04-24Commercial Press QUALIFIED92Onyama Limba
1010Maria M SaylorsFrance2024-04-12Feiner Bros QUALIFIED6Ioni Bowcher
1011Costa Y VenereRussia2024-04-25Commercial Press UNQUALIFIED37Asiya Javayant
1012Maria V ButtUnited Kingdom2024-04-20Morlong Associates NEGOTIATION86Ioni Bowcher
1013Maisha A StockhamBrazil2024-04-05Dorl, James J Esq NEGOTIATION17Ioni Bowcher
1014Mayumi N DarakjyCanada2024-04-15Feltz Printing Service NEGOTIATION40Stephen Shaw
1015Jeanfrancois Z InouyeAustralia2024-04-09Truhlar And Truhlar Attys PROPOSAL79Stephen Shaw
1016Izzy L IturbideArgentina2024-04-12Feltz Printing Service QUALIFIED68Anna Fali
1017Faith H StockhamAustralia2024-04-05Chanay, Jeffrey A Esq NEGOTIATION4Asiya Javayant
1018Isabel K GarufiItaly2024-04-12Rangoni Of Florence RENEWAL22Stephen Shaw
1019Rodrigues C WaycottUnited Kingdom2024-04-09Printing Dimensions NEW53Ioni Bowcher
1020David T GarufiBrazil2024-04-23Chanay, Jeffrey A Esq NEGOTIATION79Elwin Sharvill
1021Sinclair R SchemmerSpain2024-03-29Feiner Bros RENEWAL74Amy Elsner
1022Misaki E ButtCanada2024-04-06King, Christopher A Esq RENEWAL37Xuxue Feng
1023Jennifer J OldroydCanada2024-04-09Chemel, James L Cpa PROPOSAL94Bernardo Dominic
1024Wickens D InouyeSpain2024-04-22Printing Dimensions NEW58Ivan Magalhaes
1025Sinclair O RimUnited Kingdom2024-04-12Dorl, James J Esq RENEWAL68Asiya Javayant
1026Aika U DoeAustralia2024-04-14Truhlar And Truhlar Attys PROPOSAL68Ioni Bowcher
1027Maisha C AmigonGermany2024-04-09Benton, John B Jr PROPOSAL94Ioni Bowcher
1028Tony Y DilliardBrazil2024-04-20Printing Dimensions RENEWAL78Ioni Bowcher
1029Chavez I ButtBrazil2024-04-11Morlong Associates NEGOTIATION66Ioni Bowcher
1030Munro Z CaudyAustralia2024-04-10Truhlar And Truhlar Attys PROPOSAL83Ioni Bowcher
1031Costa Z FlosiCanada2024-04-07Truhlar And Truhlar Attys QUALIFIED55Ioni Bowcher
1032Jennifer N PerinAustralia2024-04-10Dorl, James J Esq NEW47Elwin Sharvill
1033Ricardo S MacleadItaly2024-04-25Chemel, James L Cpa RENEWAL23Anna Fali
1034Deepesh O BologniaIndia2024-04-22Morlong Associates PROPOSAL61Elwin Sharvill
1035Aruna A CaudySpain2024-04-01Chapman, Ross E Esq NEW50Stephen Shaw
1036James B BriddickIndia2024-04-05Dorl, James J Esq RENEWAL98Ivan Magalhaes
1037Misaki W WhobreyJapan2024-03-28Benton, John B Jr NEGOTIATION46Xuxue Feng
1038Jeanfrancois Q BologniaItaly2024-04-09Buckley Miller Wright UNQUALIFIED99Elwin Sharvill
1039Julie K CaldareraSpain2024-04-20Commercial Press PROPOSAL99Ivan Magalhaes
1040Nicolas J PerinRussia2024-04-06Chapman, Ross E Esq NEGOTIATION40Asiya Javayant
1041Antonio L RoysterJapan2024-04-23Chanay, Jeffrey A Esq RENEWAL63Ioni Bowcher
1042Izzy G NickaAustralia2024-04-12Feiner Bros UNQUALIFIED1Anna Fali
1043Salvatore Y InouyeUnited Kingdom2024-04-07Truhlar And Truhlar Attys UNQUALIFIED70Anna Fali
1044James T FlosiIndia2024-04-08Morlong Associates PROPOSAL63Asiya Javayant
1045Ricardo D StockhamArgentina2024-04-22Feiner Bros RENEWAL25Amy Elsner
1046Arvin H CampainCanada2024-03-28Feltz Printing Service RENEWAL10Onyama Limba
1047Leon Z BologniaFrance2024-04-08Morlong Associates UNQUALIFIED78Ioni Bowcher
1048Kadeem J CaldareraUnited Kingdom2024-04-14Commercial Press PROPOSAL63Elwin Sharvill
1049Smith S OstroskyFrance2024-04-08King, Christopher A Esq UNQUALIFIED86Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Leja J GauchoCanadaAmy Elsner QUALIFIED
Kaitlin E GillianIndiaAnna Fali QUALIFIED
Aruna G VenereJapanAnna Fali NEGOTIATION
Faith D ChuiCanadaStephen Shaw NEGOTIATION
Darci Z IturbideIndiaXuxue Feng RENEWAL
Aruna Q DarakjyArgentinaXuxue Feng QUALIFIED
Arvin M SchemmerBrazilXuxue Feng NEW
Nicolas Z FigeroaArgentinaXuxue Feng UNQUALIFIED
Leja B WaycottBrazilIvan Magalhaes RENEWAL
Sinclair E SaylorsSpainAsiya Javayant PROPOSAL
Morrow F ChuiArgentinaStephen Shaw NEW
Murillo I SaylorsFranceIoni Bowcher UNQUALIFIED
Francesco N DarakjyBrazilAnna Fali QUALIFIED
Darci S PerinItalyAmy Elsner NEW
Jones M StockhamItalyOnyama Limba NEW
Chavez B GillianFranceOnyama Limba RENEWAL
Wickens F SergiUnited KingdomStephen Shaw NEGOTIATION
Silvio P DarakjyArgentinaElwin Sharvill UNQUALIFIED
Mujtaba Z RoysterIndiaAnna Fali QUALIFIED
Kaitlin J CaldareraRussiaAsiya Javayant QUALIFIED
Julie T DoeGermanyElwin Sharvill QUALIFIED
David Z GillianUnited KingdomBernardo Dominic QUALIFIED
Greenwood X RutaGermanyBernardo Dominic QUALIFIED
Silvio L MacleadJapanIoni Bowcher NEW
Mayumi B CaudyRussiaAmy Elsner NEW
Cody F PoquetteBrazilOnyama Limba UNQUALIFIED
Murillo M NickaGermanyBernardo Dominic NEGOTIATION
Claire A MaletJapanAsiya Javayant PROPOSAL
Antonio L DoeItalyIoni Bowcher NEGOTIATION
Ivar V WaycottJapanAnna Fali NEGOTIATION
Kadeem B FlosiSpainBernardo Dominic QUALIFIED
Clifford O IturbideSpainIvan Magalhaes PROPOSAL
Nicolas M IturbideUnited KingdomAmy Elsner NEW
Jefferson U InouyeSpainAmy Elsner NEW
Ashley R KolmetzBrazilXuxue Feng UNQUALIFIED
Claire U WieserArgentinaAmy Elsner NEGOTIATION
Deepesh K DilliardIndiaBernardo Dominic RENEWAL
Aika X RutaItalyAsiya Javayant RENEWAL
Francesco B FollerJapanBernardo Dominic PROPOSAL
Kaitlin I AlbaresIndiaStephen Shaw NEW
Jeanfrancois S MaletCanadaIoni Bowcher PROPOSAL
James D PoquetteFranceIvan Magalhaes NEW
Aditya Q SaylorsRussiaAmy Elsner QUALIFIED
Aika D PoquetteIndiaElwin Sharvill NEW
Misaki W NickaCanadaAsiya Javayant NEW
Salvatore F WaycottRussiaStephen Shaw NEW
Darci F BologniaCanadaStephen Shaw RENEWAL
Clifford N DarakjySpainStephen Shaw NEGOTIATION
Rodrigues X RimFranceBernardo Dominic NEW
Smith G BowleyRussiaAsiya Javayant NEGOTIATION
Frozen Columns
Name
Clifford Q Whobrey
Kaitlin Y Iturbide
Aika Q Bolognia
Leon C Royster
Nicolas C Rim
Maisha N Morasca
Jennifer B Iturbide
Mayumi Z Ruta
Ricardo L Campain
James H Oldroyd
Costa N Bowley
Maisha S Dilliard
Wickens U Caudy
Jennifer C Oldroyd
Jefferson K Briddick
Kaitlin I Figeroa
Arvin J Glick
Munro Y Royster
Jennifer I Rulapaugh
Jennifer N Saylors
Ivar J Maclead
Nicolas W Nicka
Jefferson S Figeroa
Murillo Q Chui
Julie C Ferencz
Ricardo Z Foller
Emily Z Inouye
Isabel W Waycott
Darci M Caldarera
Antonio W Saylors
Deepesh G Doe
Antonio J Amigon
Aditya M Tollner
Tony J Dilliard
Aruna B Morasca
Chavez B Darakjy
Rodrigues D Doe
Sinclair I Morasca
Wickens B Stockham
Kaitlin M Dilliard
Wickens U Venere
Silvio N Nicka
Emily Z Malet
Smith Y Venere
Misaki A Maclead
Jones M Bolognia
David V Inouye
Munro B Schemmer
Kaitlin K Slusarski
Julie P Caldarera
IdCountryDate
1000Japan2024-03-29
1001Brazil2024-04-15
1002United Kingdom2024-04-02
1003Australia2024-04-03
1004Argentina2024-04-14
1005Australia2024-04-14
1006Germany2024-03-31
1007Spain2024-04-12
1008Germany2024-04-08
1009Canada2024-04-04
1010Japan2024-04-10
1011Australia2024-04-12
1012United Kingdom2024-03-31
1013Japan2024-04-24
1014Canada2024-04-12
1015Italy2024-04-03
1016Brazil2024-04-23
1017Russia2024-04-23
1018Japan2024-04-05
1019Italy2024-04-25
1020United Kingdom2024-04-13
1021Australia2024-04-08
1022Japan2024-03-28
1023Argentina2024-03-28
1024Spain2024-04-25
1025France2024-04-08
1026India2024-04-05
1027France2024-04-15
1028Spain2024-04-21
1029Brazil2024-03-28
1030Russia2024-04-24
1031India2024-04-17
1032United Kingdom2024-04-19
1033Argentina2024-03-28
1034Russia2024-04-04
1035India2024-04-16
1036Canada2024-04-02
1037Spain2024-04-15
1038France2024-04-04
1039Italy2024-03-31
1040Brazil2024-04-13
1041Spain2024-04-16
1042Italy2024-03-28
1043United Kingdom2024-04-25
1044Canada2024-04-06
1045Australia2024-04-05
1046India2024-04-09
1047Japan2024-03-31
1048India2024-04-02
1049India2024-04-12

On-Demand Data

NameIdCountryDate
Ivar B Maclead1000United Kingdom2024-03-29
Ivar I Rim1001Italy2024-04-24
Isabel O Gaucho1002Russia2024-03-28
Jones T Malet1003Spain2024-03-29
Nicolas S Garufi1004Italy2024-04-04
Clifford N Venere1005Japan2024-04-20
Salvatore L Venere1006United Kingdom2024-04-03
Aruna B Kusko1007Russia2024-04-04
Jeanfrancois I Marrier1008Argentina2024-04-24
Alejandro P Campain1009United Kingdom2024-03-28
Maria Y Paprocki1010Japan2024-04-17
Munro G Inouye1011Japan2024-04-04
David M Foller1012United Kingdom2024-03-28
Ashley T Albares1013Australia2024-04-12
Smith U Poquette1014Australia2024-04-19
Antonio O Waycott1015Russia2024-04-01
Chavez A Bolognia1016France2024-03-28
Julie T Poquette1017Spain2024-04-03
Murillo E Foller1018Italy2024-04-19
Julie G Waycott1019Russia2024-04-23
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Isabel A BowleyJapanXuxue Feng UNQUALIFIED
Ashley U WhobreyAustraliaIoni Bowcher RENEWAL
Stacey F StensethRussiaElwin Sharvill PROPOSAL
Smith J BowleySpainStephen Shaw UNQUALIFIED
Misaki E FerenczJapanXuxue Feng RENEWAL
Stacey M FlosiArgentinaIvan Magalhaes NEW
Maisha H FerenczRussiaAnna Fali RENEWAL
Mayumi N MacleadArgentinaAnna Fali NEW
Misaki T GillianItalyXuxue Feng QUALIFIED
Adams X DarakjySpainXuxue Feng RENEWAL
Deepesh Q CaldareraUnited KingdomIvan Magalhaes QUALIFIED
Ricardo G AmigonAustraliaAmy Elsner UNQUALIFIED
Morrow F BologniaGermanyAmy Elsner RENEWAL
Juan P VocelkaItalyBernardo Dominic QUALIFIED
Isabel M KuskoJapanBernardo Dominic RENEWAL
Octavia E PoquetteItalyElwin Sharvill PROPOSAL
Smith U KuskoItalyAsiya Javayant QUALIFIED
Kadeem R VenereArgentinaAmy Elsner PROPOSAL
Darci F FollerBrazilBernardo Dominic PROPOSAL
Darci J IturbideCanadaBernardo Dominic RENEWAL
Misaki D OstroskySpainAmy Elsner QUALIFIED
Arvin D GarufiSpainIoni Bowcher NEW
Izzy N WaycottBrazilElwin Sharvill NEGOTIATION
Munro I BologniaJapanBernardo Dominic QUALIFIED
Deepesh R CaudyGermanyAnna Fali NEGOTIATION
Maisha N RimArgentinaBernardo Dominic NEGOTIATION
Kaitlin L SergiGermanyIoni Bowcher NEW
Nicolas W FerenczFranceBernardo Dominic RENEWAL
Maisha L OldroydJapanIvan Magalhaes QUALIFIED
Salvatore H PaprockiRussiaIoni Bowcher UNQUALIFIED
Rodrigues H BriddickFranceBernardo Dominic QUALIFIED
Arvin E NickaBrazilElwin Sharvill UNQUALIFIED
Rodrigues A BologniaSpainAmy Elsner UNQUALIFIED
Costa E GillianAustraliaAnna Fali NEW
Aika L ChuiSpainOnyama Limba UNQUALIFIED
Juan X RutaRussiaBernardo Dominic QUALIFIED
Silvio T NestleAustraliaIvan Magalhaes QUALIFIED
Antonio Z GlickGermanyXuxue Feng QUALIFIED
Ashley V DarakjyIndiaStephen Shaw UNQUALIFIED
Murillo E DoeUnited KingdomAnna 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>