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
Ivar G GauchoGermanyAmy Elsner NEGOTIATION
Isabel P RimAustraliaElwin Sharvill NEW
Antonio Z MorascaCanadaIoni Bowcher QUALIFIED
Stacey P DoeFranceXuxue Feng RENEWAL
Faith K GauchoGermanyIvan Magalhaes NEW
Nicolas F KolmetzUnited KingdomBernardo Dominic PROPOSAL
Smith T BologniaGermanyIvan Magalhaes QUALIFIED
Leon I MaletBrazilAsiya Javayant UNQUALIFIED
Stacey U AmigonBrazilXuxue Feng NEW
James S StockhamSpainStephen Shaw RENEWAL
Aruna Z OstroskySpainXuxue Feng QUALIFIED
Nicolas T CaldareraFranceAsiya Javayant NEW
David V StockhamJapanIvan Magalhaes QUALIFIED
Arvin X IturbideIndiaElwin Sharvill NEGOTIATION
Sinclair U WhobreyIndiaXuxue Feng PROPOSAL
Wickens M FollerBrazilAmy Elsner PROPOSAL
David F KolmetzJapanXuxue Feng UNQUALIFIED
Kadeem F BowleyBrazilBernardo Dominic QUALIFIED
Darci R AmigonIndiaAsiya Javayant QUALIFIED
Nicolas L RimFranceAsiya Javayant RENEWAL
Arvin L GarufiFranceAsiya Javayant QUALIFIED
Ashley C NestleUnited KingdomXuxue Feng QUALIFIED
Kaitlin S AlbaresCanadaOnyama Limba QUALIFIED
Kadeem T OstroskyJapanAmy Elsner PROPOSAL
Adams Z BriddickBrazilIoni Bowcher UNQUALIFIED
Arvin O RulapaughCanadaStephen Shaw QUALIFIED
Octavia J MarrierRussiaElwin Sharvill NEW
Jeanfrancois H ChuiUnited KingdomBernardo Dominic NEGOTIATION
Francesco F IturbideAustraliaAsiya Javayant NEGOTIATION
Murillo U VenereUnited KingdomAmy Elsner QUALIFIED
Chavez I CaldareraItalyBernardo Dominic NEW
Ricardo D SlusarskiFranceElwin Sharvill NEGOTIATION
Kadeem V ShinkoArgentinaBernardo Dominic NEW
Stacey H AmigonFranceOnyama Limba RENEWAL
Greenwood K InouyeBrazilOnyama Limba NEW
Smith T FollerRussiaStephen Shaw PROPOSAL
Smith C ChuiIndiaAmy Elsner NEGOTIATION
Kadeem X MorascaSpainIvan Magalhaes NEGOTIATION
Ashley J DilliardJapanIoni Bowcher NEW
Misaki G StockhamAustraliaBernardo Dominic UNQUALIFIED
Jeanfrancois N BologniaItalyAsiya Javayant RENEWAL
Arvin Q CampainBrazilOnyama Limba UNQUALIFIED
Murillo O FlosiSpainElwin Sharvill UNQUALIFIED
Aika Z PoquetteSpainStephen Shaw NEGOTIATION
Maria H DarakjyArgentinaAmy Elsner NEW
Jennifer V ChuiArgentinaAnna Fali NEGOTIATION
Leon V NestleItalyElwin Sharvill NEW
Antonio G PoquetteIndiaOnyama Limba UNQUALIFIED
Jennifer S WaycottAustraliaAnna Fali QUALIFIED
Mayumi L CaudySpainAnna Fali RENEWAL
Horizontal
NameCountryRepresentativeStatus
Wickens A MorascaRussiaOnyama Limba RENEWAL
Misaki U FerenczArgentinaOnyama Limba QUALIFIED
Octavia S NestleSpainIoni Bowcher PROPOSAL
Nicolas Y DarakjyAustraliaBernardo Dominic PROPOSAL
Morrow S CaudySpainIoni Bowcher RENEWAL
Arvin Q RutaGermanyXuxue Feng NEW
Salvatore R GillianItalyStephen Shaw UNQUALIFIED
Faith U ShinkoJapanBernardo Dominic PROPOSAL
Jefferson J GauchoIndiaStephen Shaw UNQUALIFIED
Darci A NickaUnited KingdomIvan Magalhaes NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Isabel L ChuiUnited Kingdom2024-03-30Buckley Miller Wright NEW11Ivan Magalhaes
1001Julie S PoquetteJapan2024-04-14Morlong Associates NEGOTIATION2Bernardo Dominic
1002Deepesh D KuskoItaly2024-03-28Chemel, James L Cpa PROPOSAL90Asiya Javayant
1003Isabel D GillianArgentina2024-03-27Commercial Press PROPOSAL40Anna Fali
1004Smith W ShinkoIndia2024-03-31Rangoni Of Florence PROPOSAL87Xuxue Feng
1005Deepesh K PaprockiGermany2024-04-14Commercial Press RENEWAL24Ivan Magalhaes
1006Emily B IturbideFrance2024-04-19Dorl, James J Esq RENEWAL6Ivan Magalhaes
1007Maisha V MaletItaly2024-04-06Commercial Press QUALIFIED3Bernardo Dominic
1008Antonio G GarufiGermany2024-04-01Chapman, Ross E Esq PROPOSAL4Bernardo Dominic
1009Isabel O FerenczUnited Kingdom2024-04-07Rangoni Of Florence RENEWAL64Asiya Javayant
1010Claire H FigeroaItaly2024-04-02Feltz Printing Service NEW72Xuxue Feng
1011Aika E FigeroaIndia2024-04-22Buckley Miller Wright UNQUALIFIED40Stephen Shaw
1012Salvatore U DilliardSpain2024-04-23Rangoni Of Florence NEGOTIATION45Ioni Bowcher
1013Silvio S RimIndia2024-04-20Chemel, James L Cpa RENEWAL76Elwin Sharvill
1014Adams M OldroydRussia2024-04-11Truhlar And Truhlar Attys RENEWAL93Stephen Shaw
1015James B NestleArgentina2024-04-05Printing Dimensions PROPOSAL96Elwin Sharvill
1016Wickens A SlusarskiJapan2024-04-23Chapman, Ross E Esq RENEWAL35Onyama Limba
1017Aika Y StockhamGermany2024-04-11Feltz Printing Service QUALIFIED83Anna Fali
1018Greenwood E MaletBrazil2024-04-09Rangoni Of Florence QUALIFIED64Xuxue Feng
1019Clifford H FigeroaIndia2024-04-09Chapman, Ross E Esq UNQUALIFIED81Xuxue Feng
1020Ricardo Q GlickUnited Kingdom2024-04-05Dorl, James J Esq NEW11Ivan Magalhaes
1021Aditya B NestleUnited Kingdom2024-04-14Commercial Press PROPOSAL87Xuxue Feng
1022Greenwood W CampainJapan2024-04-24Dorl, James J Esq UNQUALIFIED30Asiya Javayant
1023Kadeem G ButtItaly2024-04-07Dorl, James J Esq RENEWAL50Amy Elsner
1024Misaki Y BowleyArgentina2024-03-28Rangoni Of Florence RENEWAL58Ioni Bowcher
1025Jones H RulapaughJapan2024-04-09Chanay, Jeffrey A Esq NEW60Xuxue Feng
1026Smith L DilliardIndia2024-03-28Chanay, Jeffrey A Esq QUALIFIED96Amy Elsner
1027Murillo Q VocelkaUnited Kingdom2024-03-29Chanay, Jeffrey A Esq NEW49Asiya Javayant
1028Maria Y CampainFrance2024-03-31Dorl, James J Esq NEW19Anna Fali
1029Clifford W BologniaRussia2024-04-18Feiner Bros UNQUALIFIED34Stephen Shaw
1030Antonio Y PaprockiArgentina2024-04-15Benton, John B Jr PROPOSAL43Elwin Sharvill
1031Sinclair T AmigonIndia2024-04-07Chanay, Jeffrey A Esq UNQUALIFIED42Elwin Sharvill
1032Greenwood K OldroydRussia2024-04-22Dorl, James J Esq PROPOSAL35Ivan Magalhaes
1033Kaitlin I GarufiGermany2024-04-21Feltz Printing Service NEGOTIATION13Amy Elsner
1034Claire U DarakjyAustralia2024-04-20Feltz Printing Service NEGOTIATION28Elwin Sharvill
1035Costa K WieserFrance2024-04-21Commercial Press UNQUALIFIED36Amy Elsner
1036Francesco E IturbideGermany2024-04-01Truhlar And Truhlar Attys RENEWAL86Bernardo Dominic
1037Jones H TollnerSpain2024-04-04Commercial Press NEGOTIATION71Anna Fali
1038Emily Y IturbideAustralia2024-04-05Truhlar And Truhlar Attys PROPOSAL93Asiya Javayant
1039Jones I RimItaly2024-04-25Feltz Printing Service RENEWAL89Amy Elsner
1040Cody I SaylorsAustralia2024-04-04Benton, John B Jr PROPOSAL51Elwin Sharvill
1041David M FollerSpain2024-04-13Benton, John B Jr NEW30Stephen Shaw
1042Juan F SlusarskiAustralia2024-04-01Chanay, Jeffrey A Esq UNQUALIFIED84Onyama Limba
1043Ivar E SaylorsItaly2024-04-22Feltz Printing Service NEGOTIATION3Xuxue Feng
1044Adams R DoeJapan2024-04-11Buckley Miller Wright QUALIFIED43Bernardo Dominic
1045Johnson M FlosiArgentina2024-04-09Morlong Associates NEW29Asiya Javayant
1046Claire L TollnerItaly2024-04-23Chemel, James L Cpa RENEWAL63Bernardo Dominic
1047Greenwood L GillianIndia2024-04-01Chanay, Jeffrey A Esq NEGOTIATION87Amy Elsner
1048Salvatore Z ShinkoSpain2024-04-03Rousseaux, Michael Esq QUALIFIED16Elwin Sharvill
1049Darci G SchemmerSpain2024-04-18Truhlar And Truhlar Attys RENEWAL26Ioni Bowcher
Frozen Rows
NameCountryRepresentativeStatus
Isabel O MarrierItalyAnna Fali NEW
Alejandro M GarufiRussiaAnna Fali NEW
Chavez F GillianFranceStephen Shaw NEW
Juan Q GillianJapanOnyama Limba UNQUALIFIED
Aditya F FlosiBrazilOnyama Limba RENEWAL
Cody N MacleadIndiaAnna Fali NEW
Murillo J GlickFranceAsiya Javayant NEW
James X CaldareraCanadaIoni Bowcher NEW
Leon S BologniaSpainBernardo Dominic RENEWAL
Juan K OstroskyBrazilAsiya Javayant QUALIFIED
Mayumi P KolmetzUnited KingdomElwin Sharvill RENEWAL
Alejandro V DilliardJapanIvan Magalhaes PROPOSAL
Costa F RimGermanyAsiya Javayant QUALIFIED
Mayumi C SergiSpainIoni Bowcher PROPOSAL
Deepesh X BriddickBrazilStephen Shaw UNQUALIFIED
Mujtaba I ChuiArgentinaOnyama Limba RENEWAL
Claire C MaletArgentinaBernardo Dominic RENEWAL
Jefferson T VocelkaFranceBernardo Dominic UNQUALIFIED
Munro U SlusarskiItalyStephen Shaw QUALIFIED
Misaki Z StensethIndiaIvan Magalhaes NEGOTIATION
Wickens H BowleyIndiaAnna Fali QUALIFIED
Octavia F SergiRussiaAnna Fali NEW
Isabel Y TollnerItalyOnyama Limba NEGOTIATION
Mayumi L RulapaughArgentinaBernardo Dominic PROPOSAL
Isabel I RulapaughIndiaBernardo Dominic RENEWAL
Faith Y OldroydAustraliaIoni Bowcher QUALIFIED
James K WaycottItalyStephen Shaw PROPOSAL
Jennifer B DilliardBrazilAnna Fali RENEWAL
Misaki L GillianJapanBernardo Dominic NEW
Stacey Q SaylorsArgentinaXuxue Feng NEW
Clifford J DarakjyGermanyAnna Fali PROPOSAL
Leja B WieserIndiaAsiya Javayant RENEWAL
Rodrigues Z PaprockiCanadaIvan Magalhaes QUALIFIED
Ivar N FigeroaItalyAsiya Javayant NEGOTIATION
Arvin T DarakjySpainStephen Shaw NEW
Jennifer S GarufiCanadaOnyama Limba NEW
Ivar S WaycottGermanyOnyama Limba NEW
Tony H VocelkaJapanStephen Shaw QUALIFIED
Mujtaba J VocelkaIndiaAsiya Javayant PROPOSAL
Francesco H WieserIndiaStephen Shaw RENEWAL
Mayumi P ButtJapanAmy Elsner NEW
Kaitlin O IturbideRussiaElwin Sharvill NEGOTIATION
Stacey Z BriddickItalyIvan Magalhaes QUALIFIED
Jones N RimFranceBernardo Dominic PROPOSAL
Aruna I StensethGermanyAnna Fali NEW
Jefferson A KolmetzAustraliaIvan Magalhaes NEW
Izzy L GarufiAustraliaAmy Elsner NEW
Johnson I CaldareraItalyIvan Magalhaes NEGOTIATION
Antonio T CaldareraGermanyXuxue Feng UNQUALIFIED
Leon S RulapaughBrazilOnyama Limba NEGOTIATION
Frozen Columns
Name
Juan S Butt
Stacey N Marrier
Mayumi I Bowley
Misaki W Ruta
Costa P Venere
Jeanfrancois M Schemmer
Kadeem I Chui
Jeanfrancois T Butt
Munro N Ferencz
David A Stenseth
Nicolas Y Garufi
Rodrigues P Flosi
Emily W Sergi
Wickens P Stenseth
Ivar G Venere
Rodrigues M Doe
Alejandro L Darakjy
Darci D Stenseth
Kadeem V Malet
Nicolas V Vocelka
Ashley H Vocelka
Maisha G Chui
Aika N Inouye
Morrow K Bolognia
David F Shinko
Antonio S Tollner
Mayumi B Kusko
Murillo W Morasca
Cody C Paprocki
Mujtaba X Wieser
Silvio G Marrier
David Y Vocelka
Johnson D Marrier
Aditya B Iturbide
Sinclair E Morasca
Chavez A Saylors
Munro Y Paprocki
Juan R Butt
Maisha J Morasca
Chavez H Ferencz
Misaki R Chui
Darci R Doe
Isabel W Bolognia
Mujtaba H Nestle
Munro I Dilliard
Kadeem R Flosi
Misaki C Morasca
Adams A Ruta
Chavez U Perin
Ashley F Maclead
IdCountryDate
1000Japan2024-04-20
1001Brazil2024-04-17
1002France2024-03-27
1003United Kingdom2024-04-20
1004Brazil2024-04-23
1005Germany2024-04-01
1006France2024-04-09
1007Japan2024-04-01
1008Spain2024-04-02
1009Spain2024-04-05
1010Spain2024-04-07
1011Canada2024-04-13
1012United Kingdom2024-04-08
1013Australia2024-04-15
1014Italy2024-04-14
1015France2024-03-30
1016Spain2024-04-24
1017Japan2024-04-22
1018Japan2024-03-27
1019Germany2024-04-18
1020Brazil2024-04-06
1021Canada2024-03-30
1022Italy2024-03-31
1023Germany2024-03-29
1024France2024-04-15
1025Argentina2024-04-02
1026France2024-03-29
1027Italy2024-04-13
1028United Kingdom2024-04-08
1029Japan2024-04-21
1030Canada2024-04-04
1031United Kingdom2024-03-27
1032Australia2024-03-30
1033Germany2024-04-20
1034Canada2024-03-30
1035Italy2024-03-29
1036Germany2024-04-08
1037Argentina2024-04-04
1038Italy2024-04-05
1039Brazil2024-04-19
1040Russia2024-04-16
1041France2024-04-22
1042Russia2024-04-12
1043Russia2024-04-09
1044Russia2024-04-14
1045United Kingdom2024-04-17
1046United Kingdom2024-04-05
1047Russia2024-04-04
1048Italy2024-04-01
1049Japan2024-04-10

