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
Faith C MaletJapanAmy Elsner NEGOTIATION
Juan A RutaArgentinaStephen Shaw NEW
Aruna M TollnerCanadaAnna Fali QUALIFIED
Costa O CampainIndiaElwin Sharvill UNQUALIFIED
Kaitlin Y ShinkoFranceAnna Fali QUALIFIED
Juan X MaletRussiaIoni Bowcher RENEWAL
Ivar P SergiIndiaAmy Elsner NEW
Francesco K RoysterArgentinaStephen Shaw PROPOSAL
Aditya N WieserAustraliaIvan Magalhaes UNQUALIFIED
Maria C RutaSpainElwin Sharvill NEW
Jennifer G AlbaresItalyAnna Fali NEW
Maria A BowleyUnited KingdomOnyama Limba RENEWAL
Maria V KuskoFranceBernardo Dominic PROPOSAL
Smith E TollnerAustraliaIoni Bowcher RENEWAL
Clifford R NestleRussiaAnna Fali NEGOTIATION
Clifford C StensethSpainAnna Fali NEW
Antonio N MorascaRussiaElwin Sharvill NEGOTIATION
Arvin D GarufiAustraliaOnyama Limba PROPOSAL
Juan H GlickGermanyXuxue Feng NEW
Jones S FollerFranceElwin Sharvill NEW
Costa R BowleyJapanBernardo Dominic NEGOTIATION
Kaitlin Q AmigonArgentinaOnyama Limba NEGOTIATION
Morrow I GarufiBrazilAmy Elsner PROPOSAL
Clifford Q MarrierIndiaIoni Bowcher RENEWAL
Juan U FigeroaSpainIoni Bowcher RENEWAL
Kaitlin S BriddickItalyStephen Shaw NEGOTIATION
David I DoeUnited KingdomOnyama Limba NEW
Rodrigues R GauchoAustraliaBernardo Dominic QUALIFIED
Silvio V GauchoRussiaAnna Fali PROPOSAL
Alejandro C MorascaBrazilElwin Sharvill QUALIFIED
Emily O WhobreyIndiaIvan Magalhaes NEW
Francesco F OldroydJapanAsiya Javayant QUALIFIED
Leon T MarrierAustraliaElwin Sharvill NEGOTIATION
Ashley A AmigonBrazilBernardo Dominic UNQUALIFIED
Mujtaba Q BriddickIndiaIvan Magalhaes QUALIFIED
Jones S PoquetteGermanyBernardo Dominic NEGOTIATION
Emily W WieserRussiaIvan Magalhaes NEGOTIATION
Claire E PoquetteIndiaElwin Sharvill PROPOSAL
Aditya F PaprockiBrazilXuxue Feng RENEWAL
Julie G BriddickArgentinaAmy Elsner NEGOTIATION
Kadeem U BologniaAustraliaOnyama Limba RENEWAL
Morrow B OldroydCanadaOnyama Limba PROPOSAL
Adams N PoquetteJapanAsiya Javayant RENEWAL
Maisha N IturbideCanadaAsiya Javayant RENEWAL
Ashley G MaletUnited KingdomXuxue Feng RENEWAL
Julie W ButtArgentinaAnna Fali NEGOTIATION
Kaitlin R NestleSpainStephen Shaw PROPOSAL
Stacey L StensethItalyBernardo Dominic PROPOSAL
Aruna H GlickFranceBernardo Dominic PROPOSAL
Jones Q PerinArgentinaIoni Bowcher RENEWAL
Horizontal
NameCountryRepresentativeStatus
Kaitlin K RulapaughBrazilBernardo Dominic NEGOTIATION
Antonio P FlosiUnited KingdomIvan Magalhaes PROPOSAL
Ivar N FollerJapanOnyama Limba NEGOTIATION
Cody S WieserCanadaOnyama Limba PROPOSAL
Adams U SaylorsIndiaIoni Bowcher RENEWAL
Kadeem Z AlbaresItalyElwin Sharvill NEGOTIATION
David K ChuiSpainAnna Fali UNQUALIFIED
Salvatore R MaletItalyIoni Bowcher NEGOTIATION
Jennifer I ChuiFranceIvan Magalhaes RENEWAL
Silvio D InouyeIndiaIvan Magalhaes UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Greenwood O MacleadItaly2024-03-28Feiner Bros NEGOTIATION84Amy Elsner
1001Leja A IturbideItaly2024-03-28Chanay, Jeffrey A Esq RENEWAL68Ivan Magalhaes
1002Kaitlin R IturbideIndia2024-03-28Buckley Miller Wright NEW51Ioni Bowcher
1003Darci P KuskoJapan2024-04-26Benton, John B Jr RENEWAL47Ivan Magalhaes
1004Isabel X SaylorsRussia2024-04-01Chemel, James L Cpa NEW70Ioni Bowcher
1005Chavez D RutaBrazil2024-04-19Commercial Press NEGOTIATION21Onyama Limba
1006Mayumi U NestleBrazil2024-04-16Chanay, Jeffrey A Esq NEGOTIATION23Asiya Javayant
1007Ashley Y GlickFrance2024-03-29Chemel, James L Cpa RENEWAL88Asiya Javayant
1008Aika K RutaItaly2024-04-24Chapman, Ross E Esq NEW58Amy Elsner
1009Misaki T OstroskyAustralia2024-04-04King, Christopher A Esq NEGOTIATION82Ioni Bowcher
1010Antonio P MaletBrazil2024-03-31Benton, John B Jr RENEWAL14Bernardo Dominic
1011Wickens O RimAustralia2024-04-09Morlong Associates NEW2Stephen Shaw
1012Maria K StockhamIndia2024-04-26Printing Dimensions QUALIFIED23Anna Fali
1013Alejandro L VocelkaRussia2024-04-13Feiner Bros QUALIFIED27Bernardo Dominic
1014Ivar F WieserRussia2024-04-23Feiner Bros PROPOSAL56Xuxue Feng
1015Stacey V GlickCanada2024-04-17Commercial Press UNQUALIFIED75Xuxue Feng
1016Mayumi I WaycottJapan2024-03-29Chapman, Ross E Esq NEGOTIATION98Amy Elsner
1017Murillo R PerinRussia2024-04-17Dorl, James J Esq QUALIFIED93Bernardo Dominic
1018Morrow I WieserCanada2024-04-04King, Christopher A Esq RENEWAL11Stephen Shaw
1019Arvin W FlosiFrance2024-04-22King, Christopher A Esq NEGOTIATION3Ivan Magalhaes
1020Wickens F StensethBrazil2024-04-16Benton, John B Jr QUALIFIED46Amy Elsner
1021Darci L VenereCanada2024-04-19Dorl, James J Esq NEGOTIATION48Elwin Sharvill
1022Francesco A SchemmerUnited Kingdom2024-04-02Feiner Bros RENEWAL64Stephen Shaw
1023Leja D RimArgentina2024-04-26Buckley Miller Wright UNQUALIFIED40Anna Fali
1024Kadeem W WieserRussia2024-04-05Morlong Associates PROPOSAL96Ivan Magalhaes
1025Francesco A MorascaCanada2024-03-28King, Christopher A Esq UNQUALIFIED62Anna Fali
1026Rodrigues P OldroydSpain2024-04-06Commercial Press RENEWAL94Ioni Bowcher
1027Smith H MaletUnited Kingdom2024-04-18Printing Dimensions QUALIFIED98Anna Fali
1028Leon S SchemmerArgentina2024-04-20King, Christopher A Esq RENEWAL18Xuxue Feng
1029Alejandro C GarufiRussia2024-04-18Chemel, James L Cpa UNQUALIFIED21Amy Elsner
1030Maisha P AmigonSpain2024-04-24Rangoni Of Florence UNQUALIFIED27Stephen Shaw
1031Greenwood P VenereJapan2024-04-06Chanay, Jeffrey A Esq RENEWAL13Bernardo Dominic
1032Leja E RoysterRussia2024-04-04Chanay, Jeffrey A Esq UNQUALIFIED27Stephen Shaw
1033Chavez I StockhamArgentina2024-03-28Buckley Miller Wright QUALIFIED0Ivan Magalhaes
1034Sinclair N WhobreyUnited Kingdom2024-04-06Benton, John B Jr RENEWAL74Amy Elsner
1035Mayumi N BriddickFrance2024-04-21Buckley Miller Wright UNQUALIFIED20Anna Fali
1036Julie G MaletArgentina2024-04-13Dorl, James J Esq NEW95Stephen Shaw
1037Aditya L BologniaIndia2024-04-05Chanay, Jeffrey A Esq RENEWAL96Anna Fali
1038Arvin E PerinRussia2024-04-14Rousseaux, Michael Esq RENEWAL91Stephen Shaw
1039Aruna A SlusarskiUnited Kingdom2024-04-14Commercial Press RENEWAL23Xuxue Feng
1040David X RulapaughSpain2024-04-03Truhlar And Truhlar Attys NEW88Anna Fali
1041James V MaletFrance2024-04-20Printing Dimensions QUALIFIED56Onyama Limba
1042Juan L SergiJapan2024-04-01Truhlar And Truhlar Attys RENEWAL17Amy Elsner
1043Jeanfrancois U RimBrazil2024-04-18Chanay, Jeffrey A Esq NEW98Onyama Limba
1044Leja P CampainAustralia2024-04-05Rangoni Of Florence NEGOTIATION33Bernardo Dominic
1045Faith I MacleadBrazil2024-04-02Chemel, James L Cpa RENEWAL73Elwin Sharvill
1046Murillo W InouyeArgentina2024-04-05Commercial Press NEW50Onyama Limba
1047Juan D FlosiUnited Kingdom2024-04-06Feltz Printing Service QUALIFIED91Amy Elsner
1048Chavez O MarrierGermany2024-04-25Chapman, Ross E Esq NEGOTIATION22Stephen Shaw
1049Greenwood T ChuiRussia2024-04-17Printing Dimensions UNQUALIFIED76Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Claire Z PaprockiGermanyBernardo Dominic NEW
Sinclair Z MarrierSpainIvan Magalhaes NEW
Chavez Q RutaJapanXuxue Feng NEW
Clifford P FollerSpainAnna Fali NEGOTIATION
Octavia V ShinkoArgentinaIoni Bowcher UNQUALIFIED
Tony P MaletCanadaAsiya Javayant QUALIFIED
Johnson A ShinkoSpainAsiya Javayant NEGOTIATION
Ricardo X SlusarskiArgentinaElwin Sharvill RENEWAL
Ivar D GauchoArgentinaAnna Fali NEW
Jennifer A MacleadCanadaIoni Bowcher NEW
Kaitlin A PoquetteBrazilBernardo Dominic RENEWAL
Johnson N KuskoFranceXuxue Feng NEW
Isabel I MaletRussiaIoni Bowcher PROPOSAL
Ivar H BriddickAustraliaAsiya Javayant PROPOSAL
Ashley V CaldareraFranceAsiya Javayant PROPOSAL
Francesco P MaletCanadaAsiya Javayant QUALIFIED
Stacey Q RutaUnited KingdomXuxue Feng RENEWAL
James A KuskoSpainBernardo Dominic RENEWAL
Deepesh T SchemmerRussiaElwin Sharvill QUALIFIED
Costa B PaprockiAustraliaIoni Bowcher PROPOSAL
Maisha I OstroskyArgentinaElwin Sharvill RENEWAL
Juan M RulapaughGermanyAsiya Javayant NEGOTIATION
Juan O RoysterAustraliaStephen Shaw PROPOSAL
Wickens D IturbideSpainAsiya Javayant NEW
Deepesh V KolmetzCanadaStephen Shaw RENEWAL
Munro U AlbaresJapanBernardo Dominic QUALIFIED
Smith N KuskoItalyAnna Fali NEGOTIATION
Aika M PoquetteAustraliaXuxue Feng UNQUALIFIED
Faith J NickaArgentinaAnna Fali NEGOTIATION
Deepesh E AmigonBrazilElwin Sharvill NEW
James A OstroskyRussiaStephen Shaw NEW
Ricardo Y MorascaRussiaIoni Bowcher RENEWAL
Adams W CaudyJapanAsiya Javayant UNQUALIFIED
Aruna V NestleCanadaBernardo Dominic NEW
Misaki C SlusarskiBrazilAnna Fali QUALIFIED
Faith R TollnerFranceAnna Fali NEW
Alejandro F DarakjyUnited KingdomIoni Bowcher PROPOSAL
Julie R PoquetteGermanyAnna Fali NEW
Misaki B SaylorsIndiaBernardo Dominic NEW
Salvatore D WaycottJapanOnyama Limba UNQUALIFIED
James X WieserCanadaIoni Bowcher QUALIFIED
Rodrigues Z KolmetzCanadaIvan Magalhaes NEW
Clifford M MarrierFranceBernardo Dominic UNQUALIFIED
Julie N BriddickIndiaStephen Shaw NEGOTIATION
Jeanfrancois Q FollerRussiaElwin Sharvill PROPOSAL
Costa Z GarufiSpainIoni Bowcher RENEWAL
Jefferson W SchemmerJapanBernardo Dominic PROPOSAL
Jennifer B GillianFranceIvan Magalhaes UNQUALIFIED
Aditya O ButtSpainIvan Magalhaes UNQUALIFIED
Leon L BologniaBrazilAnna Fali PROPOSAL
Frozen Columns
Name
Aditya X Royster
Jefferson S Figeroa
Aruna E Marrier
Jennifer J Paprocki
Jennifer B Garufi
Sinclair T Gillian
Murillo W Iturbide
Silvio N Stenseth
Maisha U Malet
Ashley G Chui
Claire F Gaucho
Stacey H Iturbide
Nicolas X Ferencz
Kaitlin I Ruta
Silvio W Inouye
Adams V Malet
Francesco Y Tollner
Adams H Nicka
Tony V Gillian
Julie A Rim
Deepesh X Saylors
Ricardo B Marrier
Cody K Schemmer
Mayumi U Poquette
Jennifer U Stenseth
Cody C Rulapaugh
Cody E Sergi
Ivar L Saylors
Jefferson X Schemmer
Izzy G Slusarski
Leon Z Briddick
Francesco H Sergi
Johnson K Venere
Rodrigues G Bowley
Francesco S Tollner
Stacey N Bolognia
Alejandro G Ostrosky
Smith D Stenseth
Clifford Y Oldroyd
Misaki X Foller
Kadeem X Inouye
Cody S Venere
Munro D Vocelka
Stacey L Dilliard
Smith K Venere
Leon R Paprocki
Julie Z Gaucho
Johnson W Stockham
Rodrigues W Tollner
Mujtaba R Malet
IdCountryDate
1000Brazil2024-04-21
1001Germany2024-03-31
1002Argentina2024-04-05
1003Japan2024-04-24
1004Japan2024-04-26
1005Germany2024-04-01
1006Spain2024-04-03
1007United Kingdom2024-04-07
1008India2024-04-05
1009United Kingdom2024-04-25
1010Spain2024-04-17
1011Germany2024-04-12
1012India2024-04-20
1013Italy2024-04-15
1014Argentina2024-04-21
1015Germany2024-04-03
1016Brazil2024-04-23
1017France2024-04-26
1018Canada2024-04-09
1019Australia2024-03-30
1020Japan2024-04-09
1021United Kingdom2024-04-08
1022Italy2024-04-20
1023Australia2024-04-26
1024Spain2024-04-17
1025Italy2024-04-02
1026Spain2024-04-13
1027Japan2024-04-08
1028Argentina2024-04-18
1029Germany2024-04-05
1030United Kingdom2024-04-21
1031India2024-04-02
1032France2024-04-17
1033United Kingdom2024-04-20
1034France2024-04-26
1035Canada2024-04-19
1036Russia2024-04-18
1037Italy2024-04-02
1038Italy2024-04-26
1039Canada2024-04-11
1040France2024-04-23
1041United Kingdom2024-03-29
1042Australia2024-04-18
1043Germany2024-03-28
1044Japan2024-04-24
1045Russia2024-04-25
1046Canada2024-04-04
1047Spain2024-04-26
1048United Kingdom2024-04-24
1049France2024-04-10

