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
Aditya C MacleadFranceIoni Bowcher NEW
Claire D AmigonUnited KingdomAmy Elsner QUALIFIED
Mayumi D SaylorsJapanAnna Fali NEW
Jones Q ButtRussiaBernardo Dominic RENEWAL
Sinclair C SaylorsJapanBernardo Dominic PROPOSAL
Ashley A KuskoFranceStephen Shaw NEW
Leja L MorascaGermanyElwin Sharvill UNQUALIFIED
Francesco S MaletRussiaStephen Shaw UNQUALIFIED
Kaitlin N PoquetteItalyAmy Elsner NEW
Jennifer Q KolmetzJapanAmy Elsner RENEWAL
Adams A GauchoArgentinaXuxue Feng PROPOSAL
Juan Q IturbideRussiaBernardo Dominic RENEWAL
Juan T StockhamItalyStephen Shaw QUALIFIED
Leon O FollerArgentinaStephen Shaw NEW
Faith H FlosiJapanXuxue Feng NEW
Ricardo X SlusarskiIndiaXuxue Feng NEW
Ricardo G AlbaresBrazilStephen Shaw NEW
James G StensethRussiaXuxue Feng RENEWAL
Ashley H PerinAustraliaIvan Magalhaes QUALIFIED
Deepesh I GillianCanadaIvan Magalhaes QUALIFIED
Costa M BriddickFranceXuxue Feng NEGOTIATION
Julie J GauchoJapanAnna Fali PROPOSAL
Maisha B SergiItalyAmy Elsner QUALIFIED
Deepesh E KolmetzRussiaAmy Elsner UNQUALIFIED
Misaki Q AlbaresCanadaBernardo Dominic RENEWAL
Faith U IturbideCanadaAmy Elsner QUALIFIED
Clifford K FollerAustraliaIvan Magalhaes RENEWAL
Mayumi K DilliardSpainAmy Elsner PROPOSAL
Costa O ChuiItalyOnyama Limba PROPOSAL
James K ChuiJapanAnna Fali UNQUALIFIED
Aruna U GarufiFranceAmy Elsner RENEWAL
Sinclair S NickaUnited KingdomIvan Magalhaes PROPOSAL
Smith L WhobreyIndiaElwin Sharvill PROPOSAL
Kadeem Y BologniaAustraliaIvan Magalhaes NEGOTIATION
Ricardo O KolmetzFranceOnyama Limba RENEWAL
Adams F CaudyItalyIvan Magalhaes NEW
Alejandro V ShinkoRussiaBernardo Dominic NEW
Arvin W AmigonSpainAnna Fali NEGOTIATION
Jennifer D PaprockiArgentinaXuxue Feng RENEWAL
Kaitlin P OldroydIndiaStephen Shaw QUALIFIED
Mayumi Q MarrierAustraliaElwin Sharvill PROPOSAL
Aika X MacleadFranceAmy Elsner RENEWAL
Costa K SaylorsSpainIvan Magalhaes PROPOSAL
Faith U FigeroaAustraliaIvan Magalhaes PROPOSAL
Maisha K RulapaughJapanXuxue Feng RENEWAL
Kadeem D SchemmerGermanyBernardo Dominic UNQUALIFIED
Stacey X FerenczUnited KingdomStephen Shaw PROPOSAL
Francesco M NickaAustraliaBernardo Dominic UNQUALIFIED
David T PerinAustraliaIoni Bowcher RENEWAL
Tony Q AlbaresJapanIoni Bowcher NEW
Horizontal
NameCountryRepresentativeStatus
Murillo U StensethItalyStephen Shaw RENEWAL
Cody D DarakjyItalyAsiya Javayant UNQUALIFIED
Julie E BriddickIndiaIvan Magalhaes NEGOTIATION
Francesco N CaldareraBrazilOnyama Limba RENEWAL
Jefferson A NestleRussiaAnna Fali RENEWAL
Isabel N MarrierRussiaXuxue Feng RENEWAL
Darci I SlusarskiGermanyIoni Bowcher NEGOTIATION
Jennifer N StockhamItalyIoni Bowcher PROPOSAL
Sinclair J CaudyIndiaBernardo Dominic UNQUALIFIED
Mujtaba I FerenczArgentinaElwin Sharvill NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Ivar A StensethUnited Kingdom2024-04-19Feiner Bros RENEWAL14Ioni Bowcher
1001Maisha U RulapaughJapan2024-04-26Benton, John B Jr NEW71Asiya Javayant
1002Munro F AlbaresAustralia2024-04-27Morlong Associates RENEWAL54Ioni Bowcher
1003Clifford C MaletArgentina2024-04-17Truhlar And Truhlar Attys QUALIFIED58Anna Fali
1004Johnson V RimJapan2024-04-11Morlong Associates RENEWAL28Amy Elsner
1005Salvatore F MaletArgentina2024-04-16Printing Dimensions RENEWAL52Elwin Sharvill
1006Ricardo O InouyeBrazil2024-04-20Benton, John B Jr UNQUALIFIED85Asiya Javayant
1007Arvin P GarufiBrazil2024-03-29King, Christopher A Esq NEGOTIATION79Onyama Limba
1008Maisha T MaletArgentina2024-04-03Commercial Press NEW89Ioni Bowcher
1009Wickens D RimGermany2024-04-06Morlong Associates UNQUALIFIED13Xuxue Feng
1010Maria Q CampainAustralia2024-04-02Chanay, Jeffrey A Esq RENEWAL94Stephen Shaw
1011Maisha I AmigonIndia2024-04-26Rousseaux, Michael Esq NEW29Elwin Sharvill
1012Juan M InouyeJapan2024-04-20Morlong Associates NEW66Ioni Bowcher
1013Aika B GauchoJapan2024-04-14Truhlar And Truhlar Attys QUALIFIED76Asiya Javayant
1014Isabel D AlbaresUnited Kingdom2024-04-24Rangoni Of Florence NEW43Elwin Sharvill
1015Juan B GlickRussia2024-04-03Chemel, James L Cpa QUALIFIED96Xuxue Feng
1016Cody A GauchoSpain2024-04-10Buckley Miller Wright PROPOSAL23Elwin Sharvill
1017Morrow W RimJapan2024-04-08Morlong Associates QUALIFIED83Stephen Shaw
1018Juan R ButtJapan2024-04-02Rangoni Of Florence NEW72Xuxue Feng
1019Maria D WaycottJapan2024-04-26Printing Dimensions RENEWAL93Elwin Sharvill
1020James E FollerArgentina2024-04-08Commercial Press NEGOTIATION91Onyama Limba
1021Izzy D PerinRussia2024-04-22Rousseaux, Michael Esq PROPOSAL6Onyama Limba
1022Jennifer W StensethGermany2024-04-17Printing Dimensions RENEWAL78Anna Fali
1023Kadeem O MacleadCanada2024-04-05Feltz Printing Service RENEWAL52Anna Fali
1024Leon Q BriddickGermany2024-04-27Dorl, James J Esq NEW87Onyama Limba
1025Alejandro W WhobreyFrance2024-04-22Rangoni Of Florence NEW37Elwin Sharvill
1026Aditya K FollerArgentina2024-04-21Dorl, James J Esq NEW28Asiya Javayant
1027Jefferson L CaldareraAustralia2024-04-07Chemel, James L Cpa NEW90Ioni Bowcher
1028Chavez T OstroskyAustralia2024-04-03Chemel, James L Cpa NEGOTIATION72Amy Elsner
1029Jefferson E StockhamGermany2024-04-14Feiner Bros UNQUALIFIED84Bernardo Dominic
1030Leja Z CaudySpain2024-04-26Chanay, Jeffrey A Esq PROPOSAL3Amy Elsner
1031Claire Y GillianFrance2024-04-04Morlong Associates NEW22Stephen Shaw
1032Maria R WaycottItaly2024-04-21Chapman, Ross E Esq QUALIFIED73Xuxue Feng
1033Maisha R DarakjyItaly2024-04-11Feltz Printing Service UNQUALIFIED60Asiya Javayant
1034Aruna T FerenczArgentina2024-04-16Feiner Bros PROPOSAL36Bernardo Dominic
1035Emily G NickaBrazil2024-04-19Commercial Press RENEWAL84Ivan Magalhaes
1036Kadeem T GlickSpain2024-04-11Morlong Associates NEW99Ioni Bowcher
1037Octavia C CampainFrance2024-04-13Rousseaux, Michael Esq PROPOSAL2Stephen Shaw
1038Leon X WhobreyCanada2024-04-15King, Christopher A Esq QUALIFIED29Amy Elsner
1039Misaki G GillianRussia2024-04-27Printing Dimensions PROPOSAL66Anna Fali
1040Emily Q RutaCanada2024-04-09Benton, John B Jr QUALIFIED64Amy Elsner
1041Munro S PerinItaly2024-04-05Commercial Press PROPOSAL47Amy Elsner
1042Chavez J BowleyItaly2024-04-19Printing Dimensions PROPOSAL17Anna Fali
1043Clifford Z GlickGermany2024-04-03Commercial Press PROPOSAL45Ivan Magalhaes
1044Leon K VocelkaJapan2024-03-29Morlong Associates QUALIFIED39Onyama Limba
1045Tony B CaudyRussia2024-04-05Chanay, Jeffrey A Esq UNQUALIFIED25Bernardo Dominic
1046Arvin A SchemmerFrance2024-04-04King, Christopher A Esq NEGOTIATION72Asiya Javayant
1047Antonio E RutaFrance2024-04-20Dorl, James J Esq UNQUALIFIED40Elwin Sharvill
1048Misaki H VenereJapan2024-04-12Chapman, Ross E Esq UNQUALIFIED62Amy Elsner
1049Izzy N VocelkaUnited Kingdom2024-04-18Morlong Associates RENEWAL67Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Deepesh J SaylorsUnited KingdomStephen Shaw UNQUALIFIED
Rodrigues Q CaudyRussiaOnyama Limba PROPOSAL
Murillo C ShinkoArgentinaElwin Sharvill RENEWAL
Nicolas Q VenereSpainIoni Bowcher QUALIFIED
Clifford F PaprockiUnited KingdomBernardo Dominic QUALIFIED
Emily Q KolmetzSpainBernardo Dominic RENEWAL
Jones E ChuiAustraliaAnna Fali NEW
Kadeem Y PerinIndiaAnna Fali NEGOTIATION
Antonio D CaldareraArgentinaAnna Fali NEW
Silvio D CaudyJapanIoni Bowcher UNQUALIFIED
David E TollnerItalyXuxue Feng PROPOSAL
Adams F VocelkaCanadaBernardo Dominic RENEWAL
Jefferson F TollnerArgentinaElwin Sharvill PROPOSAL
Morrow E ChuiArgentinaAsiya Javayant PROPOSAL
Johnson P FerenczGermanyAmy Elsner PROPOSAL
Claire X SlusarskiFranceStephen Shaw UNQUALIFIED
Clifford E AlbaresRussiaStephen Shaw NEGOTIATION
Rodrigues O ShinkoJapanOnyama Limba PROPOSAL
Juan Z StockhamSpainIvan Magalhaes QUALIFIED
Maisha P VenereFranceAsiya Javayant NEW
Ivar Z BowleyGermanyIoni Bowcher UNQUALIFIED
Clifford K MarrierGermanyAmy Elsner NEW
Francesco J PerinRussiaAsiya Javayant UNQUALIFIED
Emily M TollnerUnited KingdomIvan Magalhaes PROPOSAL
Nicolas C MaletItalyAsiya Javayant RENEWAL
Maisha A GlickSpainStephen Shaw PROPOSAL
Stacey Z InouyeRussiaIvan Magalhaes NEGOTIATION
Alejandro H AlbaresBrazilAnna Fali UNQUALIFIED
Morrow R SlusarskiJapanIvan Magalhaes QUALIFIED
Deepesh Q SchemmerGermanyXuxue Feng RENEWAL
Aika K ChuiCanadaIoni Bowcher PROPOSAL
Sinclair L FigeroaArgentinaStephen Shaw UNQUALIFIED
David G FollerGermanyBernardo Dominic UNQUALIFIED
Jeanfrancois S MorascaUnited KingdomAmy Elsner PROPOSAL
Costa Z GlickGermanyIvan Magalhaes UNQUALIFIED
Jones K StockhamBrazilIvan Magalhaes UNQUALIFIED
Alejandro X FollerRussiaIoni Bowcher NEGOTIATION
Clifford E StensethItalyOnyama Limba QUALIFIED
Emily C PaprockiFranceIoni Bowcher NEW
Misaki B NickaArgentinaElwin Sharvill QUALIFIED
Aditya H PerinUnited KingdomBernardo Dominic NEW
Costa N CaldareraGermanyOnyama Limba QUALIFIED
Alejandro N StockhamSpainAmy Elsner QUALIFIED
Emily L StockhamCanadaOnyama Limba PROPOSAL
Rodrigues C GauchoGermanyAsiya Javayant PROPOSAL
Isabel D FerenczSpainStephen Shaw RENEWAL
Kaitlin V IturbideBrazilIvan Magalhaes QUALIFIED
Juan K KolmetzArgentinaOnyama Limba PROPOSAL
Maisha C RoysterArgentinaElwin Sharvill NEGOTIATION
Chavez Q InouyeFranceAnna Fali QUALIFIED
Frozen Columns
Name
Alejandro G Shinko
Murillo K Rim
Cody I Shinko
Deepesh M Bowley
Maisha R Bowley
Mujtaba J Figeroa
Alejandro U Whobrey
Silvio S Whobrey
Silvio L Paprocki
Emily W Chui
Chavez J Ruta
Aika Q Paprocki
Tony T Waycott
Mujtaba B Royster
Izzy W Ruta
Jones I Whobrey
Octavia J Slusarski
Ricardo O Rim
Smith H Wieser
Emily N Caudy
Cody H Rim
Chavez Q Rim
Juan S Maclead
Leja S Perin
Costa S Foller
Mayumi V Gaucho
Costa B Caudy
Costa S Foller
Jefferson M Venere
Smith Q Dilliard
Leon Y Nestle
Maria E Albares
Aika B Inouye
Julie Q Briddick
Aika M Dilliard
Kaitlin L Malet
Emily J Darakjy
Emily K Bowley
Jones F Royster
Clifford L Bowley
David X Doe
Leja Z Flosi
Claire T Malet
David S Malet
Juan V Saylors
Arvin F Rulapaugh
Tony S Gillian
Kadeem H Ostrosky
Salvatore A Inouye
Murillo R Vocelka
IdCountryDate
1000United Kingdom2024-04-07
1001Spain2024-04-07
1002United Kingdom2024-04-09
1003Germany2024-04-15
1004Germany2024-04-12
1005India2024-04-21
1006Canada2024-04-16
1007Argentina2024-04-20
1008Japan2024-04-07
1009Japan2024-03-31
1010India2024-04-26
1011Argentina2024-04-07
1012Japan2024-04-11
1013Spain2024-04-08
1014Japan2024-04-10
1015Canada2024-04-10
1016Germany2024-04-04
1017Australia2024-04-01
1018Russia2024-04-04
1019Spain2024-04-04
1020Japan2024-04-17
1021United Kingdom2024-04-20
1022France2024-04-08
1023Brazil2024-04-08
1024United Kingdom2024-04-01
1025Japan2024-04-10
1026Germany2024-04-03
1027Russia2024-04-12
1028Russia2024-04-03
1029Brazil2024-04-18
1030Spain2024-04-01
1031France2024-04-26
1032India2024-04-03
1033Australia2024-04-07
1034India2024-04-09
1035India2024-04-16
1036Italy2024-04-26
1037France2024-04-03
1038Japan2024-04-10
1039Canada2024-04-06
1040United Kingdom2024-04-22
1041Brazil2024-03-30
1042India2024-04-01
1043Canada2024-04-16
1044Russia2024-04-20
1045Argentina2024-04-20
1046Argentina2024-04-27
1047France2024-04-26
1048United Kingdom2024-03-29
1049France2024-03-30

