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
Emily D IturbideRussiaIoni Bowcher UNQUALIFIED
Antonio Z CaldareraUnited KingdomAnna Fali PROPOSAL
James S GauchoFranceElwin Sharvill RENEWAL
Jeanfrancois D RutaUnited KingdomBernardo Dominic UNQUALIFIED
Mujtaba W RutaRussiaStephen Shaw UNQUALIFIED
Faith B MaletItalyIvan Magalhaes NEGOTIATION
Sinclair W CaldareraIndiaOnyama Limba NEGOTIATION
David C WieserItalyAsiya Javayant NEGOTIATION
Deepesh B VocelkaBrazilElwin Sharvill RENEWAL
Maria F DoeIndiaBernardo Dominic UNQUALIFIED
Mujtaba S GarufiIndiaBernardo Dominic QUALIFIED
Aika K PaprockiIndiaBernardo Dominic PROPOSAL
Leja C BowleyRussiaStephen Shaw NEW
Costa C WhobreyCanadaStephen Shaw UNQUALIFIED
Maisha F DarakjyJapanOnyama Limba PROPOSAL
Kaitlin A GillianCanadaIvan Magalhaes QUALIFIED
Greenwood B WieserJapanAnna Fali NEW
Aruna S NestleArgentinaOnyama Limba UNQUALIFIED
Jennifer T FollerAustraliaIoni Bowcher QUALIFIED
Francesco A RimSpainIoni Bowcher NEW
Clifford P BologniaIndiaOnyama Limba PROPOSAL
Silvio F BowleySpainElwin Sharvill NEGOTIATION
Rodrigues N MaletItalyAnna Fali QUALIFIED
Julie U MacleadRussiaAsiya Javayant RENEWAL
Deepesh X FlosiBrazilAmy Elsner NEW
James P TollnerSpainAnna Fali QUALIFIED
Maisha M PaprockiFranceBernardo Dominic UNQUALIFIED
Silvio X BologniaUnited KingdomAsiya Javayant NEGOTIATION
Leja Q FerenczRussiaXuxue Feng PROPOSAL
Morrow B OstroskyUnited KingdomIoni Bowcher NEW
Octavia N PoquetteUnited KingdomAnna Fali PROPOSAL
Munro J SlusarskiUnited KingdomBernardo Dominic NEGOTIATION
Chavez V MorascaFranceBernardo Dominic QUALIFIED
Aruna I AlbaresRussiaAmy Elsner UNQUALIFIED
Antonio Y BowleyUnited KingdomOnyama Limba QUALIFIED
Aditya A GauchoSpainOnyama Limba NEGOTIATION
Emily V PerinJapanAnna Fali NEW
Francesco B KuskoFranceAnna Fali PROPOSAL
Aika F BowleyUnited KingdomStephen Shaw NEW
Mayumi W SlusarskiCanadaAmy Elsner QUALIFIED
Isabel M RulapaughCanadaIvan Magalhaes RENEWAL
Maria M SchemmerJapanIvan Magalhaes QUALIFIED
Arvin Y WaycottUnited KingdomElwin Sharvill NEGOTIATION
Murillo Z CampainGermanyElwin Sharvill RENEWAL
Nicolas Z CaudySpainBernardo Dominic UNQUALIFIED
Clifford Y OldroydGermanyOnyama Limba PROPOSAL
Maria P PaprockiJapanBernardo Dominic RENEWAL
Murillo I CaudyIndiaAsiya Javayant UNQUALIFIED
Isabel N BologniaIndiaIoni Bowcher UNQUALIFIED
Maisha E DilliardArgentinaElwin Sharvill NEW
Horizontal
NameCountryRepresentativeStatus
Munro C OstroskyItalyBernardo Dominic RENEWAL
Adams R KuskoAustraliaBernardo Dominic RENEWAL
Morrow T FigeroaAustraliaIvan Magalhaes NEW
Ivar S DilliardJapanAsiya Javayant RENEWAL
Misaki T ShinkoGermanyIvan Magalhaes QUALIFIED
Leja F GauchoBrazilXuxue Feng QUALIFIED
Leja Q IturbideArgentinaBernardo Dominic PROPOSAL
Smith Z ShinkoItalyAmy Elsner RENEWAL
Mujtaba C GarufiUnited KingdomIvan Magalhaes UNQUALIFIED
Cody D NestleGermanyXuxue Feng PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Rodrigues O WieserUnited Kingdom2024-05-08Morlong Associates RENEWAL14Asiya Javayant
1001Antonio S PerinJapan2024-04-28Dorl, James J Esq PROPOSAL54Xuxue Feng
1002Leon O VenereFrance2024-05-13Buckley Miller Wright UNQUALIFIED75Onyama Limba
1003Tony D MacleadGermany2024-04-29Buckley Miller Wright NEW10Ioni Bowcher
1004Jefferson S FigeroaCanada2024-05-16Commercial Press RENEWAL43Ioni Bowcher
1005Juan L StensethArgentina2024-04-28Chanay, Jeffrey A Esq UNQUALIFIED22Ivan Magalhaes
1006David T MarrierJapan2024-05-06Chemel, James L Cpa NEGOTIATION61Anna Fali
1007Kaitlin W GillianBrazil2024-05-04King, Christopher A Esq PROPOSAL39Xuxue Feng
1008Stacey O BowleyArgentina2024-04-27Benton, John B Jr RENEWAL16Elwin Sharvill
1009Leja D RimUnited Kingdom2024-05-19Rangoni Of Florence NEGOTIATION77Amy Elsner
1010James V DilliardCanada2024-05-09Truhlar And Truhlar Attys NEGOTIATION22Amy Elsner
1011Aditya N ChuiBrazil2024-05-15Chapman, Ross E Esq UNQUALIFIED29Anna Fali
1012Arvin S WieserUnited Kingdom2024-04-30Chanay, Jeffrey A Esq RENEWAL66Asiya Javayant
1013Aika V StensethRussia2024-05-13Printing Dimensions PROPOSAL84Xuxue Feng
1014Silvio F AmigonAustralia2024-05-12Printing Dimensions PROPOSAL0Ivan Magalhaes
1015Cody S VocelkaUnited Kingdom2024-05-05Feltz Printing Service NEGOTIATION78Ioni Bowcher
1016Mujtaba F PoquetteFrance2024-05-09Morlong Associates QUALIFIED7Ivan Magalhaes
1017Jennifer N WhobreySpain2024-05-02Morlong Associates RENEWAL13Stephen Shaw
1018Deepesh H BowleySpain2024-04-21Feiner Bros QUALIFIED42Xuxue Feng
1019Nicolas O PoquetteGermany2024-05-05Feltz Printing Service NEW91Ioni Bowcher
1020Darci B WhobreyIndia2024-04-28Printing Dimensions NEW88Xuxue Feng
1021Rodrigues G GauchoItaly2024-04-21Commercial Press NEW70Asiya Javayant
1022Alejandro S FigeroaGermany2024-04-25Printing Dimensions NEGOTIATION13Ivan Magalhaes
1023Murillo G KolmetzCanada2024-05-03Chanay, Jeffrey A Esq RENEWAL66Onyama Limba
1024Maisha R MorascaGermany2024-05-10Morlong Associates RENEWAL78Ioni Bowcher
1025Deepesh J OldroydFrance2024-04-27Feiner Bros PROPOSAL9Onyama Limba
1026Smith U FigeroaCanada2024-04-21Rousseaux, Michael Esq PROPOSAL23Asiya Javayant
1027Murillo E RoysterFrance2024-04-30Dorl, James J Esq QUALIFIED35Anna Fali
1028Claire N DoeBrazil2024-05-04Rangoni Of Florence NEW96Onyama Limba
1029Ricardo Y GauchoFrance2024-05-07Truhlar And Truhlar Attys NEGOTIATION47Asiya Javayant
1030Faith X KolmetzGermany2024-05-17Commercial Press PROPOSAL37Bernardo Dominic
1031Jones S RulapaughFrance2024-04-29Rousseaux, Michael Esq QUALIFIED66Stephen Shaw
1032Francesco C BowleySpain2024-05-19Benton, John B Jr UNQUALIFIED22Amy Elsner
1033Clifford S KolmetzCanada2024-04-24Buckley Miller Wright RENEWAL49Bernardo Dominic
1034Darci S PerinFrance2024-05-11Truhlar And Truhlar Attys QUALIFIED48Ivan Magalhaes
1035Alejandro B VocelkaCanada2024-05-14Feltz Printing Service QUALIFIED76Xuxue Feng
1036Jefferson L BologniaBrazil2024-04-25Chapman, Ross E Esq RENEWAL52Ivan Magalhaes
1037Salvatore Z MarrierSpain2024-05-01Chemel, James L Cpa NEGOTIATION34Asiya Javayant
1038Deepesh L SergiGermany2024-05-08Feltz Printing Service NEW87Anna Fali
1039Faith K PoquetteIndia2024-05-13Dorl, James J Esq NEW32Elwin Sharvill
1040Tony H FigeroaAustralia2024-05-15Commercial Press NEGOTIATION69Ivan Magalhaes
1041Aika U VocelkaItaly2024-05-11Chanay, Jeffrey A Esq QUALIFIED48Elwin Sharvill
1042Francesco W PerinUnited Kingdom2024-04-29Truhlar And Truhlar Attys UNQUALIFIED58Stephen Shaw
1043Jennifer F GlickGermany2024-05-17Feltz Printing Service PROPOSAL95Onyama Limba
1044Aditya Z AlbaresBrazil2024-04-30Buckley Miller Wright UNQUALIFIED94Ioni Bowcher
1045Nicolas Y AlbaresFrance2024-04-30Commercial Press NEGOTIATION85Bernardo Dominic
1046Maisha G DarakjyJapan2024-05-20Dorl, James J Esq QUALIFIED54Xuxue Feng
1047Johnson W BologniaGermany2024-04-28Buckley Miller Wright RENEWAL70Amy Elsner
1048Isabel Z MaletAustralia2024-04-27Dorl, James J Esq PROPOSAL87Amy Elsner
1049Tony S KuskoCanada2024-05-07King, Christopher A Esq PROPOSAL27Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
Isabel F PerinFranceAmy Elsner RENEWAL
Maria D FlosiUnited KingdomIoni Bowcher QUALIFIED
Adams E CaudySpainStephen Shaw RENEWAL
Jennifer W VenereFranceElwin Sharvill NEGOTIATION
Ricardo V GlickIndiaBernardo Dominic PROPOSAL
Smith J GlickUnited KingdomXuxue Feng NEW
Misaki Y DilliardItalyStephen Shaw NEW
Salvatore H RimArgentinaXuxue Feng PROPOSAL
Smith P IturbideRussiaElwin Sharvill PROPOSAL
Greenwood J CampainItalyAmy Elsner NEW
Darci G MaletUnited KingdomElwin Sharvill NEGOTIATION
Morrow E RulapaughBrazilElwin Sharvill PROPOSAL
Aruna S FerenczSpainXuxue Feng NEGOTIATION
Francesco H BriddickSpainBernardo Dominic RENEWAL
Murillo C PaprockiIndiaAmy Elsner NEGOTIATION
Kadeem R KuskoJapanAmy Elsner PROPOSAL
Stacey W ChuiGermanyIoni Bowcher RENEWAL
Costa Q WhobreyJapanStephen Shaw NEGOTIATION
Smith F RoysterGermanyOnyama Limba NEGOTIATION
Rodrigues J NestleAustraliaStephen Shaw NEW
Aika I AmigonAustraliaAmy Elsner QUALIFIED
Smith C NestleArgentinaAmy Elsner NEGOTIATION
Clifford M MacleadSpainElwin Sharvill UNQUALIFIED
Jones T MaletBrazilBernardo Dominic RENEWAL
Nicolas U ChuiRussiaAsiya Javayant UNQUALIFIED
Salvatore J GlickCanadaStephen Shaw NEW
Ashley C StensethItalyXuxue Feng PROPOSAL
Munro O DarakjySpainIvan Magalhaes NEGOTIATION
Stacey D DoeJapanBernardo Dominic NEW
Ricardo Y GlickItalyXuxue Feng NEW
Smith D FerenczJapanStephen Shaw QUALIFIED
Isabel K StensethRussiaOnyama Limba NEW
Deepesh E FigeroaArgentinaAnna Fali PROPOSAL
Arvin S MaletRussiaIoni Bowcher NEGOTIATION
Adams D RutaFranceAsiya Javayant QUALIFIED
Antonio J GlickItalyAmy Elsner PROPOSAL
Antonio U NestleItalyIvan Magalhaes RENEWAL
Juan V ButtAustraliaAnna Fali NEW
David C ChuiGermanyAmy Elsner QUALIFIED
Murillo M GarufiUnited KingdomOnyama Limba UNQUALIFIED
Kadeem C BowleyItalyElwin Sharvill QUALIFIED
David V BriddickItalyOnyama Limba NEGOTIATION
David G ShinkoIndiaAnna Fali NEGOTIATION
Mujtaba F WaycottBrazilElwin Sharvill QUALIFIED
Stacey N BowleyArgentinaXuxue Feng PROPOSAL
Aika X ChuiCanadaBernardo Dominic UNQUALIFIED
Kaitlin E KolmetzCanadaElwin Sharvill NEW
Claire O SaylorsCanadaOnyama Limba RENEWAL
David Z WieserBrazilElwin Sharvill NEGOTIATION
Jones D AmigonRussiaAnna Fali PROPOSAL
Frozen Columns
Name
Mujtaba H Briddick
Octavia Y Briddick
Costa Y Malet
Salvatore X Saylors
Morrow L Royster
Aika C Royster
Ivar K Albares
Emily O Bowley
Maisha F Maclead
Juan D Dilliard
Leja S Waycott
Misaki F Nestle
Aruna E Briddick
Isabel I Butt
James I Chui
Costa S Malet
Mayumi U Iturbide
Mujtaba T Stockham
Jones A Poquette
Kadeem G Darakjy
Aditya I Darakjy
Izzy B Inouye
Mayumi F Royster
Jones O Inouye
Silvio O Doe
Isabel A Iturbide
Darci F Bowley
James X Kolmetz
Jeanfrancois T Gaucho
Jeanfrancois A Tollner
Ashley P Caudy
Mayumi Y Nestle
Ashley X Caudy
Aika P Garufi
Silvio P Waycott
Murillo U Nestle
Deepesh N Gillian
David Q Campain
Maisha R Figeroa
Faith J Waycott
Claire W Morasca
Jeanfrancois Y Nicka
Chavez Z Inouye
Julie F Vocelka
Smith A Ruta
Mujtaba F Kolmetz
Francesco Q Nestle
Leja C Malet
Greenwood V Paprocki
Tony F Albares
IdCountryDate
1000Germany2024-05-06
1001Australia2024-05-17
1002United Kingdom2024-05-03
1003Spain2024-05-09
1004Brazil2024-05-14
1005Canada2024-05-12
1006France2024-05-13
1007Italy2024-05-06
1008Russia2024-05-07
1009Russia2024-05-14
1010India2024-04-27
1011India2024-05-06
1012France2024-04-23
1013United Kingdom2024-05-12
1014Russia2024-04-27
1015Russia2024-04-29
1016Japan2024-05-14
1017Spain2024-04-30
1018India2024-05-02
1019Russia2024-04-28
1020United Kingdom2024-04-25
1021France2024-05-07
1022Spain2024-04-29
1023India2024-05-19
1024Russia2024-04-23
1025Germany2024-05-03
1026India2024-05-13
1027Australia2024-04-28
1028Italy2024-04-26
1029Spain2024-04-26
1030Australia2024-05-10
1031India2024-04-21
1032United Kingdom2024-04-22
1033Japan2024-04-24
1034Canada2024-04-26
1035India2024-05-20
1036Brazil2024-05-13
1037Brazil2024-05-06
1038France2024-05-09
1039Canada2024-05-18
1040Brazil2024-04-30
1041Brazil2024-05-09
1042France2024-04-25
1043Argentina2024-04-24
1044India2024-05-08
1045Brazil2024-05-06
1046Australia2024-04-22
1047Spain2024-05-11
1048Russia2024-05-11
1049Spain2024-04-29