On-Demand Data

NameIdCountryDate
Sinclair H Albares1000Brazil2024-03-28
Sinclair J Caldarera1001France2024-04-25
Faith D Paprocki1002United Kingdom2024-03-30
Smith H Figeroa1003Australia2024-04-22
Leja V Figeroa1004Russia2024-04-09
Kaitlin U Nestle1005Germany2024-04-11
Aruna A Dilliard1006Japan2024-04-19
Morrow T Sergi1007India2024-04-04
Costa Z Glick1008Canada2024-04-20
Jennifer U Albares1009Australia2024-03-29
Murillo Q Ruta1010Italy2024-04-01
Julie M Shinko1011Russia2024-04-07
Morrow I Stockham1012France2024-04-10
Stacey W Inouye1013United Kingdom2024-04-25
Maisha Z Waycott1014Canada2024-04-17
Aruna C Malet1015India2024-03-27
Arvin N Gillian1016Argentina2024-04-25
Silvio H Sergi1017India2024-04-23
Johnson D Ferencz1018United Kingdom2024-04-25
Juan B Schemmer1019United Kingdom2024-04-18
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Salvatore R ShinkoRussiaIvan Magalhaes PROPOSAL
Tony C GlickGermanyIvan Magalhaes QUALIFIED
Maisha I GauchoRussiaAmy Elsner PROPOSAL
Munro F VocelkaItalyAnna Fali RENEWAL
Murillo X FigeroaCanadaAnna Fali UNQUALIFIED
Chavez D KuskoFranceOnyama Limba RENEWAL
Rodrigues V WieserAustraliaOnyama Limba RENEWAL
Stacey R RimArgentinaAnna Fali QUALIFIED
Smith U AlbaresArgentinaAsiya Javayant UNQUALIFIED
Mujtaba U WieserGermanyAnna Fali RENEWAL
Leja N SlusarskiIndiaAsiya Javayant UNQUALIFIED
Munro R WhobreyAustraliaStephen Shaw NEW
Sinclair E VenereSpainAmy Elsner NEGOTIATION
Sinclair A BriddickBrazilXuxue Feng RENEWAL
Maisha M ShinkoCanadaXuxue Feng RENEWAL
Faith L ShinkoArgentinaStephen Shaw NEGOTIATION
Alejandro U ShinkoUnited KingdomXuxue Feng QUALIFIED
Ivar C FigeroaAustraliaIoni Bowcher NEW
Greenwood D VenereBrazilElwin Sharvill QUALIFIED
Jeanfrancois P OldroydIndiaIoni Bowcher PROPOSAL
Julie N DilliardRussiaElwin Sharvill NEGOTIATION
Cody Z SergiArgentinaIvan Magalhaes PROPOSAL
Chavez B GillianSpainOnyama Limba PROPOSAL
Adams E DoeItalyAnna Fali QUALIFIED
Murillo G BriddickRussiaAmy Elsner PROPOSAL
Jefferson T ButtRussiaAsiya Javayant NEW
Emily O VocelkaSpainStephen Shaw NEW
Francesco U DarakjyJapanIvan Magalhaes QUALIFIED
Mujtaba B StensethRussiaAsiya Javayant NEW
Rodrigues N RutaArgentinaBernardo Dominic NEW
Octavia T FollerAustraliaIoni Bowcher QUALIFIED
Cody V ChuiGermanyOnyama Limba UNQUALIFIED
Murillo V NestleIndiaAmy Elsner PROPOSAL
Jennifer U ShinkoFranceBernardo Dominic RENEWAL
Antonio K ShinkoGermanyElwin Sharvill NEGOTIATION
Adams V RulapaughBrazilAnna Fali QUALIFIED
Sinclair Q NickaIndiaOnyama Limba RENEWAL
Faith W AlbaresJapanBernardo Dominic NEW
Mayumi N PerinUnited KingdomBernardo Dominic UNQUALIFIED
Wickens I DarakjyFranceAsiya Javayant 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>