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
Wickens A SlusarskiJapanOnyama Limba NEGOTIATION
Nicolas V StensethBrazilAsiya Javayant UNQUALIFIED
Rodrigues F InouyeRussiaAmy Elsner NEW
Deepesh U RulapaughIndiaAmy Elsner UNQUALIFIED
Deepesh K GauchoArgentinaBernardo Dominic RENEWAL
Francesco R CampainBrazilAnna Fali QUALIFIED
Morrow S FlosiJapanAnna Fali NEGOTIATION
Misaki M KolmetzIndiaElwin Sharvill NEW
Stacey F RoysterAustraliaIoni Bowcher PROPOSAL
Jones N MarrierJapanAmy Elsner UNQUALIFIED
Greenwood X DoeItalyBernardo Dominic PROPOSAL
Claire E KolmetzAustraliaOnyama Limba RENEWAL
Greenwood Y MorascaSpainStephen Shaw QUALIFIED
Claire Q SchemmerAustraliaIoni Bowcher NEGOTIATION
Octavia Z SaylorsFranceXuxue Feng NEGOTIATION
Munro L FlosiFranceIoni Bowcher UNQUALIFIED
Ivar B FigeroaItalyIvan Magalhaes QUALIFIED
Ivar K OldroydJapanXuxue Feng NEW
Johnson D GlickUnited KingdomIoni Bowcher NEGOTIATION
Clifford V CaudyRussiaBernardo Dominic PROPOSAL
Darci X PoquetteBrazilIvan Magalhaes NEGOTIATION
Francesco H OstroskyAustraliaIoni Bowcher PROPOSAL
Adams M SaylorsArgentinaOnyama Limba RENEWAL
Greenwood O InouyeGermanyBernardo Dominic PROPOSAL
Jefferson L NickaAustraliaBernardo Dominic UNQUALIFIED
Jefferson X MorascaUnited KingdomAnna Fali QUALIFIED
Deepesh H SaylorsRussiaBernardo Dominic PROPOSAL
Maria J IturbideFranceIvan Magalhaes UNQUALIFIED
Darci Y RoysterBrazilIoni Bowcher PROPOSAL
Antonio E GlickBrazilAnna Fali NEW
Nicolas U StensethCanadaStephen Shaw RENEWAL
Leon V VocelkaUnited KingdomStephen Shaw NEW
Aditya H DoeGermanyIoni Bowcher PROPOSAL
Leja U VenereBrazilIvan Magalhaes QUALIFIED
Stacey P SaylorsBrazilAnna Fali NEW
Darci M FollerUnited KingdomIoni Bowcher QUALIFIED
Kadeem K RutaRussiaXuxue Feng NEGOTIATION
Arvin I RimArgentinaOnyama Limba RENEWAL
Cody W PaprockiRussiaIoni Bowcher QUALIFIED
Juan J BologniaRussiaXuxue Feng NEW
Johnson D StensethGermanyAmy Elsner QUALIFIED
Greenwood J BriddickItalyBernardo Dominic QUALIFIED
Morrow T VenereSpainAnna Fali UNQUALIFIED
Ricardo I IturbideItalyIvan Magalhaes RENEWAL
Jeanfrancois L AlbaresBrazilBernardo Dominic NEW
Johnson U VocelkaFranceStephen Shaw QUALIFIED
Jefferson M DarakjyAustraliaElwin Sharvill NEGOTIATION
Izzy M CaudyFranceBernardo Dominic NEGOTIATION
Maisha T ButtAustraliaElwin Sharvill NEW
Antonio X DilliardUnited KingdomIvan Magalhaes PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Rodrigues U RimRussiaIvan Magalhaes RENEWAL
Misaki L RoysterGermanyElwin Sharvill RENEWAL
Antonio Y NestleArgentinaAsiya Javayant NEGOTIATION
Ivar O SchemmerRussiaOnyama Limba NEGOTIATION
Aruna I ButtSpainAnna Fali QUALIFIED
Tony H MarrierSpainAmy Elsner NEW
Kaitlin H PaprockiUnited KingdomXuxue Feng NEGOTIATION
Emily E BologniaBrazilIvan Magalhaes NEW
Smith C SlusarskiBrazilAnna Fali NEW
Murillo Y WieserGermanyIvan Magalhaes QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Misaki F ButtJapan2024-05-11Printing Dimensions UNQUALIFIED5Asiya Javayant
1001Jones F WieserJapan2024-05-08Morlong Associates UNQUALIFIED88Amy Elsner
1002Claire F MarrierAustralia2024-05-16King, Christopher A Esq NEGOTIATION67Bernardo Dominic
1003Stacey C OstroskyArgentina2024-05-08Feiner Bros PROPOSAL8Elwin Sharvill
1004Leon I OstroskyUnited Kingdom2024-05-10Truhlar And Truhlar Attys NEW35Ivan Magalhaes
1005Izzy L DoeArgentina2024-04-27Feltz Printing Service NEW53Anna Fali
1006Leon B FollerAustralia2024-05-04Truhlar And Truhlar Attys RENEWAL52Ivan Magalhaes
1007Francesco S VocelkaItaly2024-04-22Buckley Miller Wright NEW61Bernardo Dominic
1008Alejandro A NestleIndia2024-05-04Rangoni Of Florence PROPOSAL37Ivan Magalhaes
1009Munro C KolmetzRussia2024-04-21Commercial Press PROPOSAL6Ioni Bowcher
1010Adams J StockhamJapan2024-05-11Chanay, Jeffrey A Esq UNQUALIFIED13Asiya Javayant
1011Emily V BowleyAustralia2024-05-06Chapman, Ross E Esq NEGOTIATION83Ioni Bowcher
1012Emily U VenereItaly2024-05-14Rousseaux, Michael Esq NEW97Bernardo Dominic
1013Juan O BowleyFrance2024-04-24Dorl, James J Esq QUALIFIED4Xuxue Feng
1014Isabel E GauchoFrance2024-04-29Rangoni Of Florence UNQUALIFIED24Ioni Bowcher
1015Aruna I OstroskyUnited Kingdom2024-04-26Truhlar And Truhlar Attys NEGOTIATION80Xuxue Feng
1016Deepesh Z NestleSpain2024-05-19King, Christopher A Esq NEW88Amy Elsner
1017Alejandro V GauchoSpain2024-05-19Chapman, Ross E Esq RENEWAL70Ioni Bowcher
1018Francesco K BriddickAustralia2024-04-29Chemel, James L Cpa RENEWAL71Ioni Bowcher
1019Izzy H PoquetteSpain2024-04-22Feltz Printing Service NEGOTIATION43Stephen Shaw
1020Murillo N DarakjyAustralia2024-05-01Rousseaux, Michael Esq PROPOSAL42Xuxue Feng
1021Emily B MarrierCanada2024-05-01Rangoni Of Florence UNQUALIFIED86Stephen Shaw
1022Wickens F StockhamArgentina2024-04-26Morlong Associates NEW3Stephen Shaw
1023Leja G CaldareraSpain2024-04-26Buckley Miller Wright NEGOTIATION19Onyama Limba
1024Clifford O GarufiRussia2024-05-20King, Christopher A Esq QUALIFIED29Elwin Sharvill
1025Morrow U SaylorsUnited Kingdom2024-04-26Rousseaux, Michael Esq NEW43Anna Fali
1026Francesco E RoysterUnited Kingdom2024-05-14Feiner Bros NEW95Stephen Shaw
1027Clifford D SlusarskiIndia2024-05-10Rangoni Of Florence PROPOSAL7Stephen Shaw
1028James X StockhamFrance2024-05-18Commercial Press NEW91Ivan Magalhaes
1029Francesco A CampainBrazil2024-04-21Chapman, Ross E Esq NEGOTIATION47Asiya Javayant
1030James P PoquetteRussia2024-05-18Rangoni Of Florence RENEWAL39Amy Elsner
1031Rodrigues N MarrierSpain2024-05-01Morlong Associates PROPOSAL13Anna Fali
1032Francesco J CaldareraArgentina2024-04-22Rangoni Of Florence PROPOSAL82Anna Fali
1033Juan F ButtJapan2024-05-15Chanay, Jeffrey A Esq RENEWAL79Ioni Bowcher
1034Deepesh E MaletGermany2024-05-05Chapman, Ross E Esq QUALIFIED28Anna Fali
1035Stacey G GlickGermany2024-05-06Morlong Associates QUALIFIED70Ivan Magalhaes
1036Julie U FlosiRussia2024-05-07Morlong Associates RENEWAL38Stephen Shaw
1037Chavez V PerinUnited Kingdom2024-05-10Printing Dimensions NEW94Ivan Magalhaes
1038Johnson G DarakjyJapan2024-04-23Rangoni Of Florence UNQUALIFIED60Onyama Limba
1039Salvatore H SlusarskiBrazil2024-05-05King, Christopher A Esq NEW73Xuxue Feng
1040Misaki M NestleArgentina2024-05-09Morlong Associates NEGOTIATION62Stephen Shaw
1041Jennifer C VenereSpain2024-05-08Printing Dimensions UNQUALIFIED70Xuxue Feng
1042Julie J WaycottBrazil2024-04-21Feltz Printing Service NEW41Amy Elsner
1043Jones L OstroskyUnited Kingdom2024-04-25Commercial Press RENEWAL61Asiya Javayant
1044Aruna E PerinUnited Kingdom2024-05-13Feiner Bros QUALIFIED5Ivan Magalhaes
1045Leon G VenereUnited Kingdom2024-05-08Commercial Press NEW96Onyama Limba
1046Deepesh O SergiFrance2024-04-25Printing Dimensions RENEWAL89Anna Fali
1047Claire F VenereFrance2024-05-18Benton, John B Jr QUALIFIED68Xuxue Feng
1048Aruna U CampainIndia2024-05-17Buckley Miller Wright QUALIFIED23Ioni Bowcher
1049Chavez B GillianFrance2024-05-19Printing Dimensions NEGOTIATION71Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
David A StensethUnited KingdomAmy Elsner NEW
Arvin G SchemmerJapanOnyama Limba PROPOSAL
Jones O RoysterJapanAnna Fali UNQUALIFIED
Maisha Z GarufiFranceBernardo Dominic NEGOTIATION
Mujtaba P FlosiGermanyIoni Bowcher UNQUALIFIED
Greenwood O ShinkoUnited KingdomIoni Bowcher QUALIFIED
Jones O WieserGermanyOnyama Limba RENEWAL
Juan P AmigonItalyAmy Elsner RENEWAL
Deepesh Q RulapaughFranceXuxue Feng UNQUALIFIED
Darci U FerenczRussiaAnna Fali RENEWAL
Stacey Y KuskoJapanXuxue Feng RENEWAL
Maisha N OldroydJapanXuxue Feng NEGOTIATION
Misaki J PoquetteSpainElwin Sharvill QUALIFIED
Tony L FigeroaFranceOnyama Limba RENEWAL
Julie Q VocelkaUnited KingdomAnna Fali NEW
Munro X FlosiBrazilAsiya Javayant QUALIFIED
Izzy V StensethItalyXuxue Feng UNQUALIFIED
Darci J BowleyRussiaStephen Shaw UNQUALIFIED
Maisha R NestleBrazilAnna Fali RENEWAL
Claire X GauchoAustraliaOnyama Limba UNQUALIFIED
James S CampainGermanyIvan Magalhaes NEW
Leon U VocelkaCanadaOnyama Limba RENEWAL
Munro T FlosiFranceAnna Fali PROPOSAL
Silvio H AlbaresBrazilIvan Magalhaes NEW
Wickens C MarrierRussiaXuxue Feng UNQUALIFIED
Morrow M GillianItalyIoni Bowcher PROPOSAL
Claire U NickaUnited KingdomXuxue Feng QUALIFIED
Faith I StensethBrazilAsiya Javayant UNQUALIFIED
Faith E WhobreySpainBernardo Dominic UNQUALIFIED
Mujtaba X InouyeFranceIvan Magalhaes NEW
Mayumi Z MaletFranceIvan Magalhaes NEGOTIATION
Ashley B WhobreyGermanyIoni Bowcher UNQUALIFIED
Salvatore Q PaprockiItalyIvan Magalhaes NEW
James J KuskoUnited KingdomIoni Bowcher RENEWAL
Salvatore V CaudyIndiaIvan Magalhaes NEGOTIATION
Cody B OldroydAustraliaElwin Sharvill UNQUALIFIED
Aditya H PoquetteItalyOnyama Limba UNQUALIFIED
Ashley B PerinIndiaAsiya Javayant NEGOTIATION
David K ChuiItalyAmy Elsner UNQUALIFIED
Octavia Q WaycottRussiaStephen Shaw NEW
Arvin F ButtAustraliaIoni Bowcher PROPOSAL
Nicolas L BriddickItalyElwin Sharvill PROPOSAL
Mayumi J PerinRussiaIvan Magalhaes NEGOTIATION
Maria M KolmetzSpainAnna Fali QUALIFIED
Murillo E ShinkoJapanIoni Bowcher RENEWAL
Clifford F StensethRussiaAmy Elsner NEGOTIATION
Isabel U MorascaUnited KingdomOnyama Limba NEW
Aika G VenereUnited KingdomIoni Bowcher NEGOTIATION
Darci K ButtRussiaAmy Elsner NEW
Wickens E FerenczSpainBernardo Dominic NEGOTIATION
Frozen Columns
Name
Silvio N Chui
Mayumi T Stockham
Leon K Kusko
Nicolas G Kusko
Octavia C Inouye
Darci M Doe
Adams F Butt
Murillo U Albares
Sinclair T Shinko
James R Foller
Ashley X Tollner
Leja Y Iturbide
Maria K Bolognia
Kadeem B Morasca
Greenwood J Ruta
Claire D Chui
Darci R Glick
Juan M Saylors
Morrow M Ostrosky
Faith L Nicka
Arvin W Oldroyd
Nicolas C Nestle
James C Tollner
Aruna L Maclead
Julie I Poquette
Maisha M Marrier
Isabel A Morasca
Faith B Flosi
Julie S Kolmetz
Jeanfrancois W Vocelka
Mujtaba B Saylors
Nicolas M Darakjy
Sinclair U Garufi
Emily D Flosi
Chavez R Chui
Ricardo G Oldroyd
Silvio I Figeroa
Darci N Waycott
Alejandro L Glick
Rodrigues X Kusko
Julie N Inouye
Leja C Poquette
Murillo L Rulapaugh
Octavia I Amigon
Wickens Z Briddick
Isabel H Vocelka
Costa Y Vocelka
Stacey A Bolognia
Leja K Gaucho
Ashley S Inouye
IdCountryDate
1000Brazil2024-04-23
1001India2024-05-04
1002Australia2024-05-09
1003France2024-04-30
1004India2024-04-30
1005Argentina2024-04-25
1006Japan2024-05-05
1007France2024-05-11
1008India2024-05-20
1009Russia2024-05-09
1010United Kingdom2024-04-24
1011India2024-04-21
1012Russia2024-05-14
1013India2024-05-03
1014India2024-04-30
1015Spain2024-05-04
1016France2024-05-05
1017Canada2024-04-26
1018Italy2024-05-09
1019Spain2024-05-01
1020India2024-05-01
1021United Kingdom2024-05-01
1022India2024-04-30
1023Australia2024-05-13
1024Russia2024-04-23
1025Argentina2024-05-17
1026Russia2024-05-01
1027United Kingdom2024-05-03
1028Canada2024-04-30
1029France2024-04-28
1030Spain2024-05-11
1031Brazil2024-05-11
1032India2024-05-12
1033Russia2024-05-12
1034Japan2024-05-19
1035India2024-05-05
1036Brazil2024-04-25
1037India2024-05-02
1038Germany2024-05-06
1039Australia2024-04-25
1040Russia2024-05-01
1041Brazil2024-04-30
1042United Kingdom2024-04-26
1043France2024-04-26
1044Canada2024-05-06
1045Germany2024-04-30
1046United Kingdom2024-05-08
1047Spain2024-04-24
1048Italy2024-04-25
1049Canada2024-04-24

