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
Jones L AmigonFranceBernardo Dominic UNQUALIFIED
Faith Y AlbaresJapanAnna Fali NEGOTIATION
Octavia S IturbideBrazilIoni Bowcher QUALIFIED
Ricardo G AlbaresBrazilAmy Elsner QUALIFIED
Smith V OstroskyRussiaAsiya Javayant RENEWAL
Jennifer Y AlbaresArgentinaElwin Sharvill PROPOSAL
Maisha N GillianAustraliaOnyama Limba PROPOSAL
Stacey W WaycottJapanAsiya Javayant NEGOTIATION
Jones M SaylorsGermanyStephen Shaw NEW
Kadeem S OldroydGermanyBernardo Dominic QUALIFIED
David U CampainBrazilIoni Bowcher UNQUALIFIED
Julie X WieserItalyOnyama Limba NEW
Darci D IturbideGermanyAsiya Javayant NEW
Sinclair N PaprockiJapanStephen Shaw UNQUALIFIED
Ricardo Y WhobreyJapanIvan Magalhaes RENEWAL
Johnson W BriddickSpainIvan Magalhaes QUALIFIED
Mayumi P SaylorsFranceAsiya Javayant NEGOTIATION
Mayumi U MaletIndiaStephen Shaw PROPOSAL
Isabel T SaylorsUnited KingdomAsiya Javayant RENEWAL
James D MaletFranceElwin Sharvill NEW
Juan Z CampainAustraliaStephen Shaw NEW
Faith B FigeroaGermanyIvan Magalhaes RENEWAL
Ashley U WhobreyUnited KingdomStephen Shaw UNQUALIFIED
Jones O RimJapanElwin Sharvill NEGOTIATION
Murillo U GauchoJapanBernardo Dominic UNQUALIFIED
Chavez W FigeroaGermanyBernardo Dominic UNQUALIFIED
Mujtaba M CaldareraCanadaAsiya Javayant QUALIFIED
Silvio F CampainRussiaBernardo Dominic RENEWAL
James F StockhamJapanXuxue Feng QUALIFIED
Aruna M WaycottRussiaAmy Elsner NEW
David A SlusarskiRussiaBernardo Dominic RENEWAL
Jefferson Y CampainFranceIoni Bowcher PROPOSAL
Octavia D BologniaItalyAsiya Javayant RENEWAL
Octavia M CaldareraCanadaOnyama Limba QUALIFIED
Darci V GlickJapanBernardo Dominic NEGOTIATION
Kadeem S RulapaughArgentinaAsiya Javayant NEW
Rodrigues A SchemmerGermanyIvan Magalhaes PROPOSAL
Jennifer E KolmetzItalyAmy Elsner PROPOSAL
Jeanfrancois H BriddickItalyAmy Elsner UNQUALIFIED
Chavez X RoysterFranceXuxue Feng UNQUALIFIED
Alejandro L GauchoArgentinaAmy Elsner PROPOSAL
Jeanfrancois D GarufiUnited KingdomAsiya Javayant RENEWAL
Stacey C WieserJapanIoni Bowcher QUALIFIED
Misaki R CampainBrazilOnyama Limba RENEWAL
Morrow B OstroskyIndiaBernardo Dominic NEW
Aika P PerinGermanyStephen Shaw UNQUALIFIED
Leja N MorascaAustraliaIoni Bowcher NEW
Jones G GauchoCanadaXuxue Feng PROPOSAL
Mayumi R OstroskyItalyAnna Fali UNQUALIFIED
Murillo S GarufiAustraliaElwin Sharvill NEW
Horizontal
NameCountryRepresentativeStatus
Maisha Y GlickItalyBernardo Dominic QUALIFIED
Smith M MarrierGermanyBernardo Dominic NEGOTIATION
Izzy O RoysterGermanyOnyama Limba NEGOTIATION
Silvio L RimArgentinaAsiya Javayant NEW
Costa O DarakjyArgentinaAsiya Javayant NEGOTIATION
Leja M SaylorsFranceAsiya Javayant NEW
Tony Z SchemmerFranceXuxue Feng RENEWAL
Jennifer W OstroskyRussiaXuxue Feng RENEWAL
Izzy V MorascaCanadaAnna Fali PROPOSAL
Ashley L NestleIndiaAnna Fali PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Misaki Y PerinSpain2024-04-22Benton, John B Jr UNQUALIFIED30Onyama Limba
1001Ashley C SaylorsRussia2024-04-25King, Christopher A Esq PROPOSAL74Ivan Magalhaes
1002Ricardo C FollerJapan2024-03-28Benton, John B Jr NEGOTIATION94Bernardo Dominic
1003Rodrigues W AmigonBrazil2024-04-19Printing Dimensions QUALIFIED5Amy Elsner
1004Alejandro Q PaprockiIndia2024-04-02Commercial Press NEW35Elwin Sharvill
1005Emily L OldroydIndia2024-04-17Feltz Printing Service UNQUALIFIED35Onyama Limba
1006Aruna C AlbaresRussia2024-04-25Chapman, Ross E Esq PROPOSAL55Ivan Magalhaes
1007Morrow H FigeroaJapan2024-04-18Feiner Bros NEGOTIATION15Xuxue Feng
1008Morrow K DarakjyUnited Kingdom2024-03-29Rangoni Of Florence RENEWAL95Elwin Sharvill
1009Alejandro V KuskoAustralia2024-03-30Printing Dimensions RENEWAL79Elwin Sharvill
1010Maisha Q OldroydRussia2024-03-27Chanay, Jeffrey A Esq NEGOTIATION56Onyama Limba
1011Maisha Y FollerCanada2024-04-13Printing Dimensions PROPOSAL3Ioni Bowcher
1012Costa M RulapaughGermany2024-03-30King, Christopher A Esq QUALIFIED15Xuxue Feng
1013Stacey P RimItaly2024-04-16Chanay, Jeffrey A Esq RENEWAL45Amy Elsner
1014Misaki J IturbideRussia2024-04-24Truhlar And Truhlar Attys NEGOTIATION66Onyama Limba
1015Kaitlin O MaletRussia2024-04-07Dorl, James J Esq RENEWAL61Bernardo Dominic
1016Ricardo P RoysterFrance2024-04-07Printing Dimensions NEGOTIATION85Ivan Magalhaes
1017Kadeem P StensethJapan2024-04-24Commercial Press UNQUALIFIED7Ioni Bowcher
1018Stacey G KolmetzBrazil2024-04-05Morlong Associates PROPOSAL11Ivan Magalhaes
1019Mujtaba I GauchoIndia2024-04-25Feiner Bros UNQUALIFIED49Stephen Shaw
1020Octavia W ChuiCanada2024-03-30Feltz Printing Service PROPOSAL88Ioni Bowcher
1021Darci F DoeItaly2024-04-02Truhlar And Truhlar Attys QUALIFIED19Bernardo Dominic
1022Nicolas Z SaylorsBrazil2024-04-15Morlong Associates PROPOSAL82Stephen Shaw
1023Octavia R MorascaRussia2024-04-07Benton, John B Jr QUALIFIED5Bernardo Dominic
1024Isabel U InouyeRussia2024-03-31Printing Dimensions NEGOTIATION17Elwin Sharvill
1025Faith Z DarakjyJapan2024-04-10Benton, John B Jr UNQUALIFIED38Onyama Limba
1026Jones R WhobreyGermany2024-04-18Morlong Associates NEGOTIATION25Xuxue Feng
1027Clifford Q GillianArgentina2024-03-29King, Christopher A Esq NEW80Elwin Sharvill
1028Chavez W SaylorsRussia2024-04-18Rangoni Of Florence RENEWAL17Bernardo Dominic
1029Francesco T BowleyItaly2024-04-21Commercial Press UNQUALIFIED13Xuxue Feng
1030Kaitlin O RutaFrance2024-04-16Chapman, Ross E Esq RENEWAL91Anna Fali
1031Silvio Z RulapaughIndia2024-04-05Printing Dimensions RENEWAL41Anna Fali
1032Misaki C OstroskyArgentina2024-04-18Commercial Press NEGOTIATION57Stephen Shaw
1033Chavez I ShinkoBrazil2024-03-29Rousseaux, Michael Esq UNQUALIFIED61Ivan Magalhaes
1034Maria Y IturbideGermany2024-04-19Rangoni Of Florence NEGOTIATION10Anna Fali
1035Greenwood W WaycottRussia2024-04-07Printing Dimensions NEGOTIATION67Amy Elsner
1036Johnson K OstroskyIndia2024-04-16King, Christopher A Esq RENEWAL25Amy Elsner
1037Maisha T SchemmerFrance2024-04-03Rousseaux, Michael Esq UNQUALIFIED28Stephen Shaw
1038Leon L DoeJapan2024-04-02Chanay, Jeffrey A Esq RENEWAL14Ivan Magalhaes
1039Kadeem G DarakjyRussia2024-04-14Chanay, Jeffrey A Esq NEGOTIATION98Onyama Limba
1040Jennifer O CaldareraFrance2024-04-25Rangoni Of Florence NEW87Xuxue Feng
1041Kaitlin J FollerRussia2024-04-04Buckley Miller Wright NEGOTIATION35Asiya Javayant
1042Misaki P WaycottCanada2024-03-27Dorl, James J Esq RENEWAL95Onyama Limba
1043Costa C SergiRussia2024-04-14Dorl, James J Esq PROPOSAL78Ivan Magalhaes
1044Leon U FollerUnited Kingdom2024-03-27Chanay, Jeffrey A Esq NEW39Elwin Sharvill
1045Kadeem B GillianGermany2024-04-07Chemel, James L Cpa PROPOSAL39Xuxue Feng
1046Leon T OldroydSpain2024-03-27Chemel, James L Cpa PROPOSAL26Ivan Magalhaes
1047Cody R InouyeUnited Kingdom2024-03-30King, Christopher A Esq NEGOTIATION0Onyama Limba
1048Mayumi Z SchemmerArgentina2024-04-16Rousseaux, Michael Esq NEGOTIATION40Stephen Shaw
1049Julie K VenereFrance2024-04-09Morlong Associates UNQUALIFIED85Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Morrow F AlbaresGermanyXuxue Feng RENEWAL
Leja K FigeroaRussiaOnyama Limba UNQUALIFIED
Maria J MorascaFranceAmy Elsner NEW
Aika T StockhamJapanStephen Shaw NEW
Ivar M GillianIndiaXuxue Feng QUALIFIED
Deepesh J FerenczBrazilAsiya Javayant UNQUALIFIED
Alejandro V DarakjyUnited KingdomStephen Shaw NEW
Leon E SchemmerCanadaIvan Magalhaes QUALIFIED
Izzy O ShinkoJapanIvan Magalhaes NEGOTIATION
Kadeem W GauchoUnited KingdomIvan Magalhaes RENEWAL
Izzy Z ShinkoIndiaAmy Elsner PROPOSAL
Aditya Y StockhamFranceElwin Sharvill NEW
Sinclair T PaprockiRussiaBernardo Dominic NEW
Leja Y AlbaresRussiaAnna Fali RENEWAL
Costa P DoeBrazilIoni Bowcher RENEWAL
Salvatore D KolmetzSpainAnna Fali QUALIFIED
Maria E ChuiCanadaStephen Shaw PROPOSAL
Maria L PaprockiUnited KingdomIoni Bowcher UNQUALIFIED
Wickens V MacleadIndiaIvan Magalhaes QUALIFIED
Darci G TollnerAustraliaIoni Bowcher NEW
Julie L PaprockiJapanAmy Elsner NEW
Rodrigues M SlusarskiGermanyXuxue Feng PROPOSAL
Silvio I BowleySpainAsiya Javayant NEW
Stacey Y SergiArgentinaAsiya Javayant NEW
Octavia F PerinRussiaAmy Elsner RENEWAL
Silvio F StensethGermanyIoni Bowcher NEGOTIATION
Aruna P KolmetzUnited KingdomAnna Fali RENEWAL
Kaitlin K GillianSpainIoni Bowcher UNQUALIFIED
Clifford P PerinBrazilXuxue Feng NEW
Cody T ButtIndiaIoni Bowcher PROPOSAL
Ivar A WieserRussiaAsiya Javayant PROPOSAL
Octavia S TollnerIndiaStephen Shaw NEW
Nicolas S ShinkoAustraliaBernardo Dominic NEGOTIATION
Aika X SergiBrazilAsiya Javayant UNQUALIFIED
Claire H AlbaresIndiaIvan Magalhaes NEW
Maria Q GauchoIndiaXuxue Feng QUALIFIED
Cody G StockhamBrazilAmy Elsner PROPOSAL
Alejandro L GillianBrazilAsiya Javayant RENEWAL
Wickens F SaylorsFranceAsiya Javayant RENEWAL
Wickens R NestleSpainAmy Elsner NEGOTIATION
Izzy F GillianCanadaAmy Elsner QUALIFIED
Jennifer R NestleRussiaIoni Bowcher UNQUALIFIED
Antonio D FerenczUnited KingdomAsiya Javayant QUALIFIED
Deepesh O ShinkoJapanBernardo Dominic QUALIFIED
Salvatore O BowleyUnited KingdomAmy Elsner UNQUALIFIED
Jefferson W CaldareraItalyElwin Sharvill QUALIFIED
Costa J TollnerIndiaAnna Fali NEGOTIATION
Faith C AlbaresGermanyElwin Sharvill PROPOSAL
Faith W GillianBrazilAsiya Javayant UNQUALIFIED
Jones H FigeroaIndiaIoni Bowcher QUALIFIED
Frozen Columns
Name
Stacey E Ostrosky
Mayumi U Perin
Ivar K Caudy
Munro M Caudy
Mayumi F Saylors
Mayumi R Nicka
Emily H Gaucho
Jefferson E Stockham
Adams Y Ostrosky
Munro B Ferencz
Clifford M Nicka
Ricardo L Rim
Aditya Y Iturbide
Costa S Campain
Adams F Caldarera
Smith C Paprocki
Antonio L Flosi
Sinclair O Flosi
Smith N Ruta
Rodrigues F Stockham
Cody K Rulapaugh
Nicolas M Caldarera
Maria L Shinko
Greenwood X Caudy
Tony E Perin
Stacey L Marrier
Stacey J Darakjy
Kaitlin M Doe
Claire Z Butt
Aika N Kolmetz
Wickens Z Schemmer
Mayumi M Saylors
Leja L Morasca
Emily W Paprocki
Deepesh G Bolognia
Wickens E Amigon
Jones Y Whobrey
Antonio Y Paprocki
Aruna R Dilliard
Jeanfrancois P Oldroyd
Aika R Paprocki
Cody V Campain
Clifford N Gillian
Juan V Chui
Faith D Inouye
Leon E Paprocki
Murillo R Caudy
Octavia E Ostrosky
Kadeem J Bolognia
Mujtaba U Malet
IdCountryDate
1000Japan2024-04-13
1001Japan2024-04-05
1002Japan2024-04-25
1003India2024-04-22
1004Argentina2024-04-02
1005Italy2024-04-01
1006Germany2024-04-03
1007Australia2024-04-19
1008Argentina2024-04-12
1009United Kingdom2024-04-23
1010Germany2024-04-24
1011United Kingdom2024-04-25
1012India2024-04-14
1013Italy2024-03-30
1014Canada2024-04-10
1015Japan2024-03-29
1016Italy2024-04-19
1017Russia2024-04-21
1018Italy2024-04-08
1019Brazil2024-03-28
1020India2024-04-22
1021Italy2024-04-20
1022Argentina2024-04-07
1023Spain2024-03-29
1024Germany2024-04-22
1025Canada2024-04-23
1026Argentina2024-04-12
1027Germany2024-04-06
1028Russia2024-04-02
1029Spain2024-04-18
1030Italy2024-04-06
1031France2024-04-11
1032Russia2024-04-23
1033Australia2024-04-17
1034Argentina2024-04-15
1035Germany2024-04-14
1036Spain2024-04-21
1037Italy2024-03-29
1038Italy2024-03-27
1039Argentina2024-04-15
1040India2024-03-31
1041Japan2024-04-06
1042Russia2024-04-03
1043Italy2024-04-02
1044Canada2024-04-13
1045Russia2024-04-19
1046India2024-03-28
1047Germany2024-04-13
1048Canada2024-04-09
1049Argentina2024-03-30

