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
David M OstroskyItalyAnna Fali RENEWAL
Emily M BriddickJapanOnyama Limba UNQUALIFIED
Maisha L CampainAustraliaXuxue Feng UNQUALIFIED
Costa V GauchoJapanOnyama Limba NEW
Aditya H CaudyIndiaAnna Fali QUALIFIED
Faith H FollerFranceAnna Fali NEGOTIATION
Leon E FollerUnited KingdomOnyama Limba UNQUALIFIED
Murillo S WaycottArgentinaAmy Elsner NEGOTIATION
Claire C BologniaArgentinaOnyama Limba NEW
Clifford B PaprockiIndiaAnna Fali RENEWAL
Alejandro F FollerGermanyXuxue Feng NEW
Tony L PoquetteRussiaXuxue Feng NEW
Darci F RulapaughFranceAsiya Javayant UNQUALIFIED
Jones C SlusarskiAustraliaBernardo Dominic UNQUALIFIED
Aditya S MarrierJapanIvan Magalhaes UNQUALIFIED
Aruna U StockhamUnited KingdomAmy Elsner PROPOSAL
Julie L PerinFranceOnyama Limba QUALIFIED
Clifford T PerinCanadaBernardo Dominic UNQUALIFIED
Aruna E GarufiArgentinaXuxue Feng NEW
Munro Y MacleadCanadaAsiya Javayant RENEWAL
Maria E AmigonCanadaIvan Magalhaes RENEWAL
Stacey M DoeSpainXuxue Feng QUALIFIED
Cody A GarufiIndiaStephen Shaw NEGOTIATION
Morrow R GauchoArgentinaAnna Fali NEW
Aika A VocelkaIndiaIvan Magalhaes RENEWAL
Octavia J PoquetteIndiaIoni Bowcher RENEWAL
Jones K AmigonAustraliaElwin Sharvill NEGOTIATION
Darci P DarakjySpainBernardo Dominic NEW
Ashley A PaprockiUnited KingdomAsiya Javayant PROPOSAL
Isabel P MacleadSpainOnyama Limba NEGOTIATION
Claire T AmigonIndiaAsiya Javayant UNQUALIFIED
Chavez I IturbideBrazilAmy Elsner NEGOTIATION
James W DarakjyArgentinaAnna Fali NEW
David M IturbideBrazilAsiya Javayant NEGOTIATION
Jones Y VenereJapanElwin Sharvill UNQUALIFIED
Ivar S FlosiItalyElwin Sharvill RENEWAL
Nicolas S MacleadCanadaBernardo Dominic PROPOSAL
Jennifer R VenereItalyAnna Fali NEGOTIATION
Morrow M CaldareraIndiaIoni Bowcher RENEWAL
Wickens J GillianAustraliaAsiya Javayant QUALIFIED
Faith N CaldareraFranceElwin Sharvill QUALIFIED
Darci Q MarrierItalyOnyama Limba UNQUALIFIED
Darci C DilliardCanadaIoni Bowcher PROPOSAL
Leon G IturbideRussiaAnna Fali NEW
Francesco G GauchoIndiaStephen Shaw PROPOSAL
James O SergiArgentinaAnna Fali UNQUALIFIED
Chavez U KolmetzRussiaAmy Elsner QUALIFIED
Jeanfrancois R CaldareraCanadaOnyama Limba UNQUALIFIED
Ivar I MaletUnited KingdomBernardo Dominic QUALIFIED
Mujtaba X WaycottIndiaAnna Fali QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Julie Q MaletIndiaAsiya Javayant QUALIFIED
James S FlosiIndiaXuxue Feng NEGOTIATION
Aditya I SlusarskiCanadaStephen Shaw NEGOTIATION
Cody Q GarufiAustraliaAmy Elsner PROPOSAL
Clifford Q GlickGermanyBernardo Dominic UNQUALIFIED
Ivar X OstroskyUnited KingdomAsiya Javayant NEGOTIATION
Antonio O KolmetzJapanStephen Shaw QUALIFIED
Maisha B DoeBrazilBernardo Dominic NEW
Johnson R PoquetteSpainOnyama Limba RENEWAL
Jefferson Q VenereJapanIvan Magalhaes NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Chavez D WhobreyUnited Kingdom2024-04-16Benton, John B Jr NEGOTIATION30Amy Elsner
1001Misaki K NickaSpain2024-04-10Feltz Printing Service QUALIFIED89Asiya Javayant
1002Leon K KolmetzAustralia2024-04-03Feiner Bros RENEWAL33Onyama Limba
1003Maisha L SchemmerSpain2024-03-28Chapman, Ross E Esq QUALIFIED24Xuxue Feng
1004Antonio P InouyeBrazil2024-04-04Chanay, Jeffrey A Esq RENEWAL31Bernardo Dominic
1005Isabel W WaycottIndia2024-04-19Feltz Printing Service RENEWAL73Stephen Shaw
1006Kaitlin O MacleadUnited Kingdom2024-04-25King, Christopher A Esq NEW79Anna Fali
1007Smith A MacleadBrazil2024-04-14Printing Dimensions UNQUALIFIED39Onyama Limba
1008Arvin N MaletAustralia2024-04-15Dorl, James J Esq NEW3Ioni Bowcher
1009Claire I GarufiRussia2024-03-27Commercial Press QUALIFIED3Anna Fali
1010Salvatore I ChuiCanada2024-04-06Dorl, James J Esq NEGOTIATION91Stephen Shaw
1011Mayumi G BologniaArgentina2024-04-21Dorl, James J Esq PROPOSAL94Xuxue Feng
1012Faith B RimArgentina2024-03-29Benton, John B Jr PROPOSAL46Bernardo Dominic
1013Darci G GarufiCanada2024-04-16Chanay, Jeffrey A Esq QUALIFIED99Xuxue Feng
1014Johnson S FlosiArgentina2024-04-22Buckley Miller Wright UNQUALIFIED32Stephen Shaw
1015Alejandro D KolmetzArgentina2024-04-13Benton, John B Jr RENEWAL97Anna Fali
1016Costa M BriddickIndia2024-04-12Rousseaux, Michael Esq RENEWAL16Anna Fali
1017Smith N AmigonBrazil2024-03-30Feiner Bros QUALIFIED17Amy Elsner
1018Rodrigues O NestleItaly2024-04-14Feiner Bros NEGOTIATION90Ivan Magalhaes
1019Murillo C InouyeGermany2024-04-09Chemel, James L Cpa PROPOSAL25Ioni Bowcher
1020Julie N CaudyJapan2024-03-29Feltz Printing Service PROPOSAL20Bernardo Dominic
1021Costa U DoeUnited Kingdom2024-04-16Morlong Associates UNQUALIFIED34Ioni Bowcher
1022Morrow X RutaFrance2024-03-28Rangoni Of Florence NEW39Ivan Magalhaes
1023Greenwood P FigeroaCanada2024-04-12Rousseaux, Michael Esq NEW89Onyama Limba
1024Adams L VenereItaly2024-04-09Printing Dimensions RENEWAL63Onyama Limba
1025Julie T MaletFrance2024-04-21Benton, John B Jr NEW93Anna Fali
1026Francesco H DarakjyIndia2024-04-18Chanay, Jeffrey A Esq RENEWAL59Stephen Shaw
1027Claire U SchemmerJapan2024-04-17Printing Dimensions UNQUALIFIED71Stephen Shaw
1028Chavez B WhobreyItaly2024-04-19Chemel, James L Cpa UNQUALIFIED33Ivan Magalhaes
1029Mujtaba V DarakjyArgentina2024-04-03Feiner Bros QUALIFIED29Xuxue Feng
1030Stacey X BriddickFrance2024-03-30Chapman, Ross E Esq UNQUALIFIED90Xuxue Feng
1031Tony F AlbaresGermany2024-04-13Truhlar And Truhlar Attys NEW4Onyama Limba
1032Clifford L GauchoAustralia2024-04-07Rangoni Of Florence NEW74Anna Fali
1033Francesco C PerinSpain2024-04-08Benton, John B Jr NEW0Stephen Shaw
1034Smith L CaudyUnited Kingdom2024-03-27Feiner Bros QUALIFIED56Elwin Sharvill
1035Ivar J KuskoIndia2024-04-16Feltz Printing Service RENEWAL8Elwin Sharvill
1036Clifford L MaletAustralia2024-04-12Chemel, James L Cpa PROPOSAL94Bernardo Dominic
1037Octavia D BologniaArgentina2024-04-07Commercial Press UNQUALIFIED12Asiya Javayant
1038James P IturbideSpain2024-04-08Chanay, Jeffrey A Esq UNQUALIFIED13Bernardo Dominic
1039Octavia S VenereGermany2024-04-19Dorl, James J Esq PROPOSAL32Elwin Sharvill
1040Mayumi M BowleyAustralia2024-03-28Chanay, Jeffrey A Esq UNQUALIFIED3Bernardo Dominic
1041Greenwood N KolmetzBrazil2024-04-02Buckley Miller Wright NEW60Amy Elsner
1042Claire O StockhamSpain2024-04-04Commercial Press RENEWAL13Anna Fali
1043Alejandro S VocelkaCanada2024-04-19Truhlar And Truhlar Attys NEW85Bernardo Dominic
1044Kaitlin N MacleadFrance2024-04-05Morlong Associates UNQUALIFIED15Bernardo Dominic
1045Nicolas O GauchoUnited Kingdom2024-04-13Feiner Bros NEGOTIATION22Ioni Bowcher
1046Cody B KuskoGermany2024-04-13Truhlar And Truhlar Attys UNQUALIFIED96Asiya Javayant
1047Leon V BriddickSpain2024-04-25Feiner Bros RENEWAL25Xuxue Feng
1048Ashley Q OldroydIndia2024-04-18Rangoni Of Florence UNQUALIFIED89Amy Elsner
1049Adams F OldroydUnited Kingdom2024-04-02Printing Dimensions QUALIFIED5Elwin Sharvill
Frozen Rows
NameCountryRepresentativeStatus
Salvatore Q VocelkaFranceStephen Shaw UNQUALIFIED
Maisha K SergiArgentinaIoni Bowcher RENEWAL
Izzy H RulapaughGermanyIvan Magalhaes UNQUALIFIED
Cody K RutaJapanElwin Sharvill RENEWAL
Silvio G PerinCanadaAnna Fali QUALIFIED
Jeanfrancois E MacleadUnited KingdomOnyama Limba NEGOTIATION
Aditya N KuskoFranceElwin Sharvill QUALIFIED
Mujtaba N PaprockiBrazilXuxue Feng PROPOSAL
Claire U RoysterArgentinaAsiya Javayant RENEWAL
Silvio D RutaJapanAmy Elsner NEW
Kaitlin B SchemmerFranceBernardo Dominic NEW
Misaki O WieserCanadaAmy Elsner UNQUALIFIED
Sinclair W GauchoBrazilStephen Shaw NEGOTIATION
Ashley O StensethCanadaAsiya Javayant QUALIFIED
Adams W KolmetzJapanBernardo Dominic NEW
Mujtaba V BriddickJapanIvan Magalhaes NEW
Kadeem O MaletAustraliaIvan Magalhaes NEW
Ashley S FlosiBrazilElwin Sharvill QUALIFIED
Aruna I PerinFranceElwin Sharvill UNQUALIFIED
Jefferson J VocelkaAustraliaOnyama Limba RENEWAL
Adams C SergiAustraliaAnna Fali QUALIFIED
Faith Q ShinkoRussiaAmy Elsner UNQUALIFIED
Costa L SergiAustraliaAnna Fali NEGOTIATION
Isabel L AlbaresCanadaAnna Fali QUALIFIED
Julie W CampainSpainXuxue Feng PROPOSAL
Costa X VenereItalyIvan Magalhaes PROPOSAL
Jones P MaletBrazilAsiya Javayant PROPOSAL
Jennifer F MaletAustraliaStephen Shaw RENEWAL
Julie E DarakjyGermanyXuxue Feng NEGOTIATION
Stacey I BologniaIndiaAnna Fali RENEWAL
Antonio W SaylorsBrazilXuxue Feng PROPOSAL
Silvio Q KolmetzRussiaElwin Sharvill UNQUALIFIED
Stacey C AlbaresAustraliaAsiya Javayant UNQUALIFIED
Aruna L SlusarskiGermanyBernardo Dominic QUALIFIED
Julie C KuskoRussiaXuxue Feng NEW
Kadeem P FollerArgentinaAmy Elsner NEGOTIATION
Sinclair B WhobreyIndiaAmy Elsner RENEWAL
Mujtaba X IturbideRussiaElwin Sharvill NEW
Smith H ButtFranceStephen Shaw RENEWAL
Munro G StensethItalyAsiya Javayant PROPOSAL
Wickens F BriddickUnited KingdomStephen Shaw UNQUALIFIED
Adams Z MacleadArgentinaAnna Fali PROPOSAL
Adams A IturbideJapanAnna Fali UNQUALIFIED
Aika U OstroskyItalyXuxue Feng PROPOSAL
Salvatore J RulapaughAustraliaXuxue Feng QUALIFIED
Mujtaba U IturbideRussiaXuxue Feng NEGOTIATION
Adams R StensethJapanXuxue Feng UNQUALIFIED
Munro F BriddickJapanIoni Bowcher NEW
Francesco L FollerAustraliaAnna Fali RENEWAL
Maisha K PaprockiAustraliaIoni Bowcher PROPOSAL
Frozen Columns
Name
Johnson B Whobrey
Rodrigues B Schemmer
Aika O Iturbide
Claire Y Nestle
Francesco S Flosi
Silvio P Gillian
Maisha Z Whobrey
Izzy Y Bowley
Rodrigues U Royster
Misaki S Perin
Isabel B Maclead
Rodrigues H Garufi
Francesco J Garufi
David K Kusko
Isabel E Ostrosky
Adams Y Chui
Stacey D Slusarski
Jeanfrancois Q Figeroa
Salvatore H Malet
Kadeem G Albares
Tony O Tollner
Juan G Royster
Murillo A Bolognia
Mayumi D Bowley
Silvio T Whobrey
Nicolas T Ruta
Aditya Q Nicka
Mujtaba T Saylors
Nicolas K Darakjy
Julie J Caudy
Nicolas O Tollner
Ivar X Saylors
Alejandro M Dilliard
Misaki W Foller
Arvin I Nestle
Wickens Q Doe
David S Campain
Clifford A Albares
Wickens L Rim
Octavia N Oldroyd
Greenwood F Marrier
Adams K Morasca
Costa P Perin
James A Bolognia
Isabel M Garufi
Sinclair K Whobrey
Salvatore M Marrier
Jones Q Ferencz
James Z Sergi
Ashley E Flosi
IdCountryDate
1000France2024-04-10
1001Brazil2024-03-27
1002Germany2024-04-07
1003Italy2024-04-25
1004Spain2024-04-01
1005Russia2024-04-16
1006Australia2024-04-21
1007Italy2024-04-05
1008France2024-04-06
1009France2024-04-21
1010Canada2024-03-27
1011Italy2024-04-02
1012United Kingdom2024-03-28
1013India2024-03-31
1014Japan2024-04-25
1015Brazil2024-03-28
1016Spain2024-03-30
1017Italy2024-03-29
1018Argentina2024-04-04
1019Argentina2024-04-14
1020Canada2024-04-07
1021Canada2024-04-03
1022Germany2024-04-17
1023Brazil2024-04-01
1024Spain2024-04-05
1025Brazil2024-04-21
1026France2024-04-19
1027Brazil2024-04-08
1028Spain2024-04-09
1029Russia2024-04-25
1030Argentina2024-04-15
1031France2024-03-29
1032Argentina2024-04-21
1033Australia2024-04-15
1034France2024-03-30
1035India2024-04-07
1036India2024-03-31
1037Brazil2024-04-23
1038United Kingdom2024-04-06
1039India2024-03-29
1040Canada2024-04-23
1041Australia2024-04-20
1042United Kingdom2024-04-01
1043Japan2024-04-23
1044Russia2024-04-12
1045Germany2024-04-12
1046Canada2024-04-13
1047Italy2024-04-17
1048Argentina2024-04-15
1049Spain2024-04-24

