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
Leja B MaletAustraliaStephen Shaw PROPOSAL
Julie R BowleySpainAsiya Javayant PROPOSAL
Leon T NestleSpainElwin Sharvill NEW
Morrow N GlickCanadaBernardo Dominic NEGOTIATION
Jefferson W NickaCanadaAnna Fali NEW
Mujtaba A OstroskyJapanAmy Elsner RENEWAL
Isabel B SlusarskiFranceIvan Magalhaes NEW
Aruna H NestleGermanyBernardo Dominic RENEWAL
Maria D RimUnited KingdomXuxue Feng UNQUALIFIED
Claire M BriddickBrazilAsiya Javayant NEGOTIATION
Clifford B GillianRussiaElwin Sharvill PROPOSAL
Cody Q VocelkaCanadaAsiya Javayant RENEWAL
Leon W RoysterSpainIoni Bowcher QUALIFIED
Ashley J PoquetteItalyIoni Bowcher UNQUALIFIED
Maisha F RutaAustraliaAnna Fali PROPOSAL
Octavia C SlusarskiJapanAmy Elsner RENEWAL
Mujtaba B AmigonFranceIoni Bowcher NEW
Aika N MaletBrazilAnna Fali UNQUALIFIED
Smith I CaldareraFranceAmy Elsner RENEWAL
Rodrigues B CaudyUnited KingdomAnna Fali RENEWAL
Francesco J FlosiBrazilBernardo Dominic NEW
Julie E GauchoJapanElwin Sharvill PROPOSAL
Ricardo A KolmetzItalyAnna Fali UNQUALIFIED
Wickens B WhobreyAustraliaAsiya Javayant PROPOSAL
Julie A SergiIndiaXuxue Feng QUALIFIED
Julie S MaletCanadaOnyama Limba RENEWAL
Sinclair Q KolmetzGermanyXuxue Feng RENEWAL
Munro X RulapaughArgentinaIoni Bowcher RENEWAL
Sinclair Z GarufiItalyBernardo Dominic QUALIFIED
Munro J MarrierBrazilXuxue Feng PROPOSAL
Claire G ShinkoRussiaXuxue Feng NEW
Greenwood Y KolmetzAustraliaStephen Shaw QUALIFIED
Cody S MacleadAustraliaAnna Fali QUALIFIED
Octavia O MaletFranceXuxue Feng QUALIFIED
Ivar F FollerArgentinaAmy Elsner NEW
Izzy A ButtJapanIvan Magalhaes NEGOTIATION
Maisha D WieserGermanyAnna Fali QUALIFIED
Stacey D OldroydItalyXuxue Feng NEGOTIATION
Tony L InouyeRussiaXuxue Feng NEW
Emily W VocelkaSpainIoni Bowcher NEGOTIATION
Octavia E CampainIndiaXuxue Feng UNQUALIFIED
Ivar G SlusarskiBrazilElwin Sharvill QUALIFIED
Rodrigues R ChuiUnited KingdomXuxue Feng PROPOSAL
Aruna Z OstroskyArgentinaIoni Bowcher UNQUALIFIED
Izzy G BriddickFranceAmy Elsner NEGOTIATION
Chavez G DilliardItalyAsiya Javayant UNQUALIFIED
Emily P PaprockiIndiaBernardo Dominic PROPOSAL
Emily X CaldareraBrazilElwin Sharvill NEW
Salvatore E MaletCanadaBernardo Dominic RENEWAL
Sinclair C ButtCanadaElwin Sharvill QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Darci Q NickaIndiaIoni Bowcher UNQUALIFIED
Tony K FollerRussiaBernardo Dominic PROPOSAL
Rodrigues Q ShinkoIndiaBernardo Dominic RENEWAL
Jones I ChuiIndiaBernardo Dominic NEGOTIATION
Cody I BowleyUnited KingdomIvan Magalhaes RENEWAL
Clifford I MaletBrazilOnyama Limba PROPOSAL
Kaitlin V CaudyJapanBernardo Dominic RENEWAL
Smith Z MaletBrazilIvan Magalhaes RENEWAL
Octavia X VocelkaRussiaStephen Shaw UNQUALIFIED
Leja K DilliardRussiaIoni Bowcher RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Kaitlin D MaletItaly2024-04-11King, Christopher A Esq UNQUALIFIED51Xuxue Feng
1001Clifford R DoeFrance2024-04-11Chemel, James L Cpa PROPOSAL53Ivan Magalhaes
1002Rodrigues Z RulapaughArgentina2024-04-09Truhlar And Truhlar Attys NEW0Anna Fali
1003Ivar V ButtBrazil2024-04-23Chanay, Jeffrey A Esq NEW35Stephen Shaw
1004Francesco E GauchoJapan2024-04-21Chemel, James L Cpa NEGOTIATION91Anna Fali
1005Cody M GillianRussia2024-05-05Feltz Printing Service UNQUALIFIED14Xuxue Feng
1006Aika C DoeJapan2024-04-10Commercial Press NEGOTIATION71Ioni Bowcher
1007Cody X GarufiGermany2024-04-29Chemel, James L Cpa QUALIFIED18Elwin Sharvill
1008Kaitlin R InouyeAustralia2024-05-04Feiner Bros UNQUALIFIED70Stephen Shaw
1009James K GillianFrance2024-04-23Chemel, James L Cpa UNQUALIFIED2Stephen Shaw
1010Antonio Q ChuiUnited Kingdom2024-04-24Morlong Associates NEW45Stephen Shaw
1011Ricardo C PoquetteArgentina2024-04-18Chemel, James L Cpa NEW95Elwin Sharvill
1012Jeanfrancois N DilliardArgentina2024-04-11Benton, John B Jr NEGOTIATION21Stephen Shaw
1013Aditya I NestleArgentina2024-04-29Chemel, James L Cpa NEW59Ivan Magalhaes
1014Stacey G SergiAustralia2024-05-06Dorl, James J Esq QUALIFIED57Xuxue Feng
1015Emily K MorascaSpain2024-04-14Rangoni Of Florence QUALIFIED58Ioni Bowcher
1016Murillo I DoeAustralia2024-04-09Benton, John B Jr UNQUALIFIED52Stephen Shaw
1017Isabel A DarakjySpain2024-04-27Rangoni Of Florence RENEWAL96Elwin Sharvill
1018Emily H CampainRussia2024-04-24Chemel, James L Cpa NEW14Elwin Sharvill
1019Juan D AlbaresFrance2024-04-17Chanay, Jeffrey A Esq NEW86Elwin Sharvill
1020Misaki H MaletFrance2024-04-29Feltz Printing Service NEGOTIATION28Ivan Magalhaes
1021Silvio M DoeIndia2024-04-27Chanay, Jeffrey A Esq PROPOSAL25Stephen Shaw
1022Johnson L RutaJapan2024-05-05King, Christopher A Esq RENEWAL40Stephen Shaw
1023Kadeem R PerinCanada2024-05-05Commercial Press RENEWAL0Anna Fali
1024Izzy D ChuiJapan2024-04-24Benton, John B Jr UNQUALIFIED31Ioni Bowcher
1025Kaitlin U DoeRussia2024-05-01Chanay, Jeffrey A Esq RENEWAL90Xuxue Feng
1026Costa X FlosiIndia2024-04-16Benton, John B Jr QUALIFIED56Asiya Javayant
1027Aika F InouyeIndia2024-05-03Rangoni Of Florence RENEWAL38Amy Elsner
1028Jones V OstroskyGermany2024-04-10Commercial Press NEW64Anna Fali
1029Jefferson L VenereBrazil2024-04-27Benton, John B Jr NEGOTIATION37Bernardo Dominic
1030Mayumi M AlbaresArgentina2024-04-22Morlong Associates PROPOSAL25Xuxue Feng
1031Chavez M DarakjyUnited Kingdom2024-04-30Benton, John B Jr RENEWAL93Bernardo Dominic
1032Wickens I StensethIndia2024-05-06Chemel, James L Cpa QUALIFIED72Anna Fali
1033Ricardo X DilliardArgentina2024-04-08Commercial Press NEW9Bernardo Dominic
1034Ivar X FlosiJapan2024-05-05Chemel, James L Cpa PROPOSAL0Anna Fali
1035Kadeem A SchemmerFrance2024-04-11Chapman, Ross E Esq NEGOTIATION31Bernardo Dominic
1036Kaitlin M MarrierItaly2024-05-03Printing Dimensions NEW68Xuxue Feng
1037Salvatore Q BologniaGermany2024-04-28Rousseaux, Michael Esq NEW70Asiya Javayant
1038Aika B IturbideBrazil2024-04-27Rousseaux, Michael Esq UNQUALIFIED3Stephen Shaw
1039Greenwood E PaprockiSpain2024-04-30Chemel, James L Cpa UNQUALIFIED25Bernardo Dominic
1040Izzy W FlosiBrazil2024-04-25Dorl, James J Esq NEW0Amy Elsner
1041Jeanfrancois J MaletSpain2024-05-04Feiner Bros NEW72Xuxue Feng
1042Aika B AlbaresBrazil2024-04-17Truhlar And Truhlar Attys NEGOTIATION18Bernardo Dominic
1043Kadeem R MaletRussia2024-04-10Benton, John B Jr QUALIFIED13Ioni Bowcher
1044Johnson T RulapaughGermany2024-04-23King, Christopher A Esq QUALIFIED8Ivan Magalhaes
1045James Z ChuiItaly2024-04-13Feiner Bros NEGOTIATION41Stephen Shaw
1046Jones N RimGermany2024-04-24Feltz Printing Service RENEWAL30Ivan Magalhaes
1047Cody Y GlickGermany2024-04-09Feiner Bros UNQUALIFIED82Onyama Limba
1048Adams A SergiCanada2024-04-14Feiner Bros PROPOSAL51Xuxue Feng
1049Greenwood A BowleyUnited Kingdom2024-04-22Dorl, James J Esq UNQUALIFIED47Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Julie V BowleySpainXuxue Feng UNQUALIFIED
Chavez V VenereItalyAmy Elsner NEW
Kadeem N CampainCanadaIvan Magalhaes NEW
Francesco Q TollnerBrazilBernardo Dominic QUALIFIED
Sinclair W IturbideBrazilStephen Shaw RENEWAL
Deepesh W OstroskyIndiaOnyama Limba NEGOTIATION
Alejandro T SlusarskiItalyElwin Sharvill NEGOTIATION
Kaitlin N BowleyCanadaIvan Magalhaes PROPOSAL
Ivar I FlosiUnited KingdomStephen Shaw RENEWAL
Maisha V RulapaughUnited KingdomOnyama Limba QUALIFIED
Darci V KolmetzAustraliaElwin Sharvill NEGOTIATION
Wickens M RoysterJapanIvan Magalhaes UNQUALIFIED
Izzy C ShinkoSpainIoni Bowcher QUALIFIED
Munro I AmigonAustraliaXuxue Feng UNQUALIFIED
Costa I GarufiIndiaAmy Elsner QUALIFIED
Jones W FerenczSpainBernardo Dominic UNQUALIFIED
Stacey N VenereCanadaStephen Shaw RENEWAL
Leja T MarrierItalyElwin Sharvill UNQUALIFIED
Mujtaba L TollnerCanadaOnyama Limba QUALIFIED
Emily C KolmetzItalyElwin Sharvill NEW
Murillo G StockhamGermanyXuxue Feng PROPOSAL
Mayumi A DarakjyUnited KingdomBernardo Dominic NEGOTIATION
Antonio X NickaJapanXuxue Feng NEW
Costa N TollnerArgentinaBernardo Dominic QUALIFIED
Stacey N SergiItalyIoni Bowcher NEGOTIATION
Silvio Z OstroskyJapanStephen Shaw NEGOTIATION
Isabel H WieserArgentinaIoni Bowcher NEW
Adams S MorascaCanadaIoni Bowcher QUALIFIED
Misaki A MorascaRussiaBernardo Dominic QUALIFIED
Salvatore E PerinIndiaIvan Magalhaes NEGOTIATION
Deepesh H MacleadArgentinaAnna Fali RENEWAL
Ivar B MaletAustraliaElwin Sharvill UNQUALIFIED
Silvio K VocelkaFranceAnna Fali QUALIFIED
Jennifer B GauchoIndiaXuxue Feng NEW
Adams V BologniaArgentinaStephen Shaw PROPOSAL
Morrow Y WaycottUnited KingdomElwin Sharvill QUALIFIED
Mayumi Y GlickRussiaElwin Sharvill RENEWAL
Juan H DilliardArgentinaBernardo Dominic UNQUALIFIED
Ricardo F CaldareraJapanIoni Bowcher UNQUALIFIED
Murillo D GauchoCanadaIoni Bowcher QUALIFIED
Salvatore X CaudyCanadaIvan Magalhaes NEGOTIATION
Misaki Y TollnerItalyXuxue Feng PROPOSAL
Arvin E FlosiIndiaIvan Magalhaes RENEWAL
Munro Q FollerGermanyAnna Fali RENEWAL
Murillo Q BriddickGermanyAmy Elsner PROPOSAL
Maisha Z BowleyGermanyOnyama Limba NEW
Emily K GillianRussiaAnna Fali RENEWAL
Claire I GarufiSpainElwin Sharvill NEGOTIATION
Julie P BowleyBrazilElwin Sharvill NEGOTIATION
Alejandro A CampainFranceBernardo Dominic NEGOTIATION
Frozen Columns
Name
Nicolas L Albares
Morrow S Albares
Claire X Poquette
Ivar J Royster
Leja A Oldroyd
Jefferson G Campain
Mujtaba H Maclead
James D Gaucho
Chavez A Morasca
Stacey Y Malet
Emily G Whobrey
Emily A Sergi
Isabel G Iturbide
Ashley Y Glick
Leon V Royster
Jennifer E Briddick
Antonio S Caldarera
Johnson C Campain
Aruna E Gaucho
Greenwood A Nestle
Aruna I Morasca
Deepesh N Saylors
Munro V Glick
Leon N Albares
Costa T Campain
James O Slusarski
Faith Y Glick
James X Waycott
Darci G Figeroa
Aika B Waycott
Deepesh K Glick
Emily H Whobrey
Rodrigues K Gaucho
Cody B Morasca
Leon P Poquette
Emily N Flosi
Greenwood M Foller
Jefferson C Albares
Jeanfrancois J Poquette
Leon P Perin
Kaitlin X Slusarski
Costa M Oldroyd
Munro P Maclead
Stacey G Venere
Leon M Ostrosky
Morrow P Oldroyd
Kaitlin Q Kusko
Wickens A Rim
Faith Z Briddick
Claire M Schemmer
IdCountryDate
1000Russia2024-05-06
1001Germany2024-05-04
1002United Kingdom2024-04-26
1003Brazil2024-05-05
1004Japan2024-04-16
1005Italy2024-04-09
1006Argentina2024-04-21
1007France2024-04-09
1008Australia2024-04-28
1009Brazil2024-05-04
1010India2024-04-09
1011Japan2024-05-03
1012Italy2024-04-25
1013Spain2024-04-22
1014Germany2024-04-21
1015Argentina2024-05-02
1016Italy2024-04-10
1017Germany2024-04-23
1018Germany2024-04-18
1019India2024-04-10
1020Canada2024-04-21
1021United Kingdom2024-05-01
1022Brazil2024-04-18
1023India2024-05-06
1024Canada2024-04-24
1025Japan2024-04-15
1026Australia2024-04-26
1027India2024-05-04
1028Australia2024-04-26
1029India2024-04-24
1030Spain2024-04-13
1031Russia2024-05-04
1032Argentina2024-04-22
1033Germany2024-04-14
1034Japan2024-04-27
1035France2024-04-19
1036Russia2024-04-22
1037Germany2024-04-18
1038United Kingdom2024-04-12
1039France2024-04-22
1040United Kingdom2024-04-23
1041Russia2024-04-25
1042Australia2024-04-29
1043Japan2024-05-04
1044Germany2024-05-06
1045Italy2024-04-12
1046Brazil2024-04-13
1047Canada2024-04-09
1048Italy2024-04-07
1049France2024-04-17

