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
Aika E NickaIndiaElwin Sharvill NEGOTIATION
Smith B ShinkoCanadaStephen Shaw RENEWAL
Silvio H OstroskyGermanyBernardo Dominic RENEWAL
Johnson M CampainItalyXuxue Feng NEW
Mayumi D VenereFranceIvan Magalhaes RENEWAL
Darci G GlickArgentinaOnyama Limba QUALIFIED
Mujtaba I KuskoGermanyAsiya Javayant QUALIFIED
Kaitlin D FerenczItalyIoni Bowcher PROPOSAL
Adams V CaudyFranceIoni Bowcher PROPOSAL
Adams R SlusarskiArgentinaElwin Sharvill UNQUALIFIED
Jones G ButtUnited KingdomStephen Shaw NEGOTIATION
Murillo F KuskoRussiaAmy Elsner QUALIFIED
Emily D FollerArgentinaIoni Bowcher UNQUALIFIED
Darci E OldroydAustraliaIvan Magalhaes QUALIFIED
Deepesh L BowleyRussiaXuxue Feng PROPOSAL
David K CampainAustraliaAsiya Javayant QUALIFIED
Faith V MorascaJapanElwin Sharvill NEW
Mujtaba Q MarrierAustraliaAmy Elsner QUALIFIED
Salvatore M OstroskyRussiaIvan Magalhaes UNQUALIFIED
Jefferson L GauchoArgentinaBernardo Dominic QUALIFIED
Cody U KolmetzFranceStephen Shaw QUALIFIED
Chavez E DilliardJapanIvan Magalhaes QUALIFIED
Munro F FerenczJapanAmy Elsner QUALIFIED
Ricardo F OstroskyRussiaXuxue Feng NEW
Clifford U IturbideCanadaAsiya Javayant RENEWAL
Kadeem B StensethBrazilElwin Sharvill UNQUALIFIED
Greenwood D MorascaIndiaStephen Shaw QUALIFIED
Isabel W PoquetteIndiaAnna Fali RENEWAL
Faith H MorascaRussiaAsiya Javayant NEGOTIATION
Deepesh S IturbideItalyAmy Elsner RENEWAL
Mujtaba I GlickJapanAmy Elsner NEGOTIATION
Salvatore V MaletBrazilIvan Magalhaes QUALIFIED
Murillo Z DilliardJapanBernardo Dominic PROPOSAL
Kadeem F SergiJapanOnyama Limba PROPOSAL
Maisha O PaprockiRussiaBernardo Dominic PROPOSAL
Antonio F GauchoJapanElwin Sharvill PROPOSAL
Jennifer S GarufiFranceAmy Elsner PROPOSAL
Tony U FollerSpainBernardo Dominic UNQUALIFIED
David F IturbideCanadaAnna Fali PROPOSAL
Wickens C GillianJapanElwin Sharvill RENEWAL
Johnson D BowleyFranceOnyama Limba PROPOSAL
Mujtaba I InouyeFranceIoni Bowcher RENEWAL
Maisha I GillianSpainStephen Shaw RENEWAL
Faith Q PoquetteAustraliaAsiya Javayant NEGOTIATION
Salvatore C WieserAustraliaBernardo Dominic QUALIFIED
Leja P FollerAustraliaAmy Elsner NEGOTIATION
Chavez X AmigonCanadaIoni Bowcher UNQUALIFIED
Aditya O RimAustraliaAnna Fali NEGOTIATION
Sinclair Y DarakjyBrazilAnna Fali PROPOSAL
Greenwood J TollnerUnited KingdomBernardo Dominic PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Munro P GauchoBrazilAsiya Javayant UNQUALIFIED
Isabel W IturbideAustraliaBernardo Dominic QUALIFIED
Kaitlin F PaprockiJapanElwin Sharvill UNQUALIFIED
Johnson K VocelkaRussiaOnyama Limba PROPOSAL
Francesco U BologniaUnited KingdomAmy Elsner QUALIFIED
Francesco Q VocelkaItalyOnyama Limba RENEWAL
James Y FerenczAustraliaOnyama Limba PROPOSAL
Antonio U RulapaughBrazilOnyama Limba UNQUALIFIED
Maria W DarakjyGermanyIvan Magalhaes NEGOTIATION
Wickens W StensethBrazilElwin Sharvill RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Kadeem S RimAustralia2024-04-03Printing Dimensions UNQUALIFIED45Asiya Javayant
1001Aruna B MaletRussia2024-04-17Printing Dimensions NEW9Anna Fali
1002James X FerenczSpain2024-04-23Benton, John B Jr UNQUALIFIED13Amy Elsner
1003Ivar J NickaIndia2024-04-09Printing Dimensions RENEWAL82Elwin Sharvill
1004Francesco Y MorascaItaly2024-04-01Commercial Press UNQUALIFIED92Asiya Javayant
1005Julie M OldroydBrazil2024-04-01Dorl, James J Esq UNQUALIFIED37Bernardo Dominic
1006Emily L DoeGermany2024-04-18Morlong Associates NEW70Ioni Bowcher
1007Silvio D CaldareraAustralia2024-04-11Buckley Miller Wright QUALIFIED11Xuxue Feng
1008Greenwood Z SaylorsAustralia2024-04-04Rangoni Of Florence NEW16Anna Fali
1009Kaitlin K AmigonAustralia2024-04-04Dorl, James J Esq PROPOSAL58Bernardo Dominic
1010Costa W IturbideSpain2024-04-11Chemel, James L Cpa UNQUALIFIED0Onyama Limba
1011Kaitlin O FollerGermany2024-04-13Feltz Printing Service NEW63Ioni Bowcher
1012Leja C StockhamAustralia2024-04-11Commercial Press NEW84Ivan Magalhaes
1013Jefferson Q FigeroaCanada2024-04-02Benton, John B Jr NEGOTIATION84Anna Fali
1014Claire B SergiJapan2024-04-01Benton, John B Jr UNQUALIFIED97Elwin Sharvill
1015Faith P RulapaughJapan2024-04-14Commercial Press NEGOTIATION57Amy Elsner
1016Faith F FollerArgentina2024-04-18Benton, John B Jr PROPOSAL10Onyama Limba
1017Murillo V BriddickUnited Kingdom2024-04-16Rousseaux, Michael Esq QUALIFIED61Ivan Magalhaes
1018Darci F MarrierJapan2024-04-23King, Christopher A Esq RENEWAL0Bernardo Dominic
1019Adams E CampainUnited Kingdom2024-04-21King, Christopher A Esq RENEWAL40Bernardo Dominic
1020James P SergiItaly2024-04-17Rangoni Of Florence UNQUALIFIED12Stephen Shaw
1021Faith Y GillianJapan2024-04-01Printing Dimensions PROPOSAL34Ivan Magalhaes
1022Aruna R MaletFrance2024-04-20Chemel, James L Cpa NEW87Ivan Magalhaes
1023Cody J RoysterAustralia2024-04-13King, Christopher A Esq RENEWAL76Stephen Shaw
1024Claire M CaudyItaly2024-04-10Dorl, James J Esq NEW57Anna Fali
1025Maria Q AmigonRussia2024-04-18Rangoni Of Florence QUALIFIED47Stephen Shaw
1026Cody M OldroydUnited Kingdom2024-04-02Benton, John B Jr QUALIFIED66Ioni Bowcher
1027Ivar E VenereFrance2024-04-03Morlong Associates RENEWAL45Onyama Limba
1028Morrow V WaycottAustralia2024-04-05King, Christopher A Esq QUALIFIED50Bernardo Dominic
1029James J StockhamRussia2024-04-23Morlong Associates NEW18Ivan Magalhaes
1030Jeanfrancois F SaylorsIndia2024-04-25Feiner Bros QUALIFIED31Amy Elsner
1031Cody C DoeSpain2024-03-27King, Christopher A Esq NEW60Ivan Magalhaes
1032Deepesh B ButtRussia2024-04-05Feiner Bros RENEWAL23Ioni Bowcher
1033Julie M WaycottSpain2024-04-23Buckley Miller Wright NEW89Elwin Sharvill
1034Aditya R InouyeCanada2024-04-14Feltz Printing Service UNQUALIFIED51Ioni Bowcher
1035Faith H FerenczGermany2024-04-15Feiner Bros NEGOTIATION30Stephen Shaw
1036Antonio N BowleySpain2024-03-31Benton, John B Jr UNQUALIFIED80Stephen Shaw
1037Chavez P GlickIndia2024-04-14Truhlar And Truhlar Attys QUALIFIED72Ioni Bowcher
1038Deepesh E MorascaCanada2024-04-19Feiner Bros NEGOTIATION15Stephen Shaw
1039Rodrigues F AlbaresCanada2024-04-21Dorl, James J Esq NEGOTIATION4Elwin Sharvill
1040Rodrigues H TollnerCanada2024-04-04Benton, John B Jr QUALIFIED79Anna Fali
1041Silvio F StockhamCanada2024-04-19Chemel, James L Cpa RENEWAL87Ioni Bowcher
1042Ashley D KuskoFrance2024-04-11Dorl, James J Esq NEGOTIATION33Stephen Shaw
1043Wickens T BowleySpain2024-04-02Morlong Associates RENEWAL88Ivan Magalhaes
1044Murillo U PoquetteFrance2024-04-14Dorl, James J Esq RENEWAL22Xuxue Feng
1045Aruna U VocelkaFrance2024-04-20Chanay, Jeffrey A Esq PROPOSAL67Ioni Bowcher
1046Juan M DilliardSpain2024-03-31Chanay, Jeffrey A Esq UNQUALIFIED38Xuxue Feng
1047Silvio A WieserItaly2024-04-24Buckley Miller Wright NEGOTIATION61Elwin Sharvill
1048Arvin P BowleyItaly2024-04-11Feltz Printing Service NEGOTIATION28Onyama Limba
1049Rodrigues J PaprockiJapan2024-04-14Rangoni Of Florence QUALIFIED25Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
Kadeem I BologniaBrazilOnyama Limba RENEWAL
Tony P KolmetzSpainIvan Magalhaes RENEWAL
Costa O TollnerIndiaIoni Bowcher RENEWAL
Faith O RimUnited KingdomBernardo Dominic QUALIFIED
Chavez K SergiBrazilAmy Elsner QUALIFIED
Juan Z GlickBrazilStephen Shaw QUALIFIED
Aika A SergiCanadaAmy Elsner NEGOTIATION
Mujtaba H WieserIndiaAnna Fali QUALIFIED
David S NickaBrazilAmy Elsner NEW
Julie B KolmetzFranceOnyama Limba UNQUALIFIED
Leja X SaylorsFranceXuxue Feng RENEWAL
Alejandro Z FigeroaAustraliaXuxue Feng NEGOTIATION
Jeanfrancois Z PaprockiArgentinaAnna Fali UNQUALIFIED
Aruna A AmigonIndiaElwin Sharvill NEGOTIATION
Johnson C SaylorsSpainIoni Bowcher NEW
Aditya I ButtItalyBernardo Dominic QUALIFIED
Aditya I FlosiGermanyElwin Sharvill RENEWAL
Aditya Y KolmetzRussiaAmy Elsner RENEWAL
Isabel W VenereArgentinaIvan Magalhaes PROPOSAL
Chavez S VocelkaArgentinaIoni Bowcher UNQUALIFIED
Tony N MarrierGermanyOnyama Limba PROPOSAL
Tony H NestleSpainIoni Bowcher NEW
Munro T NestleAustraliaIoni Bowcher NEW
Aditya K MaletCanadaIoni Bowcher QUALIFIED
Aditya D BriddickIndiaStephen Shaw NEW
Claire S GillianIndiaAmy Elsner NEW
Arvin S TollnerJapanOnyama Limba NEGOTIATION
Kadeem C MacleadBrazilOnyama Limba NEGOTIATION
Ashley K AmigonArgentinaAmy Elsner NEW
Costa W NestleRussiaAmy Elsner UNQUALIFIED
Chavez O DoeItalyOnyama Limba NEW
Morrow J AmigonSpainAnna Fali NEGOTIATION
Greenwood V BologniaIndiaIoni Bowcher QUALIFIED
Smith F ChuiSpainStephen Shaw NEGOTIATION
Ashley U MacleadCanadaAmy Elsner UNQUALIFIED
Sinclair A WhobreyIndiaBernardo Dominic QUALIFIED
Mayumi R WaycottAustraliaAsiya Javayant NEGOTIATION
Ricardo N DoeArgentinaElwin Sharvill NEW
Ashley A DarakjyItalyStephen Shaw NEW
Misaki W GauchoIndiaOnyama Limba PROPOSAL
Emily Y CaudyArgentinaAmy Elsner RENEWAL
Rodrigues Y IturbideJapanStephen Shaw NEGOTIATION
Mayumi Z FlosiUnited KingdomAsiya Javayant NEGOTIATION
Maisha C DoeIndiaAsiya Javayant PROPOSAL
Emily D WhobreyRussiaBernardo Dominic NEW
Ivar P VenereFranceAsiya Javayant NEGOTIATION
Ricardo I OstroskyRussiaAnna Fali PROPOSAL
Aditya Q GillianItalyElwin Sharvill UNQUALIFIED
Ricardo L RoysterIndiaXuxue Feng UNQUALIFIED
Emily Q RimAustraliaIoni Bowcher NEW
Frozen Columns
Name
Francesco P Venere
Jeanfrancois R Rim
Kaitlin G Glick
Jefferson E Caldarera
Ivar H Stockham
Salvatore Z Garufi
Nicolas I Rulapaugh
Misaki W Morasca
Morrow L Maclead
Misaki Z Doe
Tony U Stockham
James L Caudy
Faith U Rim
Jennifer L Nicka
Aika V Caldarera
Nicolas Z Gaucho
Juan Y Whobrey
Leja W Iturbide
Julie A Shinko
Alejandro L Rulapaugh
Deepesh A Malet
Silvio H Maclead
Arvin I Gillian
Silvio Y Sergi
Claire R Kusko
Silvio A Vocelka
Chavez F Vocelka
Alejandro P Albares
Misaki S Caldarera
Ivar S Malet
Morrow R Gillian
Maria G Tollner
Clifford X Venere
David U Albares
Leon Y Gaucho
Adams S Royster
Faith I Gaucho
Smith H Saylors
Clifford G Sergi
Greenwood V Rim
Salvatore V Dilliard
Tony Q Stenseth
Mujtaba J Ruta
Chavez T Venere
Deepesh B Ruta
Alejandro Y Waycott
Sinclair W Poquette
Salvatore M Stockham
Clifford W Bolognia
Kaitlin W Malet
IdCountryDate
1000Italy2024-04-01
1001Canada2024-04-02
1002Russia2024-04-10
1003Japan2024-04-07
1004France2024-04-22
1005Japan2024-04-14
1006Japan2024-04-24
1007Russia2024-03-29
1008Russia2024-04-20
1009Germany2024-04-15
1010Argentina2024-04-07
1011Brazil2024-04-16
1012Japan2024-04-06
1013France2024-04-18
1014Italy2024-04-09
1015Spain2024-03-28
1016Argentina2024-04-24
1017United Kingdom2024-04-20
1018Germany2024-04-08
1019France2024-04-20
1020Australia2024-03-28
1021Russia2024-04-18
1022Japan2024-04-03
1023Russia2024-04-17
1024France2024-04-15
1025Italy2024-03-27
1026France2024-03-29
1027Japan2024-03-29
1028Spain2024-04-18
1029Spain2024-04-21
1030Italy2024-03-30
1031Australia2024-04-01
1032Spain2024-04-10
1033Russia2024-04-16
1034Spain2024-03-31
1035Australia2024-04-21
1036Canada2024-04-04
1037Australia2024-04-04
1038Japan2024-04-13
1039Brazil2024-04-21
1040Argentina2024-03-29
1041France2024-04-03
1042Japan2024-04-09
1043United Kingdom2024-04-05
1044France2024-03-31
1045Argentina2024-04-16
1046Spain2024-04-05
1047United Kingdom2024-04-15
1048France2024-04-13
1049United Kingdom2024-04-02

