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
Clifford Y WhobreyItalyBernardo Dominic QUALIFIED
Costa B BriddickAustraliaAsiya Javayant NEW
Johnson J StockhamFranceStephen Shaw NEGOTIATION
Mujtaba D BowleyUnited KingdomIvan Magalhaes RENEWAL
Antonio C ChuiArgentinaAmy Elsner PROPOSAL
Clifford A WaycottItalyOnyama Limba NEGOTIATION
Costa B ShinkoArgentinaOnyama Limba QUALIFIED
Maisha R WieserAustraliaIvan Magalhaes UNQUALIFIED
Jefferson B AmigonSpainAmy Elsner UNQUALIFIED
Octavia M DarakjyIndiaAnna Fali QUALIFIED
Munro W NestleIndiaStephen Shaw RENEWAL
Mayumi A BowleyItalyIoni Bowcher NEGOTIATION
Mujtaba I RimGermanyStephen Shaw UNQUALIFIED
James A MacleadRussiaAsiya Javayant NEW
Murillo X SchemmerBrazilStephen Shaw RENEWAL
Jones E AmigonGermanyOnyama Limba RENEWAL
Nicolas H MaletGermanyOnyama Limba NEW
Kaitlin D PoquetteArgentinaOnyama Limba RENEWAL
Mayumi B FigeroaFranceIoni Bowcher RENEWAL
Isabel D FollerUnited KingdomIoni Bowcher QUALIFIED
Salvatore B MorascaArgentinaAsiya Javayant QUALIFIED
Julie I FollerArgentinaAmy Elsner PROPOSAL
Greenwood K OstroskyBrazilOnyama Limba NEW
Faith J ButtFranceAmy Elsner QUALIFIED
Chavez C BriddickUnited KingdomElwin Sharvill NEGOTIATION
Salvatore B ShinkoCanadaBernardo Dominic PROPOSAL
Claire O NestleBrazilOnyama Limba NEW
Octavia Z SergiCanadaXuxue Feng QUALIFIED
Claire K KuskoSpainIoni Bowcher PROPOSAL
Faith A WhobreySpainElwin Sharvill RENEWAL
Jones O MarrierCanadaElwin Sharvill RENEWAL
Murillo L MorascaCanadaIoni Bowcher PROPOSAL
Maria M MarrierIndiaBernardo Dominic NEGOTIATION
Sinclair B BowleyIndiaOnyama Limba UNQUALIFIED
Sinclair W PoquetteArgentinaBernardo Dominic PROPOSAL
David H DarakjyIndiaIoni Bowcher PROPOSAL
Izzy Z VenereGermanyAsiya Javayant QUALIFIED
Ricardo C GlickGermanyStephen Shaw UNQUALIFIED
Claire F SchemmerUnited KingdomBernardo Dominic NEGOTIATION
Chavez F OstroskyItalyIoni Bowcher RENEWAL
Tony B IturbideJapanIvan Magalhaes NEW
Ivar G MarrierGermanyAsiya Javayant RENEWAL
Mujtaba E RoysterIndiaXuxue Feng RENEWAL
Antonio E ShinkoIndiaAsiya Javayant NEGOTIATION
Claire I OldroydItalyAmy Elsner RENEWAL
Sinclair M StockhamBrazilOnyama Limba NEGOTIATION
Wickens B DoeGermanyElwin Sharvill UNQUALIFIED
Cody I DoeBrazilOnyama Limba RENEWAL
Claire R CampainFranceAsiya Javayant PROPOSAL
Salvatore D StensethJapanAsiya Javayant PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Alejandro P KolmetzIndiaOnyama Limba NEGOTIATION
Jeanfrancois A RulapaughFranceIvan Magalhaes NEW
Kaitlin P CaudyGermanyIoni Bowcher QUALIFIED
Jennifer M BologniaItalyOnyama Limba NEW
Nicolas P DilliardGermanyIvan Magalhaes NEGOTIATION
Ivar E CampainCanadaAmy Elsner QUALIFIED
Leon K PoquetteGermanyElwin Sharvill PROPOSAL
Smith F PaprockiBrazilAnna Fali NEW
Clifford I OldroydSpainAmy Elsner RENEWAL
Arvin M VocelkaGermanyElwin Sharvill UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Chavez Q PerinItaly2024-04-02Rousseaux, Michael Esq NEGOTIATION50Xuxue Feng
1001Nicolas I RimFrance2024-04-16Feltz Printing Service NEW48Ioni Bowcher
1002Tony V KuskoArgentina2024-04-26King, Christopher A Esq RENEWAL69Anna Fali
1003Clifford E KolmetzIndia2024-04-06Feiner Bros PROPOSAL60Xuxue Feng
1004Izzy S ChuiSpain2024-04-20Feiner Bros UNQUALIFIED62Onyama Limba
1005Faith Z BowleyIndia2024-04-01Printing Dimensions NEGOTIATION22Stephen Shaw
1006Deepesh G StensethItaly2024-04-04Chanay, Jeffrey A Esq RENEWAL77Elwin Sharvill
1007Emily V PaprockiCanada2024-04-01Chanay, Jeffrey A Esq QUALIFIED12Stephen Shaw
1008Jefferson N StockhamAustralia2024-04-15Truhlar And Truhlar Attys NEW27Amy Elsner
1009Kaitlin K BriddickUnited Kingdom2024-03-30Commercial Press RENEWAL81Ivan Magalhaes
1010Murillo L BowleyAustralia2024-04-23Rangoni Of Florence UNQUALIFIED16Bernardo Dominic
1011Johnson S WhobreyItaly2024-04-25Rangoni Of Florence QUALIFIED56Anna Fali
1012Wickens O FigeroaItaly2024-04-11Buckley Miller Wright UNQUALIFIED98Elwin Sharvill
1013Cody U BowleyItaly2024-04-23Buckley Miller Wright QUALIFIED18Stephen Shaw
1014Emily E ShinkoSpain2024-04-04Commercial Press UNQUALIFIED15Elwin Sharvill
1015Misaki P FerenczAustralia2024-04-25Feiner Bros QUALIFIED30Ioni Bowcher
1016Aditya O ButtItaly2024-04-04Chapman, Ross E Esq NEGOTIATION10Ioni Bowcher
1017Munro E GarufiAustralia2024-04-02Printing Dimensions RENEWAL97Onyama Limba
1018Stacey R RoysterGermany2024-04-19Rousseaux, Michael Esq RENEWAL89Ivan Magalhaes
1019Cody G MorascaUnited Kingdom2024-04-26Feiner Bros QUALIFIED81Xuxue Feng
1020Clifford Z BowleyGermany2024-04-04Dorl, James J Esq NEW19Onyama Limba
1021Mayumi R GillianRussia2024-04-19Benton, John B Jr NEGOTIATION29Onyama Limba
1022Jones C VenereUnited Kingdom2024-04-17Dorl, James J Esq QUALIFIED69Bernardo Dominic
1023Faith H CampainArgentina2024-03-30Dorl, James J Esq NEGOTIATION10Ioni Bowcher
1024Smith Y WieserArgentina2024-04-19Printing Dimensions RENEWAL39Amy Elsner
1025Juan Q AlbaresCanada2024-04-05Morlong Associates NEGOTIATION98Elwin Sharvill
1026Sinclair I SchemmerJapan2024-04-04Chanay, Jeffrey A Esq RENEWAL61Ivan Magalhaes
1027Salvatore B GarufiGermany2024-04-23Dorl, James J Esq RENEWAL59Anna Fali
1028Arvin F VenereJapan2024-04-23Rangoni Of Florence NEW28Bernardo Dominic
1029Jennifer W GarufiItaly2024-04-06Buckley Miller Wright PROPOSAL46Asiya Javayant
1030Antonio Y FollerAustralia2024-03-31Rousseaux, Michael Esq NEGOTIATION44Xuxue Feng
1031Aditya V TollnerRussia2024-04-15Dorl, James J Esq RENEWAL41Asiya Javayant
1032Jennifer H NickaCanada2024-04-26Chemel, James L Cpa NEW63Anna Fali
1033Johnson I MorascaCanada2024-04-13King, Christopher A Esq UNQUALIFIED6Ioni Bowcher
1034Ashley H NestleCanada2024-04-20Morlong Associates QUALIFIED41Xuxue Feng
1035Clifford B GauchoGermany2024-03-31Buckley Miller Wright UNQUALIFIED33Anna Fali
1036Emily F ShinkoBrazil2024-04-20Chapman, Ross E Esq UNQUALIFIED4Elwin Sharvill
1037Ashley B IturbideCanada2024-04-21Feltz Printing Service NEW99Amy Elsner
1038Johnson P SlusarskiBrazil2024-04-02Chemel, James L Cpa PROPOSAL99Onyama Limba
1039Deepesh E GauchoSpain2024-04-25Feltz Printing Service QUALIFIED26Elwin Sharvill
1040Tony E OstroskyAustralia2024-04-25Chapman, Ross E Esq PROPOSAL99Xuxue Feng
1041James T PerinRussia2024-04-05King, Christopher A Esq PROPOSAL65Ioni Bowcher
1042Aditya O RutaRussia2024-04-10Rangoni Of Florence NEW4Xuxue Feng
1043Ricardo M TollnerUnited Kingdom2024-04-23Dorl, James J Esq PROPOSAL9Stephen Shaw
1044Johnson Y CaldareraUnited Kingdom2024-04-02Chapman, Ross E Esq PROPOSAL19Ioni Bowcher
1045Julie W FigeroaItaly2024-04-18Chemel, James L Cpa RENEWAL71Asiya Javayant
1046Jeanfrancois V IturbideRussia2024-04-11Rangoni Of Florence PROPOSAL29Anna Fali
1047Chavez Y MacleadSpain2024-04-17Feiner Bros QUALIFIED15Ivan Magalhaes
1048Sinclair I MacleadIndia2024-03-31Rousseaux, Michael Esq QUALIFIED95Anna Fali
1049Salvatore B MaletRussia2024-04-18Buckley Miller Wright NEGOTIATION59Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Munro N GillianItalyXuxue Feng NEGOTIATION
Mujtaba J TollnerSpainAnna Fali RENEWAL
Mujtaba Q BologniaItalyIvan Magalhaes UNQUALIFIED
Sinclair R RulapaughJapanStephen Shaw NEW
Alejandro G MaletSpainIoni Bowcher UNQUALIFIED
Alejandro T VocelkaArgentinaAnna Fali NEGOTIATION
Chavez A KolmetzUnited KingdomOnyama Limba UNQUALIFIED
James K MaletFranceElwin Sharvill QUALIFIED
Deepesh P OstroskyItalyIoni Bowcher RENEWAL
Misaki R PoquetteGermanyIoni Bowcher NEW
Silvio H MaletSpainAmy Elsner RENEWAL
Mujtaba K InouyeSpainIoni Bowcher NEW
Adams D NickaItalyOnyama Limba NEGOTIATION
Munro U StensethRussiaXuxue Feng UNQUALIFIED
Murillo J PaprockiBrazilIoni Bowcher NEGOTIATION
Cody K ButtGermanyXuxue Feng PROPOSAL
Deepesh G MacleadItalyAmy Elsner PROPOSAL
James F CampainJapanIoni Bowcher UNQUALIFIED
Jefferson K MaletRussiaIoni Bowcher UNQUALIFIED
Antonio R TollnerUnited KingdomAnna Fali UNQUALIFIED
Ivar R VenereGermanyStephen Shaw QUALIFIED
Misaki O KolmetzFranceAsiya Javayant QUALIFIED
Juan X WieserJapanAmy Elsner NEW
Sinclair K PaprockiItalyAmy Elsner QUALIFIED
Wickens E NickaCanadaAnna Fali NEGOTIATION
Aditya U GarufiArgentinaElwin Sharvill PROPOSAL
Arvin Q FerenczArgentinaIvan Magalhaes NEGOTIATION
Clifford D CampainItalyIoni Bowcher NEW
Octavia H StensethCanadaOnyama Limba NEW
Costa H ButtFranceAnna Fali UNQUALIFIED
Julie X AmigonJapanStephen Shaw NEW
Adams T PoquetteRussiaIoni Bowcher UNQUALIFIED
Izzy I FigeroaCanadaStephen Shaw PROPOSAL
Stacey G NickaSpainOnyama Limba RENEWAL
Isabel E AmigonUnited KingdomElwin Sharvill RENEWAL
Aika X NestleRussiaIoni Bowcher NEW
Francesco N StensethFranceBernardo Dominic RENEWAL
Murillo V DarakjyGermanyAnna Fali NEW
Faith K FlosiItalyAnna Fali NEW
Kaitlin L CampainAustraliaIvan Magalhaes UNQUALIFIED
Francesco L BologniaGermanyStephen Shaw NEGOTIATION
Ivar W OldroydBrazilAnna Fali NEGOTIATION
Aika X GauchoIndiaElwin Sharvill NEW
Cody U SaylorsSpainIvan Magalhaes UNQUALIFIED
Johnson Y CaudyRussiaOnyama Limba RENEWAL
Darci P AmigonJapanXuxue Feng NEW
Nicolas G ButtIndiaIoni Bowcher QUALIFIED
Jennifer Y SlusarskiItalyStephen Shaw NEGOTIATION
Antonio I AmigonUnited KingdomAsiya Javayant QUALIFIED
Isabel L RoysterAustraliaIoni Bowcher NEW
Frozen Columns
Name
Munro O Inouye
Juan A Venere
Isabel T Venere
Rodrigues X Bolognia
Wickens F Malet
Darci I Nicka
Tony Q Briddick
Arvin A Nicka
Jennifer G Chui
Rodrigues T Malet
Ricardo L Briddick
Costa I Ruta
Maria O Maclead
Mujtaba D Malet
Costa G Kusko
Tony O Rim
Wickens P Doe
Clifford A Stenseth
Juan W Waycott
James V Nestle
Jennifer K Butt
Kaitlin E Malet
Deepesh W Kolmetz
Jeanfrancois Y Malet
Claire B Nicka
Morrow X Maclead
Murillo N Glick
Antonio R Kolmetz
Sinclair W Albares
Julie B Nicka
Clifford L Wieser
Stacey I Royster
Greenwood W Wieser
Aika Y Briddick
Ricardo O Schemmer
Emily W Rim
Mayumi G Glick
Mujtaba Z Flosi
Aika Q Slusarski
Rodrigues E Sergi
Faith M Oldroyd
Aika N Bolognia
Claire Q Marrier
Alejandro L Schemmer
Ashley D Nestle
Aruna A Shinko
Costa Y Whobrey
Jones H Tollner
Chavez T Nicka
Maria F Venere
IdCountryDate
1000France2024-04-22
1001Canada2024-04-03
1002Argentina2024-04-08
1003Argentina2024-03-30
1004Spain2024-04-05
1005Australia2024-04-16
1006Italy2024-04-12
1007Australia2024-04-18
1008Germany2024-04-09
1009France2024-03-31
1010Brazil2024-04-03
1011Russia2024-04-08
1012United Kingdom2024-04-01
1013France2024-04-05
1014Japan2024-04-18
1015Canada2024-04-15
1016France2024-04-08
1017France2024-04-23
1018France2024-04-01
1019United Kingdom2024-04-11
1020Canada2024-04-20
1021United Kingdom2024-04-25
1022Russia2024-04-23
1023Japan2024-04-09
1024Japan2024-04-04
1025Brazil2024-04-14
1026Russia2024-04-15
1027Italy2024-03-31
1028France2024-04-11
1029Argentina2024-04-17
1030Russia2024-04-23
1031Argentina2024-04-05
1032Australia2024-04-10
1033Spain2024-04-02
1034India2024-04-28
1035Russia2024-03-31
1036Argentina2024-04-28
1037Canada2024-04-14
1038Italy2024-04-08
1039Canada2024-04-03
1040Argentina2024-04-05
1041Brazil2024-04-01
1042United Kingdom2024-04-08
1043Russia2024-04-27
1044Italy2024-04-01
1045Germany2024-04-02
1046Russia2024-04-09
1047Spain2024-04-08
1048France2024-04-21
1049Australia2024-04-28

