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
James J FerenczRussiaIvan Magalhaes PROPOSAL
Julie N DoeAustraliaElwin Sharvill UNQUALIFIED
David I NestleBrazilIvan Magalhaes NEW
Nicolas C IturbideUnited KingdomOnyama Limba PROPOSAL
Greenwood Y DarakjyGermanyStephen Shaw PROPOSAL
David Y GillianGermanyXuxue Feng QUALIFIED
Maria G OldroydJapanOnyama Limba NEW
Jones C PoquetteGermanyIvan Magalhaes NEW
Aika D CaudyFranceXuxue Feng NEGOTIATION
Ivar B WaycottGermanyAsiya Javayant PROPOSAL
Adams E SchemmerGermanyIvan Magalhaes NEW
Rodrigues C ShinkoArgentinaIoni Bowcher UNQUALIFIED
Ashley D DarakjyItalyElwin Sharvill PROPOSAL
Kaitlin U GauchoUnited KingdomElwin Sharvill UNQUALIFIED
Maisha S MorascaAustraliaStephen Shaw QUALIFIED
Julie S CaudyItalyOnyama Limba RENEWAL
Munro T AlbaresJapanStephen Shaw UNQUALIFIED
Ashley J FigeroaGermanyIvan Magalhaes RENEWAL
Costa D SergiBrazilXuxue Feng RENEWAL
Claire Q MaletAustraliaAnna Fali QUALIFIED
Juan T ShinkoGermanyAnna Fali UNQUALIFIED
Octavia W MacleadGermanyAsiya Javayant UNQUALIFIED
Jones U StockhamIndiaStephen Shaw NEW
Murillo D FollerRussiaStephen Shaw NEGOTIATION
Johnson C BowleyIndiaBernardo Dominic RENEWAL
Greenwood D WhobreyUnited KingdomElwin Sharvill RENEWAL
Kadeem R BriddickUnited KingdomOnyama Limba NEGOTIATION
Misaki K WieserIndiaAnna Fali QUALIFIED
Munro Y FlosiItalyStephen Shaw PROPOSAL
David X WieserSpainStephen Shaw NEW
Alejandro U StockhamIndiaStephen Shaw UNQUALIFIED
Mujtaba X NickaSpainXuxue Feng PROPOSAL
Ashley F SaylorsIndiaElwin Sharvill NEGOTIATION
Kadeem W BriddickSpainIvan Magalhaes PROPOSAL
Maria V FlosiRussiaElwin Sharvill PROPOSAL
Morrow B GlickIndiaStephen Shaw RENEWAL
Ricardo S PerinIndiaElwin Sharvill UNQUALIFIED
Tony A NestleAustraliaIoni Bowcher RENEWAL
Izzy K StensethItalyIvan Magalhaes PROPOSAL
Maria S PaprockiIndiaIoni Bowcher NEW
Leja T FerenczRussiaAmy Elsner NEGOTIATION
Smith F SaylorsAustraliaXuxue Feng RENEWAL
Greenwood Q InouyeArgentinaElwin Sharvill UNQUALIFIED
Aruna W MaletBrazilAsiya Javayant NEGOTIATION
Aruna J KuskoSpainAnna Fali NEW
Clifford P WhobreyBrazilOnyama Limba RENEWAL
Johnson X GlickIndiaStephen Shaw RENEWAL
Chavez E BriddickJapanAsiya Javayant NEGOTIATION
Maisha W FerenczUnited KingdomAnna Fali UNQUALIFIED
Tony L WaycottRussiaStephen Shaw NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Misaki V BologniaIndiaOnyama Limba QUALIFIED
Faith V RutaIndiaAnna Fali NEW
Leja V WaycottIndiaIoni Bowcher RENEWAL
Greenwood D DarakjyArgentinaStephen Shaw PROPOSAL
Mayumi U DilliardItalyStephen Shaw UNQUALIFIED
Jefferson G StockhamRussiaAmy Elsner NEW
Ivar T BologniaItalyAsiya Javayant NEW
Darci F StensethIndiaXuxue Feng RENEWAL
Maria T FerenczFranceStephen Shaw NEW
Faith R SergiGermanyIoni Bowcher NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Isabel O DoeIndia2024-04-04Feltz Printing Service QUALIFIED74Anna Fali
1001Isabel J CaldareraGermany2024-04-01Morlong Associates RENEWAL62Onyama Limba
1002Cody J SergiBrazil2024-03-21Dorl, James J Esq NEGOTIATION82Bernardo Dominic
1003Chavez J NestleRussia2024-03-30King, Christopher A Esq UNQUALIFIED43Ioni Bowcher
1004Kadeem U PaprockiRussia2024-04-19Chapman, Ross E Esq NEW76Amy Elsner
1005Wickens Z DoeBrazil2024-03-30Feltz Printing Service NEW11Elwin Sharvill
1006Johnson P WaycottArgentina2024-03-24Benton, John B Jr NEGOTIATION67Elwin Sharvill
1007Misaki G DarakjyUnited Kingdom2024-04-10Dorl, James J Esq RENEWAL63Ioni Bowcher
1008Tony W FollerJapan2024-03-27Feiner Bros NEW3Ivan Magalhaes
1009Rodrigues H BowleyCanada2024-03-27Feiner Bros NEW59Xuxue Feng
1010Munro B CaldareraArgentina2024-04-04Benton, John B Jr UNQUALIFIED64Ivan Magalhaes
1011Ricardo Z CaldareraRussia2024-03-24Feiner Bros RENEWAL57Anna Fali
1012Smith T WhobreyArgentina2024-04-14Feltz Printing Service UNQUALIFIED21Onyama Limba
1013Silvio P WaycottJapan2024-04-17Chanay, Jeffrey A Esq NEW51Elwin Sharvill
1014Greenwood D DarakjySpain2024-04-18Feiner Bros PROPOSAL8Ivan Magalhaes
1015Adams B ChuiFrance2024-04-12Commercial Press PROPOSAL58Asiya Javayant
1016Morrow Y GauchoSpain2024-03-31Chemel, James L Cpa RENEWAL78Bernardo Dominic
1017Maria E NickaArgentina2024-03-28Truhlar And Truhlar Attys NEW50Xuxue Feng
1018Smith W CaldareraCanada2024-04-10Feltz Printing Service QUALIFIED72Ivan Magalhaes
1019Morrow F MorascaBrazil2024-04-10Morlong Associates UNQUALIFIED13Amy Elsner
1020Antonio O DarakjyRussia2024-04-18Truhlar And Truhlar Attys RENEWAL34Amy Elsner
1021David O InouyeAustralia2024-03-26Dorl, James J Esq PROPOSAL25Amy Elsner
1022Julie G GauchoAustralia2024-04-11Buckley Miller Wright UNQUALIFIED20Ioni Bowcher
1023Octavia I BowleyGermany2024-03-22Feiner Bros NEGOTIATION72Ioni Bowcher
1024Isabel J VenereFrance2024-04-05Benton, John B Jr NEW15Stephen Shaw
1025Maria T GillianCanada2024-03-24Commercial Press QUALIFIED75Stephen Shaw
1026Nicolas D CampainRussia2024-04-19Printing Dimensions NEW64Anna Fali
1027Aruna O NickaUnited Kingdom2024-03-28Rousseaux, Michael Esq RENEWAL21Asiya Javayant
1028Jefferson L NestleIndia2024-03-21Morlong Associates NEGOTIATION27Ioni Bowcher
1029Jefferson Y RoysterJapan2024-04-02Chapman, Ross E Esq UNQUALIFIED10Bernardo Dominic
1030Arvin A BologniaJapan2024-03-30Rousseaux, Michael Esq NEW38Xuxue Feng
1031Mayumi O OldroydCanada2024-04-18Rousseaux, Michael Esq PROPOSAL5Bernardo Dominic
1032Tony M OldroydUnited Kingdom2024-03-28Commercial Press UNQUALIFIED54Xuxue Feng
1033Antonio V PerinJapan2024-03-25Rousseaux, Michael Esq QUALIFIED85Amy Elsner
1034Mayumi D OldroydSpain2024-03-25Chemel, James L Cpa NEW63Bernardo Dominic
1035Ashley U MorascaJapan2024-04-03Chapman, Ross E Esq NEGOTIATION5Asiya Javayant
1036Jones Z GarufiArgentina2024-03-21Chanay, Jeffrey A Esq NEGOTIATION51Xuxue Feng
1037Wickens C RoysterArgentina2024-04-02Rousseaux, Michael Esq NEGOTIATION50Elwin Sharvill
1038Kadeem B RutaSpain2024-03-26Feiner Bros RENEWAL26Xuxue Feng
1039Sinclair X MacleadAustralia2024-03-24King, Christopher A Esq RENEWAL47Bernardo Dominic
1040Sinclair Q StockhamItaly2024-04-11Chapman, Ross E Esq PROPOSAL79Asiya Javayant
1041Leja B SlusarskiItaly2024-03-28Dorl, James J Esq PROPOSAL14Bernardo Dominic
1042David Z FollerFrance2024-03-30Buckley Miller Wright QUALIFIED14Bernardo Dominic
1043Johnson C DilliardIndia2024-03-25Chapman, Ross E Esq NEW19Asiya Javayant
1044Juan G KuskoUnited Kingdom2024-04-09Rangoni Of Florence UNQUALIFIED23Elwin Sharvill
1045Emily J MacleadAustralia2024-04-09Printing Dimensions PROPOSAL75Asiya Javayant
1046Ivar H VenereFrance2024-04-16Morlong Associates NEGOTIATION16Amy Elsner
1047Silvio U GauchoCanada2024-04-09Feltz Printing Service NEGOTIATION2Stephen Shaw
1048Alejandro N CaldareraArgentina2024-04-06Truhlar And Truhlar Attys NEGOTIATION94Asiya Javayant
1049Greenwood I RulapaughArgentina2024-04-03Chanay, Jeffrey A Esq NEGOTIATION60Ioni Bowcher
Frozen Rows
NameCountryRepresentativeStatus
Chavez T GillianItalyOnyama Limba NEGOTIATION
Leja P ChuiSpainIvan Magalhaes RENEWAL
Ricardo P SaylorsGermanyAmy Elsner NEGOTIATION
Jeanfrancois S FollerUnited KingdomOnyama Limba PROPOSAL
Mayumi G AmigonSpainIoni Bowcher RENEWAL
Faith X StensethBrazilStephen Shaw NEW
Isabel Q MarrierJapanAnna Fali QUALIFIED
Isabel E VenereIndiaStephen Shaw NEW
David E OldroydItalyStephen Shaw QUALIFIED
Octavia X BriddickFranceOnyama Limba QUALIFIED
Francesco L SchemmerFranceElwin Sharvill NEW
Mujtaba S StockhamJapanStephen Shaw UNQUALIFIED
Jones Z KolmetzFranceStephen Shaw QUALIFIED
Sinclair U SlusarskiFranceElwin Sharvill QUALIFIED
Misaki U WaycottJapanOnyama Limba NEW
Octavia M RulapaughJapanStephen Shaw QUALIFIED
Emily I DarakjyUnited KingdomOnyama Limba QUALIFIED
Johnson I CaudyAustraliaIoni Bowcher RENEWAL
Ashley Q ShinkoRussiaAnna Fali UNQUALIFIED
Deepesh Z PerinRussiaOnyama Limba NEW
Murillo P DoeArgentinaAsiya Javayant UNQUALIFIED
Octavia C ButtAustraliaXuxue Feng NEW
Aditya B RimRussiaXuxue Feng NEGOTIATION
Mayumi M MaletCanadaAnna Fali PROPOSAL
Adams F GarufiJapanElwin Sharvill UNQUALIFIED
Mayumi U BowleyAustraliaIoni Bowcher UNQUALIFIED
Maisha F VenereRussiaIvan Magalhaes NEW
Ivar M SergiBrazilOnyama Limba QUALIFIED
Munro M RoysterUnited KingdomXuxue Feng PROPOSAL
Aditya J RimJapanStephen Shaw UNQUALIFIED
Silvio G VenereAustraliaOnyama Limba QUALIFIED
Isabel X GauchoItalyBernardo Dominic PROPOSAL
Chavez H MaletCanadaStephen Shaw NEW
Antonio E GlickRussiaBernardo Dominic NEW
Maria G VenereUnited KingdomAmy Elsner PROPOSAL
Chavez H RimJapanIoni Bowcher QUALIFIED
Silvio N MaletSpainAmy Elsner NEW
Smith O AlbaresBrazilStephen Shaw NEW
Jones C ButtRussiaStephen Shaw PROPOSAL
Ivar I NestleGermanyAmy Elsner NEW
Aruna F StockhamBrazilAnna Fali NEGOTIATION
Juan J BowleyGermanyElwin Sharvill PROPOSAL
Leja T ChuiBrazilAmy Elsner RENEWAL
Stacey P OstroskySpainXuxue Feng NEGOTIATION
Silvio X KuskoSpainOnyama Limba RENEWAL
Izzy J MacleadUnited KingdomIoni Bowcher NEW
Clifford M StensethCanadaXuxue Feng NEGOTIATION
Aruna L GlickArgentinaIvan Magalhaes QUALIFIED
Misaki R WaycottArgentinaAnna Fali NEW
Tony G ButtItalyIvan Magalhaes NEW
Frozen Columns
Name
Tony B Vocelka
Leon Z Perin
Jennifer E Flosi
Alejandro A Ferencz
Aruna J Paprocki
Antonio J Venere
Stacey Y Albares
Morrow N Iturbide
Johnson P Chui
Arvin O Perin
Salvatore W Briddick
Johnson R Malet
Chavez D Sergi
Aditya C Slusarski
Izzy Z Chui
Aika M Inouye
Morrow Q Bolognia
Salvatore G Darakjy
Antonio J Butt
Darci Y Rulapaugh
Misaki F Darakjy
Sinclair T Slusarski
Chavez Y Ferencz
Aditya K Oldroyd
Salvatore P Malet
Deepesh W Rim
Francesco I Schemmer
Munro G Marrier
Costa P Poquette
Maria J Royster
Aditya F Rim
Antonio A Rim
Tony L Marrier
Ashley A Waycott
Clifford Q Venere
Faith W Waycott
Jones A Poquette
Deepesh G Chui
Ivar G Darakjy
Maisha T Foller
Murillo I Perin
Octavia G Foller
Johnson L Butt
Tony B Iturbide
Aditya H Albares
Munro Q Oldroyd
Juan R Sergi
Adams L Morasca
Ricardo K Iturbide
Silvio A Ferencz
IdCountryDate
1000Argentina2024-04-08
1001Russia2024-04-14
1002Italy2024-04-06
1003Australia2024-04-16
1004United Kingdom2024-04-02
1005Germany2024-04-05
1006Argentina2024-04-08
1007Japan2024-04-08
1008Japan2024-04-07
1009United Kingdom2024-04-01
1010France2024-03-29
1011Russia2024-03-28
1012Italy2024-04-10
1013Japan2024-04-02
1014Argentina2024-03-29
1015Canada2024-04-11
1016Russia2024-04-11
1017France2024-04-06
1018Spain2024-04-12
1019Argentina2024-03-29
1020Argentina2024-04-05
1021United Kingdom2024-04-06
1022Russia2024-04-03
1023India2024-04-13
1024Australia2024-03-30
1025France2024-04-18
1026Brazil2024-03-22
1027India2024-04-10
1028Germany2024-04-03
1029France2024-03-31
1030Japan2024-03-24
1031Russia2024-03-21
1032Russia2024-03-31
1033Russia2024-04-07
1034Canada2024-04-12
1035Argentina2024-04-13
1036Brazil2024-04-09
1037Japan2024-04-12
1038Germany2024-03-22
1039United Kingdom2024-04-09
1040Canada2024-04-02
1041Brazil2024-04-03
1042United Kingdom2024-04-13
1043India2024-04-12
1044Italy2024-04-19
1045Italy2024-04-01
1046India2024-03-23
1047Brazil2024-04-11
1048India2024-04-09
1049Russia2024-04-16

