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 I InouyeIndiaAsiya Javayant NEGOTIATION
Cody E GarufiArgentinaAmy Elsner NEGOTIATION
Aditya E StockhamAustraliaBernardo Dominic NEW
Emily V IturbideGermanyAsiya Javayant RENEWAL
Silvio X CampainCanadaAmy Elsner RENEWAL
Maisha Y PerinItalyAnna Fali NEW
Chavez D AlbaresBrazilIoni Bowcher NEW
Morrow L PoquetteItalyElwin Sharvill PROPOSAL
Jones E FerenczIndiaBernardo Dominic UNQUALIFIED
Silvio J CampainRussiaIoni Bowcher QUALIFIED
Smith H DarakjyArgentinaAsiya Javayant RENEWAL
Ashley X SchemmerFranceXuxue Feng NEW
James O MaletFranceAsiya Javayant QUALIFIED
Mujtaba V ChuiBrazilOnyama Limba PROPOSAL
Johnson F BriddickFranceAmy Elsner QUALIFIED
David S BologniaRussiaAsiya Javayant PROPOSAL
Maria N ShinkoItalyBernardo Dominic RENEWAL
Francesco Z ShinkoGermanyElwin Sharvill PROPOSAL
Isabel U CaldareraIndiaIoni Bowcher NEGOTIATION
Leon O BowleySpainAnna Fali PROPOSAL
Arvin X WaycottItalyAnna Fali NEGOTIATION
Morrow T MacleadArgentinaAnna Fali NEGOTIATION
Morrow V FigeroaGermanyXuxue Feng QUALIFIED
Aruna U SchemmerBrazilAmy Elsner RENEWAL
Isabel R KolmetzRussiaAsiya Javayant NEW
Adams O SaylorsAustraliaAmy Elsner UNQUALIFIED
Chavez W DoeUnited KingdomOnyama Limba RENEWAL
Costa S OldroydGermanyIvan Magalhaes UNQUALIFIED
Leja N SaylorsArgentinaBernardo Dominic NEW
Ivar H BowleyIndiaStephen Shaw NEW
Octavia M OldroydBrazilStephen Shaw QUALIFIED
Maisha X RimGermanyOnyama Limba UNQUALIFIED
Isabel W BologniaRussiaBernardo Dominic RENEWAL
Sinclair K FollerRussiaAsiya Javayant UNQUALIFIED
Maisha Z OldroydIndiaAnna Fali QUALIFIED
Francesco I AmigonUnited KingdomAsiya Javayant NEW
Antonio H FerenczArgentinaAmy Elsner UNQUALIFIED
Kadeem Y MaletUnited KingdomAmy Elsner NEGOTIATION
Wickens Z PerinSpainElwin Sharvill PROPOSAL
Deepesh M ShinkoIndiaAmy Elsner NEGOTIATION
Arvin U SchemmerArgentinaIoni Bowcher UNQUALIFIED
Tony N DilliardUnited KingdomXuxue Feng RENEWAL
Mujtaba X NickaIndiaIoni Bowcher QUALIFIED
Mujtaba T MarrierUnited KingdomOnyama Limba RENEWAL
Smith B CaudyUnited KingdomIvan Magalhaes PROPOSAL
Octavia M MaletItalyIoni Bowcher QUALIFIED
James W SlusarskiUnited KingdomAsiya Javayant NEGOTIATION
Ashley E SchemmerCanadaOnyama Limba UNQUALIFIED
Murillo Z ChuiRussiaStephen Shaw NEW
Costa K OldroydCanadaIvan Magalhaes NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
James M OstroskyJapanAsiya Javayant RENEWAL
Ivar V OstroskySpainBernardo Dominic QUALIFIED
Alejandro V BowleyUnited KingdomElwin Sharvill QUALIFIED
Sinclair V NickaUnited KingdomAsiya Javayant UNQUALIFIED
Isabel Q CaudyGermanyStephen Shaw NEW
Leja L GillianFranceIvan Magalhaes UNQUALIFIED
James I CaudyAustraliaAmy Elsner UNQUALIFIED
Emily R SlusarskiItalyAmy Elsner NEGOTIATION
Stacey X RoysterCanadaAnna Fali QUALIFIED
Nicolas H VenereUnited KingdomAnna Fali RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000David J KolmetzIndia2024-04-19Rangoni Of Florence PROPOSAL97Ioni Bowcher
1001Claire I SaylorsCanada2024-04-08King, Christopher A Esq NEW13Bernardo Dominic
1002Chavez H FollerIndia2024-04-16Rangoni Of Florence QUALIFIED71Amy Elsner
1003Isabel E DoeBrazil2024-04-10Chemel, James L Cpa QUALIFIED8Xuxue Feng
1004Smith M WieserAustralia2024-03-31Feltz Printing Service RENEWAL23Bernardo Dominic
1005Mayumi R AlbaresItaly2024-03-28Chanay, Jeffrey A Esq RENEWAL19Asiya Javayant
1006Aditya Q CampainCanada2024-04-09Dorl, James J Esq NEGOTIATION71Amy Elsner
1007Jeanfrancois D RulapaughBrazil2024-04-07King, Christopher A Esq RENEWAL46Asiya Javayant
1008Arvin Z MorascaJapan2024-03-31Rousseaux, Michael Esq NEW34Ivan Magalhaes
1009Silvio M MaletIndia2024-03-28King, Christopher A Esq RENEWAL23Asiya Javayant
1010Misaki W PoquetteArgentina2024-03-28Chanay, Jeffrey A Esq RENEWAL25Anna Fali
1011Aruna R VenereCanada2024-03-22Benton, John B Jr UNQUALIFIED25Asiya Javayant
1012Tony W FigeroaIndia2024-04-07Dorl, James J Esq NEW38Ioni Bowcher
1013Clifford F SaylorsFrance2024-04-11Benton, John B Jr UNQUALIFIED23Asiya Javayant
1014Mujtaba U ChuiBrazil2024-04-09Chanay, Jeffrey A Esq RENEWAL73Elwin Sharvill
1015Costa D OldroydRussia2024-03-31Rangoni Of Florence NEGOTIATION49Bernardo Dominic
1016Aika J FlosiUnited Kingdom2024-03-31Rousseaux, Michael Esq UNQUALIFIED89Xuxue Feng
1017Leon N IturbideArgentina2024-04-17Rousseaux, Michael Esq PROPOSAL7Onyama Limba
1018Greenwood D NestleItaly2024-04-10Rangoni Of Florence RENEWAL73Amy Elsner
1019Jennifer N OldroydRussia2024-03-27Commercial Press QUALIFIED91Xuxue Feng
1020Johnson L DarakjyCanada2024-03-21Feltz Printing Service RENEWAL31Amy Elsner
1021Costa U GauchoRussia2024-03-31Feiner Bros QUALIFIED37Anna Fali
1022Arvin E WaycottSpain2024-04-01Chapman, Ross E Esq UNQUALIFIED20Bernardo Dominic
1023David C StensethGermany2024-04-02Truhlar And Truhlar Attys UNQUALIFIED59Elwin Sharvill
1024Maria Y ButtSpain2024-03-24Benton, John B Jr NEW23Ioni Bowcher
1025Juan U BowleyGermany2024-04-11Printing Dimensions RENEWAL73Bernardo Dominic
1026Faith I MarrierGermany2024-04-08Truhlar And Truhlar Attys NEW64Ioni Bowcher
1027Emily I GillianIndia2024-04-15Feltz Printing Service NEGOTIATION26Xuxue Feng
1028Jennifer H GlickAustralia2024-04-09Morlong Associates NEW48Ioni Bowcher
1029Costa J BologniaBrazil2024-04-06Commercial Press NEGOTIATION38Ivan Magalhaes
1030Arvin L GlickFrance2024-04-16Chanay, Jeffrey A Esq UNQUALIFIED87Xuxue Feng
1031Maria I GlickBrazil2024-03-31Feiner Bros NEGOTIATION48Elwin Sharvill
1032Wickens S TollnerFrance2024-04-09Rangoni Of Florence UNQUALIFIED39Anna Fali
1033Johnson P DilliardAustralia2024-04-18Buckley Miller Wright RENEWAL42Bernardo Dominic
1034Claire F FlosiSpain2024-04-02Dorl, James J Esq UNQUALIFIED6Anna Fali
1035Faith Q VocelkaBrazil2024-04-02Chanay, Jeffrey A Esq UNQUALIFIED33Asiya Javayant
1036Izzy T DoeGermany2024-03-28Feltz Printing Service PROPOSAL57Asiya Javayant
1037Ashley F ChuiFrance2024-03-21Feiner Bros NEW6Ivan Magalhaes
1038Smith G StockhamFrance2024-03-31Chanay, Jeffrey A Esq UNQUALIFIED67Elwin Sharvill
1039Izzy Q MarrierGermany2024-04-01Feiner Bros RENEWAL4Stephen Shaw
1040Nicolas B WhobreyJapan2024-04-03Commercial Press NEGOTIATION17Asiya Javayant
1041Ricardo G SchemmerGermany2024-03-24Chemel, James L Cpa NEGOTIATION45Asiya Javayant
1042Ricardo Q KuskoRussia2024-03-29Feltz Printing Service NEGOTIATION4Stephen Shaw
1043Clifford U CaldareraArgentina2024-03-31Chapman, Ross E Esq PROPOSAL20Ivan Magalhaes
1044Jennifer N WhobreyFrance2024-04-13Chapman, Ross E Esq PROPOSAL44Asiya Javayant
1045Nicolas S WieserRussia2024-04-05Printing Dimensions NEGOTIATION25Anna Fali
1046Faith J BowleyAustralia2024-04-17Commercial Press NEGOTIATION22Elwin Sharvill
1047Stacey S GarufiArgentina2024-04-15Morlong Associates PROPOSAL63Stephen Shaw
1048Jennifer Q OstroskyFrance2024-04-14Feiner Bros UNQUALIFIED41Asiya Javayant
1049Ashley B WieserFrance2024-03-21Chemel, James L Cpa NEW52Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Chavez V BriddickSpainStephen Shaw NEGOTIATION
Isabel W AlbaresFranceIoni Bowcher NEW
Kaitlin I ShinkoArgentinaBernardo Dominic RENEWAL
David T InouyeCanadaXuxue Feng UNQUALIFIED
Isabel Y BriddickAustraliaAsiya Javayant QUALIFIED
Claire Q IturbideAustraliaAnna Fali PROPOSAL
Francesco L SergiIndiaAsiya Javayant UNQUALIFIED
Morrow L DarakjyAustraliaStephen Shaw RENEWAL
Jefferson A PoquetteGermanyStephen Shaw PROPOSAL
Adams U FigeroaAustraliaAsiya Javayant NEW
Emily P OstroskyCanadaIoni Bowcher NEGOTIATION
Antonio D WaycottGermanyXuxue Feng NEW
Izzy C NestleAustraliaStephen Shaw QUALIFIED
Juan M MarrierCanadaAnna Fali UNQUALIFIED
Costa B ButtArgentinaElwin Sharvill RENEWAL
David X ButtFranceAmy Elsner QUALIFIED
Jennifer N InouyeGermanyElwin Sharvill UNQUALIFIED
Antonio F WieserCanadaAmy Elsner PROPOSAL
Jones Z BowleyAustraliaIoni Bowcher PROPOSAL
Silvio W GauchoGermanyBernardo Dominic RENEWAL
David Q GauchoAustraliaIvan Magalhaes RENEWAL
Greenwood Z ShinkoRussiaElwin Sharvill NEW
Johnson P GauchoSpainElwin Sharvill PROPOSAL
Misaki R SlusarskiItalyAsiya Javayant NEGOTIATION
Rodrigues W GauchoJapanXuxue Feng RENEWAL
Costa M ButtItalyIoni Bowcher PROPOSAL
Morrow Q VocelkaGermanyStephen Shaw PROPOSAL
Ashley M FigeroaFranceOnyama Limba NEW
Cody U TollnerBrazilIvan Magalhaes RENEWAL
Maria J ShinkoBrazilXuxue Feng QUALIFIED
Wickens T FlosiAustraliaBernardo Dominic QUALIFIED
Salvatore T StockhamItalyBernardo Dominic NEGOTIATION
Darci R BowleyItalyOnyama Limba NEW
Darci A SlusarskiFranceAsiya Javayant NEW
Adams R GarufiItalyOnyama Limba QUALIFIED
Alejandro X FerenczCanadaXuxue Feng QUALIFIED
James L OldroydGermanyIvan Magalhaes RENEWAL
Jeanfrancois A WieserGermanyIvan Magalhaes NEGOTIATION
Kaitlin H GillianCanadaAnna Fali NEW
Aruna X SchemmerIndiaAsiya Javayant UNQUALIFIED
Claire O SergiSpainIvan Magalhaes QUALIFIED
Antonio K CampainJapanStephen Shaw NEGOTIATION
David Q NestleIndiaBernardo Dominic NEGOTIATION
Clifford X AmigonSpainIoni Bowcher NEGOTIATION
Jones G VocelkaAustraliaAmy Elsner RENEWAL
Jefferson A AlbaresRussiaIoni Bowcher RENEWAL
James X RutaGermanyStephen Shaw NEW
Isabel I RutaJapanStephen Shaw UNQUALIFIED
Aika H InouyeJapanAnna Fali RENEWAL
Jennifer C CaudyJapanAmy Elsner UNQUALIFIED
Frozen Columns
Name
Deepesh N Maclead
Ivar G Venere
Jennifer Z Chui
Adams G Inouye
Mayumi V Inouye
Smith Z Gillian
Emily A Whobrey
Kaitlin D Inouye
Costa R Doe
Octavia T Albares
Chavez F Vocelka
Munro M Albares
Costa U Ostrosky
Ashley J Butt
David G Butt
Kadeem X Ostrosky
Greenwood H Stockham
Antonio S Doe
Emily Q Campain
Claire B Dilliard
Darci C Ostrosky
Kadeem V Bolognia
Greenwood F Maclead
James R Slusarski
Jefferson F Flosi
Antonio R Paprocki
Ashley J Darakjy
Aditya I Waycott
Francesco L Flosi
Nicolas H Malet
Antonio Q Whobrey
Leon U Caldarera
Ricardo M Nestle
Maria Z Doe
Ashley W Gillian
Johnson M Flosi
Tony E Schemmer
Darci Z Marrier
Clifford X Sergi
Costa S Perin
Claire E Morasca
Ashley Z Dilliard
Smith Y Slusarski
Jennifer Z Venere
Morrow O Figeroa
Ivar I Schemmer
Greenwood A Slusarski
Leja Q Sergi
Faith W Gillian
Alejandro N Flosi
IdCountryDate
1000United Kingdom2024-03-30
1001Japan2024-04-14
1002United Kingdom2024-04-16
1003France2024-04-08
1004Italy2024-03-29
1005Germany2024-04-04
1006France2024-04-17
1007Spain2024-04-17
1008France2024-03-30
1009Italy2024-03-30
1010Germany2024-04-12
1011Germany2024-03-24
1012Germany2024-04-06
1013France2024-04-11
1014India2024-04-15
1015Japan2024-04-07
1016Brazil2024-04-02
1017Germany2024-04-11
1018Spain2024-04-13
1019Italy2024-04-13
1020Germany2024-03-30
1021Russia2024-04-04
1022United Kingdom2024-03-28
1023Brazil2024-04-12
1024Argentina2024-03-22
1025Brazil2024-04-07
1026Italy2024-04-02
1027Japan2024-04-15
1028Germany2024-04-03
1029Brazil2024-03-22
1030Russia2024-04-10
1031Spain2024-04-03
1032Spain2024-03-27
1033Argentina2024-04-12
1034India2024-04-15
1035Russia2024-04-19
1036Japan2024-04-11
1037India2024-04-16
1038Italy2024-03-25
1039India2024-04-04
1040France2024-04-08
1041Spain2024-03-22
1042Australia2024-04-04
1043Italy2024-03-29
1044Italy2024-04-11
1045Australia2024-03-30
1046India2024-04-01
1047Japan2024-03-30
1048United Kingdom2024-04-06
1049Russia2024-03-28

