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
Morrow C StensethGermanyStephen Shaw NEW
Munro W CampainRussiaAmy Elsner NEGOTIATION
Aditya D MaletSpainIoni Bowcher RENEWAL
Juan Q VenereBrazilXuxue Feng RENEWAL
Francesco I GauchoArgentinaOnyama Limba UNQUALIFIED
Nicolas M TollnerJapanBernardo Dominic RENEWAL
Isabel B ButtItalyAsiya Javayant NEGOTIATION
Aruna L BriddickBrazilAmy Elsner QUALIFIED
Stacey K RimUnited KingdomAmy Elsner QUALIFIED
Mayumi G KuskoItalyXuxue Feng PROPOSAL
Kadeem M IturbideUnited KingdomElwin Sharvill UNQUALIFIED
Claire E FigeroaFranceOnyama Limba NEW
Jefferson H FollerIndiaElwin Sharvill NEGOTIATION
Juan R MaletCanadaBernardo Dominic NEW
Juan Y FerenczGermanyStephen Shaw UNQUALIFIED
Munro H PerinIndiaIvan Magalhaes PROPOSAL
Costa F VenereItalyXuxue Feng QUALIFIED
Leon H MorascaJapanIoni Bowcher QUALIFIED
Adams Z KolmetzCanadaAmy Elsner UNQUALIFIED
Aika Y KolmetzArgentinaIoni Bowcher UNQUALIFIED
Julie S StockhamBrazilIoni Bowcher NEGOTIATION
Francesco S FollerBrazilIoni Bowcher PROPOSAL
Darci I MarrierCanadaAmy Elsner NEW
Arvin K GlickIndiaBernardo Dominic NEGOTIATION
Kadeem L PerinAustraliaAmy Elsner RENEWAL
Deepesh G CampainIndiaIoni Bowcher NEW
Mayumi W AmigonUnited KingdomElwin Sharvill RENEWAL
Alejandro A InouyeGermanyIvan Magalhaes NEW
Clifford K BriddickItalyStephen Shaw PROPOSAL
Faith I WaycottArgentinaOnyama Limba QUALIFIED
Cody S WieserItalyIvan Magalhaes PROPOSAL
Chavez U VocelkaIndiaIvan Magalhaes UNQUALIFIED
Ivar P WieserAustraliaIoni Bowcher RENEWAL
Chavez B KolmetzCanadaAnna Fali PROPOSAL
Nicolas I MaletCanadaAsiya Javayant NEW
Faith S SchemmerArgentinaElwin Sharvill RENEWAL
Aruna J BologniaIndiaAnna Fali PROPOSAL
Sinclair J FigeroaBrazilIoni Bowcher RENEWAL
Silvio M WieserUnited KingdomOnyama Limba PROPOSAL
James C StensethIndiaIvan Magalhaes NEW
Jeanfrancois Y WieserItalyIvan Magalhaes RENEWAL
Morrow H PaprockiBrazilBernardo Dominic PROPOSAL
Darci S KolmetzCanadaAmy Elsner NEW
Juan G GauchoArgentinaIoni Bowcher RENEWAL
Munro E DarakjyAustraliaOnyama Limba PROPOSAL
Isabel Q RutaSpainXuxue Feng UNQUALIFIED
Stacey M SergiCanadaAsiya Javayant UNQUALIFIED
Octavia L MorascaUnited KingdomAsiya Javayant QUALIFIED
Deepesh E RimBrazilIoni Bowcher PROPOSAL
Leja Q FollerGermanyXuxue Feng NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Kaitlin D OstroskyItalyXuxue Feng PROPOSAL
Jeanfrancois N VenereBrazilBernardo Dominic RENEWAL
Julie M RutaFranceXuxue Feng UNQUALIFIED
Juan W GlickItalyAnna Fali NEW
Maisha R RoysterJapanXuxue Feng QUALIFIED
Ricardo N WaycottFranceOnyama Limba NEW
Clifford N CampainIndiaStephen Shaw UNQUALIFIED
Stacey A MaletCanadaIvan Magalhaes RENEWAL
Murillo F SergiIndiaStephen Shaw RENEWAL
Aika D OstroskyAustraliaElwin Sharvill RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Mujtaba F DarakjyGermany2024-04-14Truhlar And Truhlar Attys RENEWAL21Anna Fali
1001Stacey H RimAustralia2024-04-05Chapman, Ross E Esq RENEWAL57Elwin Sharvill
1002David W MaletIndia2024-04-28King, Christopher A Esq PROPOSAL94Amy Elsner
1003Johnson J StockhamCanada2024-04-28Chemel, James L Cpa NEGOTIATION25Xuxue Feng
1004Jeanfrancois E StockhamBrazil2024-04-25Rousseaux, Michael Esq NEW94Amy Elsner
1005Antonio T ButtRussia2024-04-28Buckley Miller Wright RENEWAL14Stephen Shaw
1006Ashley B MaletSpain2024-04-10Rangoni Of Florence UNQUALIFIED41Ivan Magalhaes
1007Stacey Z CaudyRussia2024-04-26Feltz Printing Service QUALIFIED57Anna Fali
1008Nicolas N MaletGermany2024-04-22Rangoni Of Florence NEW41Stephen Shaw
1009Kadeem B WhobreyCanada2024-04-24Chapman, Ross E Esq QUALIFIED42Ioni Bowcher
1010Greenwood E RimJapan2024-04-21Buckley Miller Wright NEW5Anna Fali
1011Isabel C SchemmerIndia2024-04-27Feiner Bros QUALIFIED57Stephen Shaw
1012Kaitlin I RimFrance2024-04-18Chapman, Ross E Esq QUALIFIED6Ivan Magalhaes
1013Deepesh E FlosiUnited Kingdom2024-04-18Printing Dimensions RENEWAL94Ivan Magalhaes
1014Aruna H MacleadUnited Kingdom2024-04-06Rangoni Of Florence NEW81Anna Fali
1015Jones W MaletFrance2024-04-16Feltz Printing Service PROPOSAL62Asiya Javayant
1016Silvio M WaycottIndia2024-04-09Morlong Associates PROPOSAL0Ioni Bowcher
1017Adams C WhobreyArgentina2024-04-23Dorl, James J Esq QUALIFIED56Bernardo Dominic
1018Jefferson S RulapaughSpain2024-04-27Buckley Miller Wright UNQUALIFIED23Asiya Javayant
1019Leja P RulapaughRussia2024-04-23Chanay, Jeffrey A Esq UNQUALIFIED41Ioni Bowcher
1020Stacey O GauchoItaly2024-04-17Feiner Bros QUALIFIED30Onyama Limba
1021Octavia Y KuskoUnited Kingdom2024-04-05Feiner Bros NEGOTIATION96Ivan Magalhaes
1022Jefferson H MacleadAustralia2024-04-27Benton, John B Jr UNQUALIFIED68Ioni Bowcher
1023Leon G DoeAustralia2024-04-26Truhlar And Truhlar Attys NEW80Amy Elsner
1024Octavia H BowleyArgentina2024-04-15Buckley Miller Wright NEGOTIATION83Ioni Bowcher
1025Darci P RoysterGermany2024-04-25Printing Dimensions UNQUALIFIED48Asiya Javayant
1026Chavez V KuskoRussia2024-03-31Feiner Bros NEW76Elwin Sharvill
1027Tony H PerinIndia2024-04-26Chanay, Jeffrey A Esq NEGOTIATION73Asiya Javayant
1028Greenwood L IturbideRussia2024-04-16Feiner Bros RENEWAL24Ioni Bowcher
1029Leja R SchemmerSpain2024-04-27Chanay, Jeffrey A Esq NEGOTIATION31Anna Fali
1030Octavia F NestleSpain2024-04-18Rousseaux, Michael Esq QUALIFIED26Stephen Shaw
1031Kaitlin J DilliardItaly2024-04-25Feltz Printing Service NEW64Anna Fali
1032Juan J VenereAustralia2024-04-09Printing Dimensions RENEWAL40Stephen Shaw
1033Johnson Y StockhamItaly2024-04-27Feiner Bros UNQUALIFIED57Asiya Javayant
1034Alejandro N CaldareraItaly2024-04-19Buckley Miller Wright QUALIFIED19Onyama Limba
1035Nicolas B SaylorsRussia2024-04-07Truhlar And Truhlar Attys UNQUALIFIED80Elwin Sharvill
1036Leon T FigeroaFrance2024-04-12Feltz Printing Service QUALIFIED47Ivan Magalhaes
1037Morrow J BologniaCanada2024-04-19Printing Dimensions PROPOSAL95Asiya Javayant
1038Jennifer O BologniaItaly2024-04-02Chapman, Ross E Esq NEW59Amy Elsner
1039Sinclair R PoquetteAustralia2024-04-13Commercial Press NEGOTIATION61Ioni Bowcher
1040Silvio S FollerBrazil2024-04-12Chanay, Jeffrey A Esq NEGOTIATION79Asiya Javayant
1041Isabel B AlbaresBrazil2024-04-06Benton, John B Jr UNQUALIFIED13Onyama Limba
1042Tony E SergiJapan2024-04-01King, Christopher A Esq PROPOSAL17Amy Elsner
1043Rodrigues L PerinAustralia2024-04-09Rangoni Of Florence QUALIFIED64Onyama Limba
1044Aruna R SchemmerFrance2024-04-05Feltz Printing Service PROPOSAL41Ivan Magalhaes
1045Faith I GarufiAustralia2024-04-06Commercial Press UNQUALIFIED63Elwin Sharvill
1046Stacey G GlickFrance2024-04-17Truhlar And Truhlar Attys UNQUALIFIED63Xuxue Feng
1047Greenwood B GarufiSpain2024-04-12Feiner Bros NEGOTIATION39Asiya Javayant
1048Adams T SergiSpain2024-04-14Benton, John B Jr RENEWAL45Stephen Shaw
1049Mujtaba A ShinkoJapan2024-04-25Rousseaux, Michael Esq NEGOTIATION94Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
James Z GauchoArgentinaIvan Magalhaes NEW
Wickens K NestleItalyIoni Bowcher QUALIFIED
Nicolas K RulapaughFranceOnyama Limba NEGOTIATION
Kaitlin L StensethBrazilIvan Magalhaes NEW
Emily P StensethArgentinaElwin Sharvill PROPOSAL
Jones C NestleRussiaOnyama Limba NEGOTIATION
Salvatore Z OstroskyArgentinaBernardo Dominic PROPOSAL
Wickens F ShinkoUnited KingdomIoni Bowcher NEW
Cody S GauchoFranceIvan Magalhaes RENEWAL
James Y FlosiArgentinaOnyama Limba NEGOTIATION
Smith D GauchoCanadaXuxue Feng PROPOSAL
Aruna M GarufiCanadaIvan Magalhaes NEGOTIATION
Adams Y CampainCanadaAmy Elsner NEGOTIATION
Darci V ChuiSpainAnna Fali QUALIFIED
Adams D TollnerItalyStephen Shaw NEGOTIATION
Tony B ShinkoAustraliaStephen Shaw NEGOTIATION
Jones C FerenczIndiaIvan Magalhaes UNQUALIFIED
David V DarakjyCanadaElwin Sharvill UNQUALIFIED
Antonio Y OldroydFranceIoni Bowcher NEW
Costa F PaprockiItalyStephen Shaw NEGOTIATION
Greenwood F WaycottUnited KingdomAnna Fali PROPOSAL
Izzy Z PaprockiArgentinaAsiya Javayant PROPOSAL
Ivar V FigeroaAustraliaOnyama Limba QUALIFIED
Alejandro R RoysterFranceOnyama Limba PROPOSAL
Maisha R OldroydBrazilOnyama Limba RENEWAL
Mayumi T MaletFranceIvan Magalhaes QUALIFIED
Greenwood C PoquetteItalyElwin Sharvill NEW
Leja I MaletFranceAnna Fali NEGOTIATION
Jennifer R VenereSpainIvan Magalhaes QUALIFIED
Jennifer Z FerenczBrazilStephen Shaw UNQUALIFIED
Mujtaba N WieserUnited KingdomBernardo Dominic RENEWAL
Silvio F WhobreyCanadaBernardo Dominic NEGOTIATION
Juan W StensethAustraliaAsiya Javayant NEGOTIATION
Ivar P DoeAustraliaStephen Shaw NEGOTIATION
Sinclair A SchemmerUnited KingdomAsiya Javayant UNQUALIFIED
Jeanfrancois V OldroydIndiaAnna Fali RENEWAL
Darci G MacleadUnited KingdomIvan Magalhaes NEGOTIATION
Salvatore H MaletGermanyAsiya Javayant QUALIFIED
Sinclair S MaletArgentinaAnna Fali QUALIFIED
David J SchemmerCanadaIvan Magalhaes RENEWAL
Smith H PaprockiIndiaIvan Magalhaes QUALIFIED
Jones K FigeroaRussiaAnna Fali QUALIFIED
Claire M NickaItalyStephen Shaw PROPOSAL
Adams H CaldareraIndiaAnna Fali RENEWAL
Darci H KuskoAustraliaAsiya Javayant UNQUALIFIED
Deepesh I NestleGermanyElwin Sharvill QUALIFIED
Johnson B CampainUnited KingdomBernardo Dominic QUALIFIED
Claire G DarakjyCanadaXuxue Feng PROPOSAL
Mujtaba N VocelkaFranceAnna Fali NEW
Tony P MacleadAustraliaElwin Sharvill PROPOSAL
Frozen Columns
Name
Faith N Albares
Leja T Dilliard
Kadeem T Paprocki
Tony W Morasca
Kadeem A Royster
Jennifer K Vocelka
Adams A Bolognia
Jefferson Q Bolognia
Silvio R Rim
Murillo I Venere
Murillo U Kolmetz
Leon Q Venere
Costa E Perin
Francesco C Schemmer
Arvin W Royster
Leon W Caudy
Antonio Q Bolognia
Stacey H Saylors
Greenwood E Marrier
Julie Z Sergi
Antonio X Ostrosky
Mayumi P Ruta
Misaki V Figeroa
Jones H Caudy
Ashley J Briddick
Arvin A Vocelka
Maisha C Nicka
Antonio Y Garufi
Julie Z Bolognia
Johnson J Slusarski
Maisha O Briddick
Stacey C Nicka
Jennifer J Inouye
Juan C Glick
Aruna T Rulapaugh
Jennifer I Briddick
Faith O Butt
Ashley E Stenseth
Murillo Y Amigon
Johnson G Chui
Juan F Albares
Costa X Chui
Faith T Flosi
Adams B Gaucho
Izzy L Ferencz
Ashley J Sergi
Adams O Dilliard
Nicolas I Flosi
Claire E Venere
Julie U Butt
IdCountryDate
1000United Kingdom2024-04-01
1001Canada2024-04-16
1002Argentina2024-03-31
1003Russia2024-04-12
1004Australia2024-04-11
1005India2024-04-26
1006United Kingdom2024-04-14
1007Russia2024-04-21
1008Germany2024-04-19
1009United Kingdom2024-04-15
1010France2024-04-28
1011United Kingdom2024-04-07
1012Germany2024-04-10
1013Italy2024-04-06
1014France2024-04-26
1015Australia2024-04-04
1016United Kingdom2024-03-30
1017Japan2024-04-10
1018Germany2024-04-15
1019Russia2024-04-11
1020Spain2024-04-07
1021France2024-04-17
1022Russia2024-04-09
1023Italy2024-04-18
1024Spain2024-04-14
1025Canada2024-04-24
1026Italy2024-04-20
1027Russia2024-04-01
1028Italy2024-03-30
1029France2024-03-31
1030Italy2024-04-02
1031Italy2024-04-22
1032Canada2024-04-22
1033Italy2024-04-17
1034Spain2024-04-17
1035Brazil2024-04-22
1036Russia2024-04-18
1037Argentina2024-04-22
1038Australia2024-04-25
1039Spain2024-04-16
1040France2024-04-08
1041Argentina2024-03-31
1042Italy2024-04-23
1043Argentina2024-04-01
1044Australia2024-04-18
1045France2024-04-18
1046Canada2024-04-11
1047Argentina2024-04-21
1048Canada2024-03-30
1049Italy2024-04-12