On-Demand Data

NameIdCountryDate
Izzy A Flosi1000United Kingdom2024-03-23
Rodrigues X Stenseth1001Russia2024-04-12
Mayumi X Sergi1002Brazil2024-04-18
Jefferson Q Gaucho1003Italy2024-04-18
Ricardo T Kolmetz1004Germany2024-04-18
Juan H Oldroyd1005Canada2024-03-28
Adams K Rim1006Germany2024-04-04
Costa T Kolmetz1007India2024-03-30
Aruna R Schemmer1008France2024-03-31
Emily V Figeroa1009Spain2024-04-05
Jefferson Z Schemmer1010Italy2024-04-09
Munro A Poquette1011Australia2024-03-30
Ivar J Bolognia1012Japan2024-04-03
Alejandro R Flosi1013Brazil2024-04-07
Morrow X Amigon1014Japan2024-04-13
Ivar Y Sergi1015India2024-03-25
Murillo C Gillian1016Germany2024-04-19
Ricardo Z Amigon1017Brazil2024-04-18
Izzy Z Kolmetz1018Germany2024-03-23
Ashley H Waycott1019Argentina2024-03-28
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Alejandro D SchemmerRussiaElwin Sharvill QUALIFIED
Alejandro V OldroydBrazilAmy Elsner NEGOTIATION
Cody P BriddickAustraliaXuxue Feng RENEWAL
Chavez F FerenczAustraliaOnyama Limba PROPOSAL
Kadeem U StockhamBrazilAsiya Javayant QUALIFIED
Maria G OstroskyArgentinaXuxue Feng PROPOSAL
Smith L IturbideCanadaAsiya Javayant UNQUALIFIED
David Y PoquetteRussiaIoni Bowcher PROPOSAL
Salvatore C MaletIndiaIoni Bowcher UNQUALIFIED
Ashley D ChuiJapanIvan Magalhaes NEW
Aika R SergiItalyOnyama Limba NEGOTIATION
Mujtaba R InouyeItalyElwin Sharvill PROPOSAL
Chavez Q CaudyRussiaIvan Magalhaes QUALIFIED
Cody O CaudyJapanAmy Elsner QUALIFIED
Mujtaba W WhobreyFranceStephen Shaw QUALIFIED
Maisha Q ShinkoFranceAsiya Javayant RENEWAL
Ricardo F GauchoCanadaIvan Magalhaes QUALIFIED
Chavez K RoysterIndiaBernardo Dominic NEGOTIATION
David C SchemmerFranceIvan Magalhaes PROPOSAL
Aditya Q GauchoItalyAnna Fali QUALIFIED
Jennifer W KolmetzRussiaStephen Shaw QUALIFIED
Arvin Q FigeroaJapanBernardo Dominic QUALIFIED
Mayumi W SchemmerBrazilStephen Shaw RENEWAL
Nicolas N OldroydGermanyBernardo Dominic RENEWAL
Stacey C OstroskySpainBernardo Dominic QUALIFIED
Murillo D StensethCanadaIoni Bowcher UNQUALIFIED
Salvatore X TollnerJapanElwin Sharvill RENEWAL
Octavia L CampainUnited KingdomAmy Elsner RENEWAL
Ricardo H StockhamBrazilBernardo Dominic NEW
Costa H FollerBrazilAmy Elsner QUALIFIED
Kadeem J SaylorsBrazilOnyama Limba UNQUALIFIED
Claire C NestleIndiaAmy Elsner UNQUALIFIED
Arvin P OldroydFranceAnna Fali UNQUALIFIED
Ricardo Y MorascaUnited KingdomAnna Fali PROPOSAL
Sinclair D RimUnited KingdomIoni Bowcher PROPOSAL
Stacey Z SlusarskiSpainAnna Fali NEW
Aruna T RutaCanadaBernardo Dominic QUALIFIED
Silvio I DoeItalyIoni Bowcher NEW
Sinclair B AmigonFranceStephen Shaw RENEWAL
Morrow D SlusarskiItalyAnna Fali RENEWAL

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