On-Demand Data

NameIdCountryDate
Morrow U Kolmetz1000Russia2024-04-14
Aika Y Schemmer1001United Kingdom2024-04-12
Mujtaba H Rulapaugh1002Spain2024-04-22
Aruna B Stenseth1003Germany2024-04-12
Faith U Marrier1004Australia2024-04-20
Leja Z Foller1005Japan2024-04-21
Deepesh H Saylors1006Japan2024-04-01
Salvatore C Stenseth1007Japan2024-04-07
Jones F Slusarski1008Brazil2024-04-12
Chavez L Gillian1009Canada2024-04-12
Nicolas I Butt1010France2024-04-14
Aruna R Stockham1011France2024-04-13
Alejandro I Maclead1012Japan2024-04-21
Jones H Stenseth1013Brazil2024-04-09
Nicolas N Rulapaugh1014Russia2024-04-10
Morrow C Ferencz1015France2024-04-16
Emily Q Venere1016Germany2024-04-17
Leja U Chui1017Australia2024-04-03
Faith I Ferencz1018Japan2024-04-02
Cody I Bolognia1019Russia2024-03-27
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Jones F MarrierArgentinaBernardo Dominic QUALIFIED
Tony Q CaudyUnited KingdomAnna Fali NEGOTIATION
Arvin T NestleAustraliaXuxue Feng NEGOTIATION
Aika Y MaletAustraliaIvan Magalhaes NEW
Murillo D GarufiAustraliaXuxue Feng NEW
Izzy O NickaFranceAmy Elsner NEGOTIATION
Kaitlin N ShinkoAustraliaAmy Elsner NEGOTIATION
Leja T GarufiJapanXuxue Feng PROPOSAL
Jennifer Z TollnerFranceIvan Magalhaes RENEWAL
Sinclair E CaudyRussiaAmy Elsner RENEWAL
Maria V GillianFranceXuxue Feng NEW
Morrow W PoquetteIndiaBernardo Dominic QUALIFIED
Maisha T PaprockiItalyAmy Elsner PROPOSAL
Misaki C SlusarskiFranceElwin Sharvill UNQUALIFIED
Juan A StensethGermanyAmy Elsner QUALIFIED
Jefferson D WaycottSpainBernardo Dominic RENEWAL
Wickens Z BriddickSpainElwin Sharvill PROPOSAL
Julie R MacleadIndiaOnyama Limba RENEWAL
Ashley F SaylorsRussiaXuxue Feng QUALIFIED
Ricardo Z ButtSpainBernardo Dominic QUALIFIED
Jennifer K AlbaresRussiaAnna Fali UNQUALIFIED
Faith P WieserCanadaIvan Magalhaes QUALIFIED
David V WaycottRussiaBernardo Dominic QUALIFIED
Nicolas H VocelkaSpainAnna Fali NEW
Isabel Q StockhamJapanElwin Sharvill QUALIFIED
Morrow H WhobreyIndiaAsiya Javayant UNQUALIFIED
Mayumi I RimArgentinaAmy Elsner RENEWAL
Clifford O RoysterRussiaStephen Shaw PROPOSAL
Emily T FerenczAustraliaElwin Sharvill QUALIFIED
Misaki O MaletCanadaBernardo Dominic RENEWAL
Leja D RimAustraliaElwin Sharvill NEW
Misaki R DoeFranceAmy Elsner RENEWAL
Maria K FerenczArgentinaElwin Sharvill QUALIFIED
Claire D BriddickIndiaIvan Magalhaes QUALIFIED
Chavez D BowleyIndiaXuxue Feng UNQUALIFIED
Maisha T FlosiItalyBernardo Dominic NEGOTIATION
Emily U MaletSpainElwin Sharvill UNQUALIFIED
Leon Y ChuiBrazilIvan Magalhaes QUALIFIED
Cody O NickaArgentinaBernardo Dominic QUALIFIED
Kaitlin Y WhobreyItalyBernardo Dominic 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>