On-Demand Data

NameIdCountryDate
Izzy X Bowley1000Japan2024-04-12
Rodrigues Z Kolmetz1001Argentina2024-04-04
Tony E Caudy1002Brazil2024-03-21
Rodrigues O Chui1003France2024-03-31
Morrow K Sergi1004Japan2024-04-17
Izzy G Dilliard1005Spain2024-03-23
David X Foller1006Australia2024-04-16
Chavez Q Butt1007Japan2024-04-16
Jones K Poquette1008United Kingdom2024-04-03
Darci P Ruta1009Spain2024-03-31
Chavez W Marrier1010Brazil2024-04-12
Leon P Ferencz1011France2024-03-29
Deepesh Q Stockham1012Argentina2024-04-05
David M Tollner1013Spain2024-04-17
Ricardo A Foller1014Germany2024-04-04
Kaitlin T Rim1015Canada2024-03-26
Silvio R Kusko1016Italy2024-04-09
Kadeem G Flosi1017Canada2024-03-24
Darci X Ruta1018France2024-04-15
Nicolas N Gillian1019Italy2024-04-14
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Ivar Z ChuiJapanAnna Fali NEGOTIATION
Jennifer C WaycottJapanXuxue Feng RENEWAL
Tony T ShinkoArgentinaAnna Fali NEGOTIATION
Maisha J WieserAustraliaXuxue Feng NEGOTIATION
Wickens O StensethItalyBernardo Dominic NEGOTIATION
Aika J KolmetzBrazilIvan Magalhaes NEW
Salvatore S MaletCanadaOnyama Limba UNQUALIFIED
Kadeem J FlosiItalyOnyama Limba QUALIFIED
Munro P OldroydFranceIvan Magalhaes RENEWAL
Maisha W BriddickGermanyAsiya Javayant NEW
Smith O GauchoAustraliaAmy Elsner QUALIFIED
Cody S ButtFranceXuxue Feng NEGOTIATION
Antonio V NickaJapanBernardo Dominic PROPOSAL
Juan E PoquetteGermanyBernardo Dominic QUALIFIED
Kaitlin I DarakjyJapanXuxue Feng NEGOTIATION
Salvatore S OldroydCanadaElwin Sharvill UNQUALIFIED
Clifford C WhobreyGermanyAsiya Javayant PROPOSAL
Greenwood S WhobreyGermanyXuxue Feng PROPOSAL
Izzy U IturbideBrazilOnyama Limba RENEWAL
Claire J CampainUnited KingdomAnna Fali PROPOSAL
James L NickaBrazilIoni Bowcher QUALIFIED
Munro S GillianSpainIvan Magalhaes NEGOTIATION
Mayumi J FollerItalyIoni Bowcher QUALIFIED
Juan V DilliardRussiaIoni Bowcher PROPOSAL
Misaki V MacleadFranceAmy Elsner RENEWAL
Smith P GauchoSpainIoni Bowcher NEGOTIATION
Clifford I DilliardAustraliaAnna Fali QUALIFIED
Arvin F MorascaSpainAsiya Javayant RENEWAL
Isabel W FerenczCanadaElwin Sharvill NEW
Ivar Q FlosiSpainIoni Bowcher RENEWAL
Kadeem A NestleRussiaBernardo Dominic RENEWAL
Mayumi O ShinkoRussiaOnyama Limba NEGOTIATION
Maisha D SergiBrazilAnna Fali NEGOTIATION
Murillo F FerenczJapanIvan Magalhaes PROPOSAL
Maisha G PerinItalyElwin Sharvill UNQUALIFIED
Leja C WaycottJapanAnna Fali QUALIFIED
James C PoquetteAustraliaElwin Sharvill PROPOSAL
Darci Y WaycottIndiaIvan Magalhaes NEGOTIATION
Octavia W WaycottBrazilIvan Magalhaes NEGOTIATION
Francesco N VocelkaIndiaAnna Fali 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>