On-Demand Data

NameIdCountryDate
Isabel Y Rim1000Italy2024-04-22
Rodrigues Z Marrier1001France2024-05-02
Jennifer J Marrier1002Russia2024-05-01
Clifford X Perin1003Germany2024-05-02
Aditya S Morasca1004Canada2024-04-19
Salvatore Y Chui1005Japan2024-04-08
Wickens K Gaucho1006Italy2024-04-09
David A Albares1007Russia2024-04-21
Ivar J Dilliard1008Canada2024-05-01
Deepesh B Malet1009India2024-05-04
Adams C Tollner1010Brazil2024-04-20
Juan B Dilliard1011India2024-05-01
Munro B Saylors1012United Kingdom2024-04-13
Leon Y Kolmetz1013Canada2024-04-10
Mujtaba B Slusarski1014United Kingdom2024-05-03
Leja T Caudy1015Australia2024-04-08
Murillo L Stockham1016Germany2024-05-04
Jefferson X Waycott1017Japan2024-04-18
Mayumi R Paprocki1018Germany2024-04-09
Mayumi S Kolmetz1019Argentina2024-04-14
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Francesco T FlosiRussiaOnyama Limba QUALIFIED
Ivar A DoeRussiaAsiya Javayant QUALIFIED
Clifford I FlosiCanadaOnyama Limba UNQUALIFIED
Jeanfrancois N AmigonAustraliaAnna Fali RENEWAL
Juan Q DoeUnited KingdomXuxue Feng RENEWAL
Jefferson O RutaCanadaStephen Shaw NEGOTIATION
Izzy R DarakjyFranceOnyama Limba NEGOTIATION
Chavez V NickaAustraliaAsiya Javayant RENEWAL
Aditya S NickaItalyIoni Bowcher QUALIFIED
Johnson J SergiAustraliaIvan Magalhaes UNQUALIFIED
Smith N MaletFranceAmy Elsner NEW
Tony L MorascaJapanElwin Sharvill RENEWAL
Misaki C FollerArgentinaBernardo Dominic QUALIFIED
Arvin A MaletJapanElwin Sharvill NEGOTIATION
Misaki V MarrierArgentinaAnna Fali RENEWAL
Aruna A OstroskyJapanStephen Shaw QUALIFIED
Deepesh J ButtGermanyElwin Sharvill NEW
Kaitlin C SlusarskiRussiaBernardo Dominic RENEWAL
Juan P MaletBrazilBernardo Dominic QUALIFIED
Mayumi B MacleadRussiaAsiya Javayant NEW
Salvatore N WhobreyJapanAnna Fali QUALIFIED
Juan V CaudyRussiaXuxue Feng UNQUALIFIED
Aditya T NestleItalyElwin Sharvill QUALIFIED
Aruna S TollnerIndiaAmy Elsner NEGOTIATION
Aika D KolmetzArgentinaXuxue Feng UNQUALIFIED
Arvin N DarakjyCanadaIvan Magalhaes PROPOSAL
Aditya T NestleArgentinaElwin Sharvill UNQUALIFIED
Silvio Q GlickUnited KingdomAnna Fali RENEWAL
Arvin J FerenczGermanyIoni Bowcher NEGOTIATION
Faith C IturbideArgentinaStephen Shaw QUALIFIED
Silvio V StensethAustraliaIvan Magalhaes NEW
Antonio C GauchoJapanStephen Shaw RENEWAL
Munro C VocelkaFranceElwin Sharvill NEGOTIATION
Morrow Y BologniaJapanBernardo Dominic NEGOTIATION
Murillo W StockhamBrazilIvan Magalhaes QUALIFIED
Emily R CampainCanadaAsiya Javayant RENEWAL
Izzy Z DilliardIndiaIoni Bowcher NEW
Clifford X PoquetteCanadaAnna Fali NEW
Salvatore E OstroskyCanadaXuxue Feng UNQUALIFIED
Clifford J StensethBrazilAnna Fali QUALIFIED

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