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 K RutaFranceAmy Elsner NEW
Octavia T NickaSpainOnyama Limba UNQUALIFIED
Smith Q InouyeIndiaIvan Magalhaes QUALIFIED
Costa T SchemmerJapanIvan Magalhaes PROPOSAL
Darci A ButtSpainBernardo Dominic QUALIFIED
Ashley O FerenczGermanyAmy Elsner PROPOSAL
Misaki W RimArgentinaIoni Bowcher UNQUALIFIED
Smith P SlusarskiItalyAsiya Javayant RENEWAL
Leja V AlbaresRussiaBernardo Dominic NEGOTIATION
Ashley Z ShinkoGermanyBernardo Dominic QUALIFIED
Cody Y PerinAustraliaIvan Magalhaes NEGOTIATION
Antonio G NickaSpainIoni Bowcher NEGOTIATION
Jennifer Z BologniaArgentinaXuxue Feng RENEWAL
Adams W PaprockiItalyAsiya Javayant RENEWAL
Misaki D CampainIndiaAnna Fali NEGOTIATION
Jefferson V GauchoSpainElwin Sharvill QUALIFIED
Rodrigues J GarufiFranceBernardo Dominic NEW
Kadeem B GarufiBrazilXuxue Feng NEW
Aditya S MorascaJapanOnyama Limba RENEWAL
Morrow W RulapaughAustraliaAsiya Javayant NEGOTIATION
Arvin O BologniaGermanyAsiya Javayant PROPOSAL
Leja A CampainArgentinaIoni Bowcher NEGOTIATION
Clifford Y FerenczUnited KingdomXuxue Feng PROPOSAL
Kadeem D WieserUnited KingdomAsiya Javayant NEGOTIATION
Isabel D PoquetteAustraliaIoni Bowcher PROPOSAL
Arvin U DarakjyJapanAnna Fali UNQUALIFIED
Jones Q MacleadSpainIoni Bowcher UNQUALIFIED
Maria D WaycottIndiaIvan Magalhaes QUALIFIED
Kaitlin M RutaGermanyIvan Magalhaes UNQUALIFIED
Aruna K DarakjySpainIvan Magalhaes NEGOTIATION
Nicolas B DilliardItalyAnna Fali QUALIFIED
Mujtaba G PoquetteArgentinaIoni Bowcher PROPOSAL
Faith T DilliardFranceOnyama Limba UNQUALIFIED
Faith F BologniaJapanIoni Bowcher NEGOTIATION
Maisha D OstroskyCanadaBernardo Dominic PROPOSAL
Mujtaba X DilliardUnited KingdomElwin Sharvill UNQUALIFIED
Kadeem B RoysterBrazilIoni Bowcher QUALIFIED
Isabel U SlusarskiBrazilBernardo Dominic PROPOSAL
Kadeem E StockhamCanadaIoni Bowcher PROPOSAL
Ricardo P IturbideItalyAnna Fali QUALIFIED
Isabel S WhobreyUnited KingdomAmy Elsner NEW
Darci M NestleUnited KingdomElwin Sharvill UNQUALIFIED
Rodrigues B SlusarskiCanadaOnyama Limba UNQUALIFIED
Misaki A KolmetzRussiaAnna Fali UNQUALIFIED
Faith A FigeroaAustraliaElwin Sharvill NEGOTIATION
Silvio O FerenczFranceBernardo Dominic NEGOTIATION
Jennifer J RoysterRussiaAnna Fali PROPOSAL
Murillo X NestleItalyIvan Magalhaes UNQUALIFIED
Salvatore W WaycottCanadaIvan Magalhaes NEW
Ivar Q FollerFranceAsiya Javayant RENEWAL
Horizontal
NameCountryRepresentativeStatus
Isabel T FerenczJapanOnyama Limba UNQUALIFIED
Aika M NestleItalyAsiya Javayant PROPOSAL
Ashley N TollnerCanadaAnna Fali UNQUALIFIED
Murillo B KuskoRussiaStephen Shaw UNQUALIFIED
Tony G SaylorsArgentinaIvan Magalhaes RENEWAL
Leon P KolmetzBrazilStephen Shaw PROPOSAL
Chavez I TollnerAustraliaElwin Sharvill NEW
Ivar N FlosiRussiaElwin Sharvill QUALIFIED
Leon W ChuiUnited KingdomIoni Bowcher UNQUALIFIED
Jennifer F SaylorsFranceOnyama Limba NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Adams Z PoquetteItaly2024-04-25Morlong Associates PROPOSAL33Xuxue Feng
1001Costa N NestleRussia2024-04-20Rousseaux, Michael Esq NEW69Elwin Sharvill
1002Juan R WaycottFrance2024-04-09Benton, John B Jr UNQUALIFIED96Amy Elsner
1003Jefferson R BowleySpain2024-04-20Morlong Associates RENEWAL46Onyama Limba
1004Munro F CaldareraSpain2024-04-07Printing Dimensions QUALIFIED3Onyama Limba
1005Mujtaba T RutaIndia2024-04-06Truhlar And Truhlar Attys PROPOSAL67Onyama Limba
1006Octavia W SchemmerGermany2024-04-08Printing Dimensions PROPOSAL48Amy Elsner
1007Johnson S BowleyArgentina2024-04-22Rousseaux, Michael Esq RENEWAL65Xuxue Feng
1008Murillo J NestleArgentina2024-04-18Truhlar And Truhlar Attys UNQUALIFIED32Elwin Sharvill
1009Leja D InouyeCanada2024-04-21Chapman, Ross E Esq RENEWAL17Bernardo Dominic
1010Morrow P DoeGermany2024-04-05Benton, John B Jr PROPOSAL36Xuxue Feng
1011Alejandro A MacleadFrance2024-04-05Rangoni Of Florence UNQUALIFIED73Ivan Magalhaes
1012Jones Q RutaBrazil2024-04-10Chapman, Ross E Esq NEW69Elwin Sharvill
1013Costa A FollerArgentina2024-04-24Printing Dimensions NEGOTIATION42Anna Fali
1014Ricardo E SergiGermany2024-04-10Chanay, Jeffrey A Esq RENEWAL38Ioni Bowcher
1015Munro U VenereJapan2024-04-05Buckley Miller Wright NEW56Ioni Bowcher
1016Silvio M AlbaresBrazil2024-04-25Chanay, Jeffrey A Esq PROPOSAL86Onyama Limba
1017Sinclair D KolmetzFrance2024-04-15Buckley Miller Wright RENEWAL81Xuxue Feng
1018Murillo T PaprockiFrance2024-03-31Printing Dimensions NEGOTIATION87Stephen Shaw
1019Clifford D KuskoBrazil2024-04-02Printing Dimensions UNQUALIFIED3Bernardo Dominic
1020Jeanfrancois Z PoquetteFrance2024-04-06Commercial Press NEW77Xuxue Feng
1021Silvio O RoysterCanada2024-04-04Buckley Miller Wright RENEWAL98Asiya Javayant
1022Leon B NestleIndia2024-04-23Chemel, James L Cpa PROPOSAL37Ioni Bowcher
1023Johnson J GarufiJapan2024-04-26Buckley Miller Wright PROPOSAL85Bernardo Dominic
1024Nicolas Y BologniaSpain2024-04-19Rousseaux, Michael Esq QUALIFIED34Bernardo Dominic
1025Silvio A MarrierCanada2024-04-11Printing Dimensions QUALIFIED59Bernardo Dominic
1026Leon Y OldroydItaly2024-04-09Feiner Bros NEGOTIATION41Asiya Javayant
1027Morrow N GillianSpain2024-04-06Commercial Press NEW45Stephen Shaw
1028Darci F SlusarskiCanada2024-04-05Rousseaux, Michael Esq QUALIFIED40Ioni Bowcher
1029David D AmigonSpain2024-04-05Rousseaux, Michael Esq RENEWAL29Ioni Bowcher
1030Izzy P FollerUnited Kingdom2024-04-14Chemel, James L Cpa NEW89Ivan Magalhaes
1031Nicolas M PoquetteAustralia2024-04-15Buckley Miller Wright RENEWAL58Asiya Javayant
1032Salvatore W GarufiGermany2024-04-17King, Christopher A Esq NEW16Ivan Magalhaes
1033Costa J VocelkaBrazil2024-03-31Morlong Associates QUALIFIED7Amy Elsner
1034James U GillianCanada2024-03-28Printing Dimensions PROPOSAL88Onyama Limba
1035Mujtaba Y MorascaArgentina2024-04-12Chemel, James L Cpa QUALIFIED57Ioni Bowcher
1036Cody U AlbaresCanada2024-04-04Morlong Associates RENEWAL57Elwin Sharvill
1037Kaitlin H BriddickJapan2024-04-18Printing Dimensions NEW13Asiya Javayant
1038Costa R PerinSpain2024-03-31Truhlar And Truhlar Attys NEGOTIATION26Amy Elsner
1039Claire K AlbaresItaly2024-04-19Truhlar And Truhlar Attys PROPOSAL19Asiya Javayant
1040Silvio Y CaudyAustralia2024-04-18Rangoni Of Florence QUALIFIED33Stephen Shaw
1041Deepesh C VocelkaSpain2024-04-18Feiner Bros UNQUALIFIED25Xuxue Feng
1042Alejandro U WaycottAustralia2024-04-19Feiner Bros UNQUALIFIED77Elwin Sharvill
1043Antonio N StensethFrance2024-04-03King, Christopher A Esq NEGOTIATION60Asiya Javayant
1044Antonio J NickaIndia2024-04-03Feltz Printing Service RENEWAL77Onyama Limba
1045Costa I AmigonAustralia2024-04-15Feltz Printing Service NEGOTIATION93Elwin Sharvill
1046Emily O BriddickBrazil2024-04-11Chapman, Ross E Esq PROPOSAL68Amy Elsner
1047Smith D ChuiJapan2024-04-08Truhlar And Truhlar Attys PROPOSAL80Xuxue Feng
1048Antonio Y WhobreyRussia2024-04-09Chanay, Jeffrey A Esq UNQUALIFIED1Bernardo Dominic
1049Mayumi B VenereUnited Kingdom2024-04-10Dorl, James J Esq NEW6Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Francesco F WhobreyFranceXuxue Feng UNQUALIFIED
Izzy J KuskoJapanStephen Shaw RENEWAL
Kaitlin I SergiUnited KingdomAnna Fali UNQUALIFIED
Maria J StockhamItalyXuxue Feng NEW
Arvin L BriddickBrazilOnyama Limba PROPOSAL
Arvin Y FollerGermanyAmy Elsner NEGOTIATION
Adams F FerenczSpainOnyama Limba RENEWAL
Maisha N GauchoRussiaAmy Elsner RENEWAL
Munro A StockhamBrazilOnyama Limba NEW
Mayumi F FlosiIndiaAsiya Javayant NEW
Stacey B CaudyIndiaAmy Elsner UNQUALIFIED
Johnson X VocelkaRussiaAnna Fali UNQUALIFIED
Aditya G TollnerArgentinaBernardo Dominic QUALIFIED
Alejandro T GlickFranceAsiya Javayant RENEWAL
Costa Z GillianGermanyAnna Fali NEW
Leon X CaldareraAustraliaIoni Bowcher PROPOSAL
Maria D AmigonUnited KingdomIoni Bowcher NEW
Ivar B NickaJapanAnna Fali NEGOTIATION
Kaitlin K MarrierBrazilIvan Magalhaes RENEWAL
Greenwood Z FigeroaAustraliaIoni Bowcher RENEWAL
Leon N MorascaJapanAnna Fali PROPOSAL
Munro S PaprockiFranceStephen Shaw QUALIFIED
Aika O ChuiBrazilAnna Fali RENEWAL
Claire Z BologniaAustraliaIvan Magalhaes NEGOTIATION
Morrow G OstroskyRussiaAmy Elsner NEGOTIATION
Jones B AmigonItalyXuxue Feng QUALIFIED
Maisha H GauchoBrazilAsiya Javayant NEGOTIATION
Mujtaba V MaletSpainAnna Fali NEGOTIATION
Chavez T KolmetzArgentinaStephen Shaw QUALIFIED
Arvin B RulapaughCanadaIvan Magalhaes QUALIFIED
Julie A WaycottAustraliaStephen Shaw QUALIFIED
Morrow D MorascaRussiaAmy Elsner NEW
Jones Y GlickAustraliaAmy Elsner UNQUALIFIED
Isabel W ChuiArgentinaElwin Sharvill PROPOSAL
Aika N NickaGermanyBernardo Dominic RENEWAL
Mujtaba Y MarrierUnited KingdomAnna Fali RENEWAL
Isabel F OstroskyFranceIvan Magalhaes NEGOTIATION
Ivar R MaletBrazilBernardo Dominic NEW
Adams R SchemmerGermanyXuxue Feng RENEWAL
Smith L ChuiUnited KingdomOnyama Limba QUALIFIED
Misaki C ChuiArgentinaXuxue Feng NEW
Antonio K CaudyIndiaElwin Sharvill RENEWAL
James B NestleGermanyAnna Fali UNQUALIFIED
Leon V ButtArgentinaStephen Shaw NEGOTIATION
Francesco E GarufiBrazilStephen Shaw NEGOTIATION
Munro A MarrierGermanyAsiya Javayant UNQUALIFIED
Ricardo A MorascaItalyIoni Bowcher NEGOTIATION
Misaki F VocelkaSpainOnyama Limba QUALIFIED
Aditya J DilliardJapanBernardo Dominic QUALIFIED
Aditya K ChuiItalyIoni Bowcher RENEWAL
Frozen Columns
Name
Arvin Y Inouye
Mayumi T Briddick
Julie D Kolmetz
Arvin G Ostrosky
Salvatore N Maclead
Aika F Glick
Silvio E Kusko
James B Shinko
Adams L Gillian
Leon Q Caudy
Emily T Whobrey
Wickens T Sergi
Adams H Maclead
Emily Z Ostrosky
Jones O Stockham
Izzy K Caldarera
Greenwood M Vocelka
Kadeem F Saylors
Darci T Tollner
Arvin Q Albares
Adams Q Marrier
Wickens P Ferencz
Greenwood T Nicka
Francesco Z Garufi
Ashley D Nestle
Morrow C Briddick
Adams N Bolognia
Juan X Rim
Ricardo W Sergi
Antonio Z Schemmer
Sinclair G Venere
Faith B Darakjy
Emily X Maclead
Rodrigues L Sergi
Darci F Malet
Jefferson O Nestle
Leon V Malet
Silvio N Saylors
Alejandro N Stenseth
David E Bolognia
Francesco X Bolognia
Ivar K Bowley
Jennifer K Kusko
Morrow N Flosi
Stacey T Chui
Aditya J Briddick
Aika U Ostrosky
Adams A Albares
Silvio G Flosi
Johnson K Nicka
IdCountryDate
1000Germany2024-04-17
1001India2024-04-12
1002Spain2024-04-03
1003United Kingdom2024-04-06
1004Argentina2024-04-10
1005India2024-04-10
1006Spain2024-04-11
1007Russia2024-04-20
1008Brazil2024-04-24
1009India2024-03-29
1010Canada2024-04-08
1011Germany2024-04-06
1012France2024-03-28
1013United Kingdom2024-04-15
1014Spain2024-03-28
1015France2024-04-12
1016Spain2024-04-03
1017Brazil2024-03-31
1018Germany2024-04-07
1019Australia2024-04-05
1020Australia2024-04-01
1021Brazil2024-03-30
1022Argentina2024-04-10
1023Australia2024-04-10
1024India2024-04-21
1025Canada2024-04-15
1026Australia2024-04-17
1027Russia2024-04-22
1028Germany2024-04-21
1029United Kingdom2024-04-14
1030Germany2024-04-08
1031Russia2024-03-29
1032Canada2024-04-19
1033Australia2024-04-04
1034Japan2024-04-06
1035Japan2024-03-30
1036France2024-04-16
1037Australia2024-04-24
1038United Kingdom2024-03-28
1039Canada2024-04-06
1040India2024-04-01
1041Argentina2024-04-25
1042Argentina2024-04-12
1043Germany2024-03-31
1044Canada2024-04-16
1045Australia2024-04-24
1046Italy2024-04-14
1047France2024-04-20
1048Germany2024-04-17
1049Australia2024-04-08

On-Demand Data

NameIdCountryDate
Stacey D Oldroyd1000United Kingdom2024-04-07
Aditya T Vocelka1001Australia2024-04-05
Mayumi S Venere1002Canada2024-04-18
Kaitlin S Caldarera1003Canada2024-04-03
Juan N Rim1004India2024-04-25
Ivar N Saylors1005Spain2024-04-06
Chavez X Chui1006Australia2024-03-29
Aditya B Inouye1007Germany2024-04-02
Ivar C Garufi1008Japan2024-04-24
Chavez A Foller1009Russia2024-04-21
Juan Z Schemmer1010Spain2024-04-18
Nicolas O Poquette1011Italy2024-04-14
Maisha S Flosi1012Canada2024-04-19
James I Inouye1013France2024-04-20
Salvatore R Foller1014Spain2024-04-03
Cody N Slusarski1015Spain2024-04-24
Clifford C Schemmer1016France2024-04-16
Munro Y Campain1017United Kingdom2024-04-18
Adams K Stockham1018Italy2024-04-02
Tony E Oldroyd1019France2024-04-05
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Emily U MorascaSpainAmy Elsner RENEWAL
Aruna W MaletAustraliaXuxue Feng UNQUALIFIED
Murillo Q CampainItalyBernardo Dominic RENEWAL
Wickens I GarufiFranceOnyama Limba QUALIFIED
Leja R AmigonJapanAmy Elsner RENEWAL
Maisha Y RoysterAustraliaAmy Elsner RENEWAL
Mayumi T ButtRussiaIoni Bowcher RENEWAL
Maisha L PerinCanadaIoni Bowcher NEW
Salvatore P CaudyJapanStephen Shaw NEW
Deepesh F WhobreyJapanOnyama Limba UNQUALIFIED
Arvin N TollnerGermanyAmy Elsner PROPOSAL
Claire M PoquetteArgentinaAnna Fali PROPOSAL
Arvin H GlickItalyAmy Elsner PROPOSAL
Izzy M FigeroaJapanIvan Magalhaes NEW
Maria P FlosiRussiaOnyama Limba UNQUALIFIED
Smith Y IturbideArgentinaAmy Elsner NEW
Jennifer Q FollerAustraliaXuxue Feng PROPOSAL
Octavia M AmigonRussiaStephen Shaw RENEWAL
Munro T InouyeRussiaElwin Sharvill RENEWAL
Salvatore Q WhobreyItalyAmy Elsner UNQUALIFIED
Octavia T GillianCanadaIoni Bowcher NEGOTIATION
Emily H MacleadSpainBernardo Dominic NEW
Izzy M GauchoRussiaXuxue Feng QUALIFIED
Jennifer A BologniaRussiaAnna Fali NEW
Francesco V MaletJapanAmy Elsner QUALIFIED
Julie F WaycottBrazilXuxue Feng RENEWAL
Ricardo X InouyeItalyIoni Bowcher UNQUALIFIED
Jefferson V AmigonAustraliaStephen Shaw RENEWAL
Ashley W WieserJapanAmy Elsner NEGOTIATION
Aika F CaldareraIndiaBernardo Dominic PROPOSAL
Antonio I MacleadRussiaOnyama Limba RENEWAL
Wickens C BowleyGermanyAnna Fali RENEWAL
Wickens O OstroskyFranceStephen Shaw QUALIFIED
Munro S OldroydIndiaXuxue Feng NEW
Kaitlin Z AmigonItalyXuxue Feng PROPOSAL
James O ButtArgentinaStephen Shaw NEGOTIATION
Jennifer S VenereBrazilOnyama Limba QUALIFIED
Faith Q DilliardJapanAsiya Javayant NEGOTIATION
Mayumi C AlbaresAustraliaAmy Elsner RENEWAL
Maria K TollnerSpainBernardo Dominic 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>