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
Johnson H OldroydFranceStephen Shaw UNQUALIFIED
Misaki V GillianRussiaXuxue Feng RENEWAL
Darci J DarakjyItalyStephen Shaw PROPOSAL
Leon H FerenczJapanIoni Bowcher NEGOTIATION
Octavia F MarrierRussiaIvan Magalhaes NEGOTIATION
Mujtaba E RimJapanElwin Sharvill RENEWAL
Tony S BriddickFranceElwin Sharvill NEGOTIATION
Juan Q PerinArgentinaXuxue Feng NEGOTIATION
Smith N ChuiArgentinaXuxue Feng QUALIFIED
David Q SlusarskiRussiaIoni Bowcher RENEWAL
Greenwood S PoquetteSpainStephen Shaw RENEWAL
Claire D GarufiArgentinaAsiya Javayant NEW
Munro S FerenczArgentinaAmy Elsner UNQUALIFIED
Murillo W FerenczIndiaAmy Elsner NEGOTIATION
Mujtaba T RutaAustraliaStephen Shaw NEW
David H VocelkaArgentinaElwin Sharvill UNQUALIFIED
Wickens Q CampainFranceBernardo Dominic PROPOSAL
Kaitlin W MaletUnited KingdomOnyama Limba QUALIFIED
Maisha M MacleadGermanyIoni Bowcher RENEWAL
Mujtaba Z ShinkoFranceElwin Sharvill RENEWAL
Smith V CaudySpainXuxue Feng NEW
Ashley V FollerCanadaElwin Sharvill UNQUALIFIED
Aika J ButtRussiaAmy Elsner NEW
Stacey R GauchoUnited KingdomBernardo Dominic PROPOSAL
Cody H MarrierIndiaElwin Sharvill QUALIFIED
Kaitlin V MarrierRussiaAsiya Javayant QUALIFIED
Darci A BologniaGermanyIvan Magalhaes NEW
Jones S VocelkaSpainAsiya Javayant NEGOTIATION
Costa F NickaAustraliaIvan Magalhaes PROPOSAL
Costa S KuskoGermanyStephen Shaw RENEWAL
Smith M NickaArgentinaOnyama Limba PROPOSAL
Ricardo W AmigonRussiaAmy Elsner PROPOSAL
Aika C RulapaughItalyOnyama Limba NEW
Cody V NestleAustraliaIvan Magalhaes NEW
Emily Q SchemmerUnited KingdomStephen Shaw UNQUALIFIED
Aditya E ButtArgentinaOnyama Limba NEW
Aditya I BriddickJapanStephen Shaw UNQUALIFIED
Adams L CampainBrazilIoni Bowcher NEGOTIATION
Isabel W SchemmerCanadaBernardo Dominic UNQUALIFIED
Silvio Q BowleyArgentinaElwin Sharvill RENEWAL
Izzy U CampainRussiaXuxue Feng QUALIFIED
David S CaudyJapanBernardo Dominic UNQUALIFIED
Alejandro D WhobreyItalyXuxue Feng PROPOSAL
Morrow A WhobreyArgentinaAnna Fali RENEWAL
Arvin N ShinkoItalyAsiya Javayant NEGOTIATION
Rodrigues K FollerSpainXuxue Feng NEGOTIATION
Jones U GlickUnited KingdomAsiya Javayant RENEWAL
Jennifer Y CaldareraRussiaAnna Fali QUALIFIED
Julie Y FlosiBrazilBernardo Dominic NEGOTIATION
Deepesh D SaylorsCanadaIoni Bowcher RENEWAL
Horizontal
NameCountryRepresentativeStatus
Stacey E WaycottBrazilAmy Elsner QUALIFIED
Juan M NestleFranceAmy Elsner QUALIFIED
Silvio L KuskoCanadaAsiya Javayant NEW
Jefferson R RutaRussiaXuxue Feng QUALIFIED
Kaitlin X SergiBrazilAnna Fali NEW
Ivar C AmigonAustraliaElwin Sharvill NEW
Sinclair S RoysterGermanyElwin Sharvill QUALIFIED
Kadeem L FerenczSpainAmy Elsner NEW
Faith A ButtCanadaElwin Sharvill UNQUALIFIED
Nicolas M WieserJapanAmy Elsner QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Clifford T VenereIndia2024-04-01King, Christopher A Esq PROPOSAL72Anna Fali
1001Munro E MorascaGermany2024-04-02Printing Dimensions RENEWAL4Amy Elsner
1002Aruna D CaudyUnited Kingdom2024-04-13Printing Dimensions NEGOTIATION48Onyama Limba
1003Isabel C KolmetzItaly2024-04-15Feiner Bros QUALIFIED56Amy Elsner
1004Ivar W FerenczBrazil2024-04-27Feiner Bros NEW74Xuxue Feng
1005Ivar M SaylorsJapan2024-04-25Benton, John B Jr PROPOSAL56Asiya Javayant
1006Darci X GlickItaly2024-04-23Truhlar And Truhlar Attys UNQUALIFIED16Stephen Shaw
1007Nicolas Y BowleyItaly2024-04-18Morlong Associates NEGOTIATION89Bernardo Dominic
1008Aika R SergiBrazil2024-04-21Buckley Miller Wright PROPOSAL36Elwin Sharvill
1009Antonio F SlusarskiRussia2024-04-07Chanay, Jeffrey A Esq NEW29Ioni Bowcher
1010Claire O KolmetzGermany2024-04-18Chanay, Jeffrey A Esq UNQUALIFIED65Onyama Limba
1011Tony B ShinkoSpain2024-04-18Chanay, Jeffrey A Esq RENEWAL46Amy Elsner
1012Izzy E AlbaresJapan2024-03-29Feiner Bros QUALIFIED84Elwin Sharvill
1013Aika B ShinkoRussia2024-04-24Truhlar And Truhlar Attys NEW3Anna Fali
1014Morrow T WaycottUnited Kingdom2024-04-11Rangoni Of Florence UNQUALIFIED23Elwin Sharvill
1015Chavez F BowleyGermany2024-04-02Printing Dimensions RENEWAL27Ivan Magalhaes
1016Munro X WhobreyBrazil2024-04-01Benton, John B Jr UNQUALIFIED33Ioni Bowcher
1017Smith C AlbaresAustralia2024-04-19Rangoni Of Florence NEGOTIATION36Stephen Shaw
1018Darci C DarakjyIndia2024-04-20Commercial Press RENEWAL31Xuxue Feng
1019Jones P CaudyUnited Kingdom2024-04-21Benton, John B Jr UNQUALIFIED54Onyama Limba
1020Wickens R MaletJapan2024-04-26Rousseaux, Michael Esq NEW33Stephen Shaw
1021Arvin G CaudyItaly2024-04-26Rangoni Of Florence QUALIFIED65Stephen Shaw
1022Ricardo T DoeGermany2024-04-09King, Christopher A Esq NEGOTIATION0Onyama Limba
1023Julie C NickaBrazil2024-04-21Feiner Bros UNQUALIFIED80Anna Fali
1024Rodrigues M GillianAustralia2024-04-08Benton, John B Jr NEW30Elwin Sharvill
1025Maisha W PerinJapan2024-04-16Truhlar And Truhlar Attys UNQUALIFIED18Elwin Sharvill
1026Jeanfrancois Y FigeroaCanada2024-04-06King, Christopher A Esq NEGOTIATION1Ioni Bowcher
1027Emily C SergiUnited Kingdom2024-04-21Feiner Bros UNQUALIFIED67Ivan Magalhaes
1028Alejandro S RimIndia2024-04-12Benton, John B Jr QUALIFIED10Bernardo Dominic
1029James B MorascaRussia2024-04-20Chanay, Jeffrey A Esq UNQUALIFIED14Ivan Magalhaes
1030Alejandro W MacleadGermany2024-04-07Rousseaux, Michael Esq NEW80Ioni Bowcher
1031Alejandro N GillianRussia2024-04-21Rousseaux, Michael Esq PROPOSAL13Bernardo Dominic
1032Mujtaba K StensethJapan2024-04-01Morlong Associates PROPOSAL57Stephen Shaw
1033Ivar E ChuiAustralia2024-04-14Rousseaux, Michael Esq UNQUALIFIED3Asiya Javayant
1034Sinclair Z RimIndia2024-04-22Chanay, Jeffrey A Esq RENEWAL21Anna Fali
1035Salvatore K NestleCanada2024-03-31Commercial Press QUALIFIED28Ivan Magalhaes
1036Jones S FerenczCanada2024-04-05Chanay, Jeffrey A Esq UNQUALIFIED83Bernardo Dominic
1037Smith P NestleArgentina2024-04-08Morlong Associates UNQUALIFIED59Elwin Sharvill
1038Jones N PerinArgentina2024-04-20Feiner Bros RENEWAL28Asiya Javayant
1039Smith Z RimRussia2024-04-17Feltz Printing Service NEW21Elwin Sharvill
1040Sinclair G SchemmerItaly2024-04-06Dorl, James J Esq RENEWAL66Onyama Limba
1041Darci M FollerAustralia2024-04-27Morlong Associates PROPOSAL86Onyama Limba
1042Chavez D CaudyAustralia2024-04-05Buckley Miller Wright PROPOSAL65Elwin Sharvill
1043Aditya L MorascaGermany2024-03-30Chapman, Ross E Esq QUALIFIED2Bernardo Dominic
1044Kaitlin Q GarufiGermany2024-03-31Commercial Press RENEWAL97Xuxue Feng
1045David K CampainFrance2024-03-30Commercial Press UNQUALIFIED91Xuxue Feng
1046Francesco H RoysterAustralia2024-04-13Morlong Associates RENEWAL93Ioni Bowcher
1047Murillo W TollnerRussia2024-04-04Chapman, Ross E Esq RENEWAL11Anna Fali
1048Izzy G PaprockiJapan2024-04-25Printing Dimensions UNQUALIFIED63Anna Fali
1049Chavez T RutaJapan2024-04-14Rangoni Of Florence NEW10Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Nicolas W BowleyRussiaAnna Fali NEW
Emily E MarrierIndiaStephen Shaw NEGOTIATION
Clifford W MacleadItalyOnyama Limba UNQUALIFIED
Arvin K ShinkoItalyElwin Sharvill NEW
Isabel J SchemmerUnited KingdomStephen Shaw RENEWAL
Ricardo R NickaAustraliaElwin Sharvill QUALIFIED
Antonio K GauchoRussiaBernardo Dominic NEW
Mayumi I NestleIndiaIoni Bowcher UNQUALIFIED
Rodrigues L OldroydGermanyXuxue Feng RENEWAL
Stacey G NestleUnited KingdomOnyama Limba UNQUALIFIED
Silvio J PerinGermanyOnyama Limba UNQUALIFIED
Deepesh E WaycottSpainStephen Shaw NEW
Kaitlin F DilliardFranceBernardo Dominic QUALIFIED
Silvio F BowleyArgentinaIoni Bowcher NEGOTIATION
Cody R MaletIndiaElwin Sharvill UNQUALIFIED
Nicolas P MaletGermanyAnna Fali QUALIFIED
Ashley I FigeroaCanadaAsiya Javayant RENEWAL
Sinclair D AlbaresSpainBernardo Dominic UNQUALIFIED
Costa Y OstroskyUnited KingdomStephen Shaw UNQUALIFIED
Aika W FollerSpainIvan Magalhaes NEGOTIATION
Adams Y GauchoJapanOnyama Limba UNQUALIFIED
Arvin Q DoeUnited KingdomIvan Magalhaes UNQUALIFIED
Silvio L GlickFranceOnyama Limba NEGOTIATION
Aika U RutaUnited KingdomXuxue Feng RENEWAL
Mayumi N VocelkaCanadaXuxue Feng PROPOSAL
Ricardo W FigeroaItalyBernardo Dominic NEGOTIATION
Munro R PerinArgentinaElwin Sharvill QUALIFIED
Aika A NestleArgentinaOnyama Limba PROPOSAL
Ricardo T GauchoItalyAmy Elsner NEGOTIATION
Rodrigues N CampainSpainIvan Magalhaes RENEWAL
Arvin Z CaudyJapanStephen Shaw PROPOSAL
Kaitlin H FlosiBrazilIvan Magalhaes PROPOSAL
Claire H WaycottArgentinaIoni Bowcher NEGOTIATION
Ricardo D OstroskyBrazilXuxue Feng UNQUALIFIED
Deepesh N ButtFranceAsiya Javayant NEW
Jennifer N GlickGermanyAsiya Javayant QUALIFIED
Jeanfrancois Z FigeroaBrazilXuxue Feng QUALIFIED
Juan P FerenczIndiaXuxue Feng RENEWAL
Julie Q FigeroaCanadaXuxue Feng NEW
Murillo C DoeCanadaBernardo Dominic NEW
Kadeem I GauchoSpainXuxue Feng NEW
Wickens J GillianJapanAsiya Javayant RENEWAL
Smith K OldroydSpainAsiya Javayant UNQUALIFIED
Aika U OstroskyRussiaAsiya Javayant NEGOTIATION
Deepesh R FlosiBrazilElwin Sharvill QUALIFIED
Kaitlin S GauchoItalyAmy Elsner NEW
Izzy A FollerAustraliaAmy Elsner NEW
Kaitlin W DarakjyJapanAnna Fali NEGOTIATION
Aika N SchemmerAustraliaAsiya Javayant NEW
Ashley L RoysterItalyStephen Shaw PROPOSAL
Frozen Columns
Name
Mujtaba S Garufi
Arvin I Gaucho
Deepesh I Rim
Rodrigues U Bolognia
Jennifer F Ferencz
Mujtaba J Chui
Morrow O Kolmetz
Faith I Gaucho
Wickens K Butt
Faith G Nestle
Aditya B Bowley
Leja O Bolognia
Cody H Saylors
Mujtaba F Poquette
Arvin R Caudy
Greenwood B Sergi
Isabel P Kolmetz
Wickens O Inouye
Jefferson E Albares
Julie J Shinko
Stacey O Nicka
Jefferson I Slusarski
Isabel W Shinko
Jennifer L Paprocki
Kadeem I Doe
Jennifer Y Rulapaugh
Munro S Waycott
James R Oldroyd
David F Schemmer
Munro I Malet
Julie F Caldarera
Murillo C Nestle
Francesco R Ferencz
Sinclair O Albares
Adams V Chui
Kaitlin M Albares
Faith E Oldroyd
Ashley A Malet
Jennifer P Caldarera
Kadeem A Kolmetz
Munro K Ostrosky
Ashley M Nestle
David V Rim
Claire P Gillian
Faith S Nicka
James H Maclead
Ricardo Z Ruta
Leon M Rulapaugh
Aditya E Marrier
Darci D Dilliard
IdCountryDate
1000United Kingdom2024-04-16
1001United Kingdom2024-04-13
1002Germany2024-04-04
1003United Kingdom2024-04-25
1004Germany2024-03-31
1005Canada2024-04-10
1006India2024-04-26
1007Japan2024-04-18
1008Germany2024-04-23
1009Canada2024-04-21
1010Canada2024-04-15
1011Japan2024-04-01
1012Argentina2024-04-17
1013Russia2024-04-11
1014Germany2024-03-31
1015Australia2024-04-02
1016Germany2024-04-05
1017Germany2024-04-27
1018Brazil2024-03-30
1019United Kingdom2024-04-03
1020Argentina2024-04-01
1021Japan2024-03-30
1022Canada2024-04-24
1023Germany2024-04-03
1024India2024-04-15
1025Australia2024-04-21
1026Spain2024-03-29
1027Canada2024-04-01
1028Canada2024-04-17
1029Australia2024-04-05
1030Argentina2024-04-06
1031Canada2024-04-06
1032Argentina2024-04-07
1033Japan2024-03-30
1034Canada2024-04-11
1035Russia2024-04-22
1036Russia2024-04-23
1037Russia2024-03-30
1038Japan2024-03-29
1039Canada2024-03-29
1040Australia2024-04-02
1041United Kingdom2024-04-01
1042France2024-04-12
1043United Kingdom2024-04-01
1044Brazil2024-04-05
1045Canada2024-04-11
1046France2024-04-11
1047India2024-04-12
1048Canada2024-04-17
1049Italy2024-04-16

