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 D TollnerGermanyIvan Magalhaes UNQUALIFIED
Misaki X TollnerArgentinaBernardo Dominic UNQUALIFIED
Darci H StensethUnited KingdomStephen Shaw QUALIFIED
Kaitlin L PaprockiJapanAsiya Javayant RENEWAL
Deepesh P PoquetteItalyIvan Magalhaes PROPOSAL
Adams R GauchoAustraliaOnyama Limba NEGOTIATION
Kaitlin M RimBrazilStephen Shaw PROPOSAL
Morrow Q NestleJapanIvan Magalhaes NEW
Johnson Q SergiGermanyXuxue Feng PROPOSAL
Julie M MarrierBrazilStephen Shaw RENEWAL
Stacey X RulapaughAustraliaStephen Shaw NEW
Alejandro Y RulapaughAustraliaIvan Magalhaes QUALIFIED
Julie P AlbaresAustraliaIoni Bowcher RENEWAL
Silvio V AmigonSpainIoni Bowcher QUALIFIED
Jeanfrancois A GarufiIndiaStephen Shaw NEW
Sinclair C PaprockiCanadaOnyama Limba PROPOSAL
Nicolas N FerenczRussiaStephen Shaw NEW
Misaki H BriddickFranceElwin Sharvill NEGOTIATION
Aditya Z SchemmerJapanStephen Shaw NEGOTIATION
Izzy X MorascaGermanyIvan Magalhaes QUALIFIED
Clifford X KuskoCanadaIoni Bowcher NEW
Kadeem P MacleadItalyStephen Shaw QUALIFIED
Jefferson J GauchoCanadaAmy Elsner PROPOSAL
Aditya G OstroskyFranceIoni Bowcher NEGOTIATION
Nicolas H OstroskyAustraliaAsiya Javayant NEW
Arvin L VenereFranceOnyama Limba NEGOTIATION
Ivar L PoquetteSpainStephen Shaw NEGOTIATION
Johnson C RutaIndiaAmy Elsner PROPOSAL
Tony K FlosiAustraliaBernardo Dominic RENEWAL
Aruna I CaudyRussiaIvan Magalhaes RENEWAL
Munro Q IturbideFranceStephen Shaw NEGOTIATION
Maria P ChuiSpainOnyama Limba UNQUALIFIED
Greenwood P AmigonRussiaAnna Fali NEGOTIATION
Emily T PoquetteArgentinaAnna Fali NEW
Clifford I WhobreyIndiaStephen Shaw QUALIFIED
Jones S VenereJapanAsiya Javayant NEGOTIATION
Mujtaba W GarufiCanadaAsiya Javayant RENEWAL
Arvin B TollnerBrazilOnyama Limba QUALIFIED
Jeanfrancois E WaycottUnited KingdomXuxue Feng RENEWAL
Ricardo G OstroskyArgentinaAsiya Javayant RENEWAL
Adams C RoysterFranceAsiya Javayant NEW
Octavia R VenereGermanyIvan Magalhaes NEGOTIATION
Wickens K OstroskyFranceStephen Shaw NEW
Tony A NestleFranceOnyama Limba UNQUALIFIED
Izzy N DoeJapanIoni Bowcher QUALIFIED
Darci Q OldroydRussiaAmy Elsner RENEWAL
Johnson C GarufiRussiaElwin Sharvill PROPOSAL
Aruna X IturbideRussiaStephen Shaw UNQUALIFIED
Francesco P WhobreyIndiaXuxue Feng PROPOSAL
Julie Z GillianBrazilOnyama Limba RENEWAL
Horizontal
NameCountryRepresentativeStatus
Mujtaba S KolmetzIndiaElwin Sharvill RENEWAL
Morrow Q CaldareraSpainAsiya Javayant NEGOTIATION
Jefferson D ChuiGermanyStephen Shaw PROPOSAL
Misaki X SlusarskiSpainAmy Elsner NEW
Johnson Q VenereSpainAnna Fali NEGOTIATION
Jeanfrancois H MacleadUnited KingdomElwin Sharvill UNQUALIFIED
Ashley R BowleyUnited KingdomStephen Shaw PROPOSAL
Morrow L TollnerIndiaIvan Magalhaes QUALIFIED
Greenwood E AlbaresCanadaStephen Shaw NEGOTIATION
Wickens X StockhamSpainXuxue Feng PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Octavia Q MacleadRussia2024-04-06Truhlar And Truhlar Attys NEW28Elwin Sharvill
1001Sinclair M GauchoGermany2024-04-15Rousseaux, Michael Esq NEW14Onyama Limba
1002Smith T MorascaGermany2024-03-30Dorl, James J Esq RENEWAL40Xuxue Feng
1003David B RulapaughFrance2024-04-13Chapman, Ross E Esq PROPOSAL4Elwin Sharvill
1004Arvin V FigeroaRussia2024-03-30Rangoni Of Florence RENEWAL2Amy Elsner
1005Ashley X MacleadBrazil2024-04-06Dorl, James J Esq NEGOTIATION66Stephen Shaw
1006Alejandro C NestleRussia2024-04-07Buckley Miller Wright PROPOSAL15Ivan Magalhaes
1007Octavia E StensethCanada2024-04-20Buckley Miller Wright RENEWAL92Ioni Bowcher
1008Munro T PoquetteRussia2024-04-18Chemel, James L Cpa RENEWAL49Anna Fali
1009Kaitlin W GauchoRussia2024-04-15Chanay, Jeffrey A Esq RENEWAL74Asiya Javayant
1010Greenwood I FigeroaGermany2024-04-09Commercial Press QUALIFIED83Bernardo Dominic
1011Ricardo E RimJapan2024-04-09Chemel, James L Cpa NEW62Stephen Shaw
1012Costa N FerenczJapan2024-04-09Dorl, James J Esq NEW95Amy Elsner
1013Rodrigues Q RutaCanada2024-04-04Feiner Bros NEGOTIATION42Amy Elsner
1014Izzy W RulapaughArgentina2024-04-06Benton, John B Jr RENEWAL43Stephen Shaw
1015Greenwood F GlickGermany2024-04-08Feltz Printing Service NEGOTIATION54Anna Fali
1016Clifford F DilliardItaly2024-04-03Commercial Press PROPOSAL47Bernardo Dominic
1017Smith Y KolmetzSpain2024-04-24Buckley Miller Wright QUALIFIED9Amy Elsner
1018Emily S AlbaresItaly2024-04-12Feiner Bros PROPOSAL22Elwin Sharvill
1019Stacey P IturbideJapan2024-04-05Rangoni Of Florence QUALIFIED52Stephen Shaw
1020Munro O WaycottArgentina2024-04-07Truhlar And Truhlar Attys NEGOTIATION79Stephen Shaw
1021Octavia E ButtJapan2024-04-20Commercial Press PROPOSAL81Anna Fali
1022Munro H CampainBrazil2024-04-13Chapman, Ross E Esq NEW5Stephen Shaw
1023Octavia V DarakjyCanada2024-04-24Dorl, James J Esq UNQUALIFIED92Ivan Magalhaes
1024Faith Y KuskoArgentina2024-04-26Dorl, James J Esq NEGOTIATION52Stephen Shaw
1025Munro P BriddickRussia2024-04-07Rousseaux, Michael Esq RENEWAL39Anna Fali
1026Mujtaba D FlosiItaly2024-04-14King, Christopher A Esq NEW39Ioni Bowcher
1027Izzy V PoquetteAustralia2024-04-17Chemel, James L Cpa NEGOTIATION2Stephen Shaw
1028Clifford X BriddickRussia2024-04-22Rousseaux, Michael Esq UNQUALIFIED52Stephen Shaw
1029Murillo O DilliardItaly2024-04-28Chapman, Ross E Esq UNQUALIFIED62Elwin Sharvill
1030Misaki S GarufiGermany2024-04-02Dorl, James J Esq PROPOSAL35Asiya Javayant
1031Jefferson P GillianIndia2024-04-15Rousseaux, Michael Esq RENEWAL63Stephen Shaw
1032Faith I AlbaresBrazil2024-04-12Chemel, James L Cpa QUALIFIED86Xuxue Feng
1033Leja Y StensethUnited Kingdom2024-04-23Dorl, James J Esq UNQUALIFIED91Elwin Sharvill
1034Ivar P CampainArgentina2024-04-13Chanay, Jeffrey A Esq QUALIFIED13Anna Fali
1035Jefferson T BologniaCanada2024-04-19Rousseaux, Michael Esq QUALIFIED56Ioni Bowcher
1036Wickens C DarakjyUnited Kingdom2024-04-18Feltz Printing Service UNQUALIFIED5Bernardo Dominic
1037Jones J WhobreyAustralia2024-04-01Dorl, James J Esq RENEWAL27Xuxue Feng
1038Smith E TollnerUnited Kingdom2024-04-08Chanay, Jeffrey A Esq NEGOTIATION1Ivan Magalhaes
1039Chavez Z SaylorsRussia2024-04-25Printing Dimensions UNQUALIFIED96Anna Fali
1040Jefferson T RutaAustralia2024-04-03Printing Dimensions PROPOSAL90Onyama Limba
1041Aruna S FollerCanada2024-04-26Chapman, Ross E Esq NEW61Onyama Limba
1042Nicolas X AlbaresFrance2024-03-31Feiner Bros PROPOSAL87Asiya Javayant
1043Jones N PerinGermany2024-04-26Chapman, Ross E Esq QUALIFIED96Asiya Javayant
1044Leon P DarakjyGermany2024-04-24Chemel, James L Cpa NEW54Xuxue Feng
1045James U WieserGermany2024-04-10Chanay, Jeffrey A Esq NEGOTIATION93Xuxue Feng
1046Claire Y WaycottRussia2024-04-20Benton, John B Jr PROPOSAL62Amy Elsner
1047Emily E DarakjyJapan2024-04-25Rousseaux, Michael Esq PROPOSAL10Bernardo Dominic
1048Nicolas T BowleyArgentina2024-04-03Rousseaux, Michael Esq NEW49Ivan Magalhaes
1049Kaitlin N VenereBrazil2024-04-11Benton, John B Jr UNQUALIFIED3Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Mayumi I MorascaBrazilXuxue Feng UNQUALIFIED
Tony D NickaArgentinaXuxue Feng PROPOSAL
Jones V VenereSpainOnyama Limba RENEWAL
Francesco Z BologniaSpainAsiya Javayant NEW
Kaitlin N DoeCanadaOnyama Limba NEGOTIATION
Maisha H PoquetteRussiaBernardo Dominic NEGOTIATION
Sinclair U AlbaresArgentinaAnna Fali NEGOTIATION
Deepesh L WaycottBrazilOnyama Limba RENEWAL
Antonio C PoquetteItalyOnyama Limba NEGOTIATION
Francesco C CaudySpainAsiya Javayant PROPOSAL
Izzy N VenereJapanAnna Fali NEGOTIATION
Costa S SchemmerIndiaOnyama Limba RENEWAL
Juan H MaletGermanyAmy Elsner PROPOSAL
Kaitlin K FollerFranceXuxue Feng QUALIFIED
Maisha C AmigonJapanAsiya Javayant NEGOTIATION
Claire J RoysterItalyIoni Bowcher NEW
James S SlusarskiSpainBernardo Dominic PROPOSAL
Francesco L KolmetzSpainIoni Bowcher NEW
Chavez Q WaycottSpainStephen Shaw RENEWAL
Octavia V BowleyUnited KingdomElwin Sharvill QUALIFIED
Francesco E RulapaughCanadaBernardo Dominic NEGOTIATION
Aruna G PoquetteCanadaXuxue Feng PROPOSAL
Murillo J DoeItalyAmy Elsner NEW
Darci E StockhamFranceXuxue Feng NEGOTIATION
Arvin I FigeroaGermanyBernardo Dominic QUALIFIED
Aika P StensethIndiaIoni Bowcher PROPOSAL
Aika E GillianGermanyAsiya Javayant QUALIFIED
Juan K ShinkoItalyAmy Elsner PROPOSAL
Kadeem I SlusarskiRussiaXuxue Feng RENEWAL
Kadeem N MaletCanadaAnna Fali NEGOTIATION
Ashley B DoeCanadaAsiya Javayant NEW
Murillo X RulapaughArgentinaIoni Bowcher NEW
Mayumi X GillianIndiaOnyama Limba NEW
Isabel L NestleAustraliaBernardo Dominic UNQUALIFIED
Silvio O FollerIndiaIvan Magalhaes QUALIFIED
Clifford A OldroydArgentinaIoni Bowcher UNQUALIFIED
Antonio T GlickUnited KingdomIoni Bowcher PROPOSAL
Tony C CampainCanadaStephen Shaw PROPOSAL
Ricardo Q GlickItalyOnyama Limba QUALIFIED
Arvin J InouyeJapanIvan Magalhaes QUALIFIED
Aditya O SlusarskiIndiaIoni Bowcher NEGOTIATION
Munro S GarufiAustraliaAnna Fali UNQUALIFIED
Greenwood B VenereGermanyOnyama Limba QUALIFIED
Tony F AmigonJapanElwin Sharvill NEW
Silvio J NestleUnited KingdomBernardo Dominic NEW
Juan F RoysterCanadaAmy Elsner PROPOSAL
Leon D WhobreyGermanyIoni Bowcher NEGOTIATION
Murillo K DoeSpainAsiya Javayant NEGOTIATION
Aditya M BowleyJapanAmy Elsner NEGOTIATION
David Z GarufiSpainAnna Fali UNQUALIFIED
Frozen Columns
Name
Maria C Royster
Kaitlin W Tollner
Maisha E Perin
Silvio Q Glick
Smith O Poquette
Ricardo Z Poquette
Arvin V Dilliard
Tony G Waycott
Nicolas R Darakjy
Mayumi U Oldroyd
Jones Z Perin
Jefferson J Ostrosky
Greenwood W Stenseth
Mayumi J Caudy
Faith U Whobrey
Leon M Inouye
Claire T Saylors
Rodrigues A Flosi
Francesco D Rim
Morrow P Ruta
Kadeem P Ostrosky
Nicolas I Nestle
Emily G Maclead
Greenwood T Doe
Kaitlin K Venere
Jefferson U Whobrey
Aditya R Malet
David E Glick
Ashley P Caldarera
Greenwood M Shinko
Sinclair C Glick
Leon Q Butt
Arvin D Bolognia
Leja W Bolognia
Maria J Royster
Aruna S Doe
Murillo M Slusarski
Cody O Shinko
Isabel X Rulapaugh
Maria X Shinko
Emily Q Stockham
Greenwood K Stenseth
James A Schemmer
Stacey S Schemmer
Adams V Doe
Jennifer W Slusarski
Faith W Darakjy
Juan H Schemmer
Alejandro E Maclead
Darci R Dilliard
IdCountryDate
1000Japan2024-04-28
1001United Kingdom2024-04-20
1002Canada2024-04-06
1003Italy2024-04-06
1004Canada2024-04-03
1005Russia2024-04-14
1006Brazil2024-04-14
1007United Kingdom2024-04-15
1008Canada2024-04-26
1009Germany2024-04-27
1010Italy2024-04-06
1011Japan2024-04-15
1012Argentina2024-04-01
1013Spain2024-04-01
1014India2024-04-14
1015Canada2024-04-21
1016Australia2024-04-24
1017Germany2024-04-05
1018Italy2024-04-12
1019Germany2024-04-06
1020Germany2024-03-31
1021Argentina2024-04-23
1022Brazil2024-04-18
1023Argentina2024-04-21
1024Russia2024-04-04
1025Spain2024-04-08
1026France2024-04-20
1027Canada2024-04-19
1028Spain2024-04-19
1029Japan2024-04-22
1030Germany2024-04-15
1031Russia2024-04-17
1032Japan2024-04-02
1033Russia2024-04-03
1034Spain2024-03-31
1035Spain2024-03-30
1036Australia2024-04-02
1037Russia2024-04-13
1038United Kingdom2024-04-14
1039Argentina2024-04-25
1040Brazil2024-03-30
1041Russia2024-04-21
1042Argentina2024-04-05
1043Russia2024-04-01
1044United Kingdom2024-04-21
1045Japan2024-04-18
1046Brazil2024-04-27
1047Italy2024-04-06
1048India2024-04-22
1049Canada2024-04-27