On-Demand Data

NameIdCountryDate
Leon J Kusko1000Australia2024-04-19
David M Rulapaugh1001Germany2024-04-10
Smith F Malet1002Brazil2024-04-19
Chavez B Whobrey1003Australia2024-04-18
Mujtaba H Rulapaugh1004Brazil2024-04-22
Cody H Royster1005Australia2024-04-15
David B Whobrey1006France2024-04-13
Claire S Stockham1007Russia2024-04-12
Ashley U Slusarski1008United Kingdom2024-04-11
Mujtaba G Kolmetz1009Italy2024-04-10
Misaki I Caldarera1010Germany2024-04-10
Maria R Poquette1011Italy2024-04-10
Juan C Garufi1012Japan2024-04-08
Claire K Bolognia1013France2024-04-06
Jefferson H Figeroa1014India2024-04-28
Nicolas F Saylors1015United Kingdom2024-04-02
Arvin B Gillian1016Germany2024-04-24
Jeanfrancois G Caldarera1017Argentina2024-04-04
Stacey Y Flosi1018Russia2024-04-01
Julie W Ostrosky1019Russia2024-03-30
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Emily X OstroskyItalyBernardo Dominic RENEWAL
Aditya H VocelkaFranceOnyama Limba UNQUALIFIED
Faith C NestleArgentinaXuxue Feng RENEWAL
Chavez U FollerFranceOnyama Limba QUALIFIED
Chavez A OstroskyIndiaIvan Magalhaes RENEWAL
Maisha L AlbaresSpainIvan Magalhaes NEGOTIATION
Jones G NestleItalyAnna Fali UNQUALIFIED
Deepesh D NestleSpainOnyama Limba NEW
Morrow V FigeroaGermanyAmy Elsner QUALIFIED
Silvio Q WhobreyUnited KingdomIoni Bowcher UNQUALIFIED
Chavez N StensethItalyIoni Bowcher NEW
Clifford F MorascaArgentinaAmy Elsner RENEWAL
Darci V ShinkoIndiaElwin Sharvill RENEWAL
Faith U BologniaUnited KingdomIoni Bowcher PROPOSAL
Faith D StockhamCanadaOnyama Limba NEGOTIATION
Tony P WhobreySpainBernardo Dominic RENEWAL
David E BowleyArgentinaAmy Elsner RENEWAL
Jones H NestleBrazilElwin Sharvill RENEWAL
Juan V VenereRussiaIoni Bowcher UNQUALIFIED
Morrow K DarakjyCanadaIoni Bowcher NEGOTIATION
Antonio U DoeRussiaAnna Fali UNQUALIFIED
Aditya O MacleadItalyElwin Sharvill UNQUALIFIED
Silvio T SlusarskiSpainStephen Shaw QUALIFIED
Ashley O NestleItalyIoni Bowcher RENEWAL
David O CaldareraGermanyXuxue Feng NEGOTIATION
Isabel L NestleSpainIvan Magalhaes NEGOTIATION
Rodrigues O FerenczGermanyBernardo Dominic PROPOSAL
Izzy K FigeroaIndiaAsiya Javayant NEW
Jeanfrancois B StensethIndiaXuxue Feng RENEWAL
Aditya Q FlosiIndiaStephen Shaw PROPOSAL
Munro N MarrierBrazilOnyama Limba NEW
Izzy L ChuiUnited KingdomAsiya Javayant PROPOSAL
Aika F AlbaresItalyAmy Elsner NEW
Misaki L PaprockiSpainOnyama Limba QUALIFIED
Faith P WhobreyIndiaXuxue Feng PROPOSAL
Johnson P VenereArgentinaXuxue Feng NEW
Ashley A RoysterRussiaXuxue Feng UNQUALIFIED
Wickens B NickaBrazilAnna Fali PROPOSAL
Jefferson N NickaBrazilElwin Sharvill RENEWAL
Antonio D WieserAustraliaIoni Bowcher PROPOSAL

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