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
Salvatore U GillianGermanyBernardo Dominic RENEWAL
Rodrigues W DilliardFranceIoni Bowcher UNQUALIFIED
Deepesh V SaylorsFranceStephen Shaw RENEWAL
Maria U StockhamRussiaAnna Fali NEGOTIATION
Cody H WieserCanadaAmy Elsner RENEWAL
Leja S MorascaFranceAsiya Javayant PROPOSAL
David D StockhamItalyStephen Shaw NEW
Silvio F VenereIndiaXuxue Feng NEW
Kadeem T CaudyUnited KingdomAnna Fali PROPOSAL
Ricardo F GarufiCanadaBernardo Dominic PROPOSAL
Faith U InouyeSpainIoni Bowcher RENEWAL
Cody H DilliardArgentinaAnna Fali UNQUALIFIED
Nicolas R BowleyGermanyStephen Shaw QUALIFIED
Salvatore U ButtGermanyOnyama Limba NEGOTIATION
Munro S DarakjyBrazilAnna Fali PROPOSAL
Aditya I PaprockiUnited KingdomBernardo Dominic PROPOSAL
Silvio R MaletIndiaBernardo Dominic UNQUALIFIED
Izzy U DoeFranceAmy Elsner NEW
Aika M SlusarskiArgentinaOnyama Limba RENEWAL
Misaki N ChuiBrazilAnna Fali UNQUALIFIED
Wickens U NickaJapanBernardo Dominic PROPOSAL
Francesco V ButtFranceIoni Bowcher NEGOTIATION
Mayumi W ButtFranceAnna Fali UNQUALIFIED
Darci O OldroydGermanyStephen Shaw NEW
Leon N DilliardItalyStephen Shaw QUALIFIED
Kaitlin D VocelkaGermanyStephen Shaw NEGOTIATION
Arvin H AlbaresRussiaStephen Shaw PROPOSAL
Claire E VocelkaArgentinaOnyama Limba NEW
Nicolas P FlosiJapanOnyama Limba RENEWAL
Silvio H StockhamRussiaBernardo Dominic NEW
Chavez M RoysterCanadaAsiya Javayant NEGOTIATION
Leja Q TollnerSpainAnna Fali NEW
Alejandro K VenereUnited KingdomXuxue Feng NEGOTIATION
Darci Q CampainBrazilAnna Fali PROPOSAL
Ivar I DilliardArgentinaAsiya Javayant NEW
Murillo B BriddickAustraliaElwin Sharvill RENEWAL
Aditya F RimGermanyAmy Elsner PROPOSAL
Aditya N MaletGermanyOnyama Limba QUALIFIED
Wickens R MarrierArgentinaStephen Shaw UNQUALIFIED
Ricardo O CaudyAustraliaXuxue Feng QUALIFIED
Francesco S DoeIndiaOnyama Limba NEGOTIATION
Silvio N MacleadFranceIvan Magalhaes RENEWAL
Emily D DilliardRussiaXuxue Feng NEW
Kadeem V FerenczFranceElwin Sharvill RENEWAL
Kadeem X FollerFranceStephen Shaw QUALIFIED
Chavez N KolmetzUnited KingdomIvan Magalhaes PROPOSAL
Costa G DoeAustraliaIvan Magalhaes NEW
Clifford W InouyeGermanyXuxue Feng RENEWAL
Rodrigues Z VocelkaRussiaBernardo Dominic UNQUALIFIED
Nicolas A VocelkaGermanyStephen Shaw UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Faith C BowleyCanadaElwin Sharvill NEGOTIATION
Alejandro W FollerSpainOnyama Limba UNQUALIFIED
Jones E MaletArgentinaAsiya Javayant PROPOSAL
David R SlusarskiJapanAsiya Javayant RENEWAL
Jeanfrancois T WieserGermanyAmy Elsner QUALIFIED
Aruna J SlusarskiItalyIvan Magalhaes PROPOSAL
Murillo K OldroydBrazilBernardo Dominic PROPOSAL
Jeanfrancois E DoeUnited KingdomAnna Fali NEW
Darci I WieserArgentinaBernardo Dominic NEGOTIATION
Smith K RimRussiaBernardo Dominic QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Maria P IturbideGermany2024-04-08Benton, John B Jr RENEWAL89Amy Elsner
1001Chavez A SergiCanada2024-04-13Truhlar And Truhlar Attys NEGOTIATION31Onyama Limba
1002Stacey Z MacleadAustralia2024-03-30Morlong Associates RENEWAL38Anna Fali
1003Ashley I IturbideUnited Kingdom2024-03-30Commercial Press RENEWAL46Bernardo Dominic
1004Rodrigues F TollnerRussia2024-04-08Benton, John B Jr QUALIFIED0Anna Fali
1005Murillo X DoeIndia2024-04-11Dorl, James J Esq QUALIFIED32Ivan Magalhaes
1006Mayumi S GarufiArgentina2024-04-22Rangoni Of Florence RENEWAL53Ioni Bowcher
1007Silvio S PerinJapan2024-04-11Commercial Press RENEWAL56Onyama Limba
1008Antonio A SlusarskiGermany2024-03-31Rangoni Of Florence NEGOTIATION19Stephen Shaw
1009Izzy N AmigonIndia2024-04-03Dorl, James J Esq RENEWAL5Ioni Bowcher
1010Aditya U RoysterJapan2024-04-13Morlong Associates RENEWAL50Xuxue Feng
1011Aruna Q MaletItaly2024-04-04Truhlar And Truhlar Attys NEW43Asiya Javayant
1012Jeanfrancois Z SergiSpain2024-04-22Chapman, Ross E Esq UNQUALIFIED65Onyama Limba
1013Tony K CaudyGermany2024-04-07Rousseaux, Michael Esq PROPOSAL28Stephen Shaw
1014Kaitlin C GauchoFrance2024-03-28Rousseaux, Michael Esq UNQUALIFIED17Stephen Shaw
1015Salvatore H GarufiGermany2024-03-31King, Christopher A Esq RENEWAL63Elwin Sharvill
1016Silvio H PoquetteArgentina2024-04-23Chanay, Jeffrey A Esq NEW39Stephen Shaw
1017Clifford X RutaArgentina2024-04-02Feltz Printing Service QUALIFIED77Anna Fali
1018Jefferson X KolmetzGermany2024-04-08Rousseaux, Michael Esq NEGOTIATION60Stephen Shaw
1019Munro R MaletJapan2024-04-01Printing Dimensions RENEWAL0Ioni Bowcher
1020Rodrigues M RimRussia2024-04-18Dorl, James J Esq QUALIFIED72Onyama Limba
1021Ivar P PoquetteIndia2024-03-30Commercial Press PROPOSAL57Onyama Limba
1022James T InouyeBrazil2024-04-11Chapman, Ross E Esq NEGOTIATION21Asiya Javayant
1023Costa E FlosiBrazil2024-03-28Benton, John B Jr UNQUALIFIED71Elwin Sharvill
1024Ivar A MacleadGermany2024-03-28Morlong Associates QUALIFIED92Xuxue Feng
1025Cody X GauchoJapan2024-04-06Benton, John B Jr UNQUALIFIED48Amy Elsner
1026Jones O CaudyJapan2024-04-03Rousseaux, Michael Esq NEGOTIATION82Asiya Javayant
1027Aruna H AmigonJapan2024-04-19Truhlar And Truhlar Attys NEGOTIATION20Ivan Magalhaes
1028Kaitlin X TollnerRussia2024-04-05Buckley Miller Wright NEGOTIATION21Amy Elsner
1029Stacey E MaletSpain2024-04-25Rangoni Of Florence RENEWAL10Stephen Shaw
1030Octavia I ShinkoSpain2024-04-16Buckley Miller Wright UNQUALIFIED87Asiya Javayant
1031Rodrigues Z BowleyCanada2024-03-31Chemel, James L Cpa PROPOSAL83Asiya Javayant
1032Johnson Q MarrierRussia2024-04-03Feiner Bros QUALIFIED41Xuxue Feng
1033Claire X PoquetteFrance2024-04-21Chemel, James L Cpa UNQUALIFIED45Ioni Bowcher
1034Francesco E PerinUnited Kingdom2024-04-18Morlong Associates NEW92Amy Elsner
1035Rodrigues X TollnerBrazil2024-04-05Buckley Miller Wright QUALIFIED60Asiya Javayant
1036Rodrigues M OstroskyIndia2024-04-09Benton, John B Jr RENEWAL16Amy Elsner
1037Stacey Z WieserUnited Kingdom2024-04-11Rangoni Of Florence PROPOSAL24Ivan Magalhaes
1038Wickens R GillianGermany2024-04-14Commercial Press QUALIFIED79Stephen Shaw
1039Aditya W GauchoUnited Kingdom2024-04-01Rousseaux, Michael Esq UNQUALIFIED24Elwin Sharvill
1040Ricardo H MaletUnited Kingdom2024-04-15Chemel, James L Cpa RENEWAL6Anna Fali
1041Sinclair K RoysterRussia2024-04-19Feltz Printing Service NEGOTIATION63Asiya Javayant
1042Faith A BowleyArgentina2024-03-27Chapman, Ross E Esq NEGOTIATION79Bernardo Dominic
1043Leon P OstroskyJapan2024-03-31Rousseaux, Michael Esq NEGOTIATION0Asiya Javayant
1044Cody Y ShinkoRussia2024-04-04Printing Dimensions NEW4Elwin Sharvill
1045Julie E VocelkaGermany2024-03-31Benton, John B Jr NEGOTIATION27Stephen Shaw
1046Aruna B MacleadArgentina2024-04-08Chemel, James L Cpa RENEWAL77Asiya Javayant
1047Munro F TollnerRussia2024-04-10Benton, John B Jr NEGOTIATION29Stephen Shaw
1048Isabel I MarrierFrance2024-04-12Morlong Associates QUALIFIED33Xuxue Feng
1049Jefferson W MaletAustralia2024-04-17Buckley Miller Wright NEW39Ioni Bowcher
Frozen Rows
NameCountryRepresentativeStatus
Faith B NickaJapanAsiya Javayant NEW
Jeanfrancois N InouyeIndiaBernardo Dominic UNQUALIFIED
Silvio G OldroydItalyIoni Bowcher UNQUALIFIED
Wickens X SergiCanadaBernardo Dominic NEW
Maisha W CaudyArgentinaAsiya Javayant QUALIFIED
Munro B WhobreySpainAsiya Javayant RENEWAL
David R GauchoIndiaBernardo Dominic UNQUALIFIED
James V RutaFranceAsiya Javayant PROPOSAL
Antonio Z BologniaFranceStephen Shaw NEW
Misaki A AlbaresRussiaIvan Magalhaes RENEWAL
Adams Y RoysterFranceOnyama Limba PROPOSAL
Cody C SchemmerSpainBernardo Dominic UNQUALIFIED
Aruna J KuskoJapanAsiya Javayant NEW
Munro A SlusarskiCanadaElwin Sharvill NEW
Murillo Y CaudyCanadaAsiya Javayant NEW
Rodrigues L SchemmerArgentinaXuxue Feng RENEWAL
Sinclair R RimCanadaBernardo Dominic NEGOTIATION
Ivar M CampainItalyIvan Magalhaes RENEWAL
Silvio C FlosiRussiaBernardo Dominic UNQUALIFIED
Ivar T FerenczArgentinaStephen Shaw NEW
Salvatore B SchemmerItalyAmy Elsner NEW
Isabel I MarrierRussiaStephen Shaw PROPOSAL
Murillo E ButtGermanyAmy Elsner NEW
Leja P SergiIndiaBernardo Dominic UNQUALIFIED
Darci V AmigonItalyStephen Shaw PROPOSAL
Ricardo I WaycottRussiaElwin Sharvill RENEWAL
Aruna R NestleAustraliaXuxue Feng NEGOTIATION
Salvatore D SergiAustraliaIoni Bowcher PROPOSAL
Ricardo I OstroskyArgentinaAnna Fali NEGOTIATION
Francesco Y OstroskyItalyBernardo Dominic NEW
Faith C SergiItalyOnyama Limba QUALIFIED
Rodrigues K SergiBrazilIoni Bowcher NEW
Stacey Z ButtArgentinaAsiya Javayant RENEWAL
Octavia W MorascaIndiaIvan Magalhaes NEW
Kadeem A PoquetteArgentinaAnna Fali QUALIFIED
Aika F AmigonFranceBernardo Dominic NEGOTIATION
Antonio D GarufiFranceOnyama Limba NEGOTIATION
Smith C ChuiItalyElwin Sharvill UNQUALIFIED
Francesco Z VocelkaJapanAsiya Javayant UNQUALIFIED
Ricardo F StensethRussiaAnna Fali RENEWAL
Costa B GarufiBrazilElwin Sharvill NEW
Cody J CaldareraItalyIoni Bowcher NEW
Antonio X WieserFranceAnna Fali RENEWAL
Ricardo E MorascaGermanyBernardo Dominic QUALIFIED
Silvio Q MarrierItalyOnyama Limba NEW
Arvin S SlusarskiBrazilStephen Shaw RENEWAL
Cody T CaudySpainXuxue Feng UNQUALIFIED
Mayumi P CaldareraCanadaBernardo Dominic UNQUALIFIED
James H SergiGermanyAsiya Javayant UNQUALIFIED
Sinclair O SergiCanadaIvan Magalhaes NEGOTIATION
Frozen Columns
Name
Claire D Oldroyd
Jeanfrancois J Perin
Wickens K Caudy
Aditya V Gaucho
Costa G Schemmer
Emily K Malet
Kadeem A Sergi
Aruna R Whobrey
Adams Q Bowley
Julie K Kusko
Jefferson Q Sergi
Francesco O Kusko
Nicolas H Iturbide
Arvin T Ruta
Kaitlin S Oldroyd
Faith W Ferencz
Ivar A Waycott
James L Poquette
Mujtaba L Chui
David J Inouye
Morrow G Butt
Misaki H Tollner
Kaitlin K Paprocki
Costa T Caldarera
Silvio Q Malet
Greenwood B Marrier
Kadeem E Sergi
Kaitlin C Malet
Darci I Nestle
Johnson T Inouye
Maisha Q Doe
Julie W Doe
Claire T Royster
Cody F Slusarski
Leon T Perin
Mayumi S Slusarski
Clifford G Perin
Aditya L Nicka
Deepesh A Malet
Greenwood B Stockham
Mayumi V Paprocki
Johnson R Royster
Faith D Chui
Izzy F Figeroa
Claire K Tollner
Jennifer E Kolmetz
Aruna D Briddick
Julie M Stockham
Izzy S Perin
Antonio J Royster
IdCountryDate
1000United Kingdom2024-04-25
1001Russia2024-04-20
1002India2024-03-29
1003Argentina2024-03-28
1004United Kingdom2024-03-27
1005Canada2024-04-11
1006India2024-04-09
1007Brazil2024-04-09
1008United Kingdom2024-04-20
1009Italy2024-04-16
1010Spain2024-03-28
1011Canada2024-03-27
1012France2024-03-29
1013Argentina2024-04-14
1014Japan2024-04-12
1015Argentina2024-04-03
1016Argentina2024-04-18
1017Japan2024-04-03
1018United Kingdom2024-04-08
1019France2024-03-28
1020Spain2024-04-01
1021Australia2024-04-09
1022Argentina2024-04-08
1023Spain2024-04-11
1024India2024-04-11
1025Spain2024-03-28
1026Spain2024-04-22
1027Russia2024-04-24
1028Japan2024-04-12
1029Canada2024-04-07
1030United Kingdom2024-04-21
1031India2024-04-13
1032Spain2024-04-03
1033France2024-04-08
1034Russia2024-04-07
1035Spain2024-03-28
1036Germany2024-03-28
1037Australia2024-04-13
1038Australia2024-04-01
1039India2024-04-03
1040Brazil2024-04-25
1041Germany2024-04-20
1042United Kingdom2024-04-16
1043Argentina2024-04-23
1044Russia2024-04-22
1045Japan2024-04-11
1046India2024-04-01
1047India2024-03-31
1048Canada2024-04-12
1049Spain2024-04-07

