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
Aditya P RoysterJapanAsiya Javayant NEGOTIATION
Claire S MarrierSpainAmy Elsner NEGOTIATION
Clifford X RulapaughIndiaOnyama Limba RENEWAL
Ricardo S MarrierIndiaAsiya Javayant NEW
Deepesh W RoysterCanadaXuxue Feng NEW
Julie F PerinAustraliaIoni Bowcher NEW
Adams S RimBrazilBernardo Dominic NEGOTIATION
Claire N BowleyAustraliaXuxue Feng NEW
Izzy L SaylorsFranceIoni Bowcher PROPOSAL
Darci R RulapaughGermanyIvan Magalhaes RENEWAL
Morrow S WaycottIndiaElwin Sharvill UNQUALIFIED
Ricardo L OstroskyItalyAnna Fali QUALIFIED
Deepesh I ButtJapanStephen Shaw RENEWAL
Chavez M GillianSpainElwin Sharvill UNQUALIFIED
Maria E DoeCanadaOnyama Limba UNQUALIFIED
Arvin R CaudyIndiaBernardo Dominic PROPOSAL
Leja F NickaAustraliaStephen Shaw NEGOTIATION
Smith H OstroskyBrazilStephen Shaw RENEWAL
James W BriddickItalyIvan Magalhaes UNQUALIFIED
Aruna Y PoquetteArgentinaAmy Elsner NEW
Tony D SaylorsFranceIvan Magalhaes RENEWAL
Jefferson T AlbaresBrazilOnyama Limba NEGOTIATION
Deepesh H PoquetteArgentinaAmy Elsner RENEWAL
Greenwood Q WhobreyIndiaAsiya Javayant PROPOSAL
Antonio P NickaCanadaBernardo Dominic NEW
Alejandro N StensethItalyIvan Magalhaes RENEWAL
Costa U MacleadBrazilAsiya Javayant UNQUALIFIED
Kadeem A NickaFranceAnna Fali NEW
Julie K RutaRussiaAsiya Javayant NEW
Cody M NickaSpainAmy Elsner RENEWAL
Isabel D StockhamIndiaStephen Shaw NEGOTIATION
Clifford A ShinkoSpainAsiya Javayant RENEWAL
Rodrigues E OstroskyArgentinaIvan Magalhaes PROPOSAL
Aruna U RoysterGermanyAsiya Javayant RENEWAL
Rodrigues H WaycottArgentinaAnna Fali QUALIFIED
Nicolas C DilliardFranceElwin Sharvill NEW
Maisha V PerinSpainOnyama Limba RENEWAL
Morrow C GillianSpainAmy Elsner NEW
Aruna B RimItalyIoni Bowcher UNQUALIFIED
Costa L SlusarskiAustraliaAsiya Javayant PROPOSAL
Maisha H SlusarskiAustraliaXuxue Feng NEGOTIATION
Juan X PaprockiIndiaAnna Fali NEW
Jones D MacleadItalyXuxue Feng PROPOSAL
Aditya O SlusarskiArgentinaOnyama Limba QUALIFIED
Julie N BologniaAustraliaXuxue Feng RENEWAL
Kadeem J AlbaresFranceOnyama Limba UNQUALIFIED
Jennifer P MaletUnited KingdomAsiya Javayant NEW
Juan V NestleAustraliaBernardo Dominic PROPOSAL
Costa B KuskoIndiaAsiya Javayant QUALIFIED
Alejandro N RoysterGermanyAnna Fali NEW
Horizontal
NameCountryRepresentativeStatus
Ashley B AlbaresIndiaAsiya Javayant RENEWAL
Arvin T AmigonBrazilXuxue Feng NEGOTIATION
Clifford Z CaudyGermanyElwin Sharvill UNQUALIFIED
Jeanfrancois Z AmigonRussiaBernardo Dominic QUALIFIED
Isabel I CampainCanadaAsiya Javayant NEGOTIATION
Munro I ShinkoIndiaAnna Fali QUALIFIED
Deepesh P DoeUnited KingdomOnyama Limba RENEWAL
Smith K OstroskySpainOnyama Limba RENEWAL
James N FerenczArgentinaBernardo Dominic UNQUALIFIED
Faith V SchemmerArgentinaIvan Magalhaes QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Ivar P MaletJapan2024-04-12Commercial Press QUALIFIED88Amy Elsner
1001Smith Y StockhamBrazil2024-04-22Chapman, Ross E Esq PROPOSAL10Xuxue Feng
1002Misaki T SchemmerFrance2024-03-29Commercial Press QUALIFIED45Onyama Limba
1003Kaitlin I MarrierJapan2024-04-06Commercial Press RENEWAL5Elwin Sharvill
1004Jennifer Y FerenczUnited Kingdom2024-04-04Rangoni Of Florence PROPOSAL39Anna Fali
1005Claire X TollnerBrazil2024-04-10Feltz Printing Service PROPOSAL34Anna Fali
1006Claire N SergiJapan2024-04-10Commercial Press QUALIFIED32Elwin Sharvill
1007Claire G BologniaGermany2024-04-18Chemel, James L Cpa QUALIFIED48Amy Elsner
1008Arvin E SergiUnited Kingdom2024-04-13Morlong Associates NEGOTIATION75Bernardo Dominic
1009Darci D VocelkaCanada2024-04-20Benton, John B Jr NEGOTIATION37Bernardo Dominic
1010Johnson Z MacleadAustralia2024-04-12Printing Dimensions RENEWAL23Asiya Javayant
1011Francesco V MorascaBrazil2024-04-23Chapman, Ross E Esq RENEWAL89Elwin Sharvill
1012Clifford W BriddickUnited Kingdom2024-04-04Rousseaux, Michael Esq RENEWAL55Xuxue Feng
1013Jones E NickaFrance2024-04-26Rangoni Of Florence NEW88Onyama Limba
1014Greenwood N SaylorsSpain2024-04-16Printing Dimensions NEGOTIATION94Bernardo Dominic
1015Nicolas G FlosiArgentina2024-04-18Chemel, James L Cpa QUALIFIED89Ioni Bowcher
1016Leon X NestleJapan2024-04-08Morlong Associates QUALIFIED63Stephen Shaw
1017Stacey K MaletRussia2024-04-21Commercial Press RENEWAL23Anna Fali
1018Mujtaba T VenereGermany2024-04-07Buckley Miller Wright PROPOSAL23Bernardo Dominic
1019Arvin K WieserCanada2024-04-15Printing Dimensions RENEWAL51Anna Fali
1020Julie J MorascaUnited Kingdom2024-04-23Rousseaux, Michael Esq NEGOTIATION87Ivan Magalhaes
1021Alejandro X MorascaGermany2024-04-03Commercial Press UNQUALIFIED18Ioni Bowcher
1022Faith G BowleyBrazil2024-04-13Rousseaux, Michael Esq QUALIFIED53Onyama Limba
1023Rodrigues I SlusarskiArgentina2024-04-03Feiner Bros QUALIFIED65Onyama Limba
1024Francesco X NickaRussia2024-04-08Benton, John B Jr PROPOSAL88Anna Fali
1025Adams G ShinkoAustralia2024-03-29Buckley Miller Wright RENEWAL43Bernardo Dominic
1026Ashley O BriddickSpain2024-04-16Feiner Bros QUALIFIED4Bernardo Dominic
1027Izzy F WieserItaly2024-04-09Rangoni Of Florence RENEWAL55Onyama Limba
1028Misaki D CaudyFrance2024-04-14Chemel, James L Cpa UNQUALIFIED88Bernardo Dominic
1029Alejandro Y CaldareraCanada2024-04-01Morlong Associates NEW21Anna Fali
1030Mujtaba G SchemmerAustralia2024-04-24Chapman, Ross E Esq NEGOTIATION36Bernardo Dominic
1031Alejandro A InouyeJapan2024-04-21Printing Dimensions PROPOSAL57Xuxue Feng
1032Maria A IturbideAustralia2024-04-10Morlong Associates NEW23Ivan Magalhaes
1033Leon T RoysterGermany2024-04-10Chemel, James L Cpa QUALIFIED88Amy Elsner
1034Jones T StensethBrazil2024-04-04Benton, John B Jr RENEWAL47Amy Elsner
1035Costa U NickaSpain2024-04-03Morlong Associates RENEWAL99Onyama Limba
1036David L CampainArgentina2024-04-07Chanay, Jeffrey A Esq NEGOTIATION54Amy Elsner
1037Silvio S KolmetzArgentina2024-04-10Morlong Associates UNQUALIFIED79Ioni Bowcher
1038Wickens R FigeroaBrazil2024-04-11Chapman, Ross E Esq NEGOTIATION27Bernardo Dominic
1039Izzy Y BowleyFrance2024-04-13Dorl, James J Esq NEW44Xuxue Feng
1040Greenwood B MorascaBrazil2024-04-19Chapman, Ross E Esq NEW57Ioni Bowcher
1041Chavez N StensethGermany2024-04-06Chanay, Jeffrey A Esq PROPOSAL99Stephen Shaw
1042Aruna X OldroydItaly2024-03-29Dorl, James J Esq QUALIFIED84Onyama Limba
1043Darci M VocelkaGermany2024-04-21Morlong Associates NEGOTIATION13Onyama Limba
1044Leja D MacleadGermany2024-04-11Buckley Miller Wright RENEWAL4Xuxue Feng
1045Chavez J KolmetzJapan2024-04-18Chanay, Jeffrey A Esq PROPOSAL67Elwin Sharvill
1046Leja C GauchoGermany2024-04-11Truhlar And Truhlar Attys RENEWAL68Bernardo Dominic
1047Octavia A GarufiBrazil2024-03-31Feiner Bros NEW34Xuxue Feng
1048Jefferson Y VocelkaCanada2024-04-11Chapman, Ross E Esq PROPOSAL15Ioni Bowcher
1049Morrow V DarakjyAustralia2024-04-11Rousseaux, Michael Esq NEGOTIATION53Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Morrow C StensethUnited KingdomAnna Fali RENEWAL
Tony Y FollerCanadaAnna Fali PROPOSAL
Cody Z RimItalyStephen Shaw UNQUALIFIED
Aditya G StockhamSpainStephen Shaw RENEWAL
Adams D BologniaIndiaXuxue Feng NEGOTIATION
Mujtaba S RoysterUnited KingdomIoni Bowcher QUALIFIED
Silvio J StensethCanadaStephen Shaw NEW
Francesco E MaletAustraliaAnna Fali PROPOSAL
Misaki R SchemmerArgentinaAmy Elsner QUALIFIED
Isabel Q MaletItalyOnyama Limba QUALIFIED
Faith A MacleadCanadaIvan Magalhaes NEGOTIATION
Morrow O RoysterAustraliaOnyama Limba QUALIFIED
Wickens E MacleadFranceIvan Magalhaes UNQUALIFIED
Cody N DoeArgentinaBernardo Dominic NEW
Kaitlin Q GarufiGermanyStephen Shaw PROPOSAL
Greenwood Q RutaFranceXuxue Feng NEGOTIATION
Leja D PerinIndiaStephen Shaw NEW
Kadeem V AlbaresCanadaIvan Magalhaes QUALIFIED
Mujtaba I BologniaGermanyAsiya Javayant RENEWAL
Nicolas I InouyeRussiaAsiya Javayant NEW
James R SaylorsUnited KingdomIoni Bowcher NEW
Rodrigues V WhobreyItalyAnna Fali NEW
Tony A SaylorsJapanXuxue Feng QUALIFIED
Salvatore O BologniaIndiaOnyama Limba UNQUALIFIED
Munro A ShinkoArgentinaBernardo Dominic NEW
Jefferson T SaylorsRussiaAmy Elsner RENEWAL
Morrow T SlusarskiFranceAsiya Javayant QUALIFIED
Darci N NestleSpainElwin Sharvill QUALIFIED
Mujtaba T MaletAustraliaElwin Sharvill PROPOSAL
Cody M SlusarskiFranceXuxue Feng NEGOTIATION
Salvatore I MaletAustraliaAnna Fali UNQUALIFIED
Jennifer K PerinRussiaIvan Magalhaes QUALIFIED
Darci Y ButtItalyIoni Bowcher RENEWAL
Johnson E MarrierItalyAnna Fali QUALIFIED
Izzy Z SaylorsArgentinaIvan Magalhaes QUALIFIED
Antonio O CampainSpainOnyama Limba QUALIFIED
Darci C RutaFranceBernardo Dominic NEW
Arvin G RimItalyXuxue Feng UNQUALIFIED
Antonio C WaycottArgentinaAmy Elsner NEGOTIATION
Emily Q SergiAustraliaIoni Bowcher PROPOSAL
Salvatore Y IturbideBrazilAnna Fali UNQUALIFIED
Alejandro L ShinkoCanadaBernardo Dominic NEW
Faith Y RimUnited KingdomXuxue Feng NEGOTIATION
Arvin A RulapaughGermanyXuxue Feng NEGOTIATION
Ricardo C PoquetteRussiaOnyama Limba NEGOTIATION
Smith R DarakjySpainAmy Elsner NEW
Antonio L DilliardBrazilAnna Fali QUALIFIED
Jefferson T VocelkaArgentinaBernardo Dominic NEGOTIATION
Maria E MaletArgentinaOnyama Limba NEW
Johnson N StensethUnited KingdomAmy Elsner RENEWAL
Frozen Columns
Name
Wickens E Vocelka
Chavez V Morasca
Murillo K Ostrosky
Jeanfrancois E Saylors
Salvatore I Kolmetz
Smith O Dilliard
Sinclair A Caldarera
Kadeem W Schemmer
Darci X Schemmer
Isabel C Perin
Antonio K Malet
Sinclair Y Nicka
Tony U Maclead
Aditya J Doe
Murillo T Iturbide
Kadeem I Glick
Jennifer F Foller
Ashley N Inouye
Morrow X Darakjy
Mujtaba L Vocelka
Wickens S Ferencz
Mayumi O Bolognia
Leja B Slusarski
Munro J Bowley
Izzy B Royster
Leon I Figeroa
Juan W Waycott
Chavez X Stockham
Tony C Butt
Ricardo E Rim
Johnson F Amigon
Jennifer F Gaucho
Izzy A Gillian
Kadeem Y Paprocki
Murillo U Stockham
Isabel A Stockham
Octavia U Darakjy
Johnson D Marrier
Greenwood P Campain
Tony T Rim
Kaitlin Q Darakjy
Jones A Butt
Jones H Shinko
Aruna Z Ruta
Mujtaba U Wieser
Ashley V Kusko
Morrow J Campain
Jeanfrancois L Nicka
Mujtaba V Briddick
Leja Q Inouye
IdCountryDate
1000Argentina2024-04-19
1001United Kingdom2024-04-03
1002Brazil2024-04-23
1003Russia2024-03-28
1004Spain2024-04-08
1005Canada2024-04-23
1006Italy2024-04-06
1007Canada2024-04-22
1008Brazil2024-04-15
1009Russia2024-04-22
1010United Kingdom2024-04-19
1011Argentina2024-04-20
1012Japan2024-04-14
1013France2024-03-31
1014United Kingdom2024-04-26
1015United Kingdom2024-03-29
1016Argentina2024-04-12
1017Italy2024-04-20
1018Italy2024-04-26
1019Italy2024-04-13
1020India2024-04-25
1021United Kingdom2024-04-16
1022Canada2024-04-14
1023Canada2024-04-15
1024Spain2024-04-22
1025Russia2024-04-04
1026Russia2024-04-17
1027France2024-04-21
1028United Kingdom2024-04-06
1029Germany2024-04-16
1030Canada2024-04-02
1031India2024-04-14
1032United Kingdom2024-04-07
1033Italy2024-04-06
1034Spain2024-04-22
1035France2024-04-01
1036Spain2024-03-31
1037India2024-04-15
1038Japan2024-03-29
1039Italy2024-04-09
1040India2024-04-05
1041Australia2024-04-22
1042France2024-04-11
1043Russia2024-04-10
1044India2024-04-03
1045Germany2024-04-14
1046Canada2024-04-22
1047Spain2024-04-04
1048Spain2024-04-17
1049Australia2024-04-02

On-Demand Data

NameIdCountryDate
Morrow K Gillian1000Australia2024-04-01
Maisha C Morasca1001Spain2024-04-10
Antonio S Gillian1002Japan2024-04-10
Chavez C Butt1003Russia2024-03-31
Silvio C Bolognia1004United Kingdom2024-03-29
Faith B Inouye1005France2024-03-29
James V Perin1006Japan2024-04-05
Tony G Amigon1007Germany2024-03-30
Smith U Perin1008Argentina2024-03-28
Jeanfrancois N Nicka1009Canada2024-04-18
Mayumi X Glick1010Russia2024-04-20
Jones X Campain1011Italy2024-04-03
Deepesh Z Stenseth1012United Kingdom2024-04-06
Costa P Bolognia1013United Kingdom2024-04-08
Jennifer H Garufi1014Brazil2024-04-18
Salvatore D Briddick1015France2024-03-30
Jeanfrancois C Caldarera1016Canada2024-04-05
Smith Y Whobrey1017Spain2024-04-23
Aruna L Gaucho1018Canada2024-04-24
Deepesh R Saylors1019Japan2024-04-15
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Adams N GauchoBrazilIoni Bowcher QUALIFIED
Aika O BologniaArgentinaElwin Sharvill UNQUALIFIED
Misaki K MaletBrazilOnyama Limba NEW
Arvin O FigeroaIndiaStephen Shaw UNQUALIFIED
Aika H RutaSpainStephen Shaw RENEWAL
Octavia F FollerIndiaIoni Bowcher NEW
Smith M RoysterGermanyIvan Magalhaes NEW
Octavia X MacleadBrazilIvan Magalhaes PROPOSAL
Tony Z BriddickFranceIoni Bowcher PROPOSAL
Aika A RulapaughArgentinaAmy Elsner RENEWAL
Johnson B NickaBrazilAsiya Javayant PROPOSAL
Jones H BologniaItalyXuxue Feng NEGOTIATION
Octavia B MaletUnited KingdomAmy Elsner PROPOSAL
Julie P RoysterArgentinaXuxue Feng NEGOTIATION
Sinclair N PoquetteCanadaOnyama Limba NEW
Clifford S PerinFranceAsiya Javayant QUALIFIED
Leon V MarrierCanadaAnna Fali RENEWAL
Greenwood G MaletBrazilXuxue Feng QUALIFIED
David F RulapaughIndiaXuxue Feng QUALIFIED
James A CaldareraAustraliaOnyama Limba PROPOSAL
Arvin K RutaUnited KingdomBernardo Dominic NEGOTIATION
Rodrigues V ButtBrazilOnyama Limba NEGOTIATION
David D SaylorsItalyStephen Shaw NEGOTIATION
Deepesh Y RoysterSpainIvan Magalhaes UNQUALIFIED
Munro L TollnerIndiaAnna Fali RENEWAL
Juan C MorascaSpainStephen Shaw NEW
Jefferson O GauchoAustraliaIvan Magalhaes UNQUALIFIED
Smith V GillianJapanXuxue Feng RENEWAL
Kaitlin X BowleyJapanStephen Shaw NEW
Julie A IturbideSpainAmy Elsner NEW
Costa I WaycottBrazilIvan Magalhaes NEGOTIATION
Kadeem F NestleGermanyIoni Bowcher RENEWAL
Juan L KuskoRussiaXuxue Feng PROPOSAL
Mujtaba L AlbaresGermanyStephen Shaw UNQUALIFIED
Izzy S FigeroaFranceIvan Magalhaes PROPOSAL
Kadeem D PerinJapanOnyama Limba RENEWAL
Octavia O BologniaArgentinaAnna Fali NEGOTIATION
Antonio Q RutaFranceOnyama Limba NEGOTIATION
Alejandro Z RoysterRussiaAmy Elsner QUALIFIED
Darci M ShinkoItalyIvan Magalhaes QUALIFIED

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