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 S BowleySpainBernardo Dominic QUALIFIED
Leja G WhobreyGermanyIoni Bowcher PROPOSAL
Mayumi A PaprockiCanadaBernardo Dominic UNQUALIFIED
Arvin W NestleArgentinaIvan Magalhaes PROPOSAL
Juan D SaylorsCanadaOnyama Limba NEGOTIATION
Izzy B CaudyIndiaBernardo Dominic PROPOSAL
Emily K FerenczIndiaElwin Sharvill UNQUALIFIED
Jones X WhobreySpainBernardo Dominic QUALIFIED
Deepesh V KolmetzItalyAsiya Javayant QUALIFIED
Chavez N RutaAustraliaElwin Sharvill NEW
David T RimFranceIvan Magalhaes NEGOTIATION
Jefferson T GauchoIndiaXuxue Feng RENEWAL
Arvin U FlosiGermanyAnna Fali PROPOSAL
Kadeem J KolmetzAustraliaElwin Sharvill NEGOTIATION
Silvio F MarrierItalyElwin Sharvill RENEWAL
Emily M CaudyIndiaAmy Elsner UNQUALIFIED
Jennifer B MacleadUnited KingdomElwin Sharvill PROPOSAL
Tony J RoysterJapanOnyama Limba PROPOSAL
Johnson Q PerinUnited KingdomIvan Magalhaes RENEWAL
Jones I MaletGermanyIvan Magalhaes NEGOTIATION
Alejandro O MarrierGermanyIoni Bowcher PROPOSAL
Jefferson A KolmetzRussiaElwin Sharvill NEGOTIATION
Clifford E VocelkaIndiaStephen Shaw PROPOSAL
Emily Q FollerItalyStephen Shaw QUALIFIED
Chavez S SaylorsUnited KingdomOnyama Limba UNQUALIFIED
Octavia C GlickAustraliaXuxue Feng QUALIFIED
Adams S WhobreyUnited KingdomAsiya Javayant RENEWAL
Deepesh E DarakjySpainXuxue Feng QUALIFIED
Misaki R GarufiJapanStephen Shaw RENEWAL
Julie L RutaRussiaOnyama Limba PROPOSAL
Darci T BowleyIndiaBernardo Dominic QUALIFIED
David E GlickRussiaAmy Elsner RENEWAL
Costa W StockhamAustraliaIvan Magalhaes RENEWAL
Deepesh P RutaCanadaAsiya Javayant RENEWAL
Darci V OstroskyUnited KingdomXuxue Feng NEGOTIATION
Isabel P BriddickJapanAmy Elsner NEW
Ashley Z ButtSpainAsiya Javayant NEW
Antonio N SaylorsAustraliaXuxue Feng NEGOTIATION
Aika K GlickUnited KingdomXuxue Feng QUALIFIED
Nicolas I ChuiAustraliaAmy Elsner NEW
James M FigeroaRussiaAsiya Javayant QUALIFIED
Kadeem O MacleadCanadaAnna Fali RENEWAL
Faith Y DilliardCanadaIoni Bowcher RENEWAL
Salvatore U MorascaGermanyOnyama Limba RENEWAL
Aika U CaldareraSpainAmy Elsner RENEWAL
Johnson Z SlusarskiIndiaXuxue Feng QUALIFIED
Alejandro Y GillianUnited KingdomIoni Bowcher QUALIFIED
Jefferson G OstroskyRussiaStephen Shaw RENEWAL
Adams Y DoeJapanAmy Elsner NEW
Ashley L InouyeItalyAnna Fali NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Izzy G TollnerCanadaXuxue Feng PROPOSAL
Maria P KuskoIndiaIvan Magalhaes QUALIFIED
Aditya S CampainArgentinaAsiya Javayant RENEWAL
Faith G AlbaresGermanyIoni Bowcher QUALIFIED
Leja E RoysterJapanIvan Magalhaes NEW
Costa W NestleFranceAmy Elsner QUALIFIED
Darci X RoysterSpainIoni Bowcher UNQUALIFIED
Munro O BowleyRussiaAmy Elsner QUALIFIED
Cody X WieserJapanOnyama Limba RENEWAL
Wickens K NestleArgentinaIvan Magalhaes RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jeanfrancois B GauchoIndia2024-03-22Chemel, James L Cpa NEGOTIATION9Asiya Javayant
1001Murillo L RulapaughFrance2024-03-29Morlong Associates UNQUALIFIED47Xuxue Feng
1002Jefferson T PoquetteFrance2024-04-10Printing Dimensions NEGOTIATION85Ivan Magalhaes
1003Greenwood U AlbaresArgentina2024-03-23Chapman, Ross E Esq UNQUALIFIED53Asiya Javayant
1004Kadeem H KuskoIndia2024-04-04Buckley Miller Wright QUALIFIED39Ivan Magalhaes
1005Jones S GarufiRussia2024-04-03Feltz Printing Service PROPOSAL63Stephen Shaw
1006Johnson A WaycottFrance2024-04-16Rousseaux, Michael Esq PROPOSAL23Elwin Sharvill
1007Costa N ChuiGermany2024-03-22Rangoni Of Florence UNQUALIFIED56Elwin Sharvill
1008Mujtaba L ButtSpain2024-03-20Morlong Associates UNQUALIFIED72Asiya Javayant
1009Wickens Q ChuiUnited Kingdom2024-03-25Chemel, James L Cpa PROPOSAL14Xuxue Feng
1010Aditya K RoysterArgentina2024-03-20King, Christopher A Esq UNQUALIFIED1Amy Elsner
1011Julie V ButtJapan2024-04-07Benton, John B Jr PROPOSAL69Ivan Magalhaes
1012Rodrigues Q OldroydItaly2024-03-31Benton, John B Jr QUALIFIED46Elwin Sharvill
1013Silvio M GlickJapan2024-04-02King, Christopher A Esq NEW43Anna Fali
1014Greenwood V VocelkaIndia2024-04-07Feltz Printing Service RENEWAL83Asiya Javayant
1015Salvatore X MaletRussia2024-03-28King, Christopher A Esq RENEWAL18Ivan Magalhaes
1016Kadeem L BowleyGermany2024-03-21Benton, John B Jr NEGOTIATION94Bernardo Dominic
1017Cody D SchemmerItaly2024-03-27Chapman, Ross E Esq NEGOTIATION62Stephen Shaw
1018David V RutaSpain2024-04-07Printing Dimensions UNQUALIFIED41Asiya Javayant
1019Murillo I DoeCanada2024-04-03Chanay, Jeffrey A Esq NEW47Elwin Sharvill
1020Adams L BriddickUnited Kingdom2024-04-02Truhlar And Truhlar Attys UNQUALIFIED77Ivan Magalhaes
1021Leja F RoysterSpain2024-03-31Feiner Bros NEGOTIATION21Anna Fali
1022Jennifer X BologniaItaly2024-04-08Chanay, Jeffrey A Esq RENEWAL7Anna Fali
1023Octavia S StockhamIndia2024-04-12Chemel, James L Cpa RENEWAL45Ioni Bowcher
1024Maria A WieserFrance2024-03-24Buckley Miller Wright QUALIFIED73Ioni Bowcher
1025Alejandro P StensethArgentina2024-04-05Chemel, James L Cpa RENEWAL53Elwin Sharvill
1026Ashley P BriddickAustralia2024-04-05Truhlar And Truhlar Attys NEGOTIATION31Onyama Limba
1027Johnson J SlusarskiBrazil2024-04-05Rousseaux, Michael Esq NEW72Ivan Magalhaes
1028Kaitlin W BologniaBrazil2024-03-30Feiner Bros RENEWAL65Xuxue Feng
1029Aditya J BowleyArgentina2024-03-28Feiner Bros RENEWAL76Stephen Shaw
1030Smith F WaycottItaly2024-04-02Morlong Associates NEGOTIATION28Ioni Bowcher
1031Deepesh R PaprockiArgentina2024-03-31Chemel, James L Cpa QUALIFIED8Anna Fali
1032Jennifer W IturbideSpain2024-03-31Rangoni Of Florence NEW2Xuxue Feng
1033Costa S GlickBrazil2024-04-13Chanay, Jeffrey A Esq PROPOSAL40Anna Fali
1034Deepesh S NestleItaly2024-04-04Buckley Miller Wright NEW56Ivan Magalhaes
1035Ivar T PaprockiUnited Kingdom2024-04-03Feltz Printing Service QUALIFIED75Xuxue Feng
1036Jeanfrancois Z RimItaly2024-03-22Chemel, James L Cpa NEGOTIATION11Ioni Bowcher
1037Murillo X FerenczArgentina2024-03-31Chemel, James L Cpa NEW71Amy Elsner
1038Antonio W RulapaughBrazil2024-04-03Feiner Bros RENEWAL56Ioni Bowcher
1039Leon W AlbaresSpain2024-04-17Feiner Bros UNQUALIFIED0Elwin Sharvill
1040Juan U SergiJapan2024-04-08Buckley Miller Wright RENEWAL18Ioni Bowcher
1041Sinclair Q RimCanada2024-03-26Buckley Miller Wright QUALIFIED54Anna Fali
1042Aditya J VocelkaAustralia2024-04-04Rangoni Of Florence UNQUALIFIED41Ivan Magalhaes
1043Julie M SlusarskiItaly2024-03-31Truhlar And Truhlar Attys RENEWAL91Ioni Bowcher
1044David W StensethFrance2024-03-31Chemel, James L Cpa NEW88Xuxue Feng
1045Antonio D RulapaughArgentina2024-03-25Benton, John B Jr NEGOTIATION83Bernardo Dominic
1046Mayumi F VenereCanada2024-04-10Feltz Printing Service RENEWAL73Onyama Limba
1047Munro G MacleadSpain2024-03-25Dorl, James J Esq NEGOTIATION88Anna Fali
1048Claire D CampainBrazil2024-04-10Printing Dimensions RENEWAL32Amy Elsner
1049Francesco J PaprockiBrazil2024-03-28Truhlar And Truhlar Attys NEW21Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Jennifer R SchemmerUnited KingdomAmy Elsner UNQUALIFIED
Kaitlin R RimBrazilAmy Elsner NEGOTIATION
Leon V RimIndiaBernardo Dominic RENEWAL
Rodrigues R WhobreyCanadaAnna Fali PROPOSAL
Morrow F SlusarskiFranceStephen Shaw NEGOTIATION
Aruna E ButtBrazilElwin Sharvill NEW
Emily Y SergiGermanyElwin Sharvill UNQUALIFIED
Maria Y FollerJapanAmy Elsner RENEWAL
Aika O CaldareraCanadaIoni Bowcher RENEWAL
Rodrigues D PaprockiItalyAnna Fali NEW
Ivar H CaldareraUnited KingdomBernardo Dominic NEGOTIATION
Ricardo J IturbideJapanAsiya Javayant PROPOSAL
Nicolas M DarakjyItalyOnyama Limba UNQUALIFIED
Octavia O DilliardCanadaOnyama Limba UNQUALIFIED
Juan O GarufiJapanIoni Bowcher NEGOTIATION
Sinclair Z DarakjyRussiaStephen Shaw PROPOSAL
Chavez O BriddickRussiaBernardo Dominic NEW
Sinclair C CaudyUnited KingdomIoni Bowcher UNQUALIFIED
Darci N SlusarskiCanadaBernardo Dominic UNQUALIFIED
Jones T InouyeBrazilIoni Bowcher UNQUALIFIED
Greenwood W StockhamFranceXuxue Feng UNQUALIFIED
Maria L TollnerJapanAnna Fali QUALIFIED
Isabel P InouyeAustraliaAnna Fali NEW
Chavez M RimIndiaBernardo Dominic UNQUALIFIED
Greenwood Q WhobreyRussiaOnyama Limba RENEWAL
Deepesh Z StockhamFranceAnna Fali UNQUALIFIED
Greenwood W CampainJapanXuxue Feng UNQUALIFIED
Arvin C PerinUnited KingdomAnna Fali UNQUALIFIED
Ashley R BowleyRussiaBernardo Dominic UNQUALIFIED
Antonio B GauchoFranceXuxue Feng NEW
Stacey P CaldareraAustraliaElwin Sharvill PROPOSAL
Ricardo T RutaJapanAmy Elsner RENEWAL
Antonio D ShinkoItalyXuxue Feng NEGOTIATION
Smith X PoquetteAustraliaIvan Magalhaes UNQUALIFIED
Greenwood U GlickArgentinaAsiya Javayant UNQUALIFIED
Aruna E CaldareraRussiaIvan Magalhaes RENEWAL
Chavez W CaldareraRussiaIoni Bowcher NEW
Leja J FlosiCanadaAsiya Javayant UNQUALIFIED
Julie L BologniaArgentinaIoni Bowcher NEW
Emily J MarrierAustraliaAnna Fali UNQUALIFIED
Maria K SchemmerArgentinaIvan Magalhaes UNQUALIFIED
Cody V AlbaresCanadaElwin Sharvill NEW
Deepesh J BriddickBrazilBernardo Dominic QUALIFIED
Sinclair W MaletJapanIvan Magalhaes UNQUALIFIED
Greenwood M StockhamIndiaOnyama Limba UNQUALIFIED
Aditya P StensethSpainAmy Elsner NEW
Misaki L DoeFranceXuxue Feng RENEWAL
Aika J BowleyGermanyIoni Bowcher NEGOTIATION
Murillo P GauchoItalyOnyama Limba NEGOTIATION
Aika H OstroskyArgentinaStephen Shaw NEGOTIATION
Frozen Columns
Name
Misaki M Tollner
Aruna H Stockham
Faith I Tollner
Ivar C Bolognia
Juan R Caldarera
Morrow I Ferencz
Deepesh H Schemmer
Leja D Caldarera
Jennifer P Foller
David V Tollner
Nicolas C Nicka
Faith A Glick
Jennifer K Wieser
Aruna L Slusarski
Emily H Darakjy
Kadeem Y Ferencz
Maria M Perin
Clifford V Stenseth
Antonio Z Bolognia
Smith C Bolognia
Juan Y Saylors
Arvin S Briddick
Mayumi W Flosi
Chavez D Amigon
Ivar K Bowley
Jefferson A Oldroyd
Emily U Albares
Emily H Caldarera
Faith S Vocelka
Faith M Schemmer
Deepesh X Maclead
Ricardo J Oldroyd
Leja J Gaucho
Juan H Paprocki
Murillo J Caldarera
Antonio H Waycott
Clifford J Butt
Ricardo Z Doe
Kaitlin Q Flosi
Costa O Malet
Izzy G Perin
Misaki D Caudy
Francesco A Royster
Stacey A Butt
Maisha Z Campain
Aika Q Gillian
Jennifer V Chui
Maisha B Chui
Jennifer C Wieser
Johnson Y Stockham
IdCountryDate
1000Italy2024-03-28
1001United Kingdom2024-04-10
1002Italy2024-03-30
1003Brazil2024-04-08
1004Russia2024-03-28
1005Japan2024-03-25
1006Germany2024-04-05
1007Russia2024-03-25
1008Italy2024-04-16
1009Russia2024-04-07
1010Brazil2024-03-27
1011Argentina2024-03-24
1012United Kingdom2024-03-27
1013Brazil2024-03-29
1014Germany2024-04-06
1015Australia2024-03-29
1016Brazil2024-04-04
1017Argentina2024-04-17
1018Japan2024-03-22
1019Canada2024-04-08
1020Japan2024-03-22
1021Russia2024-03-30
1022Canada2024-04-01
1023Australia2024-04-12
1024Italy2024-03-27
1025Australia2024-03-22
1026Japan2024-04-17
1027Italy2024-03-19
1028Brazil2024-04-01
1029Brazil2024-04-02
1030France2024-04-03
1031Japan2024-04-07
1032Germany2024-04-06
1033Germany2024-04-08
1034Argentina2024-04-15
1035Japan2024-04-10
1036Germany2024-03-19
1037Japan2024-04-16
1038India2024-04-13
1039Spain2024-04-11
1040Russia2024-04-03
1041Japan2024-03-28
1042United Kingdom2024-03-22
1043Italy2024-03-24
1044France2024-03-27
1045Canada2024-04-01
1046Argentina2024-04-09
1047Germany2024-03-20
1048Canada2024-04-08
1049United Kingdom2024-03-30

On-Demand Data

NameIdCountryDate
Misaki Q Kolmetz1000Japan2024-04-13
Octavia Z Stenseth1001Australia2024-04-03
Ricardo H Royster1002Canada2024-03-21
Aruna E Stockham1003Russia2024-03-30
James X Shinko1004Germany2024-04-07
Rodrigues A Kusko1005France2024-03-28
Silvio V Foller1006India2024-04-17
Tony H Bolognia1007France2024-04-10
Wickens C Sergi1008Australia2024-04-12
Leon A Darakjy1009Germany2024-04-14
Faith G Stenseth1010Argentina2024-03-21
Arvin C Doe1011Germany2024-04-07
Leja U Foller1012Argentina2024-03-21
Jeanfrancois B Malet1013Japan2024-04-05
Arvin A Tollner1014Japan2024-04-08
Smith L Oldroyd1015Brazil2024-03-30
Deepesh T Wieser1016Spain2024-04-05
Chavez I Kolmetz1017Australia2024-03-30
Alejandro V Kolmetz1018Spain2024-04-03
Aika M Schemmer1019Spain2024-03-26
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
James C FerenczFranceAnna Fali UNQUALIFIED
Aruna G BowleyRussiaXuxue Feng NEGOTIATION
Ashley X TollnerGermanyOnyama Limba NEW
Jennifer G VocelkaRussiaElwin Sharvill UNQUALIFIED
Claire V DilliardAustraliaAsiya Javayant NEGOTIATION
Jones Z DarakjyItalyIvan Magalhaes PROPOSAL
Ricardo R AmigonRussiaElwin Sharvill RENEWAL
Ashley Y ChuiGermanyElwin Sharvill NEGOTIATION
Octavia G AlbaresCanadaXuxue Feng PROPOSAL
Wickens B CampainJapanBernardo Dominic QUALIFIED
Salvatore D MaletAustraliaOnyama Limba QUALIFIED
Jennifer J AlbaresJapanXuxue Feng QUALIFIED
Julie Q PaprockiIndiaXuxue Feng QUALIFIED
Nicolas F KolmetzGermanyIoni Bowcher NEGOTIATION
Faith L FlosiBrazilIvan Magalhaes RENEWAL
Tony B OstroskyCanadaAmy Elsner PROPOSAL
Cody Y InouyeRussiaAsiya Javayant UNQUALIFIED
Morrow M OldroydRussiaElwin Sharvill RENEWAL
Costa A PaprockiJapanIoni Bowcher RENEWAL
Ashley J SergiJapanAnna Fali QUALIFIED
Maisha C CaudyGermanyAsiya Javayant PROPOSAL
Arvin E CaldareraIndiaAnna Fali RENEWAL
Juan T PaprockiJapanOnyama Limba UNQUALIFIED
Octavia Q CaudyGermanyElwin Sharvill NEGOTIATION
Deepesh Z WaycottArgentinaElwin Sharvill RENEWAL
Mujtaba M WaycottRussiaAsiya Javayant NEGOTIATION
Chavez E StensethGermanyAnna Fali QUALIFIED
Johnson N CaudyCanadaOnyama Limba NEW
Nicolas C NickaBrazilStephen Shaw NEW
Antonio B RimRussiaBernardo Dominic PROPOSAL
Misaki B ChuiRussiaIvan Magalhaes QUALIFIED
Kaitlin E NestleBrazilAmy Elsner QUALIFIED
Jeanfrancois B GauchoBrazilElwin Sharvill NEGOTIATION
Aruna S VenereFranceIoni Bowcher NEGOTIATION
David L MorascaBrazilAnna Fali UNQUALIFIED
Munro K MorascaFranceAmy Elsner RENEWAL
Silvio X SlusarskiRussiaElwin Sharvill UNQUALIFIED
Murillo X ButtGermanyOnyama Limba RENEWAL
Leja I ShinkoRussiaIvan Magalhaes UNQUALIFIED
Jennifer M BologniaBrazilElwin 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>