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
Jennifer E WhobreyArgentinaXuxue Feng NEGOTIATION
Faith S InouyeArgentinaStephen Shaw PROPOSAL
Darci J PaprockiSpainXuxue Feng UNQUALIFIED
Tony J PerinSpainAsiya Javayant UNQUALIFIED
Maria G GarufiGermanyXuxue Feng NEW
Johnson S KolmetzAustraliaAnna Fali RENEWAL
Misaki F DilliardArgentinaAsiya Javayant UNQUALIFIED
Leja M WhobreyArgentinaStephen Shaw UNQUALIFIED
Ricardo B AlbaresJapanAsiya Javayant NEGOTIATION
Ricardo U SaylorsRussiaStephen Shaw NEW
Antonio I MacleadAustraliaOnyama Limba PROPOSAL
Tony T MorascaAustraliaBernardo Dominic PROPOSAL
Deepesh R IturbideUnited KingdomAsiya Javayant QUALIFIED
Jones W NickaItalyStephen Shaw UNQUALIFIED
Mayumi N DoeUnited KingdomStephen Shaw UNQUALIFIED
Jennifer E OstroskyIndiaAmy Elsner NEW
Darci J DoeJapanXuxue Feng NEGOTIATION
David B GauchoJapanIvan Magalhaes NEW
James Z RutaSpainAsiya Javayant NEGOTIATION
Nicolas Q BologniaItalyStephen Shaw RENEWAL
Nicolas C NickaGermanyIvan Magalhaes NEW
Faith O DoeBrazilBernardo Dominic NEGOTIATION
Mujtaba M WhobreyJapanAmy Elsner PROPOSAL
Aika O WieserUnited KingdomIoni Bowcher RENEWAL
Costa Y FollerSpainStephen Shaw NEGOTIATION
Cody Y PaprockiRussiaOnyama Limba RENEWAL
Emily D KolmetzSpainAmy Elsner UNQUALIFIED
Octavia L WieserJapanIvan Magalhaes RENEWAL
Greenwood U VocelkaIndiaAmy Elsner RENEWAL
Izzy A SaylorsSpainIvan Magalhaes NEGOTIATION
Smith L ShinkoRussiaOnyama Limba NEW
Juan Z GarufiIndiaAsiya Javayant UNQUALIFIED
Ivar A SaylorsSpainIvan Magalhaes PROPOSAL
Johnson D RutaJapanElwin Sharvill QUALIFIED
Chavez H FlosiItalyAnna Fali NEGOTIATION
Maria Y SchemmerUnited KingdomAnna Fali PROPOSAL
Morrow N MacleadItalyIoni Bowcher RENEWAL
Leja R FigeroaBrazilAsiya Javayant NEGOTIATION
Misaki L RulapaughUnited KingdomIvan Magalhaes UNQUALIFIED
Salvatore Z KuskoArgentinaAsiya Javayant RENEWAL
David S NestleFranceBernardo Dominic NEW
Rodrigues P CaldareraGermanyIoni Bowcher PROPOSAL
Claire R TollnerSpainStephen Shaw RENEWAL
Sinclair R KuskoSpainIvan Magalhaes UNQUALIFIED
Leon R GauchoArgentinaBernardo Dominic UNQUALIFIED
Alejandro Q VocelkaSpainAmy Elsner RENEWAL
Darci I WhobreyUnited KingdomOnyama Limba NEW
Smith S GlickSpainElwin Sharvill NEGOTIATION
James Q CampainUnited KingdomIvan Magalhaes RENEWAL
Claire V BologniaArgentinaStephen Shaw RENEWAL
Horizontal
NameCountryRepresentativeStatus
Misaki U CaldareraCanadaStephen Shaw NEGOTIATION
Munro H WieserJapanIoni Bowcher PROPOSAL
Jeanfrancois C ChuiBrazilAnna Fali RENEWAL
Kadeem N GlickBrazilElwin Sharvill NEGOTIATION
Juan L MacleadAustraliaXuxue Feng PROPOSAL
Ashley O SaylorsBrazilIoni Bowcher QUALIFIED
Maisha V MaletJapanAsiya Javayant UNQUALIFIED
Munro U SchemmerGermanyOnyama Limba PROPOSAL
Izzy C SergiRussiaAmy Elsner QUALIFIED
Ivar G KuskoBrazilBernardo Dominic NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jennifer H PaprockiItaly2024-04-23Feiner Bros QUALIFIED72Onyama Limba
1001Cody P MarrierIndia2024-04-27Buckley Miller Wright NEGOTIATION78Stephen Shaw
1002Ashley R SaylorsSpain2024-05-04Dorl, James J Esq QUALIFIED73Ioni Bowcher
1003Deepesh T RulapaughItaly2024-04-18Rangoni Of Florence NEW43Ivan Magalhaes
1004Misaki F SergiItaly2024-04-25Benton, John B Jr NEGOTIATION46Xuxue Feng
1005Kaitlin H RimBrazil2024-04-28Benton, John B Jr NEW58Elwin Sharvill
1006Murillo X BologniaIndia2024-04-10Dorl, James J Esq UNQUALIFIED87Stephen Shaw
1007Ricardo M BologniaArgentina2024-04-28Rousseaux, Michael Esq UNQUALIFIED77Onyama Limba
1008Octavia L FerenczJapan2024-04-26Dorl, James J Esq UNQUALIFIED47Ioni Bowcher
1009Antonio C DoeUnited Kingdom2024-04-20Benton, John B Jr UNQUALIFIED75Xuxue Feng
1010Antonio O CaudyCanada2024-04-10Morlong Associates RENEWAL64Anna Fali
1011Kadeem Q NestleCanada2024-05-07Chapman, Ross E Esq PROPOSAL57Amy Elsner
1012Silvio M FollerBrazil2024-05-05Truhlar And Truhlar Attys NEGOTIATION38Onyama Limba
1013Nicolas S PerinBrazil2024-04-26Truhlar And Truhlar Attys NEW34Asiya Javayant
1014Isabel P VocelkaFrance2024-04-15Buckley Miller Wright NEGOTIATION14Asiya Javayant
1015Salvatore V OstroskyBrazil2024-05-01Chanay, Jeffrey A Esq UNQUALIFIED46Ivan Magalhaes
1016Kaitlin I KuskoItaly2024-04-18Benton, John B Jr QUALIFIED38Ioni Bowcher
1017Smith W FigeroaIndia2024-04-21Buckley Miller Wright NEGOTIATION57Amy Elsner
1018Greenwood R RimUnited Kingdom2024-04-28Buckley Miller Wright RENEWAL38Xuxue Feng
1019Francesco X WieserAustralia2024-04-11Feiner Bros RENEWAL54Anna Fali
1020Munro R KuskoItaly2024-05-03Buckley Miller Wright QUALIFIED6Ivan Magalhaes
1021Costa A RutaBrazil2024-05-05Morlong Associates RENEWAL99Xuxue Feng
1022Chavez B InouyeCanada2024-04-16King, Christopher A Esq UNQUALIFIED6Bernardo Dominic
1023Claire Z ShinkoItaly2024-04-20Buckley Miller Wright NEW51Anna Fali
1024Sinclair G PerinJapan2024-04-28Feltz Printing Service UNQUALIFIED80Amy Elsner
1025Munro H SaylorsCanada2024-04-22Printing Dimensions RENEWAL13Stephen Shaw
1026James E OldroydGermany2024-04-21Commercial Press NEW11Bernardo Dominic
1027Isabel N BologniaArgentina2024-05-07Feltz Printing Service NEW37Anna Fali
1028Antonio F RimArgentina2024-04-25Feltz Printing Service UNQUALIFIED65Stephen Shaw
1029Aika N MacleadSpain2024-04-14Chemel, James L Cpa QUALIFIED70Asiya Javayant
1030James A ChuiGermany2024-04-22Chemel, James L Cpa NEW39Ivan Magalhaes
1031Darci Q StockhamBrazil2024-04-28Chapman, Ross E Esq UNQUALIFIED5Ivan Magalhaes
1032Francesco T BologniaArgentina2024-04-13Rangoni Of Florence NEGOTIATION17Ivan Magalhaes
1033Kadeem O DoeFrance2024-05-09Feiner Bros NEGOTIATION99Ioni Bowcher
1034Darci W KuskoRussia2024-04-26Chemel, James L Cpa QUALIFIED32Ivan Magalhaes
1035Johnson W MorascaSpain2024-04-18Feiner Bros QUALIFIED73Elwin Sharvill
1036Smith M NickaSpain2024-05-03Feltz Printing Service NEGOTIATION36Onyama Limba
1037Greenwood G FerenczUnited Kingdom2024-04-26Dorl, James J Esq NEGOTIATION83Elwin Sharvill
1038Morrow T ChuiIndia2024-04-21Morlong Associates NEW71Bernardo Dominic
1039Costa V FigeroaSpain2024-04-14King, Christopher A Esq NEGOTIATION6Onyama Limba
1040Stacey B InouyeFrance2024-04-28King, Christopher A Esq NEGOTIATION92Ivan Magalhaes
1041Cody H PerinIndia2024-05-04Rangoni Of Florence RENEWAL16Xuxue Feng
1042Stacey C FollerRussia2024-04-30Rangoni Of Florence NEGOTIATION80Xuxue Feng
1043Greenwood H RimGermany2024-05-04King, Christopher A Esq QUALIFIED95Anna Fali
1044Salvatore X SaylorsCanada2024-04-25Rangoni Of Florence PROPOSAL67Elwin Sharvill
1045James T StensethIndia2024-04-28Chapman, Ross E Esq NEGOTIATION76Anna Fali
1046Munro D NestleAustralia2024-04-26Rousseaux, Michael Esq NEW67Stephen Shaw
1047Emily N CampainGermany2024-05-05Chapman, Ross E Esq NEW29Anna Fali
1048Emily O KolmetzSpain2024-04-19Dorl, James J Esq QUALIFIED8Asiya Javayant
1049Rodrigues L FerenczGermany2024-05-04Chanay, Jeffrey A Esq NEGOTIATION74Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Antonio P SlusarskiSpainAnna Fali PROPOSAL
David S ButtAustraliaElwin Sharvill QUALIFIED
Ashley M AmigonUnited KingdomAnna Fali QUALIFIED
Claire Q VenereSpainIoni Bowcher NEGOTIATION
Deepesh S RimJapanXuxue Feng NEGOTIATION
Leja R MaletAustraliaElwin Sharvill QUALIFIED
Faith X TollnerArgentinaBernardo Dominic QUALIFIED
Jefferson T CaldareraIndiaIoni Bowcher UNQUALIFIED
Faith V AlbaresJapanBernardo Dominic QUALIFIED
Misaki B WhobreyIndiaAsiya Javayant QUALIFIED
Deepesh R VocelkaItalyElwin Sharvill NEW
Claire W ShinkoAustraliaAmy Elsner RENEWAL
Claire Q RutaGermanyIoni Bowcher QUALIFIED
Octavia G BowleySpainIvan Magalhaes PROPOSAL
Ivar I SergiIndiaIvan Magalhaes PROPOSAL
James J OldroydIndiaAmy Elsner NEGOTIATION
Faith Z NestleIndiaOnyama Limba RENEWAL
Mujtaba P KolmetzAustraliaIoni Bowcher NEW
Claire Y RutaRussiaAmy Elsner QUALIFIED
James E WaycottArgentinaStephen Shaw QUALIFIED
Ricardo U DarakjyUnited KingdomXuxue Feng PROPOSAL
Johnson O WhobreySpainStephen Shaw NEGOTIATION
Morrow N OldroydSpainBernardo Dominic QUALIFIED
Izzy L RutaAustraliaIoni Bowcher NEW
Emily K SlusarskiItalyBernardo Dominic NEGOTIATION
Alejandro Z FlosiAustraliaIvan Magalhaes UNQUALIFIED
Aditya T NestleJapanBernardo Dominic UNQUALIFIED
Mayumi G FlosiArgentinaAnna Fali QUALIFIED
Tony E CaldareraItalyAnna Fali RENEWAL
Costa F VocelkaSpainElwin Sharvill QUALIFIED
James P VenereCanadaAsiya Javayant NEW
Mayumi Y FigeroaGermanyOnyama Limba NEW
Adams C KuskoRussiaOnyama Limba QUALIFIED
Stacey I GlickItalyElwin Sharvill NEGOTIATION
Johnson G InouyeUnited KingdomAmy Elsner QUALIFIED
Costa J KuskoAustraliaAnna Fali NEGOTIATION
Deepesh K FigeroaItalyXuxue Feng PROPOSAL
Jeanfrancois E FerenczBrazilAmy Elsner UNQUALIFIED
Francesco P CaldareraGermanyAnna Fali PROPOSAL
Silvio N WieserIndiaXuxue Feng QUALIFIED
Jennifer E KolmetzSpainIvan Magalhaes QUALIFIED
Faith P CampainFranceIoni Bowcher NEGOTIATION
Tony Y BologniaGermanyXuxue Feng RENEWAL
Munro I FollerJapanIoni Bowcher PROPOSAL
Emily X PoquetteAustraliaAmy Elsner UNQUALIFIED
Arvin Y FigeroaCanadaAnna Fali QUALIFIED
Salvatore L StensethUnited KingdomAmy Elsner RENEWAL
James J PaprockiItalyIvan Magalhaes UNQUALIFIED
Aika Z FigeroaIndiaOnyama Limba QUALIFIED
Morrow D StensethUnited KingdomBernardo Dominic RENEWAL
Frozen Columns
Name
Greenwood P Kusko
Leon W Dilliard
Darci E Stenseth
Greenwood C Caldarera
David L Amigon
Maria O Caudy
Munro E Perin
Tony S Gillian
Silvio G Paprocki
Antonio T Malet
Octavia B Sergi
Kadeem Q Dilliard
Antonio I Dilliard
Mayumi I Darakjy
Rodrigues C Bolognia
Aruna Q Caldarera
Murillo Q Chui
David N Malet
Leja F Stockham
Darci R Tollner
Mayumi T Malet
Maisha U Morasca
Silvio Q Inouye
Izzy I Tollner
Tony X Rulapaugh
Jefferson U Ostrosky
Wickens E Briddick
Alejandro J Bolognia
Munro G Rulapaugh
Misaki S Schemmer
Octavia P Nestle
James D Nicka
Aika I Ruta
Ivar D Campain
Silvio M Poquette
Clifford J Bolognia
Nicolas P Marrier
Silvio B Poquette
Johnson R Bowley
David H Glick
Maria L Butt
Maisha O Darakjy
Faith W Vocelka
Faith J Albares
Jones G Marrier
Jeanfrancois P Darakjy
Maisha B Glick
Arvin J Marrier
Morrow G Vocelka
Rodrigues U Ostrosky
IdCountryDate
1000Italy2024-04-22
1001India2024-04-19
1002Argentina2024-05-04
1003Brazil2024-04-24
1004India2024-04-21
1005Canada2024-04-10
1006Italy2024-04-29
1007India2024-04-13
1008Japan2024-04-20
1009Brazil2024-05-03
1010United Kingdom2024-05-02
1011United Kingdom2024-04-20
1012Spain2024-04-10
1013Italy2024-04-16
1014Russia2024-04-16
1015Russia2024-04-28
1016Italy2024-05-02
1017Brazil2024-05-03
1018Germany2024-05-05
1019Russia2024-04-12
1020Brazil2024-05-08
1021Russia2024-04-23
1022India2024-04-30
1023France2024-04-22
1024France2024-04-22
1025Spain2024-05-02
1026Canada2024-04-16
1027Australia2024-05-01
1028Spain2024-04-15
1029France2024-05-05
1030Germany2024-04-25
1031Brazil2024-05-09
1032Australia2024-05-02
1033Russia2024-04-18
1034Australia2024-05-05
1035Australia2024-04-25
1036India2024-04-20
1037Spain2024-05-01
1038Italy2024-04-20
1039Argentina2024-04-28
1040Japan2024-05-05
1041Canada2024-05-03
1042Japan2024-05-07
1043India2024-04-12
1044India2024-05-08
1045Spain2024-04-13
1046Argentina2024-05-08
1047India2024-04-30
1048India2024-05-04
1049Canada2024-05-07

