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
Jeanfrancois I SaylorsFranceAmy Elsner NEW
Adams S SergiRussiaBernardo Dominic NEGOTIATION
Aika K CaudyGermanyBernardo Dominic QUALIFIED
Tony Y CaldareraGermanyIoni Bowcher NEGOTIATION
Stacey S MarrierBrazilXuxue Feng PROPOSAL
Jefferson H CaldareraFranceXuxue Feng RENEWAL
Juan N KuskoFranceBernardo Dominic UNQUALIFIED
Rodrigues K AmigonFranceElwin Sharvill RENEWAL
Wickens E VenereAustraliaXuxue Feng NEW
Emily R KolmetzFranceIvan Magalhaes NEW
Rodrigues Q GarufiGermanyAnna Fali RENEWAL
Jefferson Q RutaIndiaBernardo Dominic NEGOTIATION
Johnson U RoysterIndiaIoni Bowcher UNQUALIFIED
Morrow Y WieserFranceOnyama Limba NEW
Isabel G RutaArgentinaXuxue Feng NEGOTIATION
Jennifer P CampainAustraliaBernardo Dominic QUALIFIED
Isabel L SaylorsBrazilOnyama Limba NEW
Deepesh L ButtArgentinaXuxue Feng UNQUALIFIED
Greenwood C TollnerRussiaAsiya Javayant PROPOSAL
Stacey V MarrierRussiaAmy Elsner RENEWAL
Munro X WaycottCanadaIoni Bowcher NEGOTIATION
Deepesh N MaletArgentinaBernardo Dominic NEGOTIATION
Ashley T RimRussiaAsiya Javayant NEW
Arvin V GarufiItalyAmy Elsner QUALIFIED
Aditya S NickaAustraliaStephen Shaw RENEWAL
Julie A PaprockiRussiaAmy Elsner NEW
Nicolas B IturbideSpainAnna Fali RENEWAL
David U VenereItalyAnna Fali NEW
Juan S WieserJapanIoni Bowcher QUALIFIED
Antonio F MaletIndiaXuxue Feng PROPOSAL
Jefferson E StockhamGermanyIvan Magalhaes QUALIFIED
Darci F MacleadBrazilIvan Magalhaes NEGOTIATION
Jennifer J StockhamItalyIvan Magalhaes NEW
Jefferson F MarrierGermanyStephen Shaw UNQUALIFIED
Antonio U SaylorsGermanyAmy Elsner NEGOTIATION
Murillo R WaycottBrazilAmy Elsner QUALIFIED
Leja A GillianAustraliaElwin Sharvill NEW
Faith S ChuiGermanyXuxue Feng RENEWAL
Johnson P RimFranceIoni Bowcher UNQUALIFIED
Kadeem L GauchoBrazilIoni Bowcher PROPOSAL
Misaki Z FollerUnited KingdomIoni Bowcher NEW
Arvin E GlickJapanBernardo Dominic RENEWAL
Aika X SergiUnited KingdomXuxue Feng QUALIFIED
Claire W PaprockiSpainIvan Magalhaes NEGOTIATION
Arvin C BriddickIndiaOnyama Limba QUALIFIED
Alejandro U StockhamIndiaOnyama Limba NEW
Maria W DilliardJapanXuxue Feng NEGOTIATION
Wickens Q MarrierBrazilElwin Sharvill NEW
Jennifer Z ShinkoGermanyElwin Sharvill NEW
Tony N ButtAustraliaAnna Fali NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Rodrigues Q SlusarskiFranceStephen Shaw UNQUALIFIED
Isabel C ShinkoFranceElwin Sharvill PROPOSAL
Alejandro W SaylorsFranceElwin Sharvill UNQUALIFIED
Octavia O FerenczBrazilIoni Bowcher PROPOSAL
Julie B BriddickFranceOnyama Limba QUALIFIED
Greenwood W OldroydBrazilStephen Shaw RENEWAL
Emily X MarrierCanadaStephen Shaw QUALIFIED
Ricardo U FigeroaFranceStephen Shaw PROPOSAL
Izzy J KolmetzArgentinaAmy Elsner QUALIFIED
Francesco D NickaSpainXuxue Feng NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Faith B DoeArgentina2024-04-16Buckley Miller Wright NEGOTIATION7Bernardo Dominic
1001Deepesh H PoquetteFrance2024-04-19Feltz Printing Service QUALIFIED35Elwin Sharvill
1002Wickens Y WhobreyRussia2024-04-06Chapman, Ross E Esq NEGOTIATION9Bernardo Dominic
1003Chavez I InouyeJapan2024-04-23Commercial Press NEW97Onyama Limba
1004Tony P MacleadCanada2024-04-12Printing Dimensions RENEWAL63Onyama Limba
1005Cody K TollnerItaly2024-04-29Commercial Press UNQUALIFIED86Stephen Shaw
1006Julie K SaylorsArgentina2024-05-01King, Christopher A Esq UNQUALIFIED61Anna Fali
1007Morrow X TollnerGermany2024-04-29Buckley Miller Wright RENEWAL61Ivan Magalhaes
1008Morrow O TollnerArgentina2024-05-03Truhlar And Truhlar Attys NEW64Stephen Shaw
1009Darci T FollerIndia2024-04-04Rangoni Of Florence PROPOSAL22Ivan Magalhaes
1010Nicolas N KolmetzUnited Kingdom2024-04-26Benton, John B Jr NEW84Elwin Sharvill
1011Smith B StockhamCanada2024-04-25Dorl, James J Esq NEW27Amy Elsner
1012Aruna O VenereBrazil2024-04-23Chemel, James L Cpa NEW31Amy Elsner
1013Antonio C PerinIndia2024-04-06Dorl, James J Esq QUALIFIED96Elwin Sharvill
1014Juan R PaprockiItaly2024-04-19Chanay, Jeffrey A Esq RENEWAL14Asiya Javayant
1015Chavez Y MarrierFrance2024-04-04Rangoni Of Florence QUALIFIED24Anna Fali
1016Faith K DoeBrazil2024-04-10Rangoni Of Florence NEGOTIATION82Ioni Bowcher
1017James I DarakjyUnited Kingdom2024-05-01Chapman, Ross E Esq NEGOTIATION66Elwin Sharvill
1018Rodrigues I PoquetteBrazil2024-04-24Truhlar And Truhlar Attys QUALIFIED48Amy Elsner
1019Leon D PerinRussia2024-04-12Morlong Associates NEW93Onyama Limba
1020Mayumi I RulapaughJapan2024-04-13Rangoni Of Florence UNQUALIFIED98Ioni Bowcher
1021Jones C FerenczFrance2024-04-23Rangoni Of Florence PROPOSAL52Ivan Magalhaes
1022Darci N OldroydRussia2024-04-06Morlong Associates PROPOSAL8Amy Elsner
1023Izzy C BriddickArgentina2024-04-27King, Christopher A Esq NEW30Anna Fali
1024Kaitlin G FlosiArgentina2024-04-13Dorl, James J Esq NEGOTIATION60Asiya Javayant
1025Alejandro Y BriddickJapan2024-04-14Commercial Press QUALIFIED63Bernardo Dominic
1026Silvio B StensethItaly2024-04-09Dorl, James J Esq PROPOSAL36Elwin Sharvill
1027Maria G IturbideFrance2024-04-12Benton, John B Jr RENEWAL22Ioni Bowcher
1028Maisha F WhobreyJapan2024-04-04Chemel, James L Cpa QUALIFIED84Anna Fali
1029Jones S BologniaBrazil2024-04-25King, Christopher A Esq UNQUALIFIED63Xuxue Feng
1030David Z OstroskyCanada2024-04-21Rangoni Of Florence PROPOSAL26Bernardo Dominic
1031Chavez Z PoquetteFrance2024-04-11Rangoni Of Florence PROPOSAL65Amy Elsner
1032Mujtaba A CampainRussia2024-04-25Printing Dimensions RENEWAL54Onyama Limba
1033Emily Z CaldareraArgentina2024-04-19Chapman, Ross E Esq NEW31Xuxue Feng
1034Johnson B OldroydGermany2024-04-09Buckley Miller Wright NEGOTIATION8Ivan Magalhaes
1035Kadeem Z FerenczBrazil2024-04-10Rangoni Of Florence NEW62Asiya Javayant
1036Wickens Y OldroydItaly2024-04-21Feiner Bros PROPOSAL77Ivan Magalhaes
1037Cody L GlickArgentina2024-04-18Commercial Press NEGOTIATION71Onyama Limba
1038Johnson J PaprockiItaly2024-04-22Dorl, James J Esq NEGOTIATION1Elwin Sharvill
1039Rodrigues Z BowleyJapan2024-04-27Printing Dimensions NEW73Ioni Bowcher
1040Adams L FlosiItaly2024-04-23Morlong Associates UNQUALIFIED54Ivan Magalhaes
1041Octavia C MarrierAustralia2024-04-24Rousseaux, Michael Esq RENEWAL38Amy Elsner
1042Misaki A FlosiBrazil2024-04-29Morlong Associates NEGOTIATION81Asiya Javayant
1043Munro L RoysterSpain2024-04-10Chanay, Jeffrey A Esq QUALIFIED28Ivan Magalhaes
1044Antonio E FollerRussia2024-04-20Chanay, Jeffrey A Esq UNQUALIFIED48Amy Elsner
1045Sinclair I GarufiItaly2024-05-02Dorl, James J Esq NEGOTIATION47Onyama Limba
1046Maisha Q WaycottJapan2024-04-22Commercial Press UNQUALIFIED68Ioni Bowcher
1047Greenwood O DoeBrazil2024-04-18Dorl, James J Esq UNQUALIFIED17Stephen Shaw
1048Johnson Q SlusarskiJapan2024-04-04Buckley Miller Wright NEGOTIATION93Onyama Limba
1049Darci A MorascaAustralia2024-04-19Chanay, Jeffrey A Esq UNQUALIFIED48Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Kadeem C FollerUnited KingdomOnyama Limba NEGOTIATION
Aditya X DilliardBrazilStephen Shaw PROPOSAL
Maisha E RulapaughArgentinaElwin Sharvill UNQUALIFIED
Wickens W DarakjySpainIvan Magalhaes RENEWAL
Clifford P RimItalyIoni Bowcher NEW
Sinclair R NickaArgentinaBernardo Dominic NEW
Julie M WhobreyJapanAnna Fali PROPOSAL
Sinclair Y OldroydCanadaIvan Magalhaes UNQUALIFIED
Kaitlin B OldroydJapanIvan Magalhaes PROPOSAL
Kaitlin W WieserRussiaAnna Fali NEGOTIATION
Ashley J SergiGermanyStephen Shaw PROPOSAL
Jefferson L InouyeRussiaXuxue Feng RENEWAL
Alejandro T SergiCanadaElwin Sharvill PROPOSAL
Leja T DilliardBrazilAmy Elsner NEW
Claire T MaletCanadaAnna Fali UNQUALIFIED
Ricardo M ChuiCanadaAsiya Javayant NEW
Francesco I SaylorsAustraliaAmy Elsner UNQUALIFIED
Maisha I FlosiArgentinaAmy Elsner RENEWAL
Mayumi L MacleadBrazilAnna Fali NEGOTIATION
Nicolas E MacleadIndiaAsiya Javayant RENEWAL
Tony Q DarakjyGermanyAsiya Javayant NEGOTIATION
Leon H InouyeCanadaIvan Magalhaes RENEWAL
Jefferson A InouyeRussiaIoni Bowcher PROPOSAL
Smith R MacleadIndiaBernardo Dominic NEGOTIATION
Darci Z MarrierAustraliaIvan Magalhaes PROPOSAL
Costa A IturbideGermanyOnyama Limba PROPOSAL
Mujtaba D DarakjyCanadaIoni Bowcher UNQUALIFIED
Ivar M FigeroaCanadaIvan Magalhaes NEW
Leon J WaycottIndiaBernardo Dominic PROPOSAL
Kaitlin T DarakjyRussiaOnyama Limba NEGOTIATION
Mayumi M RoysterArgentinaXuxue Feng NEGOTIATION
Alejandro L OldroydJapanXuxue Feng NEGOTIATION
Salvatore H IturbideAustraliaAmy Elsner UNQUALIFIED
David E DoeBrazilElwin Sharvill QUALIFIED
Rodrigues G RutaUnited KingdomAsiya Javayant NEGOTIATION
Wickens F VenereRussiaBernardo Dominic NEGOTIATION
Darci Y StensethCanadaIoni Bowcher NEGOTIATION
Maisha F RoysterGermanyStephen Shaw UNQUALIFIED
Alejandro U GillianSpainAmy Elsner RENEWAL
Mujtaba A MacleadItalyIvan Magalhaes NEW
Ricardo Q GarufiArgentinaXuxue Feng QUALIFIED
Izzy N GillianIndiaAsiya Javayant QUALIFIED
Octavia N FerenczFranceIvan Magalhaes QUALIFIED
Jennifer L GillianSpainElwin Sharvill QUALIFIED
Aika Q MarrierRussiaAnna Fali NEGOTIATION
Smith U RulapaughSpainStephen Shaw UNQUALIFIED
Wickens G NickaSpainAnna Fali PROPOSAL
Mujtaba E ChuiRussiaStephen Shaw PROPOSAL
Darci U TollnerGermanyOnyama Limba RENEWAL
Nicolas V ButtArgentinaXuxue Feng RENEWAL
Frozen Columns
Name
Tony M Schemmer
Smith R Ruta
Salvatore D Foller
Chavez T Albares
David I Foller
Salvatore L Campain
Smith L Butt
Greenwood D Stockham
Maisha Q Flosi
Jeanfrancois G Stockham
Maria K Iturbide
Morrow A Chui
Deepesh N Foller
Silvio T Saylors
Leja W Slusarski
Julie D Amigon
Johnson X Gaucho
Murillo W Chui
Izzy L Inouye
Ricardo M Schemmer
Mujtaba N Briddick
Jennifer S Maclead
Isabel V Marrier
Alejandro I Glick
Clifford K Kolmetz
Aruna O Garufi
Aruna Q Stenseth
Misaki A Ruta
Morrow D Waycott
Smith O Stenseth
David U Bolognia
James K Doe
Salvatore T Bolognia
Leja Z Maclead
James Z Foller
Isabel E Inouye
Jones V Schemmer
Johnson T Paprocki
Costa T Campain
Greenwood D Perin
Aruna N Ostrosky
Jeanfrancois D Amigon
Juan T Doe
Leon G Garufi
Claire O Poquette
Jefferson R Stenseth
Munro L Campain
Jones G Gillian
Jones F Garufi
Francesco I Venere
IdCountryDate
1000Russia2024-04-11
1001Argentina2024-04-07
1002Canada2024-04-25
1003Spain2024-04-22
1004Germany2024-04-13
1005Germany2024-04-05
1006Spain2024-04-14
1007France2024-05-03
1008Spain2024-04-07
1009Australia2024-04-05
1010Canada2024-04-13
1011Japan2024-04-30
1012Australia2024-04-17
1013Italy2024-04-12
1014Japan2024-04-21
1015Canada2024-04-05
1016Germany2024-04-17
1017Argentina2024-04-11
1018Russia2024-04-13
1019Australia2024-04-15
1020Japan2024-05-03
1021United Kingdom2024-04-16
1022Italy2024-04-09
1023Germany2024-04-05
1024Japan2024-04-09
1025India2024-04-16
1026Canada2024-04-07
1027Russia2024-05-02
1028Germany2024-04-11
1029India2024-04-05
1030Spain2024-04-21
1031Brazil2024-04-20
1032Argentina2024-04-16
1033Argentina2024-04-11
1034Argentina2024-04-21
1035Russia2024-05-03
1036Brazil2024-04-29
1037Germany2024-04-28
1038France2024-04-11
1039Italy2024-04-21
1040Spain2024-04-30
1041France2024-04-30
1042Spain2024-04-29
1043Canada2024-04-22
1044Argentina2024-04-19
1045Italy2024-04-24
1046Spain2024-04-18
1047France2024-04-18
1048Italy2024-05-02
1049Canada2024-04-26

On-Demand Data

NameIdCountryDate
Kaitlin K Venere1000Germany2024-04-16
Morrow K Figeroa1001India2024-05-01
Costa F Venere1002Italy2024-04-14
Maria G Inouye1003Brazil2024-04-19
Ricardo W Malet1004France2024-04-08
Mayumi Q Schemmer1005Japan2024-04-10
Alejandro O Nestle1006Australia2024-04-20
Johnson O Caldarera1007Canada2024-04-14
Chavez A Caldarera1008France2024-04-09
Claire T Foller1009Spain2024-04-29
Rodrigues Z Paprocki1010Australia2024-04-29
Greenwood K Gillian1011Australia2024-04-15
Leja B Malet1012Germany2024-04-24
Wickens L Whobrey1013United Kingdom2024-04-12
Aditya H Nicka1014Brazil2024-04-24
Johnson L Ferencz1015France2024-04-22
Jefferson M Briddick1016Brazil2024-05-01
Antonio F Perin1017Germany2024-04-20
Maria K Caldarera1018Canada2024-04-19
Chavez L Marrier1019Italy2024-04-05
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Chavez M DoeFranceElwin Sharvill PROPOSAL
Ashley A AlbaresUnited KingdomIvan Magalhaes QUALIFIED
Murillo K WieserItalyXuxue Feng NEGOTIATION
Julie L KuskoArgentinaStephen Shaw RENEWAL
Arvin O SergiRussiaIoni Bowcher RENEWAL
Deepesh W WieserAustraliaAsiya Javayant RENEWAL
Emily P VenereUnited KingdomOnyama Limba QUALIFIED
Jennifer V WaycottFranceBernardo Dominic QUALIFIED
Kaitlin H KuskoCanadaAmy Elsner NEW
Misaki C RutaArgentinaElwin Sharvill UNQUALIFIED
Deepesh Q RimGermanyOnyama Limba QUALIFIED
Francesco X WieserJapanBernardo Dominic NEGOTIATION
Stacey Q RutaGermanyIvan Magalhaes NEW
Claire E WaycottFranceXuxue Feng NEW
Maria I SaylorsJapanAnna Fali RENEWAL
Nicolas A RoysterCanadaIoni Bowcher UNQUALIFIED
Ashley A InouyeJapanIoni Bowcher NEGOTIATION
Alejandro Z AlbaresRussiaAnna Fali NEW
Mujtaba L GarufiItalyStephen Shaw RENEWAL
Maisha X MarrierUnited KingdomXuxue Feng QUALIFIED
Tony A InouyeArgentinaIoni Bowcher NEW
Deepesh C GlickFranceElwin Sharvill PROPOSAL
Jones T PaprockiRussiaOnyama Limba RENEWAL
Smith T FollerCanadaIvan Magalhaes NEW
Leon M SlusarskiFranceOnyama Limba NEW
Isabel Q MacleadItalyAmy Elsner RENEWAL
Izzy G WaycottGermanyAmy Elsner QUALIFIED
Juan G KolmetzCanadaIoni Bowcher NEGOTIATION
Cody G GillianBrazilXuxue Feng RENEWAL
Adams G FigeroaRussiaOnyama Limba PROPOSAL
Nicolas R RutaRussiaAsiya Javayant UNQUALIFIED
Deepesh L RimSpainElwin Sharvill NEW
Greenwood Q ButtSpainBernardo Dominic QUALIFIED
Chavez T FerenczItalyIvan Magalhaes PROPOSAL
Darci A IturbideCanadaStephen Shaw PROPOSAL
Mujtaba I StensethUnited KingdomOnyama Limba NEW
Johnson T WhobreyItalyIvan Magalhaes RENEWAL
Claire R TollnerIndiaIvan Magalhaes UNQUALIFIED
Jennifer Q CaudyJapanAmy Elsner UNQUALIFIED
Izzy M RutaBrazilElwin Sharvill RENEWAL

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