On-Demand Data

NameIdCountryDate
Jennifer S Wieser1000Australia2024-03-30
Juan N Venere1001Argentina2024-04-17
Rodrigues Y Nicka1002Japan2024-04-04
Aditya O Nicka1003Spain2024-04-03
Greenwood I Paprocki1004France2024-04-13
Ivar F Dilliard1005Italy2024-04-04
Johnson E Briddick1006Canada2024-04-05
Cody Q Stockham1007Argentina2024-04-19
Julie T Tollner1008Spain2024-04-04
Ricardo S Flosi1009Japan2024-04-17
Julie X Whobrey1010France2024-04-02
Izzy W Bowley1011United Kingdom2024-04-09
Silvio X Flosi1012India2024-04-17
Rodrigues Z Sergi1013United Kingdom2024-04-14
Juan U Garufi1014Italy2024-04-01
Faith W Wieser1015United Kingdom2024-04-08
Kaitlin V Flosi1016Australia2024-04-19
James E Gillian1017Russia2024-04-21
Nicolas Q Inouye1018Spain2024-03-29
Claire L Waycott1019Spain2024-04-17
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Deepesh R TollnerArgentinaIoni Bowcher UNQUALIFIED
Deepesh T SchemmerCanadaStephen Shaw NEGOTIATION
Francesco M InouyeJapanXuxue Feng NEW
Kadeem E WieserFranceIoni Bowcher QUALIFIED
Aditya V RutaArgentinaAmy Elsner NEGOTIATION
Deepesh N NestleBrazilAmy Elsner PROPOSAL
Deepesh M ButtGermanyBernardo Dominic NEGOTIATION
Salvatore D FollerGermanyBernardo Dominic QUALIFIED
Arvin F OstroskyAustraliaBernardo Dominic NEW
Darci M GillianJapanOnyama Limba RENEWAL
Sinclair N FlosiBrazilAsiya Javayant RENEWAL
Mayumi W ButtCanadaAmy Elsner NEW
Jefferson U GauchoGermanyXuxue Feng NEGOTIATION
Deepesh Q AmigonSpainOnyama Limba UNQUALIFIED
Aruna U WaycottCanadaXuxue Feng NEW
Nicolas Q MaletBrazilBernardo Dominic RENEWAL
Jennifer B CampainBrazilAnna Fali PROPOSAL
Jones K BriddickAustraliaIvan Magalhaes NEGOTIATION
Juan I SergiCanadaIvan Magalhaes PROPOSAL
Greenwood F WhobreyJapanElwin Sharvill RENEWAL
Costa H SergiGermanyIvan Magalhaes QUALIFIED
Kadeem E SlusarskiCanadaIvan Magalhaes NEGOTIATION
Clifford Y SaylorsItalyIvan Magalhaes QUALIFIED
Faith L PerinGermanyStephen Shaw UNQUALIFIED
Leja J DarakjyJapanElwin Sharvill NEGOTIATION
Izzy Y FerenczSpainStephen Shaw QUALIFIED
Faith R FigeroaItalyElwin Sharvill NEW
Clifford I SchemmerAustraliaIoni Bowcher NEW
Izzy H BowleyUnited KingdomStephen Shaw NEW
Smith O SlusarskiSpainOnyama Limba RENEWAL
Ricardo X InouyeSpainBernardo Dominic PROPOSAL
Munro M PoquetteBrazilBernardo Dominic PROPOSAL
Silvio K PerinRussiaIvan Magalhaes RENEWAL
Aika D NestleFranceOnyama Limba NEGOTIATION
Aruna V SaylorsIndiaBernardo Dominic QUALIFIED
Juan N WaycottAustraliaXuxue Feng UNQUALIFIED
Faith N KuskoSpainAsiya Javayant QUALIFIED
Arvin G TollnerSpainXuxue Feng NEW
Alejandro G SaylorsCanadaIoni Bowcher PROPOSAL
Aditya C CampainArgentinaBernardo Dominic 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>