On-Demand Data

NameIdCountryDate
Leja S Foller1000Australia2024-04-13
Wickens F Campain1001Italy2024-04-24
Jefferson C Darakjy1002Spain2024-04-08
Wickens S Gaucho1003Canada2024-04-09
Maisha J Poquette1004India2024-04-16
Aika H Stenseth1005India2024-04-11
Aika F Garufi1006Argentina2024-04-21
Clifford M Ostrosky1007Australia2024-04-10
Ricardo Z Albares1008Japan2024-04-05
Stacey W Ostrosky1009Australia2024-04-17
Jones N Foller1010Germany2024-04-14
Maria S Bowley1011Japan2024-04-09
Octavia M Marrier1012Spain2024-04-06
Leja P Inouye1013Argentina2024-04-11
Maisha Y Gaucho1014United Kingdom2024-04-08
Johnson M Shinko1015Germany2024-04-03
Tony V Butt1016Germany2024-03-30
Ivar Z Darakjy1017Japan2024-04-04
Jones K Ruta1018Japan2024-04-24
Juan J Rulapaugh1019Canada2024-04-24
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Clifford B SchemmerCanadaIvan Magalhaes UNQUALIFIED
Misaki U RulapaughSpainAsiya Javayant RENEWAL
Maisha E MaletIndiaBernardo Dominic QUALIFIED
Faith L StensethIndiaBernardo Dominic UNQUALIFIED
Morrow O SchemmerArgentinaAsiya Javayant QUALIFIED
Maisha D WhobreySpainAmy Elsner UNQUALIFIED
Kaitlin L SlusarskiUnited KingdomAnna Fali PROPOSAL
Julie M MorascaIndiaStephen Shaw QUALIFIED
Izzy F RoysterIndiaStephen Shaw PROPOSAL
Murillo B AlbaresJapanAmy Elsner RENEWAL
Leon V NestleAustraliaStephen Shaw UNQUALIFIED
Tony B RulapaughAustraliaStephen Shaw PROPOSAL
Rodrigues G SlusarskiCanadaIvan Magalhaes NEGOTIATION
Chavez N FigeroaRussiaElwin Sharvill QUALIFIED
Johnson W FerenczGermanyIoni Bowcher NEGOTIATION
Leja G WaycottGermanyXuxue Feng RENEWAL
Isabel R DilliardAustraliaBernardo Dominic RENEWAL
Maria M RutaJapanBernardo Dominic NEGOTIATION
Aditya U BowleyIndiaIoni Bowcher RENEWAL
Smith C FerenczArgentinaElwin Sharvill RENEWAL
Clifford B PerinBrazilStephen Shaw PROPOSAL
Ricardo P GlickSpainAmy Elsner UNQUALIFIED
Tony R ButtUnited KingdomBernardo Dominic NEGOTIATION
Aruna R SaylorsIndiaOnyama Limba RENEWAL
Tony J FerenczFranceIvan Magalhaes UNQUALIFIED
Arvin T CaldareraUnited KingdomOnyama Limba PROPOSAL
Aruna V NickaArgentinaBernardo Dominic UNQUALIFIED
Arvin S FlosiGermanyBernardo Dominic NEW
Francesco Y GillianCanadaIoni Bowcher PROPOSAL
Aruna A SergiSpainAmy Elsner QUALIFIED
Rodrigues V BologniaJapanIoni Bowcher PROPOSAL
Misaki L GillianJapanOnyama Limba QUALIFIED
Tony W RutaSpainAnna Fali NEGOTIATION
Mayumi F DarakjyBrazilBernardo Dominic NEGOTIATION
Johnson S SergiAustraliaAnna Fali QUALIFIED
Cody A GarufiItalyXuxue Feng PROPOSAL
Ricardo Z RulapaughJapanAmy Elsner PROPOSAL
Maisha O SaylorsBrazilAnna Fali UNQUALIFIED
Jennifer P SchemmerJapanStephen Shaw QUALIFIED
Antonio N CaldareraAustraliaStephen Shaw 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>