On-Demand Data

NameIdCountryDate
Mujtaba G Slusarski1000Japan2024-04-08
Silvio Y Poquette1001Russia2024-04-07
Isabel N Chui1002Italy2024-03-29
Izzy F Figeroa1003Germany2024-03-28
Jeanfrancois F Albares1004Italy2024-03-31
Alejandro Q Royster1005France2024-03-28
James D Amigon1006India2024-04-10
Adams T Waycott1007France2024-04-13
Clifford L Perin1008Canada2024-04-25
Tony D Doe1009Spain2024-04-22
Izzy H Morasca1010Germany2024-04-13
Ashley P Ruta1011United Kingdom2024-04-04
Salvatore W Vocelka1012Spain2024-03-27
Smith F Malet1013Spain2024-04-18
Maria A Rim1014Italy2024-04-16
Adams U Royster1015France2024-03-30
Smith A Whobrey1016Canada2024-04-24
Kaitlin B Stockham1017United Kingdom2024-04-08
Leja O Ruta1018Australia2024-04-18
Deepesh D Tollner1019Brazil2024-03-30
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
James O ShinkoFranceAsiya Javayant NEW
Julie B NestleArgentinaAsiya Javayant QUALIFIED
Nicolas E OstroskyAustraliaAsiya Javayant NEGOTIATION
Aditya A WhobreyArgentinaBernardo Dominic RENEWAL
Wickens T SaylorsItalyAmy Elsner UNQUALIFIED
Leja P RoysterIndiaStephen Shaw UNQUALIFIED
Juan F AmigonCanadaIoni Bowcher RENEWAL
Johnson I ShinkoUnited KingdomIoni Bowcher NEGOTIATION
Johnson N WieserRussiaOnyama Limba NEGOTIATION
Darci C RulapaughIndiaAnna Fali UNQUALIFIED
Clifford V FlosiUnited KingdomAnna Fali RENEWAL
Clifford E ShinkoCanadaXuxue Feng QUALIFIED
Octavia J NickaSpainElwin Sharvill UNQUALIFIED
Arvin S PaprockiRussiaElwin Sharvill UNQUALIFIED
Misaki V GillianArgentinaBernardo Dominic RENEWAL
Ashley E SlusarskiArgentinaAnna Fali NEGOTIATION
Murillo C RutaBrazilAmy Elsner UNQUALIFIED
Wickens M BowleyItalyOnyama Limba UNQUALIFIED
Julie U StensethJapanBernardo Dominic UNQUALIFIED
Wickens F InouyeIndiaXuxue Feng UNQUALIFIED
Nicolas G TollnerIndiaAsiya Javayant NEGOTIATION
Greenwood J CaldareraIndiaElwin Sharvill NEW
Jefferson U GarufiBrazilIoni Bowcher NEGOTIATION
Kaitlin F BriddickIndiaOnyama Limba RENEWAL
Juan R GlickCanadaAsiya Javayant NEGOTIATION
Wickens C BologniaItalyXuxue Feng PROPOSAL
Salvatore X WaycottSpainXuxue Feng RENEWAL
Tony Z GarufiGermanyAsiya Javayant RENEWAL
Isabel L SergiCanadaIvan Magalhaes QUALIFIED
Kaitlin Z BriddickJapanAsiya Javayant UNQUALIFIED
Claire Q FerenczGermanyStephen Shaw PROPOSAL
Johnson Z WhobreyArgentinaStephen Shaw NEW
Jones S TollnerRussiaStephen Shaw PROPOSAL
Costa B BriddickCanadaXuxue Feng NEGOTIATION
Ivar Q KolmetzRussiaXuxue Feng PROPOSAL
Izzy H DoeCanadaBernardo Dominic NEW
Juan R RutaSpainAmy Elsner PROPOSAL
James K BriddickRussiaAsiya Javayant RENEWAL
Mayumi Y ShinkoArgentinaAmy Elsner QUALIFIED
Leon M FerenczItalyBernardo Dominic NEW

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