On-Demand Data

NameIdCountryDate
James Z Briddick1000Italy2024-05-18
Morrow C Nestle1001Spain2024-05-07
Leon D Waycott1002Brazil2024-05-18
Mayumi P Whobrey1003United Kingdom2024-05-06
Aditya O Campain1004Italy2024-04-26
Isabel E Darakjy1005United Kingdom2024-05-05
Sinclair V Oldroyd1006India2024-05-01
Alejandro Q Kusko1007Australia2024-05-07
Smith F Foller1008France2024-05-01
Octavia L Rulapaugh1009Argentina2024-05-10
Ashley K Foller1010Germany2024-04-30
Aruna S Schemmer1011Spain2024-04-23
Deepesh V Morasca1012Australia2024-04-21
James G Kolmetz1013Canada2024-05-01
Leja N Bowley1014Canada2024-05-15
Murillo V Stenseth1015Russia2024-05-18
Deepesh S Whobrey1016India2024-04-30
Darci B Slusarski1017France2024-04-25
David U Rim1018Spain2024-05-07
Julie S Schemmer1019Spain2024-05-03
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aruna X PaprockiGermanyElwin Sharvill UNQUALIFIED
Johnson G CaldareraIndiaIoni Bowcher NEGOTIATION
David M ChuiJapanElwin Sharvill RENEWAL
Ricardo C StensethItalyXuxue Feng PROPOSAL
Mujtaba H SaylorsSpainXuxue Feng NEGOTIATION
Sinclair S WaycottFranceAsiya Javayant PROPOSAL
Mujtaba K SergiGermanyElwin Sharvill NEW
Munro V PoquetteCanadaOnyama Limba UNQUALIFIED
James U RoysterSpainIoni Bowcher PROPOSAL
Sinclair H OstroskySpainElwin Sharvill UNQUALIFIED
Mujtaba L StensethIndiaStephen Shaw QUALIFIED
Alejandro U AlbaresAustraliaIvan Magalhaes QUALIFIED
Maria X BowleyFranceStephen Shaw PROPOSAL
Clifford T OldroydAustraliaAsiya Javayant PROPOSAL
Johnson K MacleadItalyElwin Sharvill PROPOSAL
Murillo D WieserRussiaStephen Shaw RENEWAL
Ashley H GarufiRussiaBernardo Dominic NEGOTIATION
Antonio V MacleadJapanAmy Elsner QUALIFIED
Rodrigues Y CampainBrazilXuxue Feng NEW
Arvin W TollnerCanadaAnna Fali NEGOTIATION
Arvin I InouyeIndiaIvan Magalhaes UNQUALIFIED
Jennifer A OldroydItalyIoni Bowcher RENEWAL
Smith Q PaprockiIndiaIoni Bowcher UNQUALIFIED
Julie Q InouyeFranceElwin Sharvill PROPOSAL
Emily A MaletUnited KingdomAnna Fali QUALIFIED
Aruna W ButtArgentinaBernardo Dominic PROPOSAL
Francesco C GillianBrazilBernardo Dominic QUALIFIED
Alejandro J ChuiIndiaIvan Magalhaes QUALIFIED
Aditya T RulapaughIndiaBernardo Dominic NEGOTIATION
Mujtaba S FlosiUnited KingdomIvan Magalhaes PROPOSAL
Francesco N FerenczGermanyBernardo Dominic NEW
Alejandro J WhobreyFranceElwin Sharvill NEW
Faith D StockhamIndiaIvan Magalhaes NEGOTIATION
Arvin N GarufiJapanIoni Bowcher UNQUALIFIED
Sinclair U BowleyBrazilStephen Shaw NEW
Johnson T SaylorsRussiaOnyama Limba RENEWAL
Isabel F GlickCanadaOnyama Limba NEW
Rodrigues Z WaycottFranceAmy Elsner NEGOTIATION
Ivar Y GauchoCanadaBernardo Dominic NEW
Kaitlin A FlosiUnited KingdomIoni Bowcher 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>