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
James P CampainAustraliaBernardo Dominic NEGOTIATION
Ashley F ChuiFranceAsiya Javayant NEGOTIATION
Smith A IturbideAustraliaXuxue Feng RENEWAL
Darci I WhobreyCanadaIvan Magalhaes QUALIFIED
Juan E InouyeUnited KingdomElwin Sharvill NEW
Darci W ChuiRussiaIoni Bowcher PROPOSAL
Tony Y MorascaFranceAmy Elsner UNQUALIFIED
Aditya T PoquetteAustraliaStephen Shaw RENEWAL
Jennifer G ButtBrazilAmy Elsner NEW
Ricardo G StockhamIndiaOnyama Limba PROPOSAL
Murillo K VocelkaFranceBernardo Dominic UNQUALIFIED
Ashley C BowleyAustraliaStephen Shaw PROPOSAL
Johnson I RoysterBrazilBernardo Dominic NEW
Nicolas J AmigonUnited KingdomXuxue Feng QUALIFIED
Ricardo D PaprockiItalyOnyama Limba RENEWAL
Arvin S RutaIndiaElwin Sharvill NEGOTIATION
David C BologniaIndiaIoni Bowcher NEW
Aditya I GlickArgentinaAmy Elsner RENEWAL
Mayumi Y MaletUnited KingdomStephen Shaw NEGOTIATION
Johnson Z CampainIndiaIvan Magalhaes QUALIFIED
Adams M FollerJapanAsiya Javayant NEGOTIATION
Chavez I PaprockiItalyBernardo Dominic UNQUALIFIED
Smith I StockhamCanadaElwin Sharvill QUALIFIED
Isabel K IturbideAustraliaIoni Bowcher QUALIFIED
Misaki I FollerGermanyStephen Shaw NEW
Greenwood N WieserSpainBernardo Dominic QUALIFIED
Costa F ChuiIndiaElwin Sharvill PROPOSAL
Jefferson A NickaIndiaAmy Elsner UNQUALIFIED
Julie W AmigonItalyOnyama Limba PROPOSAL
Wickens T BriddickSpainAnna Fali QUALIFIED
Aika E CaldareraCanadaElwin Sharvill QUALIFIED
Mujtaba O RimRussiaIvan Magalhaes UNQUALIFIED
Leja O StockhamCanadaElwin Sharvill NEGOTIATION
Tony F ButtBrazilAnna Fali NEGOTIATION
Aruna Z SaylorsRussiaStephen Shaw NEW
Antonio C RimItalyAsiya Javayant NEGOTIATION
Ricardo W CaudyCanadaXuxue Feng NEW
Ashley W BowleyCanadaAsiya Javayant RENEWAL
Mujtaba D RutaGermanyStephen Shaw QUALIFIED
Costa X WieserUnited KingdomAmy Elsner UNQUALIFIED
Claire J MaletRussiaBernardo Dominic RENEWAL
Smith P StensethFranceAmy Elsner UNQUALIFIED
Jones I VenereUnited KingdomBernardo Dominic UNQUALIFIED
Leja X StensethArgentinaAnna Fali QUALIFIED
Wickens O KolmetzSpainIoni Bowcher QUALIFIED
Isabel X DilliardItalyStephen Shaw RENEWAL
Murillo K GauchoArgentinaOnyama Limba PROPOSAL
Johnson I DilliardRussiaXuxue Feng UNQUALIFIED
Francesco L KolmetzRussiaIoni Bowcher RENEWAL
Mayumi J CaudyItalyAnna Fali QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Arvin X GarufiJapanElwin Sharvill PROPOSAL
Kaitlin G CaudyFranceElwin Sharvill NEGOTIATION
Jeanfrancois I GauchoUnited KingdomBernardo Dominic NEGOTIATION
Sinclair R VocelkaGermanyIoni Bowcher QUALIFIED
Julie Z FollerUnited KingdomElwin Sharvill PROPOSAL
Leon Y CampainArgentinaAsiya Javayant NEW
Ricardo F GarufiCanadaOnyama Limba NEGOTIATION
Ivar C DarakjyFranceIoni Bowcher RENEWAL
Ashley I DoeArgentinaXuxue Feng QUALIFIED
Jennifer G StensethRussiaBernardo Dominic NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Silvio T DarakjySpain2024-04-04Printing Dimensions NEGOTIATION55Onyama Limba
1001Tony P InouyeAustralia2024-03-26Chanay, Jeffrey A Esq QUALIFIED48Asiya Javayant
1002Mayumi Q SlusarskiBrazil2024-03-30Dorl, James J Esq NEW76Amy Elsner
1003Morrow E RimIndia2024-03-22King, Christopher A Esq NEGOTIATION13Stephen Shaw
1004Ricardo T GlickRussia2024-04-14King, Christopher A Esq NEW70Elwin Sharvill
1005Kadeem S BowleyUnited Kingdom2024-04-05Chanay, Jeffrey A Esq NEW63Elwin Sharvill
1006Darci Q FigeroaSpain2024-04-16Morlong Associates QUALIFIED5Ivan Magalhaes
1007Deepesh L FigeroaIndia2024-03-28Chanay, Jeffrey A Esq NEGOTIATION85Stephen Shaw
1008Leon F NestleArgentina2024-03-20Printing Dimensions NEGOTIATION19Ivan Magalhaes
1009Darci N GillianRussia2024-04-15Rangoni Of Florence QUALIFIED38Xuxue Feng
1010Isabel S WaycottIndia2024-03-30King, Christopher A Esq UNQUALIFIED75Ivan Magalhaes
1011Izzy E InouyeAustralia2024-04-17King, Christopher A Esq PROPOSAL59Elwin Sharvill
1012Jefferson M MorascaSpain2024-04-17Chapman, Ross E Esq QUALIFIED71Elwin Sharvill
1013Wickens M ButtArgentina2024-04-16Rangoni Of Florence PROPOSAL98Anna Fali
1014Salvatore Z MacleadJapan2024-04-17Rousseaux, Michael Esq RENEWAL52Onyama Limba
1015Nicolas T OldroydAustralia2024-04-07Chemel, James L Cpa RENEWAL24Bernardo Dominic
1016Faith C FlosiUnited Kingdom2024-04-08Dorl, James J Esq UNQUALIFIED44Bernardo Dominic
1017Misaki S WaycottFrance2024-03-23Rangoni Of Florence NEW17Ioni Bowcher
1018Johnson R VenereIndia2024-04-09Feiner Bros QUALIFIED68Asiya Javayant
1019Kadeem F BologniaIndia2024-03-27Chanay, Jeffrey A Esq RENEWAL92Anna Fali
1020Murillo B GillianAustralia2024-04-01Rangoni Of Florence QUALIFIED48Asiya Javayant
1021Smith T ButtAustralia2024-03-28Benton, John B Jr NEW28Onyama Limba
1022James A SaylorsJapan2024-04-18Chanay, Jeffrey A Esq UNQUALIFIED95Bernardo Dominic
1023Costa J PerinGermany2024-04-18Printing Dimensions NEGOTIATION46Amy Elsner
1024Maria X StensethUnited Kingdom2024-03-26Benton, John B Jr UNQUALIFIED4Elwin Sharvill
1025Cody M PaprockiRussia2024-03-20Chapman, Ross E Esq NEGOTIATION69Asiya Javayant
1026Greenwood D DarakjyIndia2024-04-02Buckley Miller Wright NEW43Amy Elsner
1027Maria H RulapaughAustralia2024-04-10Printing Dimensions UNQUALIFIED50Stephen Shaw
1028Aika V NickaItaly2024-03-31Printing Dimensions UNQUALIFIED59Xuxue Feng
1029Stacey U RimAustralia2024-04-15Feiner Bros RENEWAL75Anna Fali
1030Mujtaba A RoysterGermany2024-04-09Feltz Printing Service UNQUALIFIED22Anna Fali
1031Kaitlin I VocelkaJapan2024-03-24Commercial Press NEGOTIATION27Xuxue Feng
1032Salvatore W OstroskyJapan2024-04-03Morlong Associates UNQUALIFIED82Ivan Magalhaes
1033Wickens V WaycottBrazil2024-04-08Chanay, Jeffrey A Esq NEW56Xuxue Feng
1034Juan W TollnerSpain2024-04-13Benton, John B Jr NEGOTIATION13Asiya Javayant
1035Emily F InouyeItaly2024-04-05Rousseaux, Michael Esq UNQUALIFIED84Ioni Bowcher
1036Aruna E MaletFrance2024-03-25Rousseaux, Michael Esq RENEWAL13Anna Fali
1037Deepesh S OldroydJapan2024-04-04King, Christopher A Esq NEGOTIATION50Elwin Sharvill
1038Emily D DarakjyBrazil2024-04-15Chapman, Ross E Esq NEW45Ioni Bowcher
1039Faith L MaletIndia2024-03-26Truhlar And Truhlar Attys RENEWAL93Anna Fali
1040Munro F StensethItaly2024-04-13Commercial Press PROPOSAL74Xuxue Feng
1041Juan H PaprockiAustralia2024-03-23Chapman, Ross E Esq NEW48Asiya Javayant
1042Aruna M FlosiSpain2024-04-10Printing Dimensions RENEWAL24Stephen Shaw
1043Leja M WaycottRussia2024-04-10Feiner Bros UNQUALIFIED74Amy Elsner
1044Kadeem X GarufiFrance2024-03-26Morlong Associates NEGOTIATION20Stephen Shaw
1045Cody D PaprockiFrance2024-03-27Chanay, Jeffrey A Esq RENEWAL99Asiya Javayant
1046Deepesh Q KolmetzIndia2024-03-22Rousseaux, Michael Esq UNQUALIFIED40Xuxue Feng
1047Izzy W GlickJapan2024-04-18Morlong Associates NEW95Anna Fali
1048Silvio B AlbaresCanada2024-04-13Commercial Press NEGOTIATION10Onyama Limba
1049Morrow H SlusarskiBrazil2024-04-08Printing Dimensions NEGOTIATION92Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Jeanfrancois G WhobreyBrazilStephen Shaw NEGOTIATION
Kaitlin K PerinItalyStephen Shaw UNQUALIFIED
Wickens I MarrierUnited KingdomAmy Elsner RENEWAL
Jennifer O BologniaGermanyElwin Sharvill RENEWAL
Wickens R StensethSpainStephen Shaw PROPOSAL
Stacey P StensethGermanyAnna Fali QUALIFIED
Silvio L DarakjyBrazilIvan Magalhaes UNQUALIFIED
Ivar S SergiAustraliaXuxue Feng NEGOTIATION
Julie Q DilliardFranceAsiya Javayant NEW
Stacey S MacleadAustraliaBernardo Dominic NEGOTIATION
James N SaylorsCanadaIvan Magalhaes NEW
Munro D MaletJapanAmy Elsner NEGOTIATION
Greenwood S MarrierGermanyElwin Sharvill PROPOSAL
Octavia R NickaFranceIoni Bowcher NEW
Smith E SchemmerRussiaXuxue Feng NEGOTIATION
Salvatore R MaletSpainAmy Elsner NEGOTIATION
Ashley X DoeBrazilXuxue Feng RENEWAL
Julie C IturbideBrazilIoni Bowcher NEGOTIATION
David Q FlosiFranceIoni Bowcher QUALIFIED
Jefferson O SchemmerRussiaAnna Fali NEGOTIATION
Tony X GillianBrazilBernardo Dominic NEGOTIATION
Ricardo W GlickAustraliaXuxue Feng UNQUALIFIED
Nicolas G RulapaughAustraliaAnna Fali NEW
Rodrigues M PaprockiRussiaElwin Sharvill QUALIFIED
Ricardo D FlosiJapanIvan Magalhaes NEW
Darci U SergiAustraliaIoni Bowcher PROPOSAL
Jeanfrancois E WhobreySpainXuxue Feng NEW
Ashley Y PerinJapanStephen Shaw NEGOTIATION
Arvin U WhobreyAustraliaStephen Shaw NEGOTIATION
Juan R SaylorsAustraliaAsiya Javayant QUALIFIED
Aditya X GlickSpainStephen Shaw RENEWAL
Mujtaba U FigeroaSpainXuxue Feng QUALIFIED
Costa A AmigonUnited KingdomStephen Shaw NEW
Clifford L FigeroaIndiaElwin Sharvill PROPOSAL
Jennifer H OldroydRussiaAsiya Javayant UNQUALIFIED
Salvatore P FigeroaItalyIvan Magalhaes QUALIFIED
Wickens B DoeFranceStephen Shaw RENEWAL
Jones L KolmetzFranceBernardo Dominic NEGOTIATION
Salvatore N NickaSpainOnyama Limba NEGOTIATION
Nicolas H CampainGermanyStephen Shaw UNQUALIFIED
Jeanfrancois S BowleyItalyXuxue Feng RENEWAL
Chavez T GlickIndiaAmy Elsner NEGOTIATION
Julie M AmigonFranceOnyama Limba NEGOTIATION
Jeanfrancois J PerinAustraliaIvan Magalhaes NEW
Costa E DarakjyUnited KingdomAnna Fali RENEWAL
Munro I FigeroaBrazilBernardo Dominic QUALIFIED
Antonio N MacleadGermanyIvan Magalhaes PROPOSAL
Jennifer D RulapaughUnited KingdomXuxue Feng QUALIFIED
Kadeem L VocelkaCanadaXuxue Feng QUALIFIED
Adams P DoeGermanyIoni Bowcher QUALIFIED
Frozen Columns
Name
Ricardo Z Flosi
Sinclair G Waycott
Smith K Bolognia
Jones R Poquette
David W Schemmer
Salvatore R Perin
Faith X Flosi
Costa E Oldroyd
Adams F Figeroa
Munro V Maclead
Kadeem S Gillian
Aruna W Gillian
Cody N Marrier
Jeanfrancois V Bowley
Alejandro T Marrier
Darci B Schemmer
Maria J Rulapaugh
Julie P Shinko
Ivar G Oldroyd
Mujtaba T Rim
Jefferson I Stenseth
Jefferson Y Flosi
Munro W Kolmetz
Adams B Flosi
Juan U Kusko
Kadeem D Morasca
Isabel G Royster
Morrow D Butt
Ashley O Schemmer
Ricardo A Campain
Deepesh A Sergi
Isabel H Vocelka
James A Rulapaugh
Jeanfrancois S Whobrey
Alejandro K Malet
Maisha R Morasca
Tony Z Chui
Mujtaba B Vocelka
Isabel M Briddick
Ivar H Paprocki
Octavia F Nicka
Greenwood B Venere
Darci D Perin
Greenwood P Flosi
Jeanfrancois I Tollner
Arvin U Waycott
Antonio C Flosi
Salvatore K Stenseth
Cody S Caudy
Mayumi T Malet
IdCountryDate
1000Brazil2024-03-24
1001Spain2024-03-31
1002Canada2024-03-24
1003Brazil2024-04-01
1004Argentina2024-04-13
1005Canada2024-04-07
1006France2024-04-04
1007India2024-03-27
1008Brazil2024-04-02
1009Canada2024-03-20
1010Spain2024-04-01
1011Argentina2024-03-29
1012Canada2024-04-13
1013Germany2024-04-01
1014Australia2024-03-30
1015Canada2024-03-31
1016Brazil2024-03-26
1017United Kingdom2024-04-09
1018Japan2024-04-02
1019Canada2024-04-13
1020France2024-04-14
1021India2024-04-04
1022Argentina2024-04-12
1023Japan2024-04-17
1024Canada2024-04-03
1025India2024-04-09
1026France2024-04-17
1027Russia2024-04-17
1028Italy2024-04-08
1029Brazil2024-04-09
1030Germany2024-04-03
1031Germany2024-03-22
1032India2024-04-11
1033Russia2024-03-31
1034Germany2024-04-18
1035Canada2024-04-03
1036France2024-04-11
1037Canada2024-03-24
1038Brazil2024-04-03
1039Canada2024-04-13
1040Spain2024-03-21
1041Argentina2024-03-28
1042Australia2024-04-10
1043Australia2024-04-18
1044Brazil2024-03-25
1045Brazil2024-04-04
1046India2024-03-25
1047Brazil2024-04-10
1048Russia2024-03-27
1049Argentina2024-03-23

