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
Kadeem L GlickUnited KingdomAnna Fali QUALIFIED
David W InouyeCanadaAnna Fali NEGOTIATION
Emily R NestleSpainBernardo Dominic NEGOTIATION
Morrow S StensethUnited KingdomBernardo Dominic NEW
Greenwood E NickaFranceAsiya Javayant NEGOTIATION
Greenwood G OldroydBrazilIoni Bowcher NEW
Silvio D BologniaAustraliaAsiya Javayant QUALIFIED
Greenwood T SergiBrazilBernardo Dominic PROPOSAL
Jones R RulapaughFranceIoni Bowcher RENEWAL
Aruna C AmigonBrazilElwin Sharvill RENEWAL
Ricardo D PerinGermanyElwin Sharvill NEW
Francesco H SaylorsItalyXuxue Feng RENEWAL
David Y PoquetteGermanyOnyama Limba QUALIFIED
Jeanfrancois V MaletFranceIoni Bowcher RENEWAL
Aditya V AlbaresItalyOnyama Limba NEW
Sinclair M FerenczFranceAnna Fali NEGOTIATION
Greenwood L GarufiUnited KingdomElwin Sharvill PROPOSAL
David E VenereIndiaIoni Bowcher RENEWAL
Leon J MarrierUnited KingdomAsiya Javayant UNQUALIFIED
Murillo U InouyeSpainIoni Bowcher NEGOTIATION
Francesco M AmigonUnited KingdomBernardo Dominic NEGOTIATION
David I SaylorsArgentinaOnyama Limba NEGOTIATION
Misaki C WhobreyRussiaAsiya Javayant NEGOTIATION
Nicolas S MacleadJapanStephen Shaw PROPOSAL
Aruna U InouyeAustraliaBernardo Dominic QUALIFIED
Mujtaba X ButtItalyAmy Elsner NEW
Faith O BriddickJapanAmy Elsner UNQUALIFIED
Arvin E RulapaughIndiaBernardo Dominic QUALIFIED
Faith E RulapaughBrazilIoni Bowcher UNQUALIFIED
Morrow D KolmetzIndiaBernardo Dominic PROPOSAL
Maisha Q IturbideCanadaIoni Bowcher QUALIFIED
Julie I AmigonSpainBernardo Dominic UNQUALIFIED
Jefferson E DilliardGermanyIoni Bowcher NEW
Ashley I VocelkaSpainBernardo Dominic PROPOSAL
Faith D IturbideArgentinaOnyama Limba QUALIFIED
Adams O BologniaCanadaIvan Magalhaes NEW
Nicolas Q IturbideJapanIoni Bowcher QUALIFIED
Stacey V CaudyGermanyXuxue Feng QUALIFIED
Kaitlin D KuskoBrazilElwin Sharvill NEW
Kaitlin I MorascaFranceBernardo Dominic UNQUALIFIED
Izzy J PoquetteBrazilIvan Magalhaes RENEWAL
Leja Y AlbaresIndiaOnyama Limba UNQUALIFIED
Adams Y BriddickItalyAsiya Javayant UNQUALIFIED
Silvio B FollerIndiaXuxue Feng QUALIFIED
Arvin V GauchoAustraliaAnna Fali UNQUALIFIED
Leon P GauchoArgentinaAsiya Javayant QUALIFIED
Sinclair M PerinFranceStephen Shaw PROPOSAL
Silvio H GlickGermanyOnyama Limba PROPOSAL
Claire F RulapaughUnited KingdomIvan Magalhaes NEW
Aika X PoquetteFranceAnna Fali NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Misaki R MaletAustraliaStephen Shaw QUALIFIED
Isabel Z MacleadAustraliaIoni Bowcher NEW
Leja F SlusarskiCanadaElwin Sharvill NEW
Stacey R SchemmerItalyAmy Elsner NEW
Adams A InouyeBrazilXuxue Feng PROPOSAL
Jennifer Z VenereAustraliaOnyama Limba NEGOTIATION
Stacey S OstroskyJapanIvan Magalhaes NEW
David K MarrierCanadaElwin Sharvill NEGOTIATION
Julie Y SergiUnited KingdomOnyama Limba NEGOTIATION
Nicolas P OldroydCanadaOnyama Limba PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Chavez W NickaSpain2024-04-15King, Christopher A Esq NEW15Anna Fali
1001Johnson C NickaAustralia2024-04-02Printing Dimensions RENEWAL59Ioni Bowcher
1002Alejandro Z AlbaresJapan2024-04-16Chanay, Jeffrey A Esq NEGOTIATION27Asiya Javayant
1003Aika Z WieserGermany2024-04-04Chemel, James L Cpa NEGOTIATION91Bernardo Dominic
1004Octavia Q WieserGermany2024-04-12Morlong Associates QUALIFIED99Ivan Magalhaes
1005Jennifer J FerenczSpain2024-04-10Rousseaux, Michael Esq QUALIFIED68Bernardo Dominic
1006Antonio S BowleyItaly2024-04-13Rousseaux, Michael Esq RENEWAL83Stephen Shaw
1007Darci T GlickArgentina2024-04-22Dorl, James J Esq NEGOTIATION35Ivan Magalhaes
1008Maria W VocelkaJapan2024-04-15Chemel, James L Cpa PROPOSAL14Stephen Shaw
1009Juan R PerinJapan2024-04-25Commercial Press UNQUALIFIED76Onyama Limba
1010Cody H PaprockiJapan2024-04-17Chemel, James L Cpa NEW81Stephen Shaw
1011Chavez B StensethAustralia2024-03-29Chemel, James L Cpa UNQUALIFIED32Amy Elsner
1012Silvio F GarufiItaly2024-04-24Chanay, Jeffrey A Esq RENEWAL67Amy Elsner
1013Silvio G FollerUnited Kingdom2024-04-05Benton, John B Jr RENEWAL38Ioni Bowcher
1014Francesco T FollerBrazil2024-04-10Printing Dimensions RENEWAL35Ivan Magalhaes
1015Darci W MaletBrazil2024-04-11Benton, John B Jr UNQUALIFIED88Asiya Javayant
1016Leon I MaletBrazil2024-04-06Rangoni Of Florence PROPOSAL51Asiya Javayant
1017Jones P FigeroaAustralia2024-03-30King, Christopher A Esq NEGOTIATION41Ivan Magalhaes
1018Chavez S AmigonRussia2024-04-25Feltz Printing Service NEGOTIATION37Xuxue Feng
1019Ricardo C WaycottRussia2024-04-07Morlong Associates NEW30Stephen Shaw
1020Morrow C StockhamGermany2024-04-13King, Christopher A Esq RENEWAL94Ivan Magalhaes
1021Jennifer W NickaFrance2024-04-20Morlong Associates NEW84Ivan Magalhaes
1022Aika Y AmigonIndia2024-04-09Chapman, Ross E Esq RENEWAL33Asiya Javayant
1023Munro K FerenczRussia2024-04-07Printing Dimensions NEW14Ivan Magalhaes
1024Julie E SaylorsAustralia2024-04-19Feltz Printing Service UNQUALIFIED15Stephen Shaw
1025Julie K GlickJapan2024-04-16Chemel, James L Cpa UNQUALIFIED93Xuxue Feng
1026Murillo T GlickBrazil2024-04-27Rousseaux, Michael Esq QUALIFIED25Amy Elsner
1027Isabel E MaletIndia2024-04-13Chapman, Ross E Esq PROPOSAL19Asiya Javayant
1028Johnson M FigeroaItaly2024-04-18Chemel, James L Cpa QUALIFIED21Ivan Magalhaes
1029Izzy S GarufiSpain2024-04-10Printing Dimensions PROPOSAL15Onyama Limba
1030Juan A CaudyIndia2024-03-31Chanay, Jeffrey A Esq RENEWAL80Anna Fali
1031Costa X SlusarskiJapan2024-04-02Chapman, Ross E Esq RENEWAL65Xuxue Feng
1032Ashley G KolmetzIndia2024-04-20Printing Dimensions RENEWAL80Asiya Javayant
1033Isabel C KolmetzUnited Kingdom2024-04-02Chemel, James L Cpa QUALIFIED27Ioni Bowcher
1034Salvatore B IturbideUnited Kingdom2024-04-15King, Christopher A Esq RENEWAL30Onyama Limba
1035Wickens F PoquetteGermany2024-03-29Chemel, James L Cpa NEW17Asiya Javayant
1036Mayumi N IturbideIndia2024-04-04Rousseaux, Michael Esq UNQUALIFIED63Onyama Limba
1037Kaitlin Y FollerRussia2024-04-03Benton, John B Jr QUALIFIED19Anna Fali
1038Ivar K GarufiSpain2024-04-25Commercial Press NEGOTIATION89Xuxue Feng
1039Maisha W KolmetzFrance2024-04-16Benton, John B Jr UNQUALIFIED28Stephen Shaw
1040Rodrigues P MacleadUnited Kingdom2024-04-17Printing Dimensions RENEWAL63Onyama Limba
1041Morrow I GillianGermany2024-04-16Rousseaux, Michael Esq QUALIFIED11Amy Elsner
1042Maria U RimAustralia2024-04-15Benton, John B Jr RENEWAL67Ivan Magalhaes
1043Chavez U RimAustralia2024-04-02Rangoni Of Florence QUALIFIED14Xuxue Feng
1044Kadeem J MaletSpain2024-03-31Commercial Press NEGOTIATION78Ivan Magalhaes
1045James E PerinRussia2024-04-21Buckley Miller Wright NEW12Onyama Limba
1046Mujtaba N ShinkoJapan2024-04-13Rousseaux, Michael Esq UNQUALIFIED93Asiya Javayant
1047James T ChuiCanada2024-04-06Truhlar And Truhlar Attys NEW78Elwin Sharvill
1048Munro G WhobreyAustralia2024-04-16Rangoni Of Florence NEGOTIATION92Xuxue Feng
1049James S FollerJapan2024-04-15Feiner Bros QUALIFIED6Asiya Javayant
Frozen Rows
NameCountryRepresentativeStatus
Sinclair S RutaGermanyAnna Fali NEW
Ashley U AmigonArgentinaOnyama Limba UNQUALIFIED
Adams R SaylorsBrazilAmy Elsner QUALIFIED
Octavia W ChuiItalyStephen Shaw UNQUALIFIED
Costa C MarrierCanadaIvan Magalhaes PROPOSAL
Stacey G GauchoFranceAsiya Javayant QUALIFIED
Julie J MaletArgentinaBernardo Dominic NEW
Greenwood E ButtCanadaBernardo Dominic QUALIFIED
Smith C GillianSpainOnyama Limba UNQUALIFIED
David J OldroydRussiaXuxue Feng NEGOTIATION
Antonio D DilliardItalyAnna Fali QUALIFIED
Francesco G OldroydUnited KingdomStephen Shaw RENEWAL
Adams Y DilliardSpainAsiya Javayant RENEWAL
Leja W MaletRussiaAsiya Javayant QUALIFIED
Faith H KuskoAustraliaAmy Elsner NEGOTIATION
Jennifer F OldroydSpainIoni Bowcher NEW
Jeanfrancois P ButtRussiaXuxue Feng UNQUALIFIED
Smith L MaletAustraliaBernardo Dominic RENEWAL
Juan A StensethUnited KingdomAmy Elsner UNQUALIFIED
Maisha N PoquetteGermanyIvan Magalhaes NEW
Sinclair M CampainJapanBernardo Dominic NEW
Octavia N DilliardAustraliaAnna Fali UNQUALIFIED
Ricardo P VenereItalyElwin Sharvill NEGOTIATION
Izzy N BowleyBrazilElwin Sharvill UNQUALIFIED
Julie C MacleadRussiaAsiya Javayant PROPOSAL
Claire D FigeroaJapanStephen Shaw PROPOSAL
Morrow H SergiJapanAnna Fali NEW
Munro R DarakjyAustraliaXuxue Feng UNQUALIFIED
Darci F CaldareraArgentinaIvan Magalhaes QUALIFIED
Greenwood K MaletSpainIoni Bowcher QUALIFIED
Maria Y SergiJapanIoni Bowcher RENEWAL
Johnson L InouyeArgentinaBernardo Dominic NEGOTIATION
Munro C ChuiCanadaAnna Fali NEGOTIATION
Cody T FlosiIndiaStephen Shaw NEGOTIATION
Morrow G BriddickJapanAnna Fali QUALIFIED
Nicolas P SergiJapanIoni Bowcher NEW
Jeanfrancois Z PaprockiJapanAmy Elsner RENEWAL
Jennifer P KuskoArgentinaStephen Shaw NEGOTIATION
Wickens T DarakjyFranceOnyama Limba NEGOTIATION
Munro U DoeGermanyBernardo Dominic RENEWAL
Maria U WaycottItalyAsiya Javayant RENEWAL
Arvin Y RulapaughGermanyIvan Magalhaes PROPOSAL
Kaitlin Q VocelkaGermanyStephen Shaw UNQUALIFIED
Kadeem S GillianAustraliaStephen Shaw QUALIFIED
Izzy X IturbideRussiaElwin Sharvill NEGOTIATION
Sinclair Y SergiJapanAnna Fali NEGOTIATION
Munro I RoysterRussiaElwin Sharvill NEW
Emily Y SaylorsItalyIoni Bowcher QUALIFIED
Jennifer T WhobreyRussiaBernardo Dominic UNQUALIFIED
Jones B GlickBrazilAnna Fali UNQUALIFIED
Frozen Columns
Name
Deepesh F Rim
Ashley A Perin
Maisha B Morasca
Izzy O Dilliard
Costa T Morasca
Arvin N Malet
Mayumi H Vocelka
Emily U Stockham
Smith T Albares
Tony X Saylors
Adams P Ruta
Silvio A Chui
Stacey L Slusarski
Silvio W Rim
Isabel L Morasca
Rodrigues L Doe
Adams C Saylors
Munro O Kusko
Emily S Kolmetz
Stacey M Oldroyd
Salvatore C Foller
Munro I Schemmer
Greenwood H Butt
James U Kusko
Silvio L Wieser
Aika X Caudy
Ashley O Ferencz
Darci N Shinko
James T Morasca
Jeanfrancois Z Glick
Ricardo R Nicka
Julie T Rulapaugh
Darci G Bowley
Misaki B Ruta
Aika R Schemmer
Claire M Tollner
Greenwood R Bowley
James L Shinko
Mujtaba B Briddick
Aruna I Bowley
Ashley Y Inouye
Jeanfrancois I Bolognia
James E Waycott
James A Rulapaugh
Mujtaba R Butt
David L Rim
James R Morasca
Johnson C Albares
Isabel M Ferencz
Silvio F Oldroyd
IdCountryDate
1000Japan2024-04-18
1001France2024-04-17
1002Spain2024-04-21
1003Japan2024-04-24
1004Argentina2024-04-06
1005United Kingdom2024-04-08
1006Canada2024-04-16
1007United Kingdom2024-04-09
1008Argentina2024-04-19
1009India2024-04-13
1010Japan2024-04-27
1011Spain2024-04-03
1012Germany2024-04-09
1013Russia2024-04-07
1014Germany2024-04-04
1015Germany2024-04-26
1016Germany2024-04-10
1017Argentina2024-04-07
1018Argentina2024-03-31
1019Germany2024-04-17
1020Spain2024-04-05
1021Japan2024-04-15
1022India2024-03-31
1023Canada2024-03-31
1024Russia2024-04-18
1025Canada2024-04-04
1026Argentina2024-04-03
1027United Kingdom2024-04-04
1028Canada2024-04-11
1029India2024-04-15
1030Canada2024-04-13
1031Canada2024-04-05
1032Spain2024-04-27
1033India2024-04-03
1034Italy2024-04-09
1035Italy2024-04-04
1036Spain2024-04-20
1037United Kingdom2024-04-05
1038Germany2024-04-17
1039Russia2024-03-30
1040Japan2024-04-07
1041France2024-04-24
1042Spain2024-04-12
1043Brazil2024-04-16
1044United Kingdom2024-04-16
1045Germany2024-04-09
1046Italy2024-03-29
1047United Kingdom2024-04-02
1048United Kingdom2024-04-01
1049Spain2024-04-24

On-Demand Data

NameIdCountryDate
Cody P Kusko1000France2024-04-07
Nicolas N Briddick1001Australia2024-03-31
Ashley Q Amigon1002Germany2024-04-24
Leon W Poquette1003Brazil2024-04-09
Salvatore U Butt1004Italy2024-04-20
Maria I Caldarera1005Brazil2024-04-20
Alejandro M Kolmetz1006United Kingdom2024-04-07
Jeanfrancois U Whobrey1007Canada2024-04-08
Greenwood F Malet1008Italy2024-03-30
Adams A Paprocki1009Russia2024-04-23
Jeanfrancois Y Garufi1010Italy2024-04-17
Juan P Rulapaugh1011United Kingdom2024-04-08
Mayumi U Waycott1012Italy2024-04-06
Sinclair W Caldarera1013United Kingdom2024-04-21
Leon O Kusko1014Germany2024-04-21
Murillo L Rim1015Japan2024-04-25
James U Butt1016Argentina2024-04-02
Morrow Z Shinko1017Brazil2024-04-21
Jeanfrancois O Whobrey1018France2024-03-31
Jeanfrancois K Ostrosky1019Japan2024-04-20
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Costa D OldroydIndiaOnyama Limba RENEWAL
David S StensethIndiaOnyama Limba QUALIFIED
Tony L NestleUnited KingdomIoni Bowcher NEW
David I SlusarskiCanadaStephen Shaw PROPOSAL
Mujtaba R CampainItalyElwin Sharvill UNQUALIFIED
Jones N OldroydGermanyStephen Shaw QUALIFIED
Nicolas K ButtItalyElwin Sharvill UNQUALIFIED
Darci F ShinkoUnited KingdomIoni Bowcher QUALIFIED
Leja R StensethCanadaIoni Bowcher RENEWAL
Sinclair O FollerRussiaOnyama Limba NEW
Salvatore E MaletGermanyAmy Elsner NEGOTIATION
Aditya K OstroskyJapanBernardo Dominic NEGOTIATION
Faith U IturbideItalyIvan Magalhaes QUALIFIED
Maisha W RimArgentinaAsiya Javayant UNQUALIFIED
Aruna T WhobreyBrazilIoni Bowcher RENEWAL
Mayumi D VenereJapanElwin Sharvill PROPOSAL
David B WaycottFranceIoni Bowcher RENEWAL
Wickens L RoysterGermanyAnna Fali RENEWAL
Leja I InouyeRussiaOnyama Limba NEGOTIATION
Jeanfrancois C KuskoAustraliaAmy Elsner QUALIFIED
Isabel C MaletIndiaStephen Shaw RENEWAL
Smith W GillianSpainIoni Bowcher UNQUALIFIED
Salvatore S TollnerCanadaAnna Fali UNQUALIFIED
Jones K NickaAustraliaXuxue Feng UNQUALIFIED
David I WhobreyIndiaAnna Fali RENEWAL
Salvatore S ChuiCanadaAnna Fali NEW
Murillo C IturbideJapanElwin Sharvill NEW
Maria J SergiUnited KingdomAnna Fali PROPOSAL
Wickens V MacleadJapanIvan Magalhaes PROPOSAL
Ricardo Y VenereCanadaIvan Magalhaes UNQUALIFIED
Mujtaba C ButtAustraliaElwin Sharvill UNQUALIFIED
Wickens T SchemmerItalyOnyama Limba RENEWAL
Darci W StensethUnited KingdomAnna Fali NEW
Julie B OstroskyUnited KingdomBernardo Dominic PROPOSAL
Ivar G IturbideJapanAnna Fali PROPOSAL
Emily P GlickSpainIvan Magalhaes UNQUALIFIED
Ashley J NickaAustraliaIvan Magalhaes NEW
Juan A StensethJapanAsiya Javayant UNQUALIFIED
David Q BologniaCanadaStephen Shaw QUALIFIED
Morrow W ChuiUnited KingdomAnna Fali 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>