On-Demand Data

NameIdCountryDate
Murillo D Royster1000Japan2024-04-16
Clifford N Briddick1001Argentina2024-04-19
Murillo G Slusarski1002Italy2024-04-07
Kaitlin D Flosi1003Argentina2024-03-31
Stacey U Maclead1004United Kingdom2024-03-29
Deepesh R Venere1005Argentina2024-04-16
Alejandro V Bowley1006India2024-03-29
Sinclair Q Maclead1007Canada2024-04-08
Mayumi W Bolognia1008Canada2024-04-14
Ashley N Iturbide1009Brazil2024-04-02
Leon K Waycott1010Argentina2024-04-25
Aruna F Inouye1011Spain2024-04-15
Smith E Inouye1012Japan2024-04-10
Arvin D Nestle1013Canada2024-04-22
Wickens S Darakjy1014India2024-03-29
Darci I Dilliard1015Italy2024-04-04
Aruna A Albares1016Argentina2024-04-01
Costa N Malet1017Germany2024-04-07
Kadeem G Figeroa1018United Kingdom2024-04-10
James D Saylors1019Spain2024-04-04
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Izzy Y MacleadCanadaAnna Fali UNQUALIFIED
Darci W DoeCanadaXuxue Feng PROPOSAL
Adams T PoquetteRussiaIvan Magalhaes UNQUALIFIED
Julie W MaletAustraliaAnna Fali RENEWAL
Maria B AlbaresIndiaIoni Bowcher UNQUALIFIED
Sinclair M OldroydBrazilStephen Shaw QUALIFIED
Mayumi Q CaudyAustraliaAsiya Javayant RENEWAL
Jennifer N SchemmerIndiaBernardo Dominic UNQUALIFIED
Cody J BowleyJapanXuxue Feng PROPOSAL
Maria T DoeRussiaOnyama Limba NEGOTIATION
Ricardo O PaprockiArgentinaIoni Bowcher NEGOTIATION
Antonio P KuskoUnited KingdomIvan Magalhaes PROPOSAL
Jones V RulapaughItalyAmy Elsner UNQUALIFIED
Kaitlin K VenereFranceBernardo Dominic UNQUALIFIED
Octavia I RoysterAustraliaAmy Elsner NEGOTIATION
Greenwood H KuskoJapanOnyama Limba RENEWAL
Morrow S GillianArgentinaAnna Fali UNQUALIFIED
Tony O WaycottBrazilAnna Fali NEGOTIATION
Aika Q DoeIndiaOnyama Limba UNQUALIFIED
Clifford P MorascaFranceAmy Elsner RENEWAL
Silvio B GlickBrazilAsiya Javayant NEW
Jennifer N AmigonUnited KingdomAsiya Javayant QUALIFIED
Adams J GillianUnited KingdomAnna Fali UNQUALIFIED
Wickens B SergiAustraliaBernardo Dominic QUALIFIED
Claire N SchemmerAustraliaElwin Sharvill UNQUALIFIED
Mujtaba A MaletItalyIvan Magalhaes NEW
Tony F IturbideRussiaAnna Fali NEW
Sinclair T BowleyJapanIoni Bowcher UNQUALIFIED
Leja S DilliardUnited KingdomOnyama Limba NEGOTIATION
Johnson Q RimRussiaElwin Sharvill UNQUALIFIED
Wickens H ButtArgentinaStephen Shaw UNQUALIFIED
Wickens V InouyeCanadaStephen Shaw NEW
James T NestleFranceXuxue Feng PROPOSAL
Maisha R RulapaughArgentinaXuxue Feng NEGOTIATION
Juan P GarufiSpainBernardo Dominic NEW
Munro T KolmetzFranceStephen Shaw RENEWAL
Faith R GarufiJapanXuxue Feng PROPOSAL
Greenwood R CaldareraAustraliaBernardo Dominic UNQUALIFIED
Aika C WieserCanadaStephen Shaw UNQUALIFIED
Stacey Y GarufiItalyAnna Fali NEGOTIATION

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