On-Demand Data

NameIdCountryDate
Salvatore I Wieser1000Brazil2024-04-02
Stacey K Maclead1001Spain2024-04-04
Greenwood K Wieser1002Germany2024-04-02
Maisha U Malet1003Argentina2024-03-31
Leja T Royster1004Canada2024-03-29
Mujtaba I Oldroyd1005Germany2024-04-16
Murillo D Flosi1006Brazil2024-04-03
Mujtaba N Chui1007Japan2024-04-05
Jones S Albares1008Spain2024-03-25
Nicolas N Glick1009Australia2024-04-03
Morrow R Poquette1010India2024-04-14
Greenwood E Vocelka1011Brazil2024-04-05
Leja K Inouye1012France2024-03-24
Aika B Butt1013Argentina2024-03-24
Alejandro Z Amigon1014India2024-04-04
Murillo N Dilliard1015Australia2024-04-10
Darci W Tollner1016Italy2024-04-02
Rodrigues F Stenseth1017India2024-03-22
Nicolas X Malet1018Italy2024-04-12
Francesco L Rulapaugh1019Germany2024-03-30
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aika V WaycottJapanIoni Bowcher RENEWAL
Aika Y GauchoCanadaOnyama Limba UNQUALIFIED
David P VocelkaItalyElwin Sharvill QUALIFIED
Greenwood V IturbideArgentinaElwin Sharvill QUALIFIED
Francesco D KuskoArgentinaIoni Bowcher NEW
Maria C TollnerCanadaElwin Sharvill NEGOTIATION
James J MarrierItalyAnna Fali RENEWAL
Jones J MaletAustraliaAmy Elsner RENEWAL
Ashley G FollerSpainAmy Elsner UNQUALIFIED
Costa Q CaudyGermanyXuxue Feng UNQUALIFIED
Ivar A OldroydAustraliaIvan Magalhaes RENEWAL
Juan J CampainRussiaOnyama Limba UNQUALIFIED
Julie P ChuiBrazilOnyama Limba UNQUALIFIED
Maria R PoquetteSpainXuxue Feng NEW
Aruna Y WhobreyRussiaAnna Fali RENEWAL
Jefferson A FollerFranceAnna Fali NEGOTIATION
Morrow E CaldareraSpainAnna Fali PROPOSAL
Juan E MarrierSpainElwin Sharvill NEW
Costa V DilliardItalyStephen Shaw NEGOTIATION
Alejandro U PerinFranceIoni Bowcher RENEWAL
Octavia W VocelkaIndiaElwin Sharvill PROPOSAL
Arvin U WhobreyCanadaAmy Elsner RENEWAL
Maisha D SlusarskiCanadaIoni Bowcher PROPOSAL
Ricardo I BologniaGermanyBernardo Dominic NEW
Darci O TollnerCanadaAnna Fali UNQUALIFIED
Darci E OstroskyRussiaIvan Magalhaes PROPOSAL
James A KuskoAustraliaElwin Sharvill NEW
Octavia E FlosiRussiaBernardo Dominic UNQUALIFIED
Izzy Y AmigonBrazilIoni Bowcher RENEWAL
Johnson D BriddickUnited KingdomIvan Magalhaes RENEWAL
Misaki X NickaJapanBernardo Dominic QUALIFIED
David Q RimFranceAmy Elsner RENEWAL
Octavia E BologniaGermanyAnna Fali QUALIFIED
James C SergiUnited KingdomAmy Elsner UNQUALIFIED
Wickens H WieserArgentinaOnyama Limba PROPOSAL
Maria I DilliardBrazilAsiya Javayant RENEWAL
Jones Q NickaRussiaAsiya Javayant NEW
James U PaprockiSpainElwin Sharvill PROPOSAL
Chavez D ChuiGermanyAnna Fali QUALIFIED
Maisha L VocelkaGermanyAmy Elsner NEW

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