On-Demand Data

NameIdCountryDate
Murillo Y Stenseth1000United Kingdom2024-04-21
Maisha Q Albares1001France2024-04-10
Ricardo I Gaucho1002Argentina2024-04-26
Tony N Caudy1003Spain2024-04-14
Emily S Ostrosky1004Argentina2024-04-06
Smith B Stockham1005Australia2024-03-31
Isabel U Poquette1006Brazil2024-04-05
Mayumi S Kusko1007United Kingdom2024-04-13
Morrow Z Wieser1008Germany2024-04-16
Deepesh D Saylors1009United Kingdom2024-04-11
Octavia I Perin1010Germany2024-04-19
Munro N Darakjy1011Brazil2024-04-20
Antonio C Garufi1012Canada2024-04-16
Octavia R Dilliard1013Italy2024-04-20
Alejandro H Venere1014France2024-04-07
Misaki U Iturbide1015Germany2024-04-15
David O Ruta1016Argentina2024-04-01
Aditya S Rulapaugh1017Australia2024-04-11
Sinclair I Briddick1018India2024-04-03
Tony B Briddick1019Spain2024-04-22
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Nicolas H ShinkoIndiaOnyama Limba RENEWAL
Morrow J BowleyRussiaIvan Magalhaes NEGOTIATION
Aditya N CaudyFranceBernardo Dominic RENEWAL
Wickens Q GauchoItalyXuxue Feng RENEWAL
Emily A MarrierAustraliaIvan Magalhaes UNQUALIFIED
Cody E MaletItalyAsiya Javayant QUALIFIED
Sinclair O GauchoArgentinaXuxue Feng QUALIFIED
Adams I MorascaFranceElwin Sharvill NEW
Ricardo T PaprockiJapanIoni Bowcher NEW
Johnson U FollerIndiaIvan Magalhaes NEW
Jennifer Q GillianArgentinaOnyama Limba NEW
Munro G MorascaAustraliaIoni Bowcher QUALIFIED
Costa J MarrierSpainStephen Shaw UNQUALIFIED
Ashley R IturbideCanadaIvan Magalhaes RENEWAL
Salvatore U SergiRussiaAmy Elsner UNQUALIFIED
Cody O KolmetzFranceXuxue Feng QUALIFIED
Munro H AmigonGermanyElwin Sharvill PROPOSAL
Leja Q InouyeArgentinaAmy Elsner NEW
Costa Z RulapaughUnited KingdomBernardo Dominic RENEWAL
James Z BriddickJapanAsiya Javayant NEW
Arvin H MaletBrazilStephen Shaw RENEWAL
Izzy O MaletFranceAmy Elsner QUALIFIED
Misaki R RimGermanyIoni Bowcher PROPOSAL
Izzy K RutaBrazilOnyama Limba PROPOSAL
Costa M SlusarskiJapanAnna Fali PROPOSAL
Ashley I FigeroaIndiaElwin Sharvill NEW
Ashley X OldroydArgentinaIvan Magalhaes NEW
Emily N RoysterArgentinaAsiya Javayant QUALIFIED
Deepesh Q CampainRussiaAsiya Javayant NEGOTIATION
Isabel A SaylorsFranceAnna Fali NEGOTIATION
Alejandro K WieserRussiaOnyama Limba PROPOSAL
Morrow D BowleySpainXuxue Feng NEW
Mayumi C NickaBrazilStephen Shaw RENEWAL
James H CaldareraSpainElwin Sharvill NEGOTIATION
Wickens W NickaCanadaOnyama Limba RENEWAL
Cody J DoeArgentinaOnyama Limba PROPOSAL
Salvatore U MacleadItalyAnna Fali PROPOSAL
James B SaylorsAustraliaAsiya Javayant NEW
Jones W DilliardArgentinaAnna Fali RENEWAL
Misaki S ShinkoJapanAmy Elsner 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>