On-Demand Data

NameIdCountryDate
Faith Q Kolmetz1000Brazil2024-04-09
Francesco W Schemmer1001Brazil2024-04-13
Claire T Rulapaugh1002France2024-04-16
Jeanfrancois X Royster1003Argentina2024-04-03
Leon O Ferencz1004United Kingdom2024-04-23
Munro W Figeroa1005India2024-04-18
Aditya D Tollner1006United Kingdom2024-04-09
Murillo T Venere1007Japan2024-04-16
Kadeem D Kolmetz1008Canada2024-04-25
Aika I Waycott1009France2024-04-09
David A Figeroa1010France2024-03-27
Cody S Butt1011Brazil2024-04-03
Mujtaba Y Saylors1012France2024-03-27
Maria W Gillian1013United Kingdom2024-04-17
Tony W Stenseth1014Canada2024-03-30
Kaitlin N Butt1015Germany2024-04-13
Isabel M Venere1016Germany2024-04-25
Deepesh D Butt1017Argentina2024-04-07
Aruna R Caldarera1018Japan2024-04-19
Wickens A Flosi1019Canada2024-04-14
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Clifford P CaldareraUnited KingdomAsiya Javayant NEW
Misaki W ChuiItalyIoni Bowcher NEW
Darci F GillianRussiaIvan Magalhaes NEW
Stacey F MorascaGermanyIoni Bowcher PROPOSAL
Isabel M SchemmerIndiaIvan Magalhaes PROPOSAL
Ashley P WieserCanadaOnyama Limba PROPOSAL
Adams X OldroydIndiaXuxue Feng UNQUALIFIED
Ashley R FollerIndiaStephen Shaw QUALIFIED
Aika T FerenczItalyStephen Shaw NEGOTIATION
Silvio J KuskoBrazilAsiya Javayant NEGOTIATION
Leja D SergiIndiaOnyama Limba NEW
Costa M SaylorsFranceElwin Sharvill PROPOSAL
Isabel R KuskoAustraliaStephen Shaw PROPOSAL
Costa C ChuiAustraliaOnyama Limba NEW
Ricardo T PoquetteBrazilIvan Magalhaes RENEWAL
Leon T RulapaughAustraliaAmy Elsner NEGOTIATION
Salvatore B KuskoIndiaAsiya Javayant NEGOTIATION
Arvin E ShinkoUnited KingdomOnyama Limba NEGOTIATION
Rodrigues J OldroydRussiaIoni Bowcher PROPOSAL
Greenwood E PerinArgentinaOnyama Limba UNQUALIFIED
Mayumi G RutaJapanAmy Elsner RENEWAL
James X WhobreySpainAnna Fali PROPOSAL
Jones M StensethCanadaAnna Fali UNQUALIFIED
Ricardo P RutaAustraliaBernardo Dominic RENEWAL
Kaitlin R FerenczIndiaBernardo Dominic RENEWAL
Costa E RutaBrazilAsiya Javayant UNQUALIFIED
Munro X StockhamBrazilAsiya Javayant RENEWAL
Costa W MacleadRussiaAnna Fali NEW
Greenwood B OldroydJapanBernardo Dominic QUALIFIED
Izzy J PoquetteIndiaBernardo Dominic NEGOTIATION
Murillo Q KolmetzBrazilAsiya Javayant PROPOSAL
Salvatore R PoquetteIndiaAsiya Javayant QUALIFIED
Kaitlin Q NickaBrazilElwin Sharvill RENEWAL
Maisha S CaudyCanadaStephen Shaw UNQUALIFIED
Isabel X RimFranceXuxue Feng NEGOTIATION
Mujtaba G CaudySpainXuxue Feng NEGOTIATION
Darci H PoquetteFranceAsiya Javayant NEW
Kaitlin I RimSpainAnna Fali QUALIFIED
Ivar Z RimCanadaStephen Shaw NEW
Salvatore H RutaCanadaOnyama Limba 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>