On-Demand Data

NameIdCountryDate
Sinclair H Chui1000United Kingdom2024-05-20
Claire O Albares1001India2024-05-18
Salvatore Y Dilliard1002Germany2024-04-27
Aika W Paprocki1003Spain2024-05-09
Jones Y Paprocki1004Japan2024-04-25
Chavez C Ferencz1005India2024-05-04
Kaitlin E Stockham1006Russia2024-05-16
Cody W Schemmer1007India2024-04-29
Claire X Waycott1008Spain2024-05-17
Greenwood T Ferencz1009Germany2024-05-15
Misaki Y Venere1010Canada2024-05-16
Murillo T Chui1011France2024-04-26
Jeanfrancois D Morasca1012Brazil2024-05-02
Maisha J Kusko1013Canada2024-04-28
Leon R Perin1014Spain2024-05-09
Kaitlin L Perin1015Australia2024-05-18
Emily E Garufi1016Italy2024-05-04
Ricardo M Garufi1017Spain2024-05-05
Jennifer Q Chui1018Russia2024-05-13
Emily D Paprocki1019Japan2024-04-22
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Faith O KolmetzCanadaOnyama Limba PROPOSAL
Antonio L KolmetzFranceAmy Elsner UNQUALIFIED
Darci F ShinkoFranceBernardo Dominic UNQUALIFIED
Tony U GarufiGermanyIvan Magalhaes NEW
Jennifer J OldroydBrazilAmy Elsner RENEWAL
Octavia S PerinAustraliaIvan Magalhaes UNQUALIFIED
Adams V StensethArgentinaXuxue Feng NEW
Aika C VocelkaAustraliaBernardo Dominic UNQUALIFIED
Ashley P VenereUnited KingdomAsiya Javayant PROPOSAL
David T PerinGermanyElwin Sharvill UNQUALIFIED
Misaki P FerenczUnited KingdomElwin Sharvill RENEWAL
Clifford E NickaArgentinaAnna Fali QUALIFIED
Morrow N BowleyGermanyIvan Magalhaes PROPOSAL
Darci O PaprockiAustraliaStephen Shaw NEGOTIATION
Kadeem N MaletFranceIoni Bowcher QUALIFIED
Rodrigues C CaudyJapanElwin Sharvill QUALIFIED
Cody G BriddickGermanyAnna Fali NEW
Izzy A PaprockiSpainXuxue Feng UNQUALIFIED
Jennifer K GauchoArgentinaIvan Magalhaes NEW
Izzy G DilliardGermanyAmy Elsner NEGOTIATION
Isabel A SlusarskiBrazilAsiya Javayant QUALIFIED
Misaki E GarufiIndiaStephen Shaw UNQUALIFIED
Wickens E VenereSpainAnna Fali QUALIFIED
Leon X SergiAustraliaAsiya Javayant NEGOTIATION
Johnson D SlusarskiItalyAmy Elsner QUALIFIED
Sinclair S StensethCanadaAnna Fali QUALIFIED
Juan Z IturbideItalyAmy Elsner QUALIFIED
Izzy D GillianUnited KingdomBernardo Dominic NEW
Juan K FollerIndiaIvan Magalhaes NEW
Munro I BriddickRussiaXuxue Feng RENEWAL
Nicolas N StockhamFranceElwin Sharvill QUALIFIED
Jefferson E InouyeSpainAsiya Javayant NEGOTIATION
Aditya N MaletItalyOnyama Limba PROPOSAL
Morrow Q OstroskyItalyAnna Fali NEW
Octavia R VenereSpainAsiya Javayant NEW
Deepesh W GillianGermanyIvan Magalhaes UNQUALIFIED
Jefferson J GlickAustraliaAsiya Javayant PROPOSAL
Emily Y MaletAustraliaIoni Bowcher NEGOTIATION
Munro D FollerItalyAsiya Javayant RENEWAL
Ricardo H MorascaFranceElwin Sharvill UNQUALIFIED

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