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 W VenereAustraliaIvan Magalhaes RENEWAL
Murillo C BowleyRussiaOnyama Limba NEGOTIATION
Leon W DilliardJapanElwin Sharvill NEW
Izzy J RoysterAustraliaBernardo Dominic UNQUALIFIED
Leon S ButtSpainBernardo Dominic NEW
Isabel J WaycottIndiaElwin Sharvill UNQUALIFIED
Johnson A MorascaCanadaAnna Fali QUALIFIED
Stacey V GlickGermanyXuxue Feng PROPOSAL
Deepesh S CampainUnited KingdomElwin Sharvill NEGOTIATION
Leja Q VocelkaArgentinaElwin Sharvill QUALIFIED
Jeanfrancois A SaylorsJapanOnyama Limba NEW
James O MaletAustraliaOnyama Limba RENEWAL
Kadeem R GauchoIndiaAmy Elsner NEGOTIATION
Mayumi E ChuiArgentinaIvan Magalhaes NEGOTIATION
Aika B IturbideCanadaAmy Elsner NEW
Isabel L StockhamGermanyAsiya Javayant UNQUALIFIED
Kadeem H AmigonJapanBernardo Dominic RENEWAL
Antonio X RimBrazilIoni Bowcher RENEWAL
Claire V PaprockiSpainStephen Shaw NEGOTIATION
Chavez D FollerGermanyAsiya Javayant NEGOTIATION
Antonio M PaprockiItalyIvan Magalhaes QUALIFIED
Greenwood G ButtCanadaAnna Fali RENEWAL
Juan J CaudyArgentinaAsiya Javayant NEW
Ricardo V SchemmerAustraliaAmy Elsner PROPOSAL
Aika O ChuiFranceBernardo Dominic NEW
Emily B RulapaughItalyIvan Magalhaes PROPOSAL
Johnson T CampainSpainBernardo Dominic RENEWAL
Rodrigues H ChuiCanadaStephen Shaw UNQUALIFIED
Octavia H AmigonIndiaStephen Shaw RENEWAL
Clifford E SlusarskiRussiaIvan Magalhaes NEW
Kaitlin F AmigonJapanElwin Sharvill PROPOSAL
Aditya X FlosiRussiaAmy Elsner RENEWAL
Jones H VenereIndiaStephen Shaw NEGOTIATION
Claire W NickaSpainIoni Bowcher RENEWAL
Izzy X WieserCanadaXuxue Feng NEW
Juan S MorascaJapanElwin Sharvill UNQUALIFIED
Arvin G KuskoItalyXuxue Feng PROPOSAL
Misaki R CaldareraBrazilAnna Fali PROPOSAL
Juan K GillianGermanyAsiya Javayant UNQUALIFIED
Wickens U VenereCanadaOnyama Limba RENEWAL
Morrow K StockhamIndiaBernardo Dominic NEW
James W MaletBrazilXuxue Feng RENEWAL
Ivar W RimBrazilAmy Elsner UNQUALIFIED
Alejandro H IturbideSpainIoni Bowcher NEGOTIATION
Misaki T TollnerJapanBernardo Dominic PROPOSAL
Tony O GauchoSpainAsiya Javayant PROPOSAL
Faith L MaletArgentinaIoni Bowcher RENEWAL
Smith J RoysterItalyOnyama Limba UNQUALIFIED
Jeanfrancois P GillianItalyStephen Shaw NEW
Juan K GauchoItalyIoni Bowcher QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Tony V AmigonBrazilAsiya Javayant RENEWAL
Leja D StensethItalyOnyama Limba PROPOSAL
Clifford I MorascaFranceIoni Bowcher QUALIFIED
Julie U DoeSpainStephen Shaw NEGOTIATION
Mayumi Q ShinkoUnited KingdomAsiya Javayant NEGOTIATION
Johnson C DoeItalyBernardo Dominic NEW
Jeanfrancois F OldroydSpainIvan Magalhaes NEGOTIATION
Chavez H MacleadArgentinaAnna Fali NEW
Misaki T BowleyRussiaIvan Magalhaes QUALIFIED
Mujtaba Q OldroydGermanyXuxue Feng NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jones T RutaRussia2024-04-05Feltz Printing Service RENEWAL8Ivan Magalhaes
1001Emily T AlbaresJapan2024-04-22Chapman, Ross E Esq NEW65Anna Fali
1002Deepesh X WhobreyCanada2024-04-04Chemel, James L Cpa NEGOTIATION26Ivan Magalhaes
1003Kadeem L OstroskyGermany2024-04-03Feiner Bros PROPOSAL83Onyama Limba
1004Munro C CaldareraArgentina2024-04-03Chanay, Jeffrey A Esq QUALIFIED96Elwin Sharvill
1005David B DilliardArgentina2024-04-11Rousseaux, Michael Esq NEW56Bernardo Dominic
1006Aruna S ShinkoFrance2024-04-18Printing Dimensions NEW27Asiya Javayant
1007Izzy R StensethJapan2024-04-23Truhlar And Truhlar Attys RENEWAL11Elwin Sharvill
1008Smith Y MarrierSpain2024-03-30Rangoni Of Florence NEGOTIATION26Elwin Sharvill
1009Jeanfrancois A WhobreyBrazil2024-04-22King, Christopher A Esq QUALIFIED61Stephen Shaw
1010Mayumi I PerinBrazil2024-04-05Benton, John B Jr PROPOSAL41Anna Fali
1011Claire Q NestleCanada2024-04-10Printing Dimensions PROPOSAL42Anna Fali
1012Deepesh D MarrierItaly2024-04-05Commercial Press NEW97Xuxue Feng
1013Maria G GlickJapan2024-04-26Chapman, Ross E Esq NEGOTIATION98Ivan Magalhaes
1014Jones L MaletArgentina2024-04-10Rangoni Of Florence RENEWAL21Xuxue Feng
1015Wickens W IturbideCanada2024-04-10Chanay, Jeffrey A Esq RENEWAL12Bernardo Dominic
1016Alejandro T BriddickIndia2024-04-01Dorl, James J Esq NEW18Asiya Javayant
1017Kaitlin Y SergiAustralia2024-04-06Chapman, Ross E Esq RENEWAL35Ivan Magalhaes
1018Jennifer T VenereRussia2024-04-19Truhlar And Truhlar Attys QUALIFIED62Asiya Javayant
1019Claire L BriddickArgentina2024-04-25Buckley Miller Wright QUALIFIED72Anna Fali
1020Emily W DilliardRussia2024-04-15Commercial Press NEGOTIATION71Amy Elsner
1021Izzy T AlbaresUnited Kingdom2024-04-01Dorl, James J Esq RENEWAL3Asiya Javayant
1022Juan N CaldareraFrance2024-04-22Commercial Press NEGOTIATION25Amy Elsner
1023Morrow V NestleSpain2024-04-12Chemel, James L Cpa NEGOTIATION22Ioni Bowcher
1024Nicolas S FerenczAustralia2024-04-08Morlong Associates NEW73Elwin Sharvill
1025Juan V MorascaSpain2024-04-08Dorl, James J Esq NEGOTIATION60Amy Elsner
1026Julie Y BowleyArgentina2024-04-09Chemel, James L Cpa QUALIFIED79Xuxue Feng
1027Chavez J WhobreyIndia2024-04-18Dorl, James J Esq RENEWAL43Anna Fali
1028Aika Q CaudyItaly2024-04-04Feltz Printing Service PROPOSAL68Asiya Javayant
1029Kaitlin F FerenczIndia2024-04-09Feiner Bros QUALIFIED37Amy Elsner
1030David U KolmetzSpain2024-04-05Chemel, James L Cpa UNQUALIFIED65Bernardo Dominic
1031Leon V DilliardJapan2024-04-27Truhlar And Truhlar Attys PROPOSAL65Onyama Limba
1032David S StensethGermany2024-04-08Morlong Associates RENEWAL32Elwin Sharvill
1033Ashley R FollerFrance2024-04-27Chemel, James L Cpa QUALIFIED18Amy Elsner
1034Jefferson F SlusarskiIndia2024-04-07Rangoni Of Florence RENEWAL0Anna Fali
1035Jennifer D NestleFrance2024-04-12Commercial Press RENEWAL96Asiya Javayant
1036Sinclair Q CaldareraJapan2024-03-29Commercial Press NEGOTIATION64Onyama Limba
1037Rodrigues B FerenczArgentina2024-04-08Feiner Bros UNQUALIFIED92Ioni Bowcher
1038David L BriddickJapan2024-04-21Dorl, James J Esq UNQUALIFIED44Onyama Limba
1039Nicolas K MorascaUnited Kingdom2024-04-12Rangoni Of Florence QUALIFIED49Bernardo Dominic
1040Deepesh A RutaBrazil2024-04-11Rousseaux, Michael Esq NEGOTIATION35Amy Elsner
1041Alejandro U ChuiBrazil2024-04-23Truhlar And Truhlar Attys QUALIFIED34Xuxue Feng
1042Mayumi X MacleadSpain2024-04-25Rousseaux, Michael Esq NEGOTIATION6Xuxue Feng
1043Ivar Y MaletRussia2024-03-31Chemel, James L Cpa RENEWAL7Stephen Shaw
1044Tony W FlosiItaly2024-04-15Printing Dimensions UNQUALIFIED68Stephen Shaw
1045Kaitlin M FollerGermany2024-04-17Rousseaux, Michael Esq NEGOTIATION84Anna Fali
1046Johnson L PoquetteIndia2024-04-23Printing Dimensions UNQUALIFIED33Ivan Magalhaes
1047Maisha T KolmetzFrance2024-04-15Rangoni Of Florence NEGOTIATION80Xuxue Feng
1048Claire M RoysterArgentina2024-04-25Truhlar And Truhlar Attys NEW21Xuxue Feng
1049Mujtaba A CaldareraItaly2024-04-10Benton, John B Jr UNQUALIFIED77Ioni Bowcher
Frozen Rows
NameCountryRepresentativeStatus
Mujtaba J SergiSpainIoni Bowcher UNQUALIFIED
Leja B SchemmerCanadaStephen Shaw RENEWAL
Aditya M InouyeCanadaAnna Fali QUALIFIED
Wickens T ShinkoSpainOnyama Limba UNQUALIFIED
Greenwood L KuskoAustraliaOnyama Limba RENEWAL
Misaki Y ShinkoIndiaXuxue Feng NEGOTIATION
Juan Z DarakjyCanadaIvan Magalhaes NEW
Arvin Q PoquetteFranceAnna Fali NEGOTIATION
Arvin I MorascaBrazilOnyama Limba PROPOSAL
Darci U AmigonCanadaAnna Fali PROPOSAL
Francesco Q StockhamGermanyAsiya Javayant NEW
Leja A NestleItalyIvan Magalhaes RENEWAL
Nicolas G PaprockiRussiaAsiya Javayant PROPOSAL
Faith Z BowleyArgentinaAmy Elsner NEW
Munro K DarakjyItalyOnyama Limba UNQUALIFIED
Kadeem U RimSpainAnna Fali NEGOTIATION
Greenwood F SchemmerJapanOnyama Limba UNQUALIFIED
Kaitlin Z DarakjyGermanyIoni Bowcher NEW
Aditya X DarakjyFranceElwin Sharvill RENEWAL
Tony U CaudyIndiaXuxue Feng NEW
Adams G BriddickCanadaElwin Sharvill PROPOSAL
Mujtaba Q GillianAustraliaBernardo Dominic NEGOTIATION
Morrow W BologniaRussiaElwin Sharvill PROPOSAL
Rodrigues S PaprockiAustraliaStephen Shaw RENEWAL
Deepesh I DoeIndiaAnna Fali QUALIFIED
Munro J BologniaIndiaElwin Sharvill RENEWAL
Nicolas W FollerSpainOnyama Limba QUALIFIED
Arvin Z VenereGermanyElwin Sharvill UNQUALIFIED
Rodrigues V StockhamAustraliaStephen Shaw NEGOTIATION
Chavez O PoquetteArgentinaIoni Bowcher RENEWAL
Deepesh Z FollerCanadaElwin Sharvill QUALIFIED
Munro L WieserRussiaStephen Shaw RENEWAL
Ashley D VenereJapanAmy Elsner NEW
Julie X CampainRussiaAnna Fali RENEWAL
Faith O PerinCanadaIvan Magalhaes NEW
Leja Y MaletFranceIvan Magalhaes RENEWAL
Ashley W MacleadItalyIoni Bowcher RENEWAL
Juan D KolmetzUnited KingdomElwin Sharvill QUALIFIED
Tony A ChuiRussiaBernardo Dominic PROPOSAL
Aika E ShinkoRussiaIvan Magalhaes UNQUALIFIED
Juan U GlickUnited KingdomElwin Sharvill RENEWAL
Tony A InouyeArgentinaOnyama Limba QUALIFIED
Mayumi V NickaUnited KingdomIoni Bowcher RENEWAL
Morrow H StensethAustraliaIoni Bowcher QUALIFIED
Mujtaba D BowleySpainXuxue Feng NEGOTIATION
Kadeem T SchemmerRussiaOnyama Limba PROPOSAL
David R BologniaJapanIoni Bowcher QUALIFIED
Izzy T KuskoItalyIoni Bowcher NEW
Clifford T OldroydItalyElwin Sharvill NEW
Faith P KuskoRussiaIvan Magalhaes UNQUALIFIED
Frozen Columns
Name
Leon M Caudy
Morrow U Malet
Jones W Marrier
Nicolas A Stenseth
Kadeem K Campain
Izzy E Royster
Jefferson C Kolmetz
Leon A Rim
Julie U Tollner
Kadeem W Malet
Chavez B Ostrosky
Jones L Schemmer
Cody V Waycott
Faith X Sergi
Adams T Poquette
Ivar M Wieser
Izzy B Briddick
Ashley M Rim
Johnson Q Gillian
Jefferson S Albares
Murillo A Stenseth
Adams E Figeroa
Deepesh M Ruta
Leon P Schemmer
Murillo K Iturbide
Costa D Stockham
Munro J Stenseth
Jones T Garufi
Silvio F Doe
Alejandro N Caldarera
Emily K Maclead
Juan B Glick
Ivar H Marrier
Mujtaba T Campain
Aika Z Poquette
James R Schemmer
Mujtaba C Sergi
Julie T Saylors
Adams O Iturbide
Morrow G Chui
Francesco L Venere
Stacey B Iturbide
Francesco P Paprocki
Cody U Inouye
Johnson M Ostrosky
Morrow Q Amigon
Rodrigues A Saylors
Salvatore V Rulapaugh
Salvatore H Bolognia
Morrow F Maclead
IdCountryDate
1000Spain2024-04-05
1001India2024-04-03
1002Russia2024-04-08
1003Russia2024-04-21
1004Germany2024-04-07
1005Russia2024-03-31
1006Spain2024-04-22
1007United Kingdom2024-03-30
1008Spain2024-04-20
1009France2024-03-29
1010France2024-04-15
1011Argentina2024-04-11
1012France2024-04-24
1013Australia2024-04-27
1014Japan2024-04-17
1015Japan2024-04-08
1016Argentina2024-04-07
1017France2024-04-22
1018France2024-04-10
1019Italy2024-04-16
1020United Kingdom2024-04-08
1021Spain2024-03-31
1022Argentina2024-04-01
1023India2024-04-26
1024Italy2024-04-16
1025India2024-04-24
1026Argentina2024-04-08
1027India2024-04-13
1028Brazil2024-03-29
1029Australia2024-04-07
1030Spain2024-04-04
1031Canada2024-04-27
1032Russia2024-04-01
1033United Kingdom2024-04-03
1034Germany2024-03-30
1035Brazil2024-04-05
1036Germany2024-04-27
1037Germany2024-04-16
1038India2024-04-03
1039Australia2024-04-26
1040India2024-04-11
1041Canada2024-04-13
1042Spain2024-04-19
1043Russia2024-04-18
1044Russia2024-04-10
1045Japan2024-04-20
1046France2024-04-02
1047Japan2024-04-19
1048Japan2024-04-21
1049Russia2024-04-08

On-Demand Data

NameIdCountryDate
Wickens W Doe1000Italy2024-04-22
Nicolas W Venere1001Japan2024-04-01
Izzy Z Gillian1002Australia2024-04-13
Wickens K Gaucho1003Spain2024-04-24
Mayumi B Darakjy1004Russia2024-04-07
Juan I Amigon1005France2024-04-27
Aika R Vocelka1006India2024-04-24
Maisha Z Glick1007Germany2024-04-15
Wickens Z Flosi1008Canada2024-04-03
Costa Z Morasca1009United Kingdom2024-04-23
Adams J Venere1010Italy2024-04-14
Salvatore Y Gaucho1011India2024-04-27
Jefferson Z Stockham1012Australia2024-04-16
Mayumi F Stockham1013Spain2024-04-06
Misaki J Briddick1014Argentina2024-04-06
Antonio W Nicka1015Russia2024-04-05
Munro Z Rim1016Argentina2024-04-19
Mayumi U Darakjy1017Brazil2024-03-30
Misaki C Bolognia1018Russia2024-04-11
Isabel H Campain1019United Kingdom2024-03-29
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aika C MaletRussiaXuxue Feng RENEWAL
Faith E GillianBrazilStephen Shaw QUALIFIED
Greenwood F SaylorsIndiaBernardo Dominic NEW
Jennifer O KuskoRussiaAnna Fali QUALIFIED
Juan G KuskoBrazilIoni Bowcher UNQUALIFIED
Clifford Y SlusarskiRussiaBernardo Dominic NEW
Alejandro F DilliardIndiaStephen Shaw PROPOSAL
Maisha H VenereSpainOnyama Limba NEGOTIATION
James T SergiGermanyAmy Elsner NEGOTIATION
Izzy T NickaFranceOnyama Limba PROPOSAL
Ivar N VenereGermanyXuxue Feng RENEWAL
Jennifer P DilliardItalyOnyama Limba RENEWAL
Antonio U BowleyGermanyXuxue Feng NEW
Tony Y WieserUnited KingdomAmy Elsner UNQUALIFIED
Aruna B KolmetzFranceIoni Bowcher PROPOSAL
Alejandro D SchemmerUnited KingdomIvan Magalhaes QUALIFIED
Adams V MorascaJapanElwin Sharvill NEGOTIATION
Tony L BologniaAustraliaStephen Shaw RENEWAL
Adams Q SchemmerIndiaOnyama Limba NEW
Maisha T BriddickGermanyIoni Bowcher PROPOSAL
Mujtaba U WaycottIndiaBernardo Dominic PROPOSAL
Ricardo O SlusarskiBrazilAnna Fali NEGOTIATION
Mujtaba Z WieserItalyStephen Shaw NEW
Stacey Z NickaArgentinaIvan Magalhaes NEGOTIATION
Clifford I FollerArgentinaAsiya Javayant PROPOSAL
Claire Z DarakjyRussiaIoni Bowcher PROPOSAL
Leon W PaprockiJapanElwin Sharvill RENEWAL
Wickens C GauchoGermanyIvan Magalhaes UNQUALIFIED
Darci V RoysterSpainIoni Bowcher QUALIFIED
Alejandro B TollnerGermanyXuxue Feng RENEWAL
Tony D StensethItalyIoni Bowcher PROPOSAL
Faith E PoquetteJapanBernardo Dominic UNQUALIFIED
Sinclair W CaudyGermanyBernardo Dominic NEGOTIATION
Wickens P IturbideRussiaAsiya Javayant NEGOTIATION
Ivar V PaprockiFranceIvan Magalhaes NEGOTIATION
Wickens O ChuiCanadaStephen Shaw RENEWAL
Faith O ButtRussiaBernardo Dominic PROPOSAL
Jennifer G KolmetzFranceElwin Sharvill PROPOSAL
Jennifer R KuskoGermanyXuxue Feng QUALIFIED
Stacey V VenereIndiaElwin Sharvill PROPOSAL

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