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
Kaitlin N CaudyGermanyStephen Shaw NEW
Sinclair W FerenczBrazilXuxue Feng UNQUALIFIED
Tony I InouyeGermanyElwin Sharvill UNQUALIFIED
Emily L IturbideSpainIvan Magalhaes UNQUALIFIED
Jones P FlosiIndiaAnna Fali NEW
Smith T BriddickFranceAnna Fali QUALIFIED
Faith D GillianJapanXuxue Feng UNQUALIFIED
Alejandro Y WhobreySpainBernardo Dominic NEGOTIATION
Leja B SlusarskiIndiaAnna Fali RENEWAL
Jennifer B MarrierRussiaIoni Bowcher UNQUALIFIED
Mayumi Y PaprockiJapanIoni Bowcher QUALIFIED
Jeanfrancois L VenereFranceXuxue Feng QUALIFIED
David P WieserItalyAnna Fali NEW
Jefferson D StensethRussiaAmy Elsner NEGOTIATION
Juan X WieserUnited KingdomStephen Shaw NEW
Smith R PerinSpainXuxue Feng RENEWAL
Mayumi V ButtGermanyAnna Fali RENEWAL
Ricardo V DarakjySpainAnna Fali UNQUALIFIED
Wickens M VenereSpainAsiya Javayant NEW
Kaitlin G FlosiArgentinaStephen Shaw UNQUALIFIED
Mujtaba F GlickBrazilXuxue Feng UNQUALIFIED
Jeanfrancois B TollnerFranceAsiya Javayant UNQUALIFIED
Isabel X StensethAustraliaAmy Elsner PROPOSAL
David M VenereArgentinaElwin Sharvill RENEWAL
Sinclair G WaycottAustraliaAnna Fali QUALIFIED
Jeanfrancois I SergiCanadaIoni Bowcher NEGOTIATION
Tony Z GarufiItalyBernardo Dominic NEGOTIATION
Kaitlin H MaletRussiaIoni Bowcher PROPOSAL
Aika R AlbaresJapanOnyama Limba QUALIFIED
Greenwood C ButtRussiaBernardo Dominic UNQUALIFIED
Kadeem W AlbaresGermanyBernardo Dominic NEGOTIATION
Greenwood B MarrierUnited KingdomElwin Sharvill UNQUALIFIED
Leja O IturbideCanadaOnyama Limba UNQUALIFIED
Aruna N PerinArgentinaElwin Sharvill RENEWAL
Jefferson F ButtUnited KingdomStephen Shaw NEW
Greenwood H MaletFranceIvan Magalhaes UNQUALIFIED
Sinclair I KuskoBrazilIvan Magalhaes RENEWAL
Juan W AmigonGermanyAsiya Javayant NEW
Mayumi Y PoquetteAustraliaAsiya Javayant NEW
Deepesh I CampainUnited KingdomOnyama Limba NEGOTIATION
Maria W CaudyCanadaIvan Magalhaes PROPOSAL
Nicolas T RimFranceIvan Magalhaes QUALIFIED
Jennifer G GillianCanadaOnyama Limba RENEWAL
Chavez Z KuskoBrazilXuxue Feng QUALIFIED
Juan Y WhobreySpainAsiya Javayant UNQUALIFIED
Adams U FerenczCanadaIvan Magalhaes RENEWAL
Aruna U MacleadCanadaElwin Sharvill UNQUALIFIED
Murillo M StockhamJapanXuxue Feng NEW
Greenwood F FollerAustraliaBernardo Dominic RENEWAL
Clifford M WhobreyBrazilAnna Fali UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Salvatore E GauchoGermanyAsiya Javayant QUALIFIED
Kaitlin T SlusarskiFranceIoni Bowcher QUALIFIED
Adams A KuskoAustraliaIoni Bowcher NEW
Stacey J MacleadJapanAsiya Javayant NEW
Jennifer R BriddickFranceBernardo Dominic NEGOTIATION
Juan R GlickRussiaAmy Elsner NEW
Misaki R AmigonIndiaIoni Bowcher NEW
Claire P OldroydCanadaXuxue Feng QUALIFIED
Wickens G InouyeSpainAmy Elsner UNQUALIFIED
Aruna M MorascaCanadaAnna Fali RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Mayumi U StensethAustralia2024-04-03Chemel, James L Cpa NEW86Bernardo Dominic
1001Jennifer I CampainJapan2024-04-20Buckley Miller Wright QUALIFIED30Xuxue Feng
1002Jennifer Z BriddickIndia2024-04-19Printing Dimensions UNQUALIFIED54Ivan Magalhaes
1003Aruna D CaudySpain2024-04-09Rousseaux, Michael Esq NEW22Bernardo Dominic
1004Smith Y OldroydSpain2024-04-23Printing Dimensions PROPOSAL37Amy Elsner
1005Tony R FollerAustralia2024-04-13Morlong Associates RENEWAL64Xuxue Feng
1006Clifford U WaycottFrance2024-04-03Dorl, James J Esq RENEWAL49Xuxue Feng
1007Juan V FigeroaRussia2024-04-08King, Christopher A Esq UNQUALIFIED64Amy Elsner
1008Aditya K InouyeItaly2024-04-17Feiner Bros RENEWAL83Elwin Sharvill
1009Silvio G FigeroaUnited Kingdom2024-04-02Rousseaux, Michael Esq RENEWAL65Ioni Bowcher
1010Clifford K SlusarskiBrazil2024-03-29Rangoni Of Florence RENEWAL96Anna Fali
1011Clifford Q MaletJapan2024-03-29Commercial Press UNQUALIFIED14Ioni Bowcher
1012Clifford O PoquetteItaly2024-04-20Truhlar And Truhlar Attys PROPOSAL2Onyama Limba
1013James D FerenczSpain2024-04-12Chanay, Jeffrey A Esq RENEWAL36Ioni Bowcher
1014Silvio J DoeGermany2024-04-11Feltz Printing Service RENEWAL3Ivan Magalhaes
1015Misaki D RutaCanada2024-04-20Chapman, Ross E Esq PROPOSAL66Stephen Shaw
1016Faith K BowleyJapan2024-04-19Chanay, Jeffrey A Esq PROPOSAL20Asiya Javayant
1017Darci D ShinkoGermany2024-04-04Buckley Miller Wright QUALIFIED10Anna Fali
1018Greenwood K PerinGermany2024-04-14Chapman, Ross E Esq UNQUALIFIED27Elwin Sharvill
1019Juan D SergiCanada2024-03-28Chapman, Ross E Esq PROPOSAL32Anna Fali
1020Alejandro F RulapaughSpain2024-04-16Rangoni Of Florence RENEWAL19Onyama Limba
1021Emily Q NickaAustralia2024-04-20Rousseaux, Michael Esq NEW88Stephen Shaw
1022Mayumi Y ChuiRussia2024-04-19King, Christopher A Esq PROPOSAL40Stephen Shaw
1023Ivar N SlusarskiAustralia2024-04-14Dorl, James J Esq RENEWAL39Elwin Sharvill
1024Alejandro O SlusarskiRussia2024-03-29King, Christopher A Esq PROPOSAL27Asiya Javayant
1025Nicolas B OldroydItaly2024-04-05Benton, John B Jr NEGOTIATION29Stephen Shaw
1026Silvio I FollerSpain2024-04-12Printing Dimensions UNQUALIFIED25Ivan Magalhaes
1027Sinclair N NickaJapan2024-03-29Dorl, James J Esq NEW76Xuxue Feng
1028Alejandro Z SchemmerFrance2024-03-28Buckley Miller Wright NEGOTIATION41Elwin Sharvill
1029Isabel H NickaRussia2024-03-31Feiner Bros RENEWAL89Ivan Magalhaes
1030Octavia N PerinSpain2024-03-30Feiner Bros NEGOTIATION72Ioni Bowcher
1031Jones M PaprockiArgentina2024-03-29Chapman, Ross E Esq RENEWAL8Elwin Sharvill
1032Wickens D NestleUnited Kingdom2024-04-08Chemel, James L Cpa NEGOTIATION2Ioni Bowcher
1033Salvatore R DarakjyGermany2024-04-17Printing Dimensions UNQUALIFIED99Bernardo Dominic
1034Sinclair E OstroskyBrazil2024-04-09Truhlar And Truhlar Attys UNQUALIFIED85Bernardo Dominic
1035Johnson P WieserAustralia2024-04-12Rousseaux, Michael Esq PROPOSAL87Asiya Javayant
1036Costa K PerinAustralia2024-04-01Rousseaux, Michael Esq NEGOTIATION36Bernardo Dominic
1037Nicolas Y SchemmerSpain2024-03-26Chanay, Jeffrey A Esq QUALIFIED32Xuxue Feng
1038Jennifer H SaylorsSpain2024-03-26Commercial Press UNQUALIFIED37Asiya Javayant
1039Adams M GarufiUnited Kingdom2024-03-29Truhlar And Truhlar Attys RENEWAL11Amy Elsner
1040Chavez L CaudyFrance2024-04-08Chanay, Jeffrey A Esq PROPOSAL51Ivan Magalhaes
1041Jones R RoysterItaly2024-04-13Rousseaux, Michael Esq PROPOSAL52Xuxue Feng
1042Smith M OldroydCanada2024-04-23King, Christopher A Esq NEW44Stephen Shaw
1043Adams A TollnerBrazil2024-04-06Benton, John B Jr RENEWAL94Xuxue Feng
1044Juan R FerenczGermany2024-04-23Feiner Bros RENEWAL39Ivan Magalhaes
1045Francesco F GauchoArgentina2024-03-31Printing Dimensions NEW17Anna Fali
1046Smith J WieserArgentina2024-04-04Chemel, James L Cpa QUALIFIED94Ioni Bowcher
1047Maisha H OldroydFrance2024-04-16Chemel, James L Cpa RENEWAL45Anna Fali
1048Cody V ButtSpain2024-04-04Commercial Press QUALIFIED69Asiya Javayant
1049Ashley D MaletBrazil2024-03-28Truhlar And Truhlar Attys QUALIFIED58Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Smith V AmigonGermanyXuxue Feng UNQUALIFIED
Darci S FlosiBrazilBernardo Dominic RENEWAL
Octavia P RulapaughGermanyElwin Sharvill QUALIFIED
Aika Z FerenczItalyAsiya Javayant NEW
Kaitlin X InouyeGermanyAmy Elsner PROPOSAL
Deepesh M MacleadIndiaBernardo Dominic UNQUALIFIED
Chavez K BologniaFranceIvan Magalhaes PROPOSAL
Smith V DarakjyRussiaElwin Sharvill RENEWAL
Kaitlin J NickaRussiaAnna Fali RENEWAL
Clifford P MaletGermanyAnna Fali RENEWAL
Leon U BriddickSpainIoni Bowcher NEW
Maria P MacleadUnited KingdomAsiya Javayant RENEWAL
Rodrigues X IturbideCanadaAmy Elsner RENEWAL
Aditya U BriddickBrazilElwin Sharvill PROPOSAL
Antonio V ChuiArgentinaXuxue Feng QUALIFIED
Leja P PerinIndiaIvan Magalhaes NEGOTIATION
Munro J PoquetteSpainOnyama Limba UNQUALIFIED
Aika W WaycottSpainBernardo Dominic NEW
Rodrigues M MaletCanadaIoni Bowcher RENEWAL
Chavez W IturbideItalyStephen Shaw NEGOTIATION
Jennifer Z BriddickArgentinaAmy Elsner UNQUALIFIED
Antonio H MacleadIndiaOnyama Limba RENEWAL
Francesco C RulapaughJapanAsiya Javayant RENEWAL
Salvatore Y AlbaresArgentinaOnyama Limba NEW
Francesco N MaletFranceIoni Bowcher NEW
Francesco G KolmetzFranceStephen Shaw UNQUALIFIED
Jones M WaycottJapanElwin Sharvill UNQUALIFIED
Kadeem J FerenczSpainStephen Shaw QUALIFIED
Smith C OstroskyUnited KingdomElwin Sharvill UNQUALIFIED
Misaki O VocelkaItalyBernardo Dominic QUALIFIED
Johnson R OldroydGermanyStephen Shaw RENEWAL
Tony H FollerRussiaStephen Shaw PROPOSAL
Jones E RoysterJapanStephen Shaw UNQUALIFIED
Tony T MorascaGermanyOnyama Limba UNQUALIFIED
Aruna I KuskoCanadaAsiya Javayant NEW
Faith O SergiCanadaElwin Sharvill NEW
Nicolas I RimIndiaStephen Shaw UNQUALIFIED
Sinclair H FlosiAustraliaOnyama Limba NEW
James U DarakjyIndiaIoni Bowcher PROPOSAL
Leon M MaletCanadaElwin Sharvill RENEWAL
Sinclair G RoysterItalyBernardo Dominic QUALIFIED
Wickens O FerenczCanadaIoni Bowcher RENEWAL
Aditya C GlickSpainAmy Elsner NEW
Julie M OldroydUnited KingdomIvan Magalhaes NEW
Tony D CaldareraFranceOnyama Limba RENEWAL
James Y WaycottBrazilStephen Shaw QUALIFIED
Jones P AmigonCanadaStephen Shaw NEW
Faith W ButtIndiaElwin Sharvill UNQUALIFIED
Darci H GauchoCanadaStephen Shaw UNQUALIFIED
Emily U WaycottSpainAsiya Javayant QUALIFIED
Frozen Columns
Name
Alejandro Y Caudy
Tony B Rim
Emily R Wieser
Mujtaba K Briddick
Mayumi H Morasca
Clifford P Stockham
Maisha R Inouye
Jeanfrancois L Schemmer
Mayumi S Wieser
Leja T Campain
David P Caldarera
Izzy A Figeroa
Clifford F Doe
Isabel M Flosi
Sinclair K Rim
Maria P Iturbide
Cody B Poquette
Tony P Wieser
Jennifer B Rulapaugh
Arvin Q Rim
Mujtaba C Flosi
Aruna Y Paprocki
Ashley A Bolognia
Arvin R Flosi
Leja Y Caudy
Jones G Stenseth
Mayumi X Whobrey
Mayumi O Malet
Emily S Kusko
Kaitlin J Malet
Sinclair Y Gillian
Kadeem F Doe
Munro B Nestle
Ivar T Ostrosky
Francesco I Glick
Faith Z Nicka
Greenwood M Bowley
Nicolas C Paprocki
Juan B Dilliard
Sinclair D Maclead
Maria R Ruta
Francesco J Royster
Wickens W Tollner
Jefferson E Slusarski
Clifford R Caldarera
Faith E Kolmetz
Ivar O Figeroa
Greenwood X Maclead
Mayumi W Glick
Leon W Iturbide
IdCountryDate
1000Argentina2024-04-12
1001Russia2024-04-04
1002Argentina2024-04-10
1003Brazil2024-04-03
1004Argentina2024-04-05
1005Argentina2024-04-04
1006Italy2024-03-28
1007Germany2024-03-26
1008Spain2024-03-31
1009Russia2024-04-07
1010Germany2024-04-13
1011United Kingdom2024-04-01
1012Australia2024-04-10
1013Italy2024-04-04
1014Italy2024-04-23
1015Argentina2024-04-03
1016Japan2024-04-13
1017Australia2024-04-11
1018Brazil2024-03-30
1019Germany2024-04-22
1020Italy2024-04-11
1021Italy2024-04-10
1022Brazil2024-04-10
1023France2024-03-26
1024France2024-04-21
1025France2024-04-06
1026Japan2024-04-07
1027Brazil2024-04-20
1028Italy2024-04-05
1029United Kingdom2024-04-17
1030Russia2024-04-03
1031Russia2024-04-04
1032Argentina2024-03-27
1033Japan2024-04-12
1034Italy2024-04-13
1035Argentina2024-04-01
1036India2024-04-11
1037France2024-04-02
1038Germany2024-04-05
1039India2024-04-21
1040Argentina2024-04-20
1041Italy2024-04-11
1042Germany2024-03-26
1043Germany2024-04-08
1044Australia2024-04-24
1045Germany2024-04-09
1046United Kingdom2024-04-17
1047France2024-04-03
1048United Kingdom2024-04-02
1049France2024-04-03

On-Demand Data

NameIdCountryDate
Sinclair P Stockham1000Italy2024-04-05
Misaki Z Whobrey1001Spain2024-03-26
Johnson D Schemmer1002Italy2024-03-27
Ashley X Briddick1003France2024-04-09
Aruna N Shinko1004Spain2024-04-08
Murillo I Rulapaugh1005Japan2024-04-17
Chavez Q Shinko1006Brazil2024-04-07
Antonio M Doe1007United Kingdom2024-03-30
Claire R Briddick1008United Kingdom2024-04-01
Claire N Iturbide1009France2024-04-23
Johnson E Royster1010France2024-04-23
Adams R Foller1011Canada2024-04-06
Jefferson M Kusko1012Canada2024-04-11
Izzy G Kusko1013Italy2024-04-04
Leja X Waycott1014Australia2024-04-13
Chavez K Malet1015India2024-04-24
Ashley Z Paprocki1016Japan2024-04-01
Clifford W Poquette1017India2024-03-27
Murillo K Morasca1018France2024-04-02
Jeanfrancois V Whobrey1019Brazil2024-03-28
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Octavia H GauchoCanadaElwin Sharvill RENEWAL
Jones F ButtJapanStephen Shaw QUALIFIED
Greenwood O WhobreyFranceBernardo Dominic UNQUALIFIED
Claire P GillianSpainOnyama Limba NEW
Johnson V SchemmerIndiaIvan Magalhaes RENEWAL
Faith Q CaudyGermanyAnna Fali NEW
Ashley Y DilliardBrazilIvan Magalhaes NEGOTIATION
Adams E KuskoItalyElwin Sharvill QUALIFIED
Julie X BriddickCanadaOnyama Limba NEW
Maria M AmigonArgentinaIvan Magalhaes RENEWAL
Jones W GarufiArgentinaOnyama Limba QUALIFIED
Leon H SchemmerArgentinaBernardo Dominic QUALIFIED
Izzy P ButtItalyXuxue Feng PROPOSAL
Claire Z PaprockiCanadaOnyama Limba QUALIFIED
Murillo D BriddickGermanyAmy Elsner QUALIFIED
Chavez S WhobreyGermanyStephen Shaw NEW
Morrow X PerinAustraliaXuxue Feng NEW
Maisha Q BriddickItalyAnna Fali NEGOTIATION
Smith J ButtAustraliaElwin Sharvill PROPOSAL
Maria V FollerGermanyIvan Magalhaes RENEWAL
Johnson K SergiUnited KingdomXuxue Feng PROPOSAL
Francesco C AmigonUnited KingdomOnyama Limba UNQUALIFIED
Silvio C WaycottArgentinaStephen Shaw PROPOSAL
Kadeem W MaletArgentinaOnyama Limba UNQUALIFIED
Jefferson I RoysterItalyIvan Magalhaes UNQUALIFIED
Stacey R KuskoSpainAmy Elsner UNQUALIFIED
David E BriddickArgentinaAmy Elsner NEW
Maisha I GauchoAustraliaStephen Shaw NEGOTIATION
Darci K FigeroaGermanyStephen Shaw UNQUALIFIED
Greenwood C WhobreyUnited KingdomAsiya Javayant RENEWAL
Darci A MaletAustraliaXuxue Feng NEW
Adams X SaylorsFranceIoni Bowcher PROPOSAL
Izzy U MarrierAustraliaOnyama Limba RENEWAL
Jeanfrancois W StensethItalyAnna Fali NEW
Ivar E WaycottJapanIoni Bowcher NEGOTIATION
Kaitlin F OldroydRussiaXuxue Feng QUALIFIED
Izzy A WieserArgentinaElwin Sharvill NEGOTIATION
Johnson O VenereAustraliaAmy Elsner RENEWAL
Ivar A FigeroaUnited KingdomStephen Shaw NEW
Leon W GarufiItalyElwin Sharvill QUALIFIED

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