On-Demand Data

NameIdCountryDate
Rodrigues M Bowley1000India2024-03-28
Jennifer M Schemmer1001Argentina2024-03-28
Darci W Paprocki1002United Kingdom2024-04-04
David M Bolognia1003Japan2024-04-07
Jeanfrancois Q Ferencz1004Germany2024-03-31
Maisha D Garufi1005Germany2024-04-24
Cody C Garufi1006Germany2024-04-09
Arvin Q Ruta1007United Kingdom2024-04-11
Morrow S Venere1008France2024-04-04
Isabel I Schemmer1009India2024-04-20
Murillo K Stenseth1010United Kingdom2024-04-21
Mayumi Z Gillian1011India2024-04-24
Darci N Morasca1012France2024-04-21
Jones S Albares1013United Kingdom2024-04-02
Emily V Flosi1014France2024-04-18
Juan Q Paprocki1015Japan2024-04-06
Arvin B Inouye1016Australia2024-04-16
Jeanfrancois G Dilliard1017Russia2024-04-20
Nicolas Q Nestle1018France2024-04-09
Aruna B Morasca1019Australia2024-04-21
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Johnson Z PaprockiItalyElwin Sharvill UNQUALIFIED
Wickens K ShinkoFranceXuxue Feng PROPOSAL
Cody A NickaRussiaElwin Sharvill PROPOSAL
Ashley F InouyeIndiaIoni Bowcher PROPOSAL
Aika Y MacleadBrazilIoni Bowcher NEGOTIATION
Silvio E SergiFranceIvan Magalhaes UNQUALIFIED
Aika O NickaAustraliaAsiya Javayant QUALIFIED
Misaki K RimJapanAmy Elsner PROPOSAL
Cody O AmigonJapanBernardo Dominic NEW
Chavez G GlickUnited KingdomAsiya Javayant RENEWAL
Clifford O CampainIndiaAnna Fali NEGOTIATION
Kaitlin O GillianFranceElwin Sharvill RENEWAL
Octavia S DilliardIndiaElwin Sharvill UNQUALIFIED
Rodrigues X FlosiGermanyAmy Elsner QUALIFIED
Tony H FollerAustraliaAmy Elsner RENEWAL
Aditya Z MacleadJapanAmy Elsner NEW
Jones M DoeUnited KingdomStephen Shaw UNQUALIFIED
Leja Q RoysterArgentinaStephen Shaw UNQUALIFIED
Jeanfrancois T BowleyIndiaElwin Sharvill QUALIFIED
Claire S PaprockiAustraliaAnna Fali NEGOTIATION
Clifford X FlosiFranceIoni Bowcher PROPOSAL
David U NickaGermanyStephen Shaw QUALIFIED
Kaitlin R BologniaCanadaElwin Sharvill NEW
Nicolas C BriddickFranceXuxue Feng UNQUALIFIED
Munro Z StensethSpainAmy Elsner NEW
Murillo R WhobreyCanadaOnyama Limba PROPOSAL
Sinclair X KolmetzArgentinaBernardo Dominic NEGOTIATION
Faith T AlbaresGermanyAsiya Javayant UNQUALIFIED
James B NickaItalyIoni Bowcher QUALIFIED
Silvio E StensethIndiaAnna Fali RENEWAL
Ivar N PoquetteCanadaAnna Fali NEW
Jeanfrancois Q WieserBrazilAsiya Javayant UNQUALIFIED
Morrow J ButtRussiaStephen Shaw NEW
Aditya R GarufiUnited KingdomIvan Magalhaes RENEWAL
Morrow Z MaletBrazilAnna Fali NEGOTIATION
Ivar V RimFranceXuxue Feng NEW
Morrow E RutaArgentinaElwin Sharvill QUALIFIED
Mayumi C WaycottArgentinaIoni Bowcher PROPOSAL
Mayumi P BologniaGermanyElwin Sharvill RENEWAL
Jeanfrancois E NickaItalyBernardo Dominic UNQUALIFIED

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