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
Silvio E MaletAustraliaIoni Bowcher NEW
Ashley U SlusarskiSpainIvan Magalhaes PROPOSAL
Aditya D VocelkaJapanElwin Sharvill NEGOTIATION
Arvin U CaldareraIndiaBernardo Dominic PROPOSAL
Ivar J RoysterCanadaAmy Elsner NEW
Darci H GlickUnited KingdomIoni Bowcher NEW
Jeanfrancois J SergiJapanBernardo Dominic QUALIFIED
Aruna N AlbaresGermanyOnyama Limba NEW
Jeanfrancois W RimRussiaStephen Shaw UNQUALIFIED
Morrow N MaletFranceElwin Sharvill RENEWAL
Clifford H PerinCanadaXuxue Feng QUALIFIED
Smith T CaudyRussiaElwin Sharvill QUALIFIED
Ivar P GauchoAustraliaAsiya Javayant UNQUALIFIED
Jennifer F GlickCanadaIoni Bowcher NEGOTIATION
Aika S InouyeCanadaAnna Fali UNQUALIFIED
Aditya L FlosiBrazilAnna Fali PROPOSAL
Darci D NickaArgentinaXuxue Feng NEGOTIATION
Octavia J RimRussiaAsiya Javayant NEGOTIATION
Ivar E KolmetzSpainElwin Sharvill NEGOTIATION
Wickens H WieserSpainStephen Shaw RENEWAL
Johnson Y OstroskyIndiaIoni Bowcher NEGOTIATION
Isabel W WaycottFranceAsiya Javayant QUALIFIED
Jennifer E PerinItalyElwin Sharvill RENEWAL
Maria E SchemmerCanadaAmy Elsner NEW
Silvio D ShinkoUnited KingdomStephen Shaw QUALIFIED
Maria Q DarakjyGermanyIvan Magalhaes UNQUALIFIED
Nicolas M MarrierItalyOnyama Limba QUALIFIED
Munro B StensethGermanyAsiya Javayant NEGOTIATION
Izzy D MarrierItalyAnna Fali RENEWAL
Ricardo F GlickCanadaAnna Fali UNQUALIFIED
Murillo U CaudyJapanOnyama Limba NEW
Tony V ButtSpainStephen Shaw PROPOSAL
Ashley L ButtUnited KingdomXuxue Feng QUALIFIED
Ashley N PoquetteJapanAnna Fali NEGOTIATION
Silvio C SergiFranceStephen Shaw QUALIFIED
Maria N KuskoArgentinaOnyama Limba UNQUALIFIED
Deepesh K FigeroaCanadaBernardo Dominic PROPOSAL
Chavez N CampainJapanAsiya Javayant NEW
Salvatore S WieserItalyOnyama Limba NEGOTIATION
Jones L AmigonRussiaAnna Fali UNQUALIFIED
Maisha C BologniaBrazilOnyama Limba PROPOSAL
Munro I PaprockiRussiaAmy Elsner NEGOTIATION
Misaki F ShinkoJapanStephen Shaw PROPOSAL
Maria Z OldroydCanadaAnna Fali PROPOSAL
James P RimGermanyAnna Fali PROPOSAL
Ivar N KuskoCanadaBernardo Dominic PROPOSAL
Antonio G SlusarskiAustraliaStephen Shaw QUALIFIED
Adams E MaletItalyStephen Shaw QUALIFIED
Salvatore Z ChuiAustraliaOnyama Limba NEGOTIATION
Jennifer Y IturbideFranceBernardo Dominic NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Costa F DarakjyAustraliaStephen Shaw PROPOSAL
Morrow B NickaItalyIoni Bowcher NEGOTIATION
Rodrigues H CampainJapanElwin Sharvill PROPOSAL
Nicolas G MarrierArgentinaIoni Bowcher QUALIFIED
Nicolas V DarakjySpainIvan Magalhaes RENEWAL
Darci U VenereCanadaIoni Bowcher NEGOTIATION
Kaitlin Z NickaUnited KingdomBernardo Dominic RENEWAL
Misaki X CaldareraItalyAmy Elsner RENEWAL
Claire H MaletBrazilIvan Magalhaes NEW
Stacey Q DarakjyBrazilXuxue Feng NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Nicolas R AlbaresBrazil2024-04-05Chemel, James L Cpa UNQUALIFIED76Onyama Limba
1001James Z BriddickArgentina2024-04-20Chapman, Ross E Esq RENEWAL94Stephen Shaw
1002Wickens H IturbideCanada2024-04-07Buckley Miller Wright NEGOTIATION48Asiya Javayant
1003Greenwood M ShinkoBrazil2024-04-21Chapman, Ross E Esq NEGOTIATION0Asiya Javayant
1004Maisha O OstroskyCanada2024-04-04Benton, John B Jr NEW37Anna Fali
1005Aditya D RutaSpain2024-04-17Rousseaux, Michael Esq NEGOTIATION23Anna Fali
1006Juan B RulapaughCanada2024-04-23King, Christopher A Esq RENEWAL98Onyama Limba
1007Faith C VocelkaSpain2024-04-23Chanay, Jeffrey A Esq UNQUALIFIED12Ioni Bowcher
1008Munro X SaylorsAustralia2024-04-27Buckley Miller Wright PROPOSAL45Elwin Sharvill
1009Maisha J FerenczCanada2024-04-22Feltz Printing Service PROPOSAL77Stephen Shaw
1010Sinclair B VocelkaCanada2024-04-30Rousseaux, Michael Esq QUALIFIED69Xuxue Feng
1011Darci W FerenczArgentina2024-04-26Dorl, James J Esq PROPOSAL12Bernardo Dominic
1012Cody R IturbideSpain2024-04-13Commercial Press NEGOTIATION86Bernardo Dominic
1013Silvio E GarufiAustralia2024-04-22Truhlar And Truhlar Attys NEW39Asiya Javayant
1014Francesco E KuskoFrance2024-04-22Feltz Printing Service NEGOTIATION15Ivan Magalhaes
1015Silvio Q CaudyBrazil2024-04-16Feiner Bros QUALIFIED25Anna Fali
1016Juan V BriddickRussia2024-04-08Rangoni Of Florence NEW44Anna Fali
1017Salvatore H WaycottArgentina2024-04-22Benton, John B Jr NEW60Ivan Magalhaes
1018Ivar M FigeroaAustralia2024-04-18Chanay, Jeffrey A Esq NEW83Onyama Limba
1019Ashley W VocelkaJapan2024-04-04Printing Dimensions NEW26Ivan Magalhaes
1020Julie U SergiArgentina2024-04-02Feltz Printing Service NEW19Asiya Javayant
1021David Z DoeJapan2024-04-03Benton, John B Jr NEW65Stephen Shaw
1022Costa F TollnerGermany2024-04-06Truhlar And Truhlar Attys PROPOSAL45Bernardo Dominic
1023David D AmigonItaly2024-04-11Chapman, Ross E Esq UNQUALIFIED56Ioni Bowcher
1024Ivar Q RutaUnited Kingdom2024-04-14Dorl, James J Esq NEGOTIATION31Ivan Magalhaes
1025Arvin R BologniaArgentina2024-04-16Dorl, James J Esq NEW62Ioni Bowcher
1026Rodrigues S KolmetzBrazil2024-04-25Morlong Associates QUALIFIED17Onyama Limba
1027Deepesh O VocelkaFrance2024-04-22Benton, John B Jr UNQUALIFIED42Ioni Bowcher
1028Kaitlin Y FollerFrance2024-04-03Rousseaux, Michael Esq NEW77Asiya Javayant
1029Emily C BriddickGermany2024-04-12Rousseaux, Michael Esq NEW13Onyama Limba
1030Aika P RoysterIndia2024-04-30Chemel, James L Cpa UNQUALIFIED66Xuxue Feng
1031Claire R ShinkoFrance2024-04-06Commercial Press RENEWAL92Asiya Javayant
1032Francesco C OldroydJapan2024-04-10Feltz Printing Service UNQUALIFIED66Ivan Magalhaes
1033Darci M FigeroaFrance2024-04-10Chemel, James L Cpa NEW34Stephen Shaw
1034Jones T CampainCanada2024-04-30Benton, John B Jr NEGOTIATION73Xuxue Feng
1035Maria D MaletFrance2024-04-30Rangoni Of Florence UNQUALIFIED47Ioni Bowcher
1036Nicolas Z WhobreyBrazil2024-04-19Chemel, James L Cpa PROPOSAL17Ivan Magalhaes
1037Stacey W AmigonFrance2024-04-05Truhlar And Truhlar Attys QUALIFIED76Stephen Shaw
1038Izzy P WieserRussia2024-04-30King, Christopher A Esq UNQUALIFIED82Ioni Bowcher
1039Morrow B RoysterUnited Kingdom2024-04-20Truhlar And Truhlar Attys NEGOTIATION49Elwin Sharvill
1040Smith D RulapaughUnited Kingdom2024-04-12Morlong Associates NEW9Stephen Shaw
1041Leon A GillianJapan2024-04-30Benton, John B Jr NEW35Stephen Shaw
1042James A MorascaUnited Kingdom2024-04-25Feltz Printing Service NEW36Xuxue Feng
1043Smith W ChuiJapan2024-04-15Rousseaux, Michael Esq NEGOTIATION52Bernardo Dominic
1044Greenwood G BriddickRussia2024-04-23Rangoni Of Florence UNQUALIFIED83Onyama Limba
1045Deepesh V AlbaresJapan2024-04-13Dorl, James J Esq UNQUALIFIED78Ivan Magalhaes
1046Arvin S MorascaAustralia2024-04-21Truhlar And Truhlar Attys UNQUALIFIED84Amy Elsner
1047Johnson C VocelkaItaly2024-04-06Printing Dimensions UNQUALIFIED55Bernardo Dominic
1048Jefferson E VocelkaGermany2024-04-29Dorl, James J Esq NEGOTIATION31Stephen Shaw
1049Arvin Q MorascaJapan2024-04-26Chemel, James L Cpa NEGOTIATION82Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Kaitlin W MaletUnited KingdomAsiya Javayant RENEWAL
Mayumi P OstroskyFranceAmy Elsner RENEWAL
Rodrigues S NestleItalyStephen Shaw RENEWAL
Jones X SergiIndiaIvan Magalhaes UNQUALIFIED
Jennifer U PoquetteIndiaIoni Bowcher PROPOSAL
Jennifer U VocelkaFranceAmy Elsner QUALIFIED
Aika J NickaArgentinaIoni Bowcher PROPOSAL
Alejandro U PaprockiArgentinaXuxue Feng PROPOSAL
Darci X OldroydFranceStephen Shaw PROPOSAL
James U FigeroaArgentinaOnyama Limba RENEWAL
Cody H FollerBrazilIvan Magalhaes UNQUALIFIED
Munro W GarufiCanadaIvan Magalhaes PROPOSAL
Ivar D StensethBrazilElwin Sharvill NEW
Ivar X DoeGermanyStephen Shaw QUALIFIED
Jefferson G PerinBrazilXuxue Feng NEW
Maria C ShinkoAustraliaStephen Shaw NEGOTIATION
Emily X AmigonAustraliaElwin Sharvill UNQUALIFIED
Kaitlin Z MorascaJapanIoni Bowcher PROPOSAL
Aditya B RutaAustraliaBernardo Dominic QUALIFIED
Mayumi B BriddickUnited KingdomElwin Sharvill NEGOTIATION
Leon Z FlosiFranceIoni Bowcher NEW
Aruna S AmigonBrazilElwin Sharvill UNQUALIFIED
Alejandro I NickaRussiaIvan Magalhaes RENEWAL
Misaki R MarrierIndiaIoni Bowcher UNQUALIFIED
Juan E MorascaBrazilBernardo Dominic NEGOTIATION
Octavia R SaylorsCanadaAnna Fali NEGOTIATION
Izzy O OstroskyArgentinaAnna Fali UNQUALIFIED
Smith L DilliardSpainIvan Magalhaes QUALIFIED
Kadeem N CampainUnited KingdomIoni Bowcher NEW
Misaki V PerinGermanyBernardo Dominic RENEWAL
Deepesh A FigeroaSpainIvan Magalhaes UNQUALIFIED
Misaki H VocelkaCanadaStephen Shaw PROPOSAL
Ivar V StockhamItalyStephen Shaw QUALIFIED
Jennifer T OldroydAustraliaIoni Bowcher PROPOSAL
Juan A AmigonJapanXuxue Feng PROPOSAL
Cody F SchemmerItalyOnyama Limba RENEWAL
Stacey Z ChuiSpainIvan Magalhaes NEW
Johnson L ShinkoArgentinaStephen Shaw QUALIFIED
Mayumi M TollnerUnited KingdomBernardo Dominic RENEWAL
Mujtaba B FlosiAustraliaElwin Sharvill NEGOTIATION
Emily A GlickGermanyBernardo Dominic NEW
Maisha I RimJapanAsiya Javayant UNQUALIFIED
Jefferson G MaletIndiaAsiya Javayant QUALIFIED
Smith U KolmetzAustraliaIvan Magalhaes RENEWAL
Nicolas O MaletIndiaIvan Magalhaes QUALIFIED
Juan L ShinkoItalyAmy Elsner QUALIFIED
Isabel G DarakjyItalyStephen Shaw NEGOTIATION
Jones U GauchoSpainAnna Fali RENEWAL
Izzy U GillianItalyAnna Fali QUALIFIED
Arvin D GlickFranceAnna Fali NEW
Frozen Columns
Name
Octavia U Gillian
Isabel J Chui
Cody P Vocelka
Darci M Tollner
Chavez L Poquette
Sinclair G Garufi
Maria Q Doe
Jefferson Q Oldroyd
Mayumi R Chui
Maria B Bolognia
Faith X Malet
Sinclair X Sergi
Misaki I Schemmer
Tony B Whobrey
Morrow W Doe
Leja J Malet
Claire Y Garufi
Octavia F Caldarera
Adams K Oldroyd
Misaki T Figeroa
Kadeem H Poquette
Kaitlin J Poquette
Clifford A Kusko
Izzy B Darakjy
Antonio S Paprocki
Aruna J Figeroa
Ashley K Saylors
Morrow K Doe
Kaitlin W Dilliard
Ricardo D Ostrosky
Aditya F Gaucho
Alejandro M Dilliard
Cody U Rulapaugh
Faith M Ostrosky
Leon W Amigon
Murillo W Wieser
Jennifer S Gillian
Antonio S Royster
Antonio U Kolmetz
Aditya D Paprocki
Faith C Kusko
Ashley O Rim
Juan V Shinko
Izzy V Kolmetz
Rodrigues H Dilliard
Smith Y Malet
Cody P Royster
Stacey S Stenseth
Emily Y Nicka
Jeanfrancois I Marrier
IdCountryDate
1000Russia2024-04-22
1001India2024-04-16
1002Germany2024-04-29
1003Russia2024-04-29
1004India2024-04-08
1005Italy2024-04-29
1006India2024-04-28
1007Canada2024-04-02
1008Japan2024-04-21
1009Russia2024-04-21
1010Australia2024-04-06
1011Argentina2024-04-15
1012Brazil2024-04-10
1013United Kingdom2024-04-02
1014United Kingdom2024-04-13
1015Italy2024-04-01
1016India2024-04-13
1017India2024-04-12
1018United Kingdom2024-04-16
1019Russia2024-04-06
1020Japan2024-04-23
1021Argentina2024-04-18
1022India2024-04-14
1023Argentina2024-04-04
1024Australia2024-04-25
1025France2024-04-03
1026Canada2024-04-07
1027Italy2024-04-14
1028Japan2024-04-14
1029India2024-04-12
1030Argentina2024-04-11
1031Canada2024-04-26
1032Spain2024-04-12
1033Argentina2024-04-10
1034United Kingdom2024-04-23
1035Australia2024-04-29
1036India2024-04-21
1037Canada2024-04-26
1038Japan2024-04-13
1039Russia2024-04-20
1040Brazil2024-04-27
1041India2024-04-17
1042Brazil2024-04-02
1043Italy2024-04-20
1044Russia2024-04-29
1045India2024-04-15
1046Italy2024-04-14
1047Australia2024-04-30
1048Argentina2024-04-14
1049Brazil2024-04-25