On-Demand Data

NameIdCountryDate
Maisha F Bolognia1000Argentina2024-04-26
Kaitlin G Glick1001Japan2024-04-19
Mayumi H Nestle1002Australia2024-04-23
Wickens P Doe1003France2024-04-04
Mujtaba E Whobrey1004Argentina2024-04-22
Tony X Ostrosky1005Italy2024-04-17
Aika A Inouye1006France2024-04-03
Ivar W Dilliard1007Italy2024-04-16
Jones N Chui1008Italy2024-04-19
Isabel P Nestle1009Canada2024-04-16
Nicolas K Bowley1010Japan2024-04-03
Wickens R Perin1011Brazil2024-04-01
Ricardo Q Saylors1012Germany2024-04-13
Kaitlin A Royster1013Russia2024-04-03
Clifford Z Gillian1014Japan2024-04-08
Jennifer U Caudy1015Italy2024-04-06
Stacey V Caudy1016France2024-04-14
Cody C Wieser1017Australia2024-04-27
Leon C Wieser1018Australia2024-04-21
Munro Q Oldroyd1019Canada2024-03-30
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Francesco Z GarufiCanadaIvan Magalhaes NEW
Leja V RulapaughArgentinaBernardo Dominic PROPOSAL
Greenwood Q BowleyRussiaIoni Bowcher RENEWAL
Wickens N IturbideGermanyOnyama Limba UNQUALIFIED
Juan L GauchoAustraliaXuxue Feng QUALIFIED
Arvin O NestleAustraliaOnyama Limba RENEWAL
Jefferson Q SaylorsIndiaOnyama Limba PROPOSAL
Sinclair Y CaldareraJapanIvan Magalhaes NEW
James Y CaudyIndiaAmy Elsner PROPOSAL
Jeanfrancois N ChuiIndiaStephen Shaw NEW
Alejandro W VocelkaBrazilOnyama Limba NEW
Isabel A FlosiAustraliaAsiya Javayant NEW
Faith X ChuiJapanAsiya Javayant PROPOSAL
Arvin O AlbaresBrazilIoni Bowcher PROPOSAL
Stacey Q FerenczItalyBernardo Dominic RENEWAL
Jennifer Y PaprockiIndiaIoni Bowcher RENEWAL
Leja O PoquetteItalyOnyama Limba NEGOTIATION
Jones K VenereRussiaAmy Elsner PROPOSAL
Juan V FerenczBrazilAmy Elsner PROPOSAL
Aruna B KuskoAustraliaIoni Bowcher NEW
Aruna Z DoeRussiaAmy Elsner NEGOTIATION
Morrow Q KuskoBrazilAmy Elsner UNQUALIFIED
Tony C WaycottArgentinaXuxue Feng NEGOTIATION
Francesco Q CampainCanadaStephen Shaw NEW
Costa Y GlickJapanAsiya Javayant NEW
James P SlusarskiArgentinaBernardo Dominic UNQUALIFIED
David Z MarrierArgentinaStephen Shaw PROPOSAL
Greenwood J FlosiIndiaBernardo Dominic UNQUALIFIED
Octavia E OstroskySpainAnna Fali UNQUALIFIED
Costa V NestleItalyBernardo Dominic NEW
Clifford F DilliardArgentinaIvan Magalhaes PROPOSAL
Smith C KuskoArgentinaBernardo Dominic NEGOTIATION
Wickens W CaldareraSpainElwin Sharvill NEGOTIATION
Izzy A AmigonGermanyAmy Elsner NEW
Jones N DoeSpainStephen Shaw NEW
Kaitlin E OstroskyRussiaOnyama Limba QUALIFIED
Morrow B KolmetzBrazilStephen Shaw NEW
James V WieserItalyXuxue Feng RENEWAL
Silvio B AmigonAustraliaOnyama Limba RENEWAL
Octavia V FlosiGermanyIoni Bowcher 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>