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
Antonio M RutaIndiaAmy Elsner QUALIFIED
Chavez Q CaldareraCanadaIoni Bowcher NEGOTIATION
Rodrigues V BologniaGermanyAnna Fali PROPOSAL
Darci D ChuiCanadaAsiya Javayant NEGOTIATION
Murillo F RoysterCanadaBernardo Dominic PROPOSAL
Munro R MacleadUnited KingdomBernardo Dominic RENEWAL
Munro F WaycottSpainStephen Shaw RENEWAL
Misaki W GillianCanadaXuxue Feng QUALIFIED
Stacey H IturbideJapanBernardo Dominic NEW
Aika B ChuiSpainElwin Sharvill QUALIFIED
Claire P BowleyItalyBernardo Dominic RENEWAL
Francesco R ShinkoRussiaXuxue Feng UNQUALIFIED
Arvin Z MaletBrazilAmy Elsner NEGOTIATION
Johnson K GillianRussiaStephen Shaw UNQUALIFIED
Izzy R RulapaughArgentinaAsiya Javayant QUALIFIED
Jefferson M DoeRussiaBernardo Dominic UNQUALIFIED
Jennifer X GauchoSpainXuxue Feng PROPOSAL
Aruna Q MacleadSpainStephen Shaw NEGOTIATION
Arvin A BologniaRussiaAmy Elsner NEGOTIATION
Chavez Y RutaAustraliaXuxue Feng NEW
Octavia D VenereCanadaOnyama Limba NEGOTIATION
Isabel G RoysterArgentinaOnyama Limba UNQUALIFIED
Faith S FigeroaFranceOnyama Limba NEGOTIATION
Julie V RutaItalyBernardo Dominic RENEWAL
Murillo J MarrierGermanyAmy Elsner QUALIFIED
Murillo X NestleJapanIoni Bowcher NEGOTIATION
Morrow S DarakjyCanadaBernardo Dominic NEGOTIATION
Costa E BowleyItalyStephen Shaw UNQUALIFIED
Aika V KolmetzUnited KingdomOnyama Limba NEW
Julie U ButtJapanIvan Magalhaes PROPOSAL
Greenwood T DarakjyRussiaElwin Sharvill NEGOTIATION
Aruna A StockhamJapanOnyama Limba NEW
Izzy T CaudyCanadaStephen Shaw QUALIFIED
Aditya F CaudyAustraliaIoni Bowcher NEW
Alejandro D ButtAustraliaAmy Elsner QUALIFIED
Leon O RimAustraliaIoni Bowcher NEW
Clifford E GillianBrazilStephen Shaw QUALIFIED
Emily Z RulapaughBrazilIvan Magalhaes UNQUALIFIED
Leon X SchemmerSpainXuxue Feng UNQUALIFIED
Ricardo L BologniaIndiaXuxue Feng RENEWAL
James D FlosiBrazilStephen Shaw PROPOSAL
Jeanfrancois R IturbideItalyOnyama Limba UNQUALIFIED
Izzy X AlbaresRussiaStephen Shaw NEGOTIATION
Smith V MacleadBrazilElwin Sharvill PROPOSAL
Izzy P BologniaIndiaIvan Magalhaes QUALIFIED
Jeanfrancois D CampainFranceIoni Bowcher NEW
Stacey N SaylorsGermanyIoni Bowcher RENEWAL
Morrow P PoquetteCanadaAnna Fali PROPOSAL
Stacey K GauchoCanadaAsiya Javayant QUALIFIED
Sinclair V RulapaughFranceAnna Fali UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Sinclair E AlbaresFranceStephen Shaw NEW
Isabel G GauchoUnited KingdomAnna Fali NEW
Mayumi Z OldroydFranceElwin Sharvill RENEWAL
Rodrigues I RutaItalyOnyama Limba NEGOTIATION
Antonio C InouyeRussiaOnyama Limba NEGOTIATION
Kadeem K NickaItalyIoni Bowcher NEW
Isabel R OldroydFranceOnyama Limba PROPOSAL
Izzy W MaletBrazilStephen Shaw NEGOTIATION
Rodrigues U SaylorsFranceAsiya Javayant NEGOTIATION
Isabel D FigeroaArgentinaStephen Shaw RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Murillo B FigeroaSpain2024-04-02Feiner Bros UNQUALIFIED39Bernardo Dominic
1001Silvio V SaylorsAustralia2024-04-19Rangoni Of Florence UNQUALIFIED67Elwin Sharvill
1002Greenwood F FigeroaIndia2024-03-31Morlong Associates UNQUALIFIED72Ivan Magalhaes
1003Kaitlin U RulapaughRussia2024-04-22Printing Dimensions NEW81Ioni Bowcher
1004Octavia K FigeroaJapan2024-04-23Chapman, Ross E Esq QUALIFIED45Ivan Magalhaes
1005Greenwood X FlosiAustralia2024-04-08Chapman, Ross E Esq UNQUALIFIED54Asiya Javayant
1006Murillo R MarrierIndia2024-03-30Morlong Associates RENEWAL43Ioni Bowcher
1007David A BriddickArgentina2024-04-11Rousseaux, Michael Esq QUALIFIED77Amy Elsner
1008Leon F NickaJapan2024-04-01Chemel, James L Cpa PROPOSAL95Xuxue Feng
1009Arvin U FollerFrance2024-04-22Printing Dimensions UNQUALIFIED93Elwin Sharvill
1010Morrow V BriddickFrance2024-03-29Dorl, James J Esq NEGOTIATION16Anna Fali
1011Greenwood I MorascaItaly2024-04-25Truhlar And Truhlar Attys UNQUALIFIED99Ivan Magalhaes
1012Rodrigues X DoeJapan2024-04-14Buckley Miller Wright RENEWAL88Stephen Shaw
1013Jeanfrancois P WhobreyItaly2024-04-02Chemel, James L Cpa NEGOTIATION64Ivan Magalhaes
1014Salvatore B MorascaJapan2024-04-25Commercial Press QUALIFIED99Asiya Javayant
1015Francesco Q StensethIndia2024-04-17Buckley Miller Wright PROPOSAL49Stephen Shaw
1016Aruna U ChuiCanada2024-04-23King, Christopher A Esq NEGOTIATION78Ivan Magalhaes
1017Johnson U GillianIndia2024-04-14Feiner Bros NEGOTIATION60Onyama Limba
1018Sinclair T ChuiItaly2024-04-18Feltz Printing Service UNQUALIFIED70Elwin Sharvill
1019Izzy H RoysterItaly2024-04-15Rangoni Of Florence RENEWAL3Stephen Shaw
1020Isabel I GillianUnited Kingdom2024-04-03Printing Dimensions RENEWAL84Xuxue Feng
1021Jefferson J CaldareraCanada2024-03-31Rangoni Of Florence NEGOTIATION29Xuxue Feng
1022Smith O InouyeCanada2024-04-10Feltz Printing Service UNQUALIFIED59Stephen Shaw
1023Kaitlin H SlusarskiIndia2024-04-08Commercial Press NEW65Elwin Sharvill
1024Murillo J WaycottRussia2024-04-26Morlong Associates NEW76Elwin Sharvill
1025Ricardo H RutaFrance2024-04-24Chemel, James L Cpa QUALIFIED30Onyama Limba
1026Deepesh R OstroskyFrance2024-04-18Chapman, Ross E Esq RENEWAL16Amy Elsner
1027Antonio O FlosiGermany2024-03-29Buckley Miller Wright NEGOTIATION81Anna Fali
1028Francesco G VocelkaCanada2024-04-20Benton, John B Jr QUALIFIED71Onyama Limba
1029Munro T RoysterFrance2024-04-11Chapman, Ross E Esq UNQUALIFIED55Asiya Javayant
1030Juan T WieserIndia2024-04-01Morlong Associates UNQUALIFIED75Amy Elsner
1031Aditya V GillianFrance2024-04-09Feltz Printing Service QUALIFIED39Xuxue Feng
1032Nicolas C BriddickRussia2024-04-26Rousseaux, Michael Esq RENEWAL82Anna Fali
1033Leja P BowleyGermany2024-04-14Chanay, Jeffrey A Esq UNQUALIFIED22Bernardo Dominic
1034Misaki U SchemmerSpain2024-04-02Rangoni Of Florence RENEWAL95Ioni Bowcher
1035Costa E WhobreyArgentina2024-03-29Printing Dimensions NEW35Ioni Bowcher
1036Darci G PoquetteJapan2024-04-04Rangoni Of Florence NEW12Stephen Shaw
1037Antonio E ChuiUnited Kingdom2024-04-27Feiner Bros UNQUALIFIED87Ioni Bowcher
1038Leja R FerenczCanada2024-04-14Feiner Bros RENEWAL2Bernardo Dominic
1039Aruna Y RutaSpain2024-04-09Rangoni Of Florence PROPOSAL1Amy Elsner
1040Jennifer H ChuiBrazil2024-04-05Morlong Associates NEW29Xuxue Feng
1041Faith R DoeCanada2024-04-05Morlong Associates QUALIFIED72Ioni Bowcher
1042Deepesh X GauchoSpain2024-04-04Rousseaux, Michael Esq NEW36Onyama Limba
1043Alejandro P RutaFrance2024-04-04Chemel, James L Cpa NEGOTIATION56Anna Fali
1044Tony E MarrierAustralia2024-04-08Morlong Associates NEGOTIATION47Asiya Javayant
1045Adams O PaprockiUnited Kingdom2024-04-22Chemel, James L Cpa NEW0Onyama Limba
1046Jennifer E FollerFrance2024-04-17Dorl, James J Esq NEGOTIATION22Onyama Limba
1047Isabel X ShinkoJapan2024-04-22King, Christopher A Esq QUALIFIED26Ivan Magalhaes
1048Salvatore H PerinItaly2024-04-22Rangoni Of Florence NEW57Asiya Javayant
1049Isabel G BologniaAustralia2024-03-30Buckley Miller Wright QUALIFIED55Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Emily A GauchoAustraliaXuxue Feng PROPOSAL
Faith W OstroskyAustraliaElwin Sharvill NEW
Aruna L RimRussiaStephen Shaw NEW
Darci G WieserSpainAmy Elsner UNQUALIFIED
Claire U FigeroaUnited KingdomElwin Sharvill UNQUALIFIED
Kadeem S NickaItalyStephen Shaw NEGOTIATION
Chavez L GillianRussiaIoni Bowcher PROPOSAL
Aruna P MorascaCanadaElwin Sharvill NEW
Misaki H AlbaresIndiaAsiya Javayant RENEWAL
Kadeem H VocelkaArgentinaAmy Elsner NEW
Greenwood B BowleyIndiaStephen Shaw UNQUALIFIED
James B FigeroaBrazilStephen Shaw PROPOSAL
Ricardo N MaletIndiaElwin Sharvill NEW
Nicolas V ShinkoSpainAsiya Javayant PROPOSAL
James C DarakjyUnited KingdomAnna Fali PROPOSAL
Ashley D MaletAustraliaStephen Shaw UNQUALIFIED
Kadeem B RimSpainOnyama Limba NEGOTIATION
Stacey Y BriddickRussiaElwin Sharvill NEW
Jones P CaudyJapanAsiya Javayant NEGOTIATION
Arvin G FigeroaUnited KingdomBernardo Dominic QUALIFIED
Julie P NestleItalyIoni Bowcher QUALIFIED
Jones N RutaAustraliaBernardo Dominic RENEWAL
Sinclair T FerenczSpainIoni Bowcher NEW
Tony P GillianArgentinaIvan Magalhaes RENEWAL
Claire X FlosiSpainIoni Bowcher UNQUALIFIED
Mayumi K PaprockiBrazilOnyama Limba RENEWAL
Costa F CaldareraSpainElwin Sharvill UNQUALIFIED
Greenwood X WieserArgentinaAsiya Javayant RENEWAL
Greenwood Z WieserArgentinaIvan Magalhaes UNQUALIFIED
Maisha Z GarufiItalyIoni Bowcher QUALIFIED
Aika F ButtRussiaAsiya Javayant NEGOTIATION
Clifford R DoeArgentinaBernardo Dominic NEW
Kaitlin F KuskoGermanyStephen Shaw RENEWAL
Smith E DarakjyJapanOnyama Limba RENEWAL
Jennifer D MacleadGermanyIvan Magalhaes QUALIFIED
Misaki B WhobreyGermanyIvan Magalhaes QUALIFIED
Isabel A GillianFranceElwin Sharvill NEW
Nicolas E OldroydJapanAsiya Javayant PROPOSAL
Juan T CaldareraItalyIvan Magalhaes RENEWAL
Stacey M SaylorsRussiaIvan Magalhaes UNQUALIFIED
Arvin N MacleadItalyElwin Sharvill PROPOSAL
Izzy C FigeroaGermanyIoni Bowcher NEW
Jeanfrancois E DoeJapanIvan Magalhaes NEW
Maisha Y PerinSpainStephen Shaw NEGOTIATION
Adams Q KuskoFranceElwin Sharvill RENEWAL
Leja K DilliardSpainBernardo Dominic NEW
Aruna V WieserItalyStephen Shaw PROPOSAL
Leon Q MorascaUnited KingdomAsiya Javayant UNQUALIFIED
Mayumi O VocelkaItalyAnna Fali NEW
Aika T DilliardJapanXuxue Feng QUALIFIED
Frozen Columns
Name
Francesco M Stockham
Morrow P Chui
Deepesh T Vocelka
Darci E Dilliard
Aruna F Venere
Johnson L Caldarera
Aika T Gaucho
Ricardo V Oldroyd
Aditya F Kolmetz
Mayumi O Whobrey
Kadeem X Saylors
Faith F Foller
Tony P Malet
Maisha O Rim
Octavia F Shinko
Nicolas P Nestle
Leja S Darakjy
Murillo T Kolmetz
Nicolas F Poquette
Aika V Albares
Jeanfrancois R Slusarski
Greenwood K Oldroyd
Mujtaba P Amigon
Kaitlin G Waycott
Clifford Q Ruta
Kaitlin C Kolmetz
James O Ferencz
Morrow L Inouye
Isabel Q Saylors
Jefferson N Morasca
Ashley M Doe
Kadeem V Wieser
Maria D Poquette
Cody C Caldarera
Morrow Y Amigon
Kadeem B Tollner
Kaitlin X Butt
Mayumi I Foller
Alejandro O Wieser
Francesco I Waycott
Isabel W Rim
Stacey K Butt
Salvatore R Darakjy
Misaki O Perin
Deepesh U Campain
Jefferson E Marrier
Rodrigues X Dilliard
Clifford D Venere
Ivar U Royster
Darci G Tollner
IdCountryDate
1000Italy2024-04-27
1001United Kingdom2024-04-14
1002Australia2024-04-05
1003Canada2024-04-27
1004Argentina2024-04-19
1005Italy2024-03-29
1006Russia2024-04-20
1007Argentina2024-04-15
1008Japan2024-04-25
1009Japan2024-04-04
1010Australia2024-04-26
1011Japan2024-04-18
1012Japan2024-04-02
1013Spain2024-04-27
1014Brazil2024-04-03
1015France2024-04-19
1016United Kingdom2024-04-19
1017Germany2024-04-03
1018France2024-03-31
1019France2024-04-08
1020Germany2024-04-17
1021Canada2024-04-26
1022Australia2024-04-27
1023Argentina2024-04-07
1024Germany2024-04-08
1025United Kingdom2024-04-05
1026United Kingdom2024-04-15
1027India2024-04-11
1028Japan2024-04-03
1029Spain2024-04-01
1030Germany2024-04-10
1031Argentina2024-04-21
1032Brazil2024-04-22
1033Brazil2024-03-30
1034Japan2024-04-07
1035Australia2024-04-11
1036Italy2024-03-29
1037Russia2024-04-27
1038Australia2024-04-01
1039Japan2024-03-31
1040Canada2024-04-15
1041Canada2024-04-08
1042Argentina2024-04-01
1043Spain2024-04-27
1044Argentina2024-03-31
1045Argentina2024-04-24
1046Germany2024-04-15
1047Argentina2024-04-20
1048France2024-04-02
1049Russia2024-04-02

On-Demand Data

NameIdCountryDate
Isabel Z Butt1000Russia2024-04-04
Arvin B Whobrey1001Australia2024-04-12
Jeanfrancois Y Figeroa1002Italy2024-04-03
Aika O Sergi1003Spain2024-04-23
Maria F Darakjy1004Russia2024-04-07
Kaitlin U Morasca1005Spain2024-04-02
Jones O Ruta1006France2024-04-06
Leon Z Wieser1007Spain2024-04-06
Mayumi J Briddick1008Spain2024-04-05
Izzy G Glick1009Canada2024-04-09
Isabel E Inouye1010Russia2024-04-01
Alejandro U Garufi1011Russia2024-04-12
Cody I Bowley1012Argentina2024-04-04
Francesco U Glick1013United Kingdom2024-04-10
Ashley E Maclead1014Argentina2024-04-21
Johnson K Marrier1015Germany2024-04-05
Rodrigues W Stockham1016Canada2024-04-09
Jeanfrancois K Ostrosky1017Canada2024-03-31
Jones E Shinko1018Spain2024-04-15
Greenwood D Schemmer1019Italy2024-03-29
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Ivar B OldroydGermanyBernardo Dominic UNQUALIFIED
Kadeem I WhobreyGermanyXuxue Feng NEGOTIATION
Aruna C CampainJapanOnyama Limba QUALIFIED
Francesco B WhobreyIndiaBernardo Dominic QUALIFIED
Smith T RulapaughFranceIoni Bowcher NEGOTIATION
Salvatore N PaprockiAustraliaXuxue Feng QUALIFIED
Tony R MarrierAustraliaStephen Shaw QUALIFIED
Arvin W MarrierGermanyBernardo Dominic NEGOTIATION
Izzy G CaudyUnited KingdomXuxue Feng NEW
Emily B VenereCanadaIvan Magalhaes RENEWAL
Cody D RimRussiaAnna Fali PROPOSAL
Cody I CampainBrazilBernardo Dominic NEGOTIATION
Arvin R StensethSpainStephen Shaw NEGOTIATION
Misaki E FigeroaIndiaStephen Shaw NEGOTIATION
Salvatore K OstroskyItalyElwin Sharvill RENEWAL
Mujtaba R SaylorsAustraliaIvan Magalhaes UNQUALIFIED
Julie N BowleyRussiaIvan Magalhaes QUALIFIED
Wickens I StockhamJapanIoni Bowcher RENEWAL
Claire T KolmetzBrazilAsiya Javayant QUALIFIED
Greenwood U PaprockiCanadaAsiya Javayant PROPOSAL
Adams G RimArgentinaStephen Shaw UNQUALIFIED
Octavia M AlbaresRussiaElwin Sharvill NEGOTIATION
Maria E FollerAustraliaElwin Sharvill NEW
Izzy H GarufiArgentinaIvan Magalhaes UNQUALIFIED
Francesco X MarrierRussiaIoni Bowcher QUALIFIED
James I FigeroaUnited KingdomAmy Elsner NEW
Tony T MacleadGermanyAsiya Javayant UNQUALIFIED
Clifford L GillianJapanAnna Fali RENEWAL
Octavia H SaylorsItalyXuxue Feng UNQUALIFIED
Kaitlin X ButtSpainXuxue Feng RENEWAL
Jennifer Q VenereArgentinaIvan Magalhaes NEW
Alejandro I ButtUnited KingdomAsiya Javayant NEGOTIATION
Jones L MorascaGermanyIvan Magalhaes UNQUALIFIED
Stacey I FollerFranceAnna Fali QUALIFIED
Wickens J StensethJapanOnyama Limba QUALIFIED
Wickens S StockhamUnited KingdomElwin Sharvill NEW
David M FigeroaBrazilIvan Magalhaes RENEWAL
Izzy A ChuiSpainAmy Elsner QUALIFIED
Julie N CaldareraCanadaOnyama Limba NEGOTIATION
Leja P SaylorsArgentinaBernardo Dominic PROPOSAL

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