On-Demand Data

NameIdCountryDate
James F Foller1000Italy2024-04-18
Johnson M Ruta1001Spain2024-04-30
Francesco O Chui1002Brazil2024-04-14
Emily T Whobrey1003Spain2024-04-08
Smith U Inouye1004Spain2024-04-21
Rodrigues J Royster1005Spain2024-04-17
Deepesh L Stenseth1006Brazil2024-04-11
Adams V Ruta1007Argentina2024-04-15
David J Nestle1008Japan2024-04-16
Emily A Slusarski1009Japan2024-04-09
Mujtaba M Stenseth1010United Kingdom2024-04-17
Ashley U Flosi1011United Kingdom2024-04-03
Wickens A Ruta1012Italy2024-04-13
Mujtaba T Kusko1013Spain2024-04-25
Antonio A Nestle1014Argentina2024-04-09
Salvatore M Caudy1015France2024-04-06
Alejandro F Malet1016Japan2024-04-11
Leon Y Oldroyd1017India2024-04-10
Kaitlin L Whobrey1018Japan2024-04-17
Jennifer G Bolognia1019Canada2024-04-15
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Julie G VenereRussiaElwin Sharvill PROPOSAL
Munro C MacleadAustraliaElwin Sharvill RENEWAL
Kaitlin W StockhamGermanyStephen Shaw QUALIFIED
Jennifer W MaletGermanyBernardo Dominic NEW
Faith Z AmigonBrazilAmy Elsner QUALIFIED
Tony I DarakjyGermanyStephen Shaw QUALIFIED
Stacey E PerinGermanyOnyama Limba NEGOTIATION
Mayumi G ChuiItalyXuxue Feng QUALIFIED
Juan M NickaItalyAsiya Javayant NEGOTIATION
Costa X OldroydBrazilAmy Elsner QUALIFIED
Claire C DoeUnited KingdomIvan Magalhaes NEW
Johnson J WhobreyBrazilBernardo Dominic PROPOSAL
Maria H PoquetteRussiaAnna Fali NEGOTIATION
Mujtaba R KuskoIndiaAnna Fali PROPOSAL
Emily D ChuiArgentinaElwin Sharvill QUALIFIED
Juan F ButtUnited KingdomOnyama Limba PROPOSAL
Munro Y VocelkaRussiaElwin Sharvill PROPOSAL
Mujtaba M KolmetzJapanAsiya Javayant NEW
Costa G FigeroaUnited KingdomOnyama Limba PROPOSAL
Leja K AmigonFranceIvan Magalhaes RENEWAL
Adams G DilliardCanadaAmy Elsner NEW
Izzy J BriddickJapanElwin Sharvill RENEWAL
Sinclair V MorascaUnited KingdomIvan Magalhaes NEW
Salvatore A FlosiItalyAnna Fali RENEWAL
Jefferson Z DilliardFranceBernardo Dominic NEW
Leon M PoquetteRussiaAnna Fali NEGOTIATION
Faith L RimIndiaIoni Bowcher NEGOTIATION
Mujtaba G RutaAustraliaXuxue Feng NEW
Jones O MaletItalyBernardo Dominic PROPOSAL
Juan H FlosiCanadaStephen Shaw UNQUALIFIED
Murillo U DilliardRussiaOnyama Limba PROPOSAL
Aruna P OstroskyGermanyIvan Magalhaes NEGOTIATION
Jefferson U CampainCanadaIoni Bowcher NEGOTIATION
Clifford G SaylorsSpainElwin Sharvill NEW
Juan Z PerinBrazilAsiya Javayant QUALIFIED
Alejandro V BologniaRussiaStephen Shaw NEGOTIATION
Tony H FigeroaBrazilBernardo Dominic NEGOTIATION
Stacey B MaletUnited KingdomBernardo Dominic NEGOTIATION
James Z SaylorsIndiaIvan Magalhaes QUALIFIED
Maisha G PaprockiJapanBernardo Dominic NEW

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