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
Morrow Q FlosiFranceAmy Elsner PROPOSAL
Kadeem U DilliardBrazilAsiya Javayant NEW
James W RulapaughGermanyStephen Shaw QUALIFIED
Izzy C KolmetzAustraliaIvan Magalhaes PROPOSAL
Clifford W BologniaGermanyStephen Shaw RENEWAL
Francesco T CaldareraItalyAmy Elsner RENEWAL
Kaitlin H DarakjyFranceAmy Elsner NEW
Francesco C WieserFranceStephen Shaw NEW
Kaitlin F SergiBrazilIvan Magalhaes PROPOSAL
Silvio E ChuiIndiaAmy Elsner UNQUALIFIED
Adams J InouyeGermanyIvan Magalhaes UNQUALIFIED
Darci C BriddickRussiaIoni Bowcher NEGOTIATION
Francesco V GillianItalyBernardo Dominic RENEWAL
Claire H NickaSpainIvan Magalhaes UNQUALIFIED
Mujtaba Q ButtItalyIoni Bowcher NEW
Jefferson X StockhamRussiaBernardo Dominic UNQUALIFIED
Alejandro M VocelkaRussiaAsiya Javayant NEW
Kadeem B PoquetteJapanBernardo Dominic NEW
Mayumi Y ShinkoUnited KingdomAmy Elsner NEW
James G FlosiBrazilIvan Magalhaes UNQUALIFIED
Leja V BriddickBrazilStephen Shaw NEW
Juan M IturbideCanadaAnna Fali NEGOTIATION
Francesco E MaletIndiaAsiya Javayant UNQUALIFIED
Julie Q DilliardItalyAmy Elsner RENEWAL
Deepesh A InouyeCanadaStephen Shaw PROPOSAL
Kadeem R CaudySpainIoni Bowcher RENEWAL
Greenwood A RoysterItalyIvan Magalhaes UNQUALIFIED
Chavez N SaylorsGermanyElwin Sharvill NEGOTIATION
Misaki V RulapaughSpainIoni Bowcher PROPOSAL
Clifford F VocelkaUnited KingdomIoni Bowcher RENEWAL
Alejandro R IturbideFranceOnyama Limba QUALIFIED
Aruna K WaycottUnited KingdomBernardo Dominic NEGOTIATION
Emily F SaylorsBrazilIoni Bowcher QUALIFIED
Leon W SchemmerAustraliaElwin Sharvill PROPOSAL
Chavez M GlickIndiaAmy Elsner PROPOSAL
Smith A KuskoItalyIvan Magalhaes UNQUALIFIED
Leon W WieserJapanIoni Bowcher NEGOTIATION
Mayumi F MarrierAustraliaIoni Bowcher PROPOSAL
Wickens E SchemmerBrazilBernardo Dominic RENEWAL
Maisha X SlusarskiGermanyXuxue Feng UNQUALIFIED
Ashley E SchemmerUnited KingdomStephen Shaw QUALIFIED
Emily I StensethJapanAsiya Javayant QUALIFIED
Leon G PoquetteSpainIvan Magalhaes UNQUALIFIED
Faith N CaudyCanadaAnna Fali UNQUALIFIED
Clifford Q RimJapanIvan Magalhaes PROPOSAL
Octavia Z ShinkoJapanAmy Elsner QUALIFIED
Aruna Z SaylorsSpainBernardo Dominic QUALIFIED
Clifford C FigeroaAustraliaAmy Elsner QUALIFIED
Mujtaba U DoeArgentinaAsiya Javayant PROPOSAL
Tony O CaudyArgentinaAmy Elsner NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Ashley J GlickArgentinaAmy Elsner UNQUALIFIED
Deepesh M VenereUnited KingdomIoni Bowcher QUALIFIED
Mujtaba A SergiBrazilStephen Shaw NEW
Tony O MarrierJapanElwin Sharvill RENEWAL
Octavia R NestleArgentinaOnyama Limba RENEWAL
Ashley M FlosiFranceElwin Sharvill UNQUALIFIED
Maria I SergiJapanIvan Magalhaes NEW
Stacey Q OstroskyBrazilIoni Bowcher RENEWAL
Francesco G VenereUnited KingdomAsiya Javayant NEW
Mayumi M GlickArgentinaXuxue Feng RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jones Y StensethSpain2024-04-15Buckley Miller Wright PROPOSAL78Ivan Magalhaes
1001Izzy X DarakjyArgentina2024-03-31Truhlar And Truhlar Attys PROPOSAL44Bernardo Dominic
1002Jones U MaletCanada2024-04-24Morlong Associates PROPOSAL57Xuxue Feng
1003Aika X PerinAustralia2024-04-26Benton, John B Jr NEGOTIATION58Onyama Limba
1004Maria T BologniaIndia2024-04-06Chanay, Jeffrey A Esq UNQUALIFIED53Elwin Sharvill
1005Rodrigues X VenereUnited Kingdom2024-04-27Chapman, Ross E Esq PROPOSAL28Elwin Sharvill
1006Adams I VocelkaUnited Kingdom2024-04-10Chanay, Jeffrey A Esq QUALIFIED74Elwin Sharvill
1007Isabel Q KolmetzUnited Kingdom2024-04-03Rousseaux, Michael Esq NEGOTIATION88Bernardo Dominic
1008Adams T VocelkaJapan2024-03-31Morlong Associates QUALIFIED58Amy Elsner
1009Antonio C SergiSpain2024-04-27Chapman, Ross E Esq RENEWAL87Stephen Shaw
1010Mujtaba W SaylorsCanada2024-04-16Commercial Press PROPOSAL82Amy Elsner
1011Sinclair Q GarufiFrance2024-04-24Printing Dimensions RENEWAL63Amy Elsner
1012Ricardo J WhobreyGermany2024-04-08King, Christopher A Esq NEGOTIATION85Amy Elsner
1013Murillo V RutaJapan2024-04-21Rousseaux, Michael Esq NEGOTIATION15Elwin Sharvill
1014Smith I MorascaSpain2024-04-13Benton, John B Jr RENEWAL64Xuxue Feng
1015Izzy Y OldroydArgentina2024-03-30Benton, John B Jr PROPOSAL28Ioni Bowcher
1016Antonio S NickaArgentina2024-04-28Morlong Associates UNQUALIFIED77Bernardo Dominic
1017Silvio Y RutaItaly2024-04-13Chemel, James L Cpa NEW80Bernardo Dominic
1018Silvio W VenereJapan2024-04-07Rangoni Of Florence NEW85Onyama Limba
1019Izzy F BowleyRussia2024-04-16Rangoni Of Florence NEW29Ivan Magalhaes
1020Clifford M ChuiFrance2024-04-12Morlong Associates PROPOSAL12Bernardo Dominic
1021Ricardo Z SlusarskiIndia2024-04-05Dorl, James J Esq RENEWAL76Ioni Bowcher
1022Tony H BriddickJapan2024-04-13Rangoni Of Florence RENEWAL14Asiya Javayant
1023Maisha H SergiAustralia2024-04-02Chapman, Ross E Esq RENEWAL96Xuxue Feng
1024Munro B SergiBrazil2024-04-12Chapman, Ross E Esq UNQUALIFIED74Ivan Magalhaes
1025Darci V MorascaBrazil2024-04-04Chemel, James L Cpa NEGOTIATION66Ioni Bowcher
1026Emily U RutaIndia2024-04-02Feiner Bros UNQUALIFIED77Anna Fali
1027Smith T MaletIndia2024-04-21Rangoni Of Florence NEW4Stephen Shaw
1028Morrow P WieserUnited Kingdom2024-04-28Rangoni Of Florence UNQUALIFIED73Anna Fali
1029Ivar P RulapaughFrance2024-04-20Chapman, Ross E Esq PROPOSAL46Anna Fali
1030Ivar V FlosiGermany2024-03-30Rousseaux, Michael Esq NEW56Asiya Javayant
1031Maria N RoysterUnited Kingdom2024-04-13Morlong Associates PROPOSAL68Anna Fali
1032Johnson Q RutaBrazil2024-04-28Feiner Bros QUALIFIED50Xuxue Feng
1033Misaki R IturbideItaly2024-04-11Benton, John B Jr RENEWAL75Elwin Sharvill
1034Claire P BriddickGermany2024-04-13Chapman, Ross E Esq PROPOSAL51Bernardo Dominic
1035Wickens B ButtSpain2024-04-12Truhlar And Truhlar Attys NEGOTIATION94Amy Elsner
1036Francesco M CaudyJapan2024-04-05Feiner Bros NEGOTIATION31Anna Fali
1037Adams U StockhamIndia2024-04-02King, Christopher A Esq QUALIFIED40Onyama Limba
1038Juan N WhobreyBrazil2024-04-12Buckley Miller Wright NEW10Xuxue Feng
1039Smith G OstroskyArgentina2024-03-30Benton, John B Jr NEW19Elwin Sharvill
1040Kaitlin S DoeIndia2024-04-12Rousseaux, Michael Esq QUALIFIED20Anna Fali
1041Jeanfrancois F OstroskyUnited Kingdom2024-04-27Benton, John B Jr QUALIFIED37Stephen Shaw
1042Isabel Q SlusarskiFrance2024-04-22Rousseaux, Michael Esq PROPOSAL20Ioni Bowcher
1043Jones B TollnerRussia2024-04-07Chemel, James L Cpa NEGOTIATION89Xuxue Feng
1044Leja L VocelkaGermany2024-04-08Chanay, Jeffrey A Esq RENEWAL55Elwin Sharvill
1045Clifford J FigeroaArgentina2024-04-26King, Christopher A Esq NEGOTIATION58Ioni Bowcher
1046Maria I OstroskyJapan2024-04-23Buckley Miller Wright UNQUALIFIED83Asiya Javayant
1047Alejandro J SlusarskiBrazil2024-04-26Commercial Press RENEWAL58Ioni Bowcher
1048Chavez T PaprockiUnited Kingdom2024-04-05King, Christopher A Esq RENEWAL10Bernardo Dominic
1049Johnson M DoeUnited Kingdom2024-04-28Benton, John B Jr UNQUALIFIED70Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Costa R FerenczBrazilIvan Magalhaes UNQUALIFIED
David Q GarufiSpainAmy Elsner NEW
Alejandro Q FigeroaFranceIvan Magalhaes PROPOSAL
Aika Z FlosiUnited KingdomAnna Fali NEW
Greenwood K StensethSpainAnna Fali NEGOTIATION
Silvio M SchemmerItalyAmy Elsner RENEWAL
Francesco U WaycottUnited KingdomAsiya Javayant PROPOSAL
Tony X NestleItalyAmy Elsner PROPOSAL
Julie J FlosiItalyAsiya Javayant RENEWAL
Chavez X DarakjyBrazilXuxue Feng NEGOTIATION
Jennifer P FerenczGermanyOnyama Limba QUALIFIED
Kaitlin D StockhamIndiaXuxue Feng PROPOSAL
Clifford T OldroydBrazilXuxue Feng NEGOTIATION
Kaitlin B WaycottSpainBernardo Dominic PROPOSAL
Stacey D DoeBrazilAnna Fali UNQUALIFIED
Jeanfrancois S KolmetzIndiaAnna Fali UNQUALIFIED
Murillo G PerinUnited KingdomAsiya Javayant NEGOTIATION
Mayumi I KuskoBrazilAmy Elsner RENEWAL
Ricardo O TollnerIndiaElwin Sharvill RENEWAL
Clifford Q FlosiJapanOnyama Limba NEGOTIATION
Francesco A GarufiGermanyIoni Bowcher UNQUALIFIED
Chavez A WieserUnited KingdomXuxue Feng NEW
Izzy P GillianItalyElwin Sharvill UNQUALIFIED
Misaki X SlusarskiRussiaBernardo Dominic PROPOSAL
Murillo Y DoeGermanyIvan Magalhaes QUALIFIED
Sinclair M OstroskyIndiaElwin Sharvill RENEWAL
Mujtaba B CaldareraSpainElwin Sharvill NEGOTIATION
Aruna U OstroskyItalyAsiya Javayant PROPOSAL
Isabel Z StensethGermanyElwin Sharvill QUALIFIED
Sinclair Q MacleadIndiaStephen Shaw NEGOTIATION
Jones I RutaArgentinaAnna Fali NEW
David A RimArgentinaAnna Fali NEGOTIATION
Morrow H VocelkaGermanyIvan Magalhaes UNQUALIFIED
Ashley Z SlusarskiRussiaAsiya Javayant RENEWAL
Jefferson J StockhamBrazilAnna Fali RENEWAL
Claire A VenereItalyElwin Sharvill QUALIFIED
Silvio F PaprockiFranceAsiya Javayant NEW
Murillo O DoeItalyXuxue Feng UNQUALIFIED
Murillo C SlusarskiCanadaAnna Fali QUALIFIED
Octavia I AmigonAustraliaAnna Fali RENEWAL
Mujtaba Y VocelkaJapanXuxue Feng QUALIFIED
Aditya T CaudyArgentinaIvan Magalhaes NEW
Ricardo Q CampainUnited KingdomBernardo Dominic NEW
Aditya A IturbideRussiaIvan Magalhaes NEW
Jennifer T BriddickCanadaIoni Bowcher QUALIFIED
Chavez I SergiJapanAnna Fali NEGOTIATION
Claire T AlbaresUnited KingdomOnyama Limba NEW
Octavia Q CampainBrazilAnna Fali NEW
Rodrigues H PerinArgentinaAmy Elsner UNQUALIFIED
Ricardo L GlickFranceAnna Fali QUALIFIED
Frozen Columns
Name
Maria W Perin
Morrow X Paprocki
Morrow V Albares
Smith W Doe
Murillo J Rim
Clifford L Doe
Smith L Darakjy
Jeanfrancois E Butt
Kadeem C Malet
Leon C Venere
Juan G Garufi
Nicolas D Royster
Leja B Gaucho
Julie M Whobrey
Kadeem D Ruta
Alejandro P Garufi
Claire K Briddick
Arvin L Poquette
Maisha O Butt
Salvatore Z Garufi
Johnson N Garufi
Ashley F Tollner
Juan U Waycott
Jefferson A Maclead
Misaki L Dilliard
Smith W Briddick
Jefferson B Campain
Clifford V Albares
Tony V Doe
Alejandro E Garufi
Ricardo N Dilliard
Stacey W Stockham
Maisha K Flosi
Mayumi T Kusko
Murillo X Nicka
Stacey Q Malet
Alejandro M Venere
Maria N Figeroa
Jeanfrancois J Stockham
Nicolas Q Caldarera
Kadeem M Whobrey
Leon B Sergi
Morrow Z Doe
Ivar U Saylors
Sinclair L Ostrosky
Ricardo N Gillian
Leon J Malet
Silvio T Saylors
Stacey D Ostrosky
Deepesh T Maclead
IdCountryDate
1000Spain2024-03-30
1001Spain2024-04-10
1002Australia2024-04-13
1003Russia2024-04-12
1004France2024-04-20
1005Argentina2024-04-01
1006India2024-04-06
1007India2024-04-12
1008Spain2024-04-06
1009Italy2024-03-31
1010France2024-04-28
1011Australia2024-04-08
1012Brazil2024-04-21
1013Russia2024-04-08
1014Spain2024-04-09
1015United Kingdom2024-04-16
1016Italy2024-04-12
1017Russia2024-04-20
1018Argentina2024-04-23
1019Australia2024-04-09
1020United Kingdom2024-04-12
1021Japan2024-04-17
1022United Kingdom2024-04-16
1023Australia2024-04-12
1024Australia2024-04-12
1025India2024-04-21
1026Canada2024-03-31
1027Brazil2024-03-31
1028Brazil2024-04-01
1029United Kingdom2024-04-16
1030India2024-04-04
1031France2024-04-13
1032Brazil2024-04-14
1033India2024-04-04
1034Brazil2024-04-17
1035France2024-04-17
1036India2024-04-03
1037Spain2024-04-24
1038France2024-04-18
1039United Kingdom2024-04-25
1040Spain2024-04-03
1041France2024-04-21
1042Argentina2024-04-09
1043Spain2024-04-04
1044India2024-04-19
1045Spain2024-04-04
1046Italy2024-04-15
1047United Kingdom2024-04-04
1048Spain2024-04-13
1049Canada2024-04-04

On-Demand Data

NameIdCountryDate
Rodrigues D Kusko1000Australia2024-04-17
Silvio H Bolognia1001Brazil2024-04-26
Kaitlin R Caldarera1002Brazil2024-04-21
Cody Z Malet1003Japan2024-04-17
Arvin K Iturbide1004Italy2024-04-09
Johnson W Stockham1005United Kingdom2024-04-05
Leon F Figeroa1006Argentina2024-04-28
David V Slusarski1007Russia2024-04-26
Ricardo R Gaucho1008India2024-03-30
Salvatore N Perin1009Canada2024-04-22
Jeanfrancois E Ostrosky1010Spain2024-04-19
Emily K Kusko1011India2024-04-20
Salvatore G Rulapaugh1012India2024-04-19
Arvin B Albares1013Spain2024-04-14
Maria O Oldroyd1014Japan2024-04-25
Leja F Oldroyd1015Russia2024-04-20
Leja L Chui1016Argentina2024-04-05
Salvatore K Perin1017United Kingdom2024-04-08
Stacey J Amigon1018Russia2024-04-13
Kaitlin N Flosi1019India2024-04-01
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Arvin K MaletItalyIoni Bowcher NEW
Ricardo A RoysterIndiaXuxue Feng QUALIFIED
Leon V DilliardArgentinaOnyama Limba UNQUALIFIED
James E WieserItalyOnyama Limba QUALIFIED
Ricardo W GauchoRussiaIoni Bowcher NEW
Aditya U VocelkaUnited KingdomIoni Bowcher NEW
Johnson H WhobreyGermanyIoni Bowcher PROPOSAL
Costa E MarrierRussiaAmy Elsner NEGOTIATION
Misaki P GarufiJapanAnna Fali UNQUALIFIED
Faith V DarakjyItalyAnna Fali NEW
Ivar V StockhamSpainElwin Sharvill RENEWAL
Wickens A CampainIndiaIvan Magalhaes RENEWAL
Antonio Y NickaBrazilOnyama Limba NEGOTIATION
Maisha B SergiJapanAnna Fali QUALIFIED
Munro U FigeroaJapanOnyama Limba QUALIFIED
Chavez D SaylorsAustraliaStephen Shaw NEW
Stacey F MacleadJapanAmy Elsner NEW
Kadeem E PaprockiIndiaAmy Elsner RENEWAL
Jefferson U DoeGermanyElwin Sharvill UNQUALIFIED
Antonio R CaldareraUnited KingdomOnyama Limba QUALIFIED
Greenwood Y DilliardArgentinaStephen Shaw NEW
Faith Y IturbideBrazilIoni Bowcher RENEWAL
Greenwood I KuskoArgentinaIvan Magalhaes NEW
Faith B BriddickRussiaAnna Fali PROPOSAL
Kaitlin U PerinArgentinaStephen Shaw NEGOTIATION
Ivar S FerenczJapanOnyama Limba UNQUALIFIED
Juan M KolmetzAustraliaOnyama Limba RENEWAL
Tony N InouyeAustraliaAmy Elsner QUALIFIED
Clifford X BologniaFranceElwin Sharvill RENEWAL
Alejandro Y FerenczSpainElwin Sharvill RENEWAL
Kaitlin H MacleadItalyAmy Elsner UNQUALIFIED
Silvio V MarrierIndiaElwin Sharvill NEW
Faith D InouyeAustraliaXuxue Feng QUALIFIED
Misaki B KuskoItalyXuxue Feng UNQUALIFIED
Ashley Z MorascaRussiaOnyama Limba QUALIFIED
Darci B GauchoCanadaAmy Elsner UNQUALIFIED
Silvio V BowleyAustraliaOnyama Limba PROPOSAL
Adams Z StockhamFranceAnna Fali NEGOTIATION
Leon V RutaFranceXuxue Feng RENEWAL
Leon V MorascaJapanIvan Magalhaes 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>