On-Demand Data

NameIdCountryDate
Ivar H Tollner1000United Kingdom2024-05-08
Antonio J Flosi1001Spain2024-04-16
Kaitlin U Wieser1002France2024-05-02
Aika J Rim1003Canada2024-04-27
Jennifer K Amigon1004Spain2024-04-17
Munro M Vocelka1005Spain2024-05-09
Rodrigues I Ferencz1006Japan2024-05-03
Mayumi R Caudy1007United Kingdom2024-04-28
Costa F Bowley1008Brazil2024-05-04
Leon J Nicka1009India2024-04-24
Misaki V Tollner1010India2024-05-04
Mujtaba A Wieser1011Germany2024-04-10
Mayumi F Malet1012Japan2024-04-15
Mujtaba E Paprocki1013Brazil2024-05-06
Emily N Saylors1014Brazil2024-05-05
Arvin R Kusko1015Italy2024-04-12
Isabel V Paprocki1016Brazil2024-04-19
Octavia O Vocelka1017United Kingdom2024-05-01
Mayumi L Garufi1018Russia2024-05-07
Octavia T Nicka1019Russia2024-05-03
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Silvio G KuskoBrazilOnyama Limba QUALIFIED
Leon V CampainItalyElwin Sharvill UNQUALIFIED
Misaki H AmigonRussiaElwin Sharvill PROPOSAL
Mujtaba H WaycottGermanyStephen Shaw NEW
Antonio L DoeSpainIoni Bowcher NEGOTIATION
Isabel B SlusarskiGermanyIoni Bowcher PROPOSAL
Kaitlin Q TollnerFranceElwin Sharvill NEW
Silvio F GillianCanadaAmy Elsner NEW
Izzy B GarufiIndiaAnna Fali UNQUALIFIED
Morrow W GauchoUnited KingdomBernardo Dominic UNQUALIFIED
Cody I InouyeArgentinaElwin Sharvill NEW
Ashley G RutaArgentinaAnna Fali PROPOSAL
Tony G MarrierUnited KingdomStephen Shaw NEGOTIATION
Emily S FlosiAustraliaElwin Sharvill NEW
Nicolas T TollnerBrazilAnna Fali NEW
Rodrigues W MarrierCanadaXuxue Feng NEW
Costa K FlosiRussiaAnna Fali PROPOSAL
Smith T IturbideBrazilAmy Elsner NEW
Maisha D BriddickItalyAmy Elsner QUALIFIED
Salvatore R FollerBrazilAnna Fali UNQUALIFIED
Ashley E WaycottBrazilAmy Elsner QUALIFIED
Aika X MacleadBrazilAnna Fali PROPOSAL
Clifford N DilliardFranceAnna Fali NEW
Claire M RutaSpainIoni Bowcher UNQUALIFIED
Darci T FlosiUnited KingdomIoni Bowcher NEW
Morrow B PerinJapanAmy Elsner NEGOTIATION
Darci G WieserJapanAsiya Javayant UNQUALIFIED
Kaitlin K StockhamAustraliaAnna Fali NEW
Greenwood J StensethArgentinaBernardo Dominic UNQUALIFIED
Julie D PaprockiGermanyAmy Elsner UNQUALIFIED
Ricardo N FlosiGermanyIvan Magalhaes PROPOSAL
Ricardo H OstroskyUnited KingdomBernardo Dominic NEW
Aruna K FollerArgentinaOnyama Limba QUALIFIED
Murillo F GillianIndiaAsiya Javayant NEW
Adams L GillianJapanAnna Fali QUALIFIED
Jeanfrancois J TollnerItalyAsiya Javayant PROPOSAL
Faith A AlbaresCanadaXuxue Feng UNQUALIFIED
Juan G MaletCanadaBernardo Dominic QUALIFIED
Ivar Y InouyeBrazilXuxue Feng RENEWAL
Izzy D ButtFranceAmy Elsner 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>