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
Emily W VocelkaFranceBernardo Dominic PROPOSAL
Isabel W IturbideBrazilIvan Magalhaes PROPOSAL
James A RutaCanadaIvan Magalhaes UNQUALIFIED
Antonio R MacleadIndiaXuxue Feng QUALIFIED
Aruna D MaletArgentinaOnyama Limba RENEWAL
Silvio N RutaCanadaAnna Fali UNQUALIFIED
Claire V MorascaJapanElwin Sharvill NEGOTIATION
Emily J WieserRussiaIoni Bowcher NEGOTIATION
Cody S MorascaCanadaStephen Shaw NEGOTIATION
David T CaldareraUnited KingdomAsiya Javayant QUALIFIED
Jones C BologniaJapanIoni Bowcher NEGOTIATION
Aruna J StockhamItalyAnna Fali NEGOTIATION
Tony T BowleyItalyAsiya Javayant PROPOSAL
Ashley X SchemmerSpainStephen Shaw NEGOTIATION
Smith D MaletUnited KingdomOnyama Limba QUALIFIED
Mujtaba K BriddickIndiaBernardo Dominic UNQUALIFIED
Leja T VocelkaJapanIoni Bowcher QUALIFIED
Mujtaba R SchemmerJapanAnna Fali PROPOSAL
Rodrigues Q GarufiUnited KingdomAnna Fali RENEWAL
Greenwood O MaletGermanyAnna Fali RENEWAL
Johnson B FerenczJapanIoni Bowcher RENEWAL
Cody Z BowleyArgentinaOnyama Limba NEGOTIATION
Maisha G KolmetzSpainBernardo Dominic RENEWAL
Johnson S MorascaGermanyIvan Magalhaes NEGOTIATION
Aika K RulapaughGermanyAsiya Javayant NEW
Kadeem B IturbideAustraliaAsiya Javayant UNQUALIFIED
Darci U MaletRussiaAnna Fali NEGOTIATION
Deepesh V AmigonBrazilBernardo Dominic NEW
Costa K OstroskyAustraliaAsiya Javayant UNQUALIFIED
Adams W BologniaJapanBernardo Dominic NEGOTIATION
Leja A WieserAustraliaElwin Sharvill RENEWAL
Leja K RutaArgentinaXuxue Feng QUALIFIED
Mayumi L SlusarskiJapanAmy Elsner PROPOSAL
Morrow U GlickUnited KingdomIoni Bowcher PROPOSAL
Aditya T FlosiJapanAnna Fali NEGOTIATION
James O VenereIndiaElwin Sharvill UNQUALIFIED
Maisha U WhobreyGermanyBernardo Dominic NEGOTIATION
Salvatore D GauchoSpainStephen Shaw PROPOSAL
Maisha F CaldareraRussiaIvan Magalhaes UNQUALIFIED
Misaki W SlusarskiCanadaOnyama Limba UNQUALIFIED
Izzy A ChuiSpainStephen Shaw NEW
Salvatore M GlickFranceStephen Shaw NEGOTIATION
Clifford Y RoysterCanadaAmy Elsner NEW
Kaitlin V MorascaFranceAsiya Javayant RENEWAL
Aika Y MaletFranceElwin Sharvill NEGOTIATION
Kadeem I VocelkaArgentinaBernardo Dominic RENEWAL
Ivar C VocelkaIndiaElwin Sharvill UNQUALIFIED
Juan X StensethFranceXuxue Feng UNQUALIFIED
Kadeem X WaycottCanadaAmy Elsner NEW
Faith V DarakjyCanadaElwin Sharvill NEW
Horizontal
NameCountryRepresentativeStatus
Juan H ChuiItalyXuxue Feng UNQUALIFIED
Smith E FerenczSpainStephen Shaw QUALIFIED
Salvatore W ButtIndiaOnyama Limba NEGOTIATION
Ricardo Q RulapaughJapanAnna Fali PROPOSAL
Isabel T PoquetteAustraliaStephen Shaw RENEWAL
Salvatore U CaudyArgentinaBernardo Dominic PROPOSAL
Morrow U InouyeSpainStephen Shaw NEGOTIATION
Wickens P FollerUnited KingdomElwin Sharvill QUALIFIED
Octavia G KolmetzAustraliaStephen Shaw PROPOSAL
Arvin V AmigonItalyOnyama Limba NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Faith U StockhamJapan2024-04-28Chapman, Ross E Esq UNQUALIFIED89Amy Elsner
1001Sinclair O RulapaughSpain2024-05-04Rangoni Of Florence UNQUALIFIED23Onyama Limba
1002Misaki Y StockhamIndia2024-04-20Rousseaux, Michael Esq RENEWAL25Xuxue Feng
1003Izzy B RulapaughItaly2024-04-19Rangoni Of Florence QUALIFIED23Elwin Sharvill
1004Kadeem V ButtItaly2024-05-09Commercial Press NEW25Onyama Limba
1005James U AlbaresItaly2024-05-08Feltz Printing Service UNQUALIFIED77Onyama Limba
1006Cody E IturbideGermany2024-04-22Rousseaux, Michael Esq RENEWAL15Bernardo Dominic
1007Greenwood Y MaletFrance2024-04-22Chemel, James L Cpa RENEWAL58Ioni Bowcher
1008Leon E DoeRussia2024-04-19Feiner Bros RENEWAL2Ivan Magalhaes
1009Claire F InouyeCanada2024-05-03Chemel, James L Cpa UNQUALIFIED69Stephen Shaw
1010Smith W MorascaUnited Kingdom2024-04-30Chanay, Jeffrey A Esq QUALIFIED80Xuxue Feng
1011Darci S RutaItaly2024-05-05Benton, John B Jr NEW13Onyama Limba
1012Jones M PaprockiUnited Kingdom2024-04-14Printing Dimensions NEW93Ivan Magalhaes
1013Kaitlin G OstroskyRussia2024-04-18Chemel, James L Cpa NEW79Onyama Limba
1014Rodrigues O PerinArgentina2024-04-13Feiner Bros QUALIFIED9Stephen Shaw
1015Clifford G ButtItaly2024-05-04Chapman, Ross E Esq NEW16Onyama Limba
1016Francesco O BriddickAustralia2024-04-24Commercial Press NEGOTIATION93Anna Fali
1017Deepesh Q ButtGermany2024-04-28Feltz Printing Service PROPOSAL66Anna Fali
1018Aika D PoquetteIndia2024-04-17Commercial Press NEW75Xuxue Feng
1019Aika F SaylorsJapan2024-05-09Chanay, Jeffrey A Esq QUALIFIED38Stephen Shaw
1020Aditya G WhobreyItaly2024-04-17Rangoni Of Florence RENEWAL95Bernardo Dominic
1021Leon N FerenczBrazil2024-05-07Printing Dimensions PROPOSAL58Asiya Javayant
1022Izzy C FigeroaIndia2024-04-22King, Christopher A Esq NEW72Bernardo Dominic
1023David M WieserFrance2024-04-25Printing Dimensions NEW12Onyama Limba
1024Maria U OldroydFrance2024-04-29King, Christopher A Esq NEW9Ivan Magalhaes
1025Arvin P IturbideCanada2024-05-09Rangoni Of Florence RENEWAL44Onyama Limba
1026Francesco T CampainBrazil2024-05-01Benton, John B Jr NEGOTIATION26Amy Elsner
1027Munro T FlosiItaly2024-04-28King, Christopher A Esq PROPOSAL58Ioni Bowcher
1028Leja N AmigonGermany2024-05-03Feltz Printing Service NEW31Xuxue Feng
1029Leja Z ShinkoBrazil2024-05-05Chanay, Jeffrey A Esq UNQUALIFIED30Onyama Limba
1030Johnson K PoquetteRussia2024-04-21Chemel, James L Cpa RENEWAL50Ioni Bowcher
1031Stacey I StensethItaly2024-05-04Chapman, Ross E Esq PROPOSAL58Xuxue Feng
1032Darci H BologniaIndia2024-04-27Printing Dimensions NEGOTIATION18Anna Fali
1033Juan X RulapaughBrazil2024-04-27Buckley Miller Wright RENEWAL35Ivan Magalhaes
1034Aruna W GarufiArgentina2024-04-22Printing Dimensions QUALIFIED46Ivan Magalhaes
1035Jeanfrancois U StensethIndia2024-04-27Commercial Press UNQUALIFIED79Anna Fali
1036Julie J WaycottGermany2024-05-04Chapman, Ross E Esq PROPOSAL32Bernardo Dominic
1037Chavez B SergiAustralia2024-04-23Feiner Bros UNQUALIFIED98Asiya Javayant
1038Jones M SlusarskiGermany2024-04-19Printing Dimensions NEGOTIATION88Anna Fali
1039Leja C GarufiRussia2024-04-30Chemel, James L Cpa RENEWAL6Amy Elsner
1040Costa T OstroskyItaly2024-05-05Commercial Press QUALIFIED5Onyama Limba
1041Leja P VocelkaIndia2024-04-16Feiner Bros UNQUALIFIED85Elwin Sharvill
1042David X CaudyItaly2024-05-05Feltz Printing Service QUALIFIED6Onyama Limba
1043Johnson Z OstroskyUnited Kingdom2024-04-19Chanay, Jeffrey A Esq RENEWAL22Xuxue Feng
1044Munro M SlusarskiIndia2024-05-08Feltz Printing Service NEW40Asiya Javayant
1045Alejandro P FlosiJapan2024-05-09Morlong Associates NEW73Xuxue Feng
1046Jones V AlbaresGermany2024-05-09Chanay, Jeffrey A Esq RENEWAL18Stephen Shaw
1047Aditya L ChuiBrazil2024-05-07King, Christopher A Esq RENEWAL67Amy Elsner
1048Faith N OldroydSpain2024-04-23Dorl, James J Esq QUALIFIED59Asiya Javayant
1049Emily A CaudyUnited Kingdom2024-04-15Truhlar And Truhlar Attys QUALIFIED13Ioni Bowcher
Frozen Rows
NameCountryRepresentativeStatus
Sinclair O SaylorsBrazilIoni Bowcher QUALIFIED
Izzy N IturbideArgentinaAnna Fali NEGOTIATION
Maisha N IturbideItalyElwin Sharvill QUALIFIED
Johnson O GlickGermanyAnna Fali NEGOTIATION
Francesco N DarakjyCanadaBernardo Dominic NEGOTIATION
Mayumi G OldroydCanadaAsiya Javayant PROPOSAL
James Q WhobreyJapanIvan Magalhaes UNQUALIFIED
Rodrigues R PoquetteBrazilBernardo Dominic NEGOTIATION
Darci M BologniaFranceXuxue Feng UNQUALIFIED
Murillo C IturbideItalyAmy Elsner QUALIFIED
Murillo T StensethJapanElwin Sharvill PROPOSAL
Smith L GillianUnited KingdomIoni Bowcher QUALIFIED
Kadeem V GauchoUnited KingdomBernardo Dominic RENEWAL
Misaki J SchemmerJapanXuxue Feng PROPOSAL
Cody S NickaBrazilIvan Magalhaes RENEWAL
Tony Y PaprockiAustraliaAsiya Javayant NEW
Clifford K CaldareraRussiaAmy Elsner PROPOSAL
Costa U ButtGermanyAsiya Javayant RENEWAL
Kadeem G ShinkoFranceAmy Elsner UNQUALIFIED
Antonio Z DarakjyRussiaBernardo Dominic UNQUALIFIED
Silvio J ChuiArgentinaBernardo Dominic UNQUALIFIED
Julie A FigeroaUnited KingdomAnna Fali RENEWAL
Clifford C PerinGermanyXuxue Feng QUALIFIED
Nicolas K CaldareraGermanyXuxue Feng NEGOTIATION
Kadeem C FlosiRussiaIoni Bowcher QUALIFIED
Tony R OstroskyArgentinaStephen Shaw NEW
Johnson X NickaRussiaStephen Shaw NEW
Leja N FerenczBrazilBernardo Dominic UNQUALIFIED
Johnson X StensethGermanyOnyama Limba UNQUALIFIED
Salvatore K GauchoAustraliaElwin Sharvill RENEWAL
Isabel T CampainFranceAsiya Javayant PROPOSAL
Jones E ButtBrazilStephen Shaw NEGOTIATION
Juan F RutaCanadaBernardo Dominic QUALIFIED
Kaitlin X AmigonFranceIvan Magalhaes UNQUALIFIED
Aditya F GlickRussiaAnna Fali NEW
Stacey C TollnerFranceIoni Bowcher RENEWAL
Morrow Q MorascaJapanXuxue Feng RENEWAL
Ricardo L RimJapanXuxue Feng UNQUALIFIED
Julie G AmigonCanadaIoni Bowcher NEW
Misaki Q DilliardUnited KingdomAnna Fali NEGOTIATION
Aditya H MaletItalyIoni Bowcher NEW
Morrow H SergiIndiaStephen Shaw QUALIFIED
Nicolas Z VocelkaAustraliaAsiya Javayant UNQUALIFIED
Isabel S FollerBrazilAmy Elsner QUALIFIED
Kadeem B DoeJapanAsiya Javayant NEW
Wickens I FigeroaSpainAsiya Javayant NEW
Izzy K OldroydRussiaBernardo Dominic RENEWAL
Kaitlin C DoeJapanStephen Shaw PROPOSAL
Antonio T ButtGermanyStephen Shaw RENEWAL
Darci P VenereSpainBernardo Dominic NEW
Frozen Columns
Name
Ricardo Z Ostrosky
Juan T Venere
Greenwood L Iturbide
Johnson X Garufi
Darci T Venere
Kadeem I Glick
Sinclair T Butt
Aruna W Venere
Salvatore C Glick
Darci T Albares
Smith Q Marrier
Isabel W Albares
Francesco T Flosi
Silvio I Nicka
Maria O Tollner
Darci D Slusarski
Izzy H Maclead
Octavia T Iturbide
Adams L Butt
Izzy N Rim
Jennifer X Morasca
Claire A Royster
Rodrigues T Gaucho
Munro P Campain
Chavez X Ferencz
Costa S Shinko
Leon X Gillian
Morrow C Ferencz
Jefferson C Sergi
Silvio A Malet
Clifford Q Venere
Darci P Paprocki
Aika Q Malet
Clifford J Ruta
Claire N Tollner
Ricardo F Ruta
Tony M Iturbide
Costa O Whobrey
Munro Q Inouye
David Q Iturbide
Adams Z Rim
Smith Z Butt
Cody Q Maclead
Leon W Oldroyd
Jefferson X Chui
Clifford P Nicka
Leja E Ferencz
Stacey B Bowley
Tony T Ostrosky
Arvin A Albares
IdCountryDate
1000Australia2024-05-01
1001France2024-04-22
1002United Kingdom2024-04-27
1003United Kingdom2024-04-27
1004Russia2024-04-16
1005India2024-04-23
1006Spain2024-04-25
1007Canada2024-04-16
1008Canada2024-04-23
1009Italy2024-05-05
1010Canada2024-04-26
1011United Kingdom2024-04-11
1012Germany2024-05-03
1013India2024-04-21
1014Canada2024-04-28
1015United Kingdom2024-05-08
1016Germany2024-04-13
1017Russia2024-04-27
1018Italy2024-04-17
1019India2024-04-13
1020Russia2024-04-25
1021United Kingdom2024-04-17
1022Argentina2024-04-23
1023Germany2024-04-24
1024United Kingdom2024-04-17
1025Germany2024-04-12
1026Australia2024-04-21
1027Russia2024-04-24
1028France2024-04-17
1029United Kingdom2024-04-25
1030United Kingdom2024-05-08
1031France2024-04-12
1032Italy2024-04-26
1033Germany2024-04-28
1034Spain2024-05-08
1035Brazil2024-05-09
1036Italy2024-04-26
1037Japan2024-05-07
1038Russia2024-04-23
1039France2024-04-14
1040India2024-04-28
1041Russia2024-05-06
1042Brazil2024-04-12
1043Brazil2024-04-28
1044Spain2024-05-08
1045Japan2024-05-01
1046Russia2024-04-25
1047Spain2024-04-25
1048Australia2024-04-19
1049Argentina2024-05-10

On-Demand Data

NameIdCountryDate
Francesco K Amigon1000France2024-04-28
Leja Y Rim1001Japan2024-04-26
James Q Vocelka1002Italy2024-05-06
Sinclair M Gillian1003Spain2024-04-13
Octavia F Darakjy1004Russia2024-05-09
Aditya J Tollner1005India2024-04-25
Greenwood Y Malet1006Japan2024-05-01
Mujtaba J Doe1007United Kingdom2024-05-05
Johnson U Schemmer1008Japan2024-04-15
Izzy B Sergi1009Brazil2024-04-30
Misaki J Paprocki1010Argentina2024-05-05
Aditya D Iturbide1011India2024-04-18
Julie F Malet1012Italy2024-04-15
Leon W Malet1013India2024-05-05
Cody A Schemmer1014Australia2024-04-20
Alejandro R Morasca1015Italy2024-05-04
Ashley H Stenseth1016Argentina2024-04-15
Claire Q Ferencz1017India2024-04-30
Maisha Z Bowley1018Brazil2024-04-24
David A Nicka1019France2024-05-10
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Arvin C KuskoFranceAnna Fali PROPOSAL
Morrow P ChuiJapanOnyama Limba QUALIFIED
Ivar I MaletGermanyAmy Elsner PROPOSAL
Tony Z VocelkaFranceElwin Sharvill NEGOTIATION
Morrow W CaldareraFranceIoni Bowcher PROPOSAL
Deepesh Z CaldareraJapanStephen Shaw RENEWAL
Maria O AlbaresGermanyOnyama Limba RENEWAL
Aruna A FlosiJapanAsiya Javayant PROPOSAL
Ivar Q DarakjySpainElwin Sharvill PROPOSAL
Francesco A SergiCanadaOnyama Limba RENEWAL
Rodrigues M VocelkaIndiaBernardo Dominic NEGOTIATION
Claire W FerenczUnited KingdomElwin Sharvill RENEWAL
Emily Y RutaIndiaStephen Shaw NEGOTIATION
Murillo O OldroydBrazilIoni Bowcher QUALIFIED
Kaitlin F StockhamFranceIoni Bowcher NEGOTIATION
Costa R SaylorsGermanyOnyama Limba QUALIFIED
Izzy O ShinkoUnited KingdomIvan Magalhaes NEGOTIATION
Smith Q WhobreyRussiaAmy Elsner PROPOSAL
Smith D RoysterArgentinaIoni Bowcher PROPOSAL
Maisha Z FlosiRussiaIoni Bowcher UNQUALIFIED
Ricardo Q OldroydJapanAnna Fali UNQUALIFIED
Aditya C CaldareraUnited KingdomStephen Shaw RENEWAL
Deepesh T WaycottBrazilAmy Elsner NEW
Juan M FollerArgentinaStephen Shaw UNQUALIFIED
Darci K DoeGermanyAsiya Javayant QUALIFIED
Aika K BologniaArgentinaIvan Magalhaes UNQUALIFIED
Julie X FollerUnited KingdomIvan Magalhaes QUALIFIED
Ivar C GauchoCanadaOnyama Limba QUALIFIED
Ivar N GarufiRussiaXuxue Feng UNQUALIFIED
Morrow Z InouyeGermanyBernardo Dominic QUALIFIED
Silvio G StockhamFranceOnyama Limba PROPOSAL
Smith K StockhamItalyElwin Sharvill RENEWAL
Octavia B KuskoItalyBernardo Dominic PROPOSAL
Munro I RutaItalyIoni Bowcher NEW
Cody X CaldareraArgentinaXuxue Feng QUALIFIED
Adams E MaletSpainAnna Fali PROPOSAL
Julie N BowleyArgentinaIoni Bowcher QUALIFIED
Aruna O PerinJapanAnna Fali PROPOSAL
Octavia Q WhobreyGermanyBernardo Dominic NEW
Misaki N FigeroaBrazilOnyama Limba 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>