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
Jennifer Y RimBrazilIoni Bowcher RENEWAL
Nicolas Y ChuiGermanyAsiya Javayant UNQUALIFIED
Kadeem B FerenczIndiaAmy Elsner NEW
Jeanfrancois O MorascaSpainOnyama Limba NEW
Francesco A ShinkoRussiaAnna Fali PROPOSAL
Ricardo B FlosiJapanXuxue Feng NEGOTIATION
Munro V VenereUnited KingdomIoni Bowcher RENEWAL
Aruna H FollerBrazilAmy Elsner RENEWAL
Ricardo K AlbaresCanadaStephen Shaw QUALIFIED
Silvio J GauchoSpainElwin Sharvill NEW
Maisha S RoysterSpainAmy Elsner NEW
Leja O AmigonFranceAsiya Javayant RENEWAL
Jeanfrancois J OstroskyJapanStephen Shaw UNQUALIFIED
Izzy O SaylorsSpainXuxue Feng PROPOSAL
Juan L ButtSpainIoni Bowcher NEW
Leja K FerenczBrazilAmy Elsner QUALIFIED
Juan O CaudyIndiaAsiya Javayant UNQUALIFIED
Munro H RutaAustraliaAnna Fali QUALIFIED
Jeanfrancois O MaletBrazilBernardo Dominic NEGOTIATION
Nicolas Q SergiIndiaAsiya Javayant UNQUALIFIED
Jefferson P WhobreyGermanyStephen Shaw PROPOSAL
Kadeem F VocelkaGermanyStephen Shaw PROPOSAL
Misaki O CaudyJapanStephen Shaw RENEWAL
Mujtaba S StensethUnited KingdomAnna Fali NEW
Francesco S MacleadJapanIvan Magalhaes PROPOSAL
David P InouyeSpainXuxue Feng QUALIFIED
Claire O TollnerGermanyAmy Elsner NEW
Aruna B KuskoJapanAmy Elsner PROPOSAL
Claire W VocelkaItalyBernardo Dominic NEGOTIATION
Juan V MaletJapanIoni Bowcher RENEWAL
Mujtaba X AmigonAustraliaBernardo Dominic PROPOSAL
Claire R StockhamItalyAnna Fali QUALIFIED
Deepesh U FigeroaRussiaOnyama Limba NEW
Morrow L PoquetteUnited KingdomStephen Shaw RENEWAL
Wickens M BriddickGermanyAmy Elsner UNQUALIFIED
Julie J GillianSpainAmy Elsner NEGOTIATION
Ricardo T BologniaJapanIoni Bowcher PROPOSAL
Misaki Z PerinSpainXuxue Feng NEGOTIATION
Silvio B RulapaughIndiaIoni Bowcher QUALIFIED
Greenwood K InouyeSpainStephen Shaw NEW
Johnson D WieserCanadaAnna Fali NEGOTIATION
Jeanfrancois H StockhamBrazilStephen Shaw UNQUALIFIED
Adams T DoeUnited KingdomIoni Bowcher RENEWAL
Maria J DoeRussiaAmy Elsner NEW
Ivar S DilliardArgentinaXuxue Feng QUALIFIED
Julie M BologniaJapanOnyama Limba NEGOTIATION
Julie S FerenczUnited KingdomIvan Magalhaes QUALIFIED
David I SergiSpainAmy Elsner NEGOTIATION
David V KuskoItalyAnna Fali NEW
Juan Z RutaRussiaIvan Magalhaes QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Jones V StensethArgentinaAnna Fali RENEWAL
Misaki L IturbideCanadaAmy Elsner NEW
Sinclair F BriddickSpainAsiya Javayant UNQUALIFIED
Adams U MaletItalyStephen Shaw PROPOSAL
James F DarakjyIndiaXuxue Feng NEW
Mayumi C NickaArgentinaXuxue Feng UNQUALIFIED
Aditya E GarufiItalyXuxue Feng QUALIFIED
Aruna T SergiAustraliaOnyama Limba NEW
Tony O ButtSpainStephen Shaw RENEWAL
Darci M GauchoFranceXuxue Feng QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Chavez W RoysterJapan2024-03-28Morlong Associates NEW84Onyama Limba
1001Tony E BriddickIndia2024-03-31Rousseaux, Michael Esq RENEWAL23Bernardo Dominic
1002Faith T WhobreyItaly2024-03-18Chanay, Jeffrey A Esq NEW75Asiya Javayant
1003Costa O BowleySpain2024-04-10Chemel, James L Cpa NEGOTIATION58Ioni Bowcher
1004James R BologniaBrazil2024-03-18Printing Dimensions QUALIFIED80Ioni Bowcher
1005Sinclair F DilliardCanada2024-04-11Feltz Printing Service RENEWAL11Bernardo Dominic
1006Costa O ChuiRussia2024-04-08Rangoni Of Florence QUALIFIED8Ivan Magalhaes
1007Emily Z SlusarskiFrance2024-03-23Rousseaux, Michael Esq RENEWAL31Bernardo Dominic
1008Francesco C NestleItaly2024-03-18Buckley Miller Wright PROPOSAL0Ioni Bowcher
1009Ricardo B SlusarskiGermany2024-04-13Dorl, James J Esq RENEWAL65Xuxue Feng
1010Morrow J SaylorsCanada2024-04-09Printing Dimensions PROPOSAL49Onyama Limba
1011Misaki V FigeroaIndia2024-03-24Chanay, Jeffrey A Esq UNQUALIFIED46Stephen Shaw
1012Faith C FlosiItaly2024-04-14Feltz Printing Service UNQUALIFIED52Xuxue Feng
1013Wickens A TollnerJapan2024-03-29Chemel, James L Cpa NEW29Xuxue Feng
1014Tony F MarrierBrazil2024-03-25Chapman, Ross E Esq NEGOTIATION74Asiya Javayant
1015Mujtaba H AmigonSpain2024-04-05Printing Dimensions NEW3Ivan Magalhaes
1016Clifford U MorascaRussia2024-04-08Feltz Printing Service PROPOSAL18Ioni Bowcher
1017Jones N OstroskyFrance2024-03-31King, Christopher A Esq NEW14Onyama Limba
1018Francesco V WieserItaly2024-03-26King, Christopher A Esq RENEWAL92Asiya Javayant
1019Morrow I SchemmerCanada2024-03-19Chapman, Ross E Esq NEGOTIATION88Stephen Shaw
1020Kaitlin Z GlickFrance2024-04-13Feltz Printing Service RENEWAL23Bernardo Dominic
1021Ashley L FollerUnited Kingdom2024-04-06Chemel, James L Cpa NEW44Onyama Limba
1022Murillo X PoquetteBrazil2024-04-07Rousseaux, Michael Esq QUALIFIED28Xuxue Feng
1023Jefferson X DarakjyCanada2024-04-13Buckley Miller Wright QUALIFIED7Anna Fali
1024Octavia H RulapaughSpain2024-04-06Feiner Bros UNQUALIFIED87Bernardo Dominic
1025Isabel I AmigonBrazil2024-04-11King, Christopher A Esq NEW21Ioni Bowcher
1026Kaitlin G KolmetzItaly2024-03-18Benton, John B Jr NEW63Stephen Shaw
1027Aruna N IturbideIndia2024-04-02Printing Dimensions QUALIFIED87Amy Elsner
1028Maria U OldroydAustralia2024-04-02Rangoni Of Florence NEGOTIATION99Elwin Sharvill
1029Alejandro H OldroydFrance2024-04-05Rousseaux, Michael Esq PROPOSAL81Ioni Bowcher
1030Silvio I FollerUnited Kingdom2024-04-10Rangoni Of Florence NEW88Ioni Bowcher
1031Jones M CaudyGermany2024-04-09Chemel, James L Cpa PROPOSAL99Amy Elsner
1032Juan K AlbaresCanada2024-04-08Rousseaux, Michael Esq RENEWAL38Asiya Javayant
1033Deepesh M AlbaresBrazil2024-03-24Feltz Printing Service QUALIFIED82Onyama Limba
1034Jennifer V MarrierItaly2024-04-08King, Christopher A Esq UNQUALIFIED51Asiya Javayant
1035Isabel S SlusarskiAustralia2024-03-18Chemel, James L Cpa NEW75Stephen Shaw
1036Nicolas W PerinArgentina2024-03-23Dorl, James J Esq UNQUALIFIED9Bernardo Dominic
1037Wickens E FollerGermany2024-03-28Chapman, Ross E Esq NEGOTIATION97Amy Elsner
1038Salvatore S BowleyUnited Kingdom2024-03-18Buckley Miller Wright NEGOTIATION88Anna Fali
1039Faith P VocelkaUnited Kingdom2024-03-29Rangoni Of Florence UNQUALIFIED17Xuxue Feng
1040Costa E KolmetzGermany2024-03-31Rangoni Of Florence UNQUALIFIED55Elwin Sharvill
1041Jones A PaprockiArgentina2024-03-26Benton, John B Jr NEGOTIATION10Amy Elsner
1042Tony Y CaudyRussia2024-04-10Rangoni Of Florence RENEWAL16Onyama Limba
1043Jennifer G DarakjyAustralia2024-03-25Rousseaux, Michael Esq NEGOTIATION42Xuxue Feng
1044Ashley A BologniaGermany2024-04-03Dorl, James J Esq NEW37Onyama Limba
1045Ivar V VocelkaItaly2024-04-11King, Christopher A Esq PROPOSAL88Stephen Shaw
1046Jennifer O GauchoSpain2024-04-15Feltz Printing Service NEGOTIATION25Ivan Magalhaes
1047Antonio L DarakjyIndia2024-03-19Chapman, Ross E Esq UNQUALIFIED47Bernardo Dominic
1048Darci G FigeroaGermany2024-03-28Morlong Associates QUALIFIED44Ivan Magalhaes
1049Ashley G MarrierBrazil2024-03-21Chemel, James L Cpa QUALIFIED98Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Izzy T BriddickCanadaIoni Bowcher UNQUALIFIED
David C ShinkoCanadaAmy Elsner NEW
Leon E SaylorsJapanAsiya Javayant PROPOSAL
Cody E NickaCanadaBernardo Dominic UNQUALIFIED
Greenwood S CampainBrazilStephen Shaw PROPOSAL
Rodrigues M GarufiGermanyAnna Fali PROPOSAL
Costa O ButtBrazilBernardo Dominic NEGOTIATION
Darci M MarrierFranceIoni Bowcher RENEWAL
Munro T FollerSpainOnyama Limba NEW
Aika E MarrierRussiaOnyama Limba RENEWAL
Mujtaba Z NestleArgentinaBernardo Dominic QUALIFIED
Costa G ShinkoArgentinaOnyama Limba NEGOTIATION
Julie M PaprockiIndiaAsiya Javayant PROPOSAL
David K GarufiJapanBernardo Dominic QUALIFIED
Silvio Z ChuiGermanyElwin Sharvill NEW
Alejandro Z BowleyIndiaIvan Magalhaes NEGOTIATION
Jones A BriddickBrazilAnna Fali NEGOTIATION
Leon Q RoysterSpainXuxue Feng PROPOSAL
Maria S GillianBrazilIoni Bowcher NEW
Isabel K DoeAustraliaAmy Elsner RENEWAL
Aika A DilliardCanadaBernardo Dominic PROPOSAL
Jennifer A DilliardUnited KingdomAsiya Javayant PROPOSAL
Octavia Q ShinkoRussiaStephen Shaw QUALIFIED
Emily M DarakjyUnited KingdomAsiya Javayant RENEWAL
Maisha J PoquetteArgentinaAmy Elsner NEW
Cody C RulapaughCanadaAsiya Javayant NEGOTIATION
David J BologniaFranceOnyama Limba QUALIFIED
Darci L AmigonSpainAnna Fali QUALIFIED
Claire M VenereUnited KingdomStephen Shaw RENEWAL
Darci A PaprockiCanadaXuxue Feng NEGOTIATION
Jennifer V ChuiBrazilXuxue Feng RENEWAL
Nicolas H GillianJapanAmy Elsner PROPOSAL
Munro J GarufiItalyBernardo Dominic PROPOSAL
Maria T RulapaughJapanBernardo Dominic NEGOTIATION
Jeanfrancois A PerinAustraliaIvan Magalhaes NEGOTIATION
Sinclair U DarakjyGermanyAsiya Javayant NEW
Aditya L VocelkaArgentinaIoni Bowcher QUALIFIED
Darci Z AmigonGermanyStephen Shaw PROPOSAL
David Q VenereIndiaElwin Sharvill PROPOSAL
Tony V IturbideItalyStephen Shaw RENEWAL
Julie U AlbaresGermanyAsiya Javayant NEGOTIATION
Jefferson V SaylorsItalyIoni Bowcher PROPOSAL
Munro G StockhamSpainElwin Sharvill NEGOTIATION
Tony X StockhamJapanAnna Fali NEW
Jefferson S SergiItalyElwin Sharvill QUALIFIED
Claire E MaletAustraliaIvan Magalhaes NEW
Murillo S FollerJapanAnna Fali RENEWAL
Jennifer M PaprockiRussiaElwin Sharvill NEGOTIATION
Sinclair R CaldareraArgentinaElwin Sharvill NEGOTIATION
Jones X MorascaFranceBernardo Dominic UNQUALIFIED
Frozen Columns
Name
Darci X Ostrosky
Jefferson W Bolognia
Smith G Kolmetz
Ashley Q Whobrey
Silvio Z Iturbide
Claire O Ostrosky
Stacey G Shinko
Johnson R Rim
Kadeem F Caldarera
Salvatore A Kolmetz
Jennifer Z Bolognia
Claire M Sergi
Costa V Garufi
Ashley K Ostrosky
David G Amigon
Claire F Nestle
Deepesh W Slusarski
Munro G Sergi
Isabel V Iturbide
Munro W Royster
Ricardo O Nestle
Ricardo D Slusarski
Jeanfrancois J Waycott
Deepesh N Butt
Maisha B Tollner
Greenwood F Morasca
Emily G Nicka
Tony M Inouye
Johnson Y Nestle
Emily V Darakjy
Jones Y Kolmetz
Wickens C Vocelka
Clifford S Ostrosky
Jones W Perin
Aditya D Morasca
Adams H Malet
Antonio K Maclead
Maria O Gaucho
Aruna K Royster
Jeanfrancois J Nicka
Julie R Chui
Murillo J Garufi
Rodrigues F Schemmer
Johnson C Ostrosky
Adams P Nestle
Jefferson A Briddick
Maria Z Slusarski
Francesco G Whobrey
Darci K Glick
Arvin Z Nicka
IdCountryDate
1000India2024-04-06
1001Japan2024-04-05
1002Argentina2024-04-15
1003Canada2024-03-27
1004United Kingdom2024-04-03
1005Brazil2024-04-14
1006Spain2024-04-03
1007France2024-03-23
1008Germany2024-04-04
1009France2024-03-19
1010India2024-04-05
1011Russia2024-04-04
1012Germany2024-03-24
1013Russia2024-04-12
1014Japan2024-03-20
1015Canada2024-03-27
1016Spain2024-03-19
1017Japan2024-03-27
1018Russia2024-03-22
1019France2024-03-17
1020Germany2024-03-23
1021Germany2024-03-17
1022Argentina2024-04-01
1023Italy2024-03-27
1024Canada2024-03-30
1025Brazil2024-03-26
1026Italy2024-03-28
1027Japan2024-04-11
1028Canada2024-03-18
1029Italy2024-04-01
1030Russia2024-04-12
1031Russia2024-04-08
1032Brazil2024-03-20
1033Germany2024-03-29
1034Australia2024-03-23
1035Australia2024-03-23
1036France2024-03-20
1037Argentina2024-03-29
1038Japan2024-03-29
1039United Kingdom2024-04-13
1040Japan2024-04-13
1041Canada2024-03-20
1042Germany2024-04-09
1043Australia2024-04-05
1044Australia2024-03-28
1045Japan2024-03-19
1046Australia2024-03-27
1047Argentina2024-04-06
1048Argentina2024-04-12
1049Canada2024-04-15

On-Demand Data

NameIdCountryDate
Chavez A Stockham1000United Kingdom2024-03-22
Murillo Y Rim1001France2024-03-27
Johnson T Shinko1002Argentina2024-04-04
Maria X Flosi1003United Kingdom2024-04-09
Isabel I Stenseth1004Spain2024-03-26
Faith Y Sergi1005Germany2024-03-23
Sinclair V Doe1006Japan2024-04-15
Isabel U Darakjy1007Brazil2024-03-28
Sinclair K Amigon1008Russia2024-04-02
Misaki X Oldroyd1009Australia2024-04-04
Claire U Royster1010Germany2024-03-30
Antonio A Butt1011Brazil2024-04-13
Kadeem N Gillian1012Argentina2024-04-15
Emily X Iturbide1013Brazil2024-04-04
Tony E Campain1014India2024-04-05
Aditya H Caldarera1015Italy2024-03-22
Jeanfrancois G Slusarski1016France2024-03-17
Leja W Sergi1017Brazil2024-03-18
Jones G Bowley1018Argentina2024-04-07
Smith K Butt1019Spain2024-04-01
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Misaki L OstroskyJapanBernardo Dominic QUALIFIED
Chavez L RutaFranceStephen Shaw UNQUALIFIED
Rodrigues P KuskoGermanyIoni Bowcher UNQUALIFIED
Chavez K ChuiCanadaOnyama Limba RENEWAL
Johnson K RimArgentinaBernardo Dominic NEGOTIATION
Nicolas C MaletArgentinaElwin Sharvill NEW
Nicolas I GlickCanadaBernardo Dominic NEW
Juan I KuskoIndiaXuxue Feng QUALIFIED
Chavez M OldroydUnited KingdomIoni Bowcher PROPOSAL
Julie T SchemmerFranceOnyama Limba RENEWAL
Murillo S KolmetzItalyIvan Magalhaes NEW
Juan I CampainGermanyElwin Sharvill UNQUALIFIED
Aditya V CampainAustraliaIoni Bowcher NEW
Isabel I VocelkaRussiaAnna Fali PROPOSAL
Jones H BowleyJapanElwin Sharvill UNQUALIFIED
Ricardo U WaycottGermanyBernardo Dominic NEGOTIATION
Ivar P NickaCanadaOnyama Limba NEGOTIATION
Mayumi Q GauchoJapanIvan Magalhaes RENEWAL
Emily C MaletSpainAnna Fali UNQUALIFIED
Arvin V FerenczItalyStephen Shaw NEGOTIATION
Ashley L GillianFranceAmy Elsner NEGOTIATION
Darci E SchemmerAustraliaElwin Sharvill QUALIFIED
Adams T PoquetteJapanXuxue Feng UNQUALIFIED
Jennifer O PoquetteIndiaXuxue Feng RENEWAL
Arvin H AmigonItalyAmy Elsner QUALIFIED
Isabel Z OstroskyJapanOnyama Limba NEGOTIATION
Morrow S DilliardJapanIvan Magalhaes RENEWAL
Ivar W GauchoIndiaElwin Sharvill UNQUALIFIED
Costa F NickaBrazilXuxue Feng NEGOTIATION
David L GarufiUnited KingdomAmy Elsner PROPOSAL
Leon E RutaItalyIoni Bowcher NEW
Octavia X SaylorsBrazilStephen Shaw NEGOTIATION
Mujtaba P WieserCanadaIoni Bowcher PROPOSAL
Aika Z FollerGermanyAnna Fali PROPOSAL
Ashley T WieserUnited KingdomBernardo Dominic NEW
Munro D GarufiCanadaAmy Elsner PROPOSAL
Maria Z RulapaughAustraliaXuxue Feng QUALIFIED
Faith L RimBrazilOnyama Limba NEW
Leja T MaletItalyAnna Fali NEW
Juan R SlusarskiIndiaElwin Sharvill 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>