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
Misaki I MaletFranceAmy Elsner RENEWAL
Deepesh H GarufiUnited KingdomIvan Magalhaes NEGOTIATION
Maria K StensethBrazilIvan Magalhaes PROPOSAL
Ivar Y FollerFranceStephen Shaw QUALIFIED
Cody F NestleCanadaIvan Magalhaes RENEWAL
Salvatore W BriddickArgentinaAnna Fali NEGOTIATION
Ashley K MacleadItalyElwin Sharvill NEW
Aika E GillianSpainAnna Fali NEGOTIATION
Julie I NestleItalyElwin Sharvill NEW
David Z CaldareraGermanyOnyama Limba NEW
Octavia M MacleadAustraliaOnyama Limba QUALIFIED
Maisha B GauchoIndiaXuxue Feng PROPOSAL
Ivar T SaylorsArgentinaXuxue Feng PROPOSAL
Rodrigues U IturbideAustraliaStephen Shaw NEGOTIATION
Smith O VocelkaJapanOnyama Limba PROPOSAL
Claire V DoeItalyElwin Sharvill UNQUALIFIED
Silvio Y BologniaUnited KingdomXuxue Feng RENEWAL
Julie K PerinCanadaIoni Bowcher NEGOTIATION
Octavia G SergiCanadaAsiya Javayant NEW
Nicolas S OstroskyItalyIvan Magalhaes UNQUALIFIED
James P MaletGermanyIvan Magalhaes RENEWAL
Clifford Q IturbideSpainAnna Fali QUALIFIED
Clifford X PoquetteArgentinaXuxue Feng UNQUALIFIED
Aika V DilliardFranceElwin Sharvill RENEWAL
Misaki A MarrierJapanXuxue Feng UNQUALIFIED
Adams W CaudyUnited KingdomStephen Shaw QUALIFIED
Wickens G ChuiCanadaAnna Fali PROPOSAL
Jefferson J AlbaresSpainAmy Elsner QUALIFIED
Julie K NickaAustraliaIoni Bowcher NEGOTIATION
Ashley O WhobreyRussiaAmy Elsner RENEWAL
Izzy P GlickGermanyAsiya Javayant UNQUALIFIED
Sinclair I DarakjyArgentinaOnyama Limba QUALIFIED
Emily U SlusarskiArgentinaOnyama Limba PROPOSAL
Adams E IturbideAustraliaXuxue Feng PROPOSAL
Cody P OstroskyArgentinaElwin Sharvill NEW
Costa O ChuiUnited KingdomIvan Magalhaes UNQUALIFIED
Leon K StensethUnited KingdomAnna Fali QUALIFIED
Juan K MacleadIndiaAmy Elsner PROPOSAL
Isabel P DilliardItalyStephen Shaw NEGOTIATION
Izzy O VocelkaUnited KingdomElwin Sharvill NEW
Clifford K NickaAustraliaStephen Shaw NEGOTIATION
Antonio U ChuiUnited KingdomAmy Elsner RENEWAL
Jennifer M RoysterAustraliaBernardo Dominic QUALIFIED
Octavia A OstroskyItalyAnna Fali NEW
Octavia Y VocelkaIndiaIoni Bowcher NEGOTIATION
Julie Q ButtGermanyAmy Elsner PROPOSAL
Claire M WieserBrazilAnna Fali PROPOSAL
Aika O MacleadIndiaXuxue Feng RENEWAL
David I VenereGermanyStephen Shaw NEGOTIATION
Ivar R WaycottSpainStephen Shaw QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Jennifer B NickaFranceBernardo Dominic NEGOTIATION
Aruna Q VocelkaRussiaOnyama Limba NEGOTIATION
Ivar J VenereIndiaXuxue Feng QUALIFIED
Emily N KolmetzJapanStephen Shaw NEGOTIATION
Aruna R KuskoGermanyAmy Elsner RENEWAL
Julie P FollerAustraliaAnna Fali NEW
Johnson L GauchoJapanOnyama Limba QUALIFIED
Costa S CampainFranceIoni Bowcher NEGOTIATION
Mayumi D DoeGermanyBernardo Dominic UNQUALIFIED
Jones G CaudyJapanIoni Bowcher QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Munro Y PerinSpain2024-04-24Rousseaux, Michael Esq RENEWAL35Anna Fali
1001Izzy I AmigonBrazil2024-04-21Buckley Miller Wright NEGOTIATION55Elwin Sharvill
1002Munro R CaldareraRussia2024-04-19King, Christopher A Esq NEGOTIATION34Asiya Javayant
1003Mujtaba Z NickaRussia2024-04-07Chemel, James L Cpa PROPOSAL39Bernardo Dominic
1004Alejandro X GlickAustralia2024-04-16Rangoni Of Florence QUALIFIED6Asiya Javayant
1005Tony N StockhamIndia2024-04-18Chapman, Ross E Esq RENEWAL99Asiya Javayant
1006Murillo I InouyeBrazil2024-03-31Benton, John B Jr UNQUALIFIED84Ivan Magalhaes
1007Alejandro Y FerenczArgentina2024-04-18Chanay, Jeffrey A Esq UNQUALIFIED3Amy Elsner
1008Silvio E DarakjySpain2024-04-22Printing Dimensions UNQUALIFIED74Ioni Bowcher
1009Murillo Y GillianFrance2024-04-23Dorl, James J Esq PROPOSAL47Bernardo Dominic
1010Darci G MaletAustralia2024-04-15Dorl, James J Esq NEW11Anna Fali
1011James W NestleUnited Kingdom2024-04-13Benton, John B Jr QUALIFIED28Xuxue Feng
1012Salvatore L NestleUnited Kingdom2024-04-03Truhlar And Truhlar Attys RENEWAL92Onyama Limba
1013Julie C SergiIndia2024-04-12Dorl, James J Esq NEW10Anna Fali
1014Maisha X FlosiGermany2024-04-15Rangoni Of Florence QUALIFIED41Xuxue Feng
1015Murillo J FlosiRussia2024-04-16Buckley Miller Wright NEW95Onyama Limba
1016Greenwood G KuskoGermany2024-04-09Dorl, James J Esq QUALIFIED42Ioni Bowcher
1017Maisha S BriddickRussia2024-04-19Buckley Miller Wright UNQUALIFIED10Elwin Sharvill
1018Silvio C InouyeCanada2024-04-15Printing Dimensions UNQUALIFIED78Anna Fali
1019Greenwood P VenereFrance2024-04-05Feiner Bros RENEWAL49Onyama Limba
1020Clifford F IturbideItaly2024-04-20Morlong Associates RENEWAL45Elwin Sharvill
1021Ricardo W RimFrance2024-04-18Benton, John B Jr PROPOSAL99Ioni Bowcher
1022Jennifer U VenereJapan2024-04-21Dorl, James J Esq NEW68Bernardo Dominic
1023Alejandro D MorascaGermany2024-04-06Morlong Associates NEW50Ivan Magalhaes
1024Leja G RutaCanada2024-04-11Printing Dimensions NEW14Asiya Javayant
1025Tony D MarrierBrazil2024-04-16Printing Dimensions NEGOTIATION57Ivan Magalhaes
1026Costa X OldroydJapan2024-04-21Rousseaux, Michael Esq QUALIFIED81Xuxue Feng
1027Munro D PerinGermany2024-04-21Feiner Bros NEW46Xuxue Feng
1028Costa S KolmetzRussia2024-04-10Benton, John B Jr QUALIFIED36Xuxue Feng
1029Cody R OstroskyItaly2024-04-27Dorl, James J Esq RENEWAL19Elwin Sharvill
1030Aruna I KolmetzCanada2024-04-27Commercial Press UNQUALIFIED96Amy Elsner
1031Munro U WaycottBrazil2024-04-22King, Christopher A Esq UNQUALIFIED35Asiya Javayant
1032Mujtaba S RulapaughRussia2024-04-20Feiner Bros UNQUALIFIED95Bernardo Dominic
1033Costa X ButtSpain2024-03-31Rousseaux, Michael Esq QUALIFIED9Anna Fali
1034Morrow G GarufiRussia2024-04-08Commercial Press NEGOTIATION32Amy Elsner
1035Johnson L SergiIndia2024-04-09Dorl, James J Esq PROPOSAL60Amy Elsner
1036Costa N VenereAustralia2024-04-20Printing Dimensions NEW27Asiya Javayant
1037Clifford W MorascaCanada2024-04-24Printing Dimensions NEW74Stephen Shaw
1038Aika N DarakjyJapan2024-03-30Benton, John B Jr NEW75Anna Fali
1039Francesco M AlbaresCanada2024-03-31Truhlar And Truhlar Attys NEGOTIATION12Bernardo Dominic
1040Ricardo O StensethAustralia2024-04-22Chapman, Ross E Esq UNQUALIFIED15Ivan Magalhaes
1041Claire V BowleyFrance2024-04-05Feiner Bros PROPOSAL27Ivan Magalhaes
1042James Z RimAustralia2024-04-17Chanay, Jeffrey A Esq NEGOTIATION0Stephen Shaw
1043Mujtaba A MarrierArgentina2024-04-14Feltz Printing Service QUALIFIED47Amy Elsner
1044Smith P DoeUnited Kingdom2024-04-27Chemel, James L Cpa PROPOSAL57Anna Fali
1045Kadeem V BowleyFrance2024-04-09Dorl, James J Esq NEGOTIATION64Bernardo Dominic
1046Maria U VenereCanada2024-03-31King, Christopher A Esq NEW10Asiya Javayant
1047Chavez K MaletFrance2024-04-13Feltz Printing Service PROPOSAL24Onyama Limba
1048James K IturbideGermany2024-04-05Feltz Printing Service NEGOTIATION50Asiya Javayant
1049James R StensethIndia2024-04-26Chemel, James L Cpa QUALIFIED78Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Aruna O BriddickIndiaBernardo Dominic NEGOTIATION
Juan S OldroydItalyOnyama Limba UNQUALIFIED
Adams P FerenczGermanyOnyama Limba NEW
Deepesh L RutaCanadaAnna Fali PROPOSAL
Octavia Q BriddickSpainBernardo Dominic RENEWAL
Izzy A PoquetteAustraliaOnyama Limba UNQUALIFIED
Jeanfrancois M BologniaCanadaXuxue Feng PROPOSAL
Smith X BowleyBrazilIvan Magalhaes QUALIFIED
David M RutaBrazilIvan Magalhaes NEW
James E PoquetteCanadaOnyama Limba RENEWAL
Silvio D StensethItalyStephen Shaw QUALIFIED
Clifford Z MaletCanadaXuxue Feng QUALIFIED
Misaki H StensethJapanElwin Sharvill RENEWAL
Munro M SergiCanadaAnna Fali QUALIFIED
Jones J AlbaresItalyAsiya Javayant NEW
Claire N ButtCanadaAsiya Javayant RENEWAL
Kaitlin U GillianRussiaStephen Shaw UNQUALIFIED
Maria R MaletArgentinaIvan Magalhaes PROPOSAL
Ashley S SlusarskiItalyIvan Magalhaes RENEWAL
Tony M ChuiSpainStephen Shaw QUALIFIED
Octavia R DarakjyAustraliaIoni Bowcher NEGOTIATION
Julie Q BriddickGermanyStephen Shaw PROPOSAL
Sinclair M SergiArgentinaAnna Fali PROPOSAL
Adams O IturbideAustraliaIvan Magalhaes QUALIFIED
Smith E NickaJapanAmy Elsner NEW
Darci N StensethUnited KingdomElwin Sharvill NEGOTIATION
Ashley T WaycottArgentinaStephen Shaw UNQUALIFIED
Isabel V AlbaresFranceAnna Fali NEW
Ashley E SchemmerRussiaStephen Shaw PROPOSAL
Izzy I SlusarskiSpainAmy Elsner RENEWAL
Aruna O MacleadFranceAsiya Javayant UNQUALIFIED
Maria E DoeBrazilXuxue Feng QUALIFIED
Mujtaba B FigeroaIndiaAsiya Javayant UNQUALIFIED
Jones J PerinItalyAnna Fali NEGOTIATION
Nicolas B BowleyAustraliaOnyama Limba QUALIFIED
Alejandro L OldroydFranceOnyama Limba NEGOTIATION
Wickens N BologniaJapanBernardo Dominic RENEWAL
Leon U InouyeCanadaBernardo Dominic PROPOSAL
Cody K MacleadAustraliaIoni Bowcher UNQUALIFIED
Mujtaba I BriddickArgentinaIoni Bowcher NEGOTIATION
Ricardo N MacleadCanadaStephen Shaw NEGOTIATION
Darci S IturbideRussiaAsiya Javayant NEW
Munro I MaletSpainBernardo Dominic QUALIFIED
Aruna F SergiGermanyAsiya Javayant NEGOTIATION
Aruna I GarufiSpainBernardo Dominic PROPOSAL
Salvatore N OldroydAustraliaAnna Fali NEW
Sinclair C WaycottCanadaXuxue Feng QUALIFIED
Emily Z WaycottCanadaIvan Magalhaes NEW
Claire D CaudySpainStephen Shaw UNQUALIFIED
Silvio L RimUnited KingdomBernardo Dominic PROPOSAL
Frozen Columns
Name
Claire N Darakjy
Misaki C Vocelka
Nicolas G Ostrosky
Adams W Marrier
Claire V Doe
Rodrigues J Butt
Aika C Malet
Jefferson Q Bowley
Leon A Caldarera
James P Marrier
Maisha C Albares
Ashley K Inouye
Silvio G Shinko
Faith U Gillian
Leon O Flosi
Jeanfrancois U Briddick
Salvatore D Chui
Morrow E Paprocki
Julie Z Dilliard
Nicolas S Butt
Costa L Rulapaugh
Aditya E Rulapaugh
Ivar L Paprocki
James Y Bolognia
Chavez A Whobrey
Adams C Waycott
Darci G Marrier
Antonio N Nestle
Juan D Paprocki
Silvio M Morasca
Morrow H Sergi
Isabel B Gaucho
Jennifer S Tollner
Leja F Briddick
Smith G Butt
Kadeem N Nicka
Morrow L Marrier
Kadeem S Slusarski
Tony T Dilliard
Silvio R Bowley
Aruna Q Glick
Ricardo Q Maclead
Claire V Marrier
Rodrigues A Marrier
Julie A Sergi
Isabel F Amigon
Izzy F Stockham
Mayumi G Bolognia
Mujtaba Y Saylors
Murillo X Royster
IdCountryDate
1000Brazil2024-04-26
1001India2024-04-18
1002India2024-04-26
1003United Kingdom2024-04-02
1004Argentina2024-04-22
1005Japan2024-04-11
1006Russia2024-04-14
1007India2024-04-03
1008Argentina2024-04-12
1009Brazil2024-04-20
1010Italy2024-04-11
1011France2024-04-22
1012Italy2024-04-21
1013Canada2024-04-22
1014Australia2024-04-03
1015United Kingdom2024-04-02
1016France2024-04-08
1017France2024-04-15
1018Japan2024-04-21
1019Germany2024-04-14
1020India2024-04-09
1021Brazil2024-04-25
1022Russia2024-04-09
1023Canada2024-04-14
1024India2024-04-14
1025Russia2024-04-10
1026Spain2024-04-03
1027Canada2024-04-01
1028Japan2024-04-18
1029Russia2024-04-21
1030Russia2024-04-16
1031France2024-04-20
1032Germany2024-04-23
1033Brazil2024-04-21
1034Argentina2024-04-15
1035France2024-04-04
1036Brazil2024-04-14
1037Japan2024-04-24
1038Argentina2024-04-12
1039Japan2024-04-08
1040Japan2024-04-04
1041Spain2024-04-11
1042Argentina2024-04-14
1043France2024-04-25
1044France2024-04-08
1045Australia2024-04-09
1046Argentina2024-04-02
1047United Kingdom2024-04-22
1048Australia2024-04-10
1049Canada2024-04-07

On-Demand Data

NameIdCountryDate
Antonio E Darakjy1000Brazil2024-04-18
Aditya T Nestle1001Japan2024-04-18
Clifford C Bowley1002Russia2024-04-17
Wickens A Rulapaugh1003Australia2024-04-25
Tony K Rim1004Germany2024-04-27
Munro T Amigon1005Canada2024-04-06
Leja K Caudy1006Italy2024-03-30
Munro B Ruta1007Canada2024-04-02
Antonio N Campain1008Italy2024-04-20
Faith B Kusko1009Canada2024-04-21
Rodrigues M Paprocki1010Brazil2024-04-02
David V Flosi1011Germany2024-03-30
Maisha O Sergi1012Argentina2024-04-07
Misaki D Bowley1013Japan2024-04-07
Arvin A Nestle1014Argentina2024-04-01
Johnson S Inouye1015Australia2024-04-20
Aruna B Briddick1016Australia2024-04-08
Claire A Malet1017Russia2024-04-23
Leon H Amigon1018India2024-04-24
Morrow K Royster1019France2024-04-21
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Misaki N OldroydFranceXuxue Feng NEGOTIATION
Francesco O AlbaresFranceElwin Sharvill RENEWAL
Darci A SergiCanadaElwin Sharvill PROPOSAL
Clifford U ButtSpainIvan Magalhaes UNQUALIFIED
Munro K MaletBrazilElwin Sharvill NEW
Morrow E MaletGermanyOnyama Limba NEW
Emily L AlbaresUnited KingdomXuxue Feng UNQUALIFIED
Chavez K PaprockiJapanAmy Elsner UNQUALIFIED
Ricardo U IturbideJapanBernardo Dominic UNQUALIFIED
Johnson V RulapaughItalyIvan Magalhaes NEGOTIATION
James U PaprockiBrazilElwin Sharvill NEW
Isabel V KuskoCanadaAmy Elsner QUALIFIED
Julie M AmigonJapanElwin Sharvill NEGOTIATION
Morrow W AlbaresArgentinaAnna Fali NEW
Ashley D StensethCanadaAmy Elsner NEGOTIATION
Aruna B WieserJapanBernardo Dominic PROPOSAL
Murillo M SergiItalyIoni Bowcher UNQUALIFIED
Salvatore R ChuiGermanyIoni Bowcher UNQUALIFIED
Morrow Z AmigonUnited KingdomAmy Elsner RENEWAL
David O WaycottGermanyAsiya Javayant PROPOSAL
Antonio K StockhamFranceIoni Bowcher UNQUALIFIED
Sinclair A GarufiArgentinaAmy Elsner PROPOSAL
Isabel I TollnerArgentinaAmy Elsner NEW
Isabel K AmigonUnited KingdomElwin Sharvill NEW
Clifford X WhobreyCanadaIoni Bowcher UNQUALIFIED
Octavia Z RulapaughBrazilElwin Sharvill UNQUALIFIED
Maria J KuskoGermanyBernardo Dominic NEGOTIATION
Cody K WhobreySpainIoni Bowcher RENEWAL
Faith M MaletAustraliaStephen Shaw QUALIFIED
Mayumi I CaldareraItalyAsiya Javayant NEW
Smith U AmigonUnited KingdomBernardo Dominic NEGOTIATION
Faith U CampainSpainXuxue Feng PROPOSAL
Ricardo M CaudyItalyOnyama Limba QUALIFIED
Nicolas E InouyeArgentinaXuxue Feng RENEWAL
Morrow R GarufiAustraliaAnna Fali QUALIFIED
Tony G AmigonCanadaXuxue Feng QUALIFIED
Maria M RimBrazilStephen Shaw RENEWAL
Smith P StensethGermanyElwin Sharvill UNQUALIFIED
Mayumi G RimRussiaAmy Elsner PROPOSAL
Munro P OstroskyRussiaAnna Fali 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>