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 J SchemmerSpainAmy Elsner NEGOTIATION
Adams B RoysterSpainElwin Sharvill RENEWAL
Izzy M SchemmerGermanyAnna Fali PROPOSAL
Chavez Y RulapaughJapanAnna Fali PROPOSAL
Cody N ChuiFranceElwin Sharvill NEW
Sinclair R MaletAustraliaStephen Shaw PROPOSAL
Jennifer N MaletGermanyAsiya Javayant NEW
Ashley S InouyeBrazilOnyama Limba UNQUALIFIED
Jefferson I FigeroaUnited KingdomAmy Elsner RENEWAL
Aditya C RutaRussiaAmy Elsner RENEWAL
Morrow O RimItalyBernardo Dominic QUALIFIED
Isabel M MarrierRussiaAnna Fali NEW
Greenwood I ShinkoAustraliaElwin Sharvill UNQUALIFIED
Leja G WieserAustraliaBernardo Dominic QUALIFIED
Clifford X GarufiUnited KingdomAnna Fali NEW
Izzy L InouyeIndiaIvan Magalhaes PROPOSAL
Costa J VocelkaCanadaIvan Magalhaes NEW
Aruna F SaylorsUnited KingdomOnyama Limba UNQUALIFIED
Mujtaba D MarrierItalyAnna Fali UNQUALIFIED
Francesco D FollerCanadaXuxue Feng NEW
Morrow Q ShinkoIndiaXuxue Feng NEGOTIATION
Emily V StockhamJapanOnyama Limba QUALIFIED
Emily L WieserRussiaXuxue Feng QUALIFIED
Murillo M BriddickItalyIoni Bowcher RENEWAL
Deepesh H FollerSpainIoni Bowcher NEW
Clifford E InouyeAustraliaOnyama Limba UNQUALIFIED
Cody V MarrierUnited KingdomElwin Sharvill PROPOSAL
Morrow N CaudyCanadaAmy Elsner UNQUALIFIED
Leon G SaylorsArgentinaStephen Shaw RENEWAL
Isabel J DoeSpainIvan Magalhaes QUALIFIED
Johnson J BologniaSpainIvan Magalhaes NEW
Maisha B RutaArgentinaXuxue Feng NEW
Jennifer Y KuskoFranceAnna Fali RENEWAL
Deepesh O StockhamCanadaStephen Shaw PROPOSAL
Leon C ButtArgentinaBernardo Dominic QUALIFIED
Faith A FerenczItalyXuxue Feng QUALIFIED
Morrow Y VenereCanadaAsiya Javayant PROPOSAL
Mujtaba K MarrierItalyIoni Bowcher NEW
Darci H SaylorsJapanStephen Shaw NEW
Deepesh F AmigonArgentinaOnyama Limba PROPOSAL
Silvio C GauchoIndiaBernardo Dominic PROPOSAL
Smith W AlbaresSpainXuxue Feng PROPOSAL
Claire V ChuiAustraliaBernardo Dominic RENEWAL
Adams B CampainItalyBernardo Dominic RENEWAL
Izzy R FigeroaIndiaBernardo Dominic QUALIFIED
Morrow U SergiRussiaIoni Bowcher RENEWAL
Rodrigues S AlbaresBrazilIvan Magalhaes RENEWAL
Jones H RoysterArgentinaOnyama Limba UNQUALIFIED
David V KuskoIndiaAsiya Javayant QUALIFIED
Tony Z VocelkaAustraliaStephen Shaw RENEWAL
Horizontal
NameCountryRepresentativeStatus
Isabel S PoquetteRussiaXuxue Feng QUALIFIED
Jeanfrancois K OldroydItalyAnna Fali PROPOSAL
Smith I VenereSpainIoni Bowcher NEW
Stacey J SlusarskiBrazilBernardo Dominic PROPOSAL
James S SlusarskiSpainAsiya Javayant UNQUALIFIED
Wickens X CampainSpainBernardo Dominic UNQUALIFIED
Antonio S KuskoCanadaStephen Shaw PROPOSAL
Clifford P MaletGermanyBernardo Dominic UNQUALIFIED
Arvin Q BologniaIndiaOnyama Limba QUALIFIED
Chavez Z CaudyCanadaAnna Fali NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Aditya I StensethRussia2024-04-16Chapman, Ross E Esq NEW71Xuxue Feng
1001Ivar Z WieserArgentina2024-04-15Feiner Bros PROPOSAL16Elwin Sharvill
1002Costa H MorascaBrazil2024-04-01Feltz Printing Service UNQUALIFIED16Onyama Limba
1003Greenwood D DoeBrazil2024-04-02Chanay, Jeffrey A Esq PROPOSAL58Stephen Shaw
1004Stacey X WieserSpain2024-03-27Chanay, Jeffrey A Esq RENEWAL3Ivan Magalhaes
1005James Y VocelkaRussia2024-04-18Rangoni Of Florence UNQUALIFIED55Ioni Bowcher
1006Ivar Z MaletBrazil2024-04-24Chemel, James L Cpa RENEWAL78Ivan Magalhaes
1007Claire I OldroydGermany2024-04-24Morlong Associates NEW72Ivan Magalhaes
1008Ricardo F BriddickCanada2024-04-19Rousseaux, Michael Esq RENEWAL2Xuxue Feng
1009Aditya T BriddickSpain2024-03-26Commercial Press UNQUALIFIED3Stephen Shaw
1010Jefferson W OldroydBrazil2024-03-27Commercial Press RENEWAL2Amy Elsner
1011Kaitlin W CaldareraUnited Kingdom2024-04-14King, Christopher A Esq UNQUALIFIED93Asiya Javayant
1012Jeanfrancois Z DoeFrance2024-04-02Rousseaux, Michael Esq RENEWAL93Stephen Shaw
1013Silvio G OstroskyIndia2024-03-30Buckley Miller Wright UNQUALIFIED25Ivan Magalhaes
1014James P StockhamSpain2024-04-22Commercial Press QUALIFIED71Xuxue Feng
1015Chavez D WhobreyRussia2024-04-12Rangoni Of Florence UNQUALIFIED46Ioni Bowcher
1016Mujtaba B NickaArgentina2024-04-15Printing Dimensions NEGOTIATION93Ioni Bowcher
1017Aditya C MaletGermany2024-03-31Chanay, Jeffrey A Esq QUALIFIED83Ioni Bowcher
1018Kadeem G BriddickFrance2024-04-02Buckley Miller Wright NEGOTIATION25Bernardo Dominic
1019Chavez Y VocelkaGermany2024-04-13Feltz Printing Service QUALIFIED16Stephen Shaw
1020Claire W PaprockiAustralia2024-04-03Truhlar And Truhlar Attys UNQUALIFIED98Bernardo Dominic
1021Nicolas A NickaFrance2024-04-17Truhlar And Truhlar Attys RENEWAL81Onyama Limba
1022Smith E CaudyCanada2024-04-05Feltz Printing Service RENEWAL39Bernardo Dominic
1023Stacey V WhobreyBrazil2024-04-15Chemel, James L Cpa UNQUALIFIED97Asiya Javayant
1024Aika R SlusarskiJapan2024-03-31Commercial Press UNQUALIFIED42Elwin Sharvill
1025Ivar C VenereBrazil2024-04-14Chanay, Jeffrey A Esq PROPOSAL4Amy Elsner
1026Claire K SergiItaly2024-04-20Feltz Printing Service NEW96Asiya Javayant
1027Antonio D VocelkaFrance2024-04-08Rousseaux, Michael Esq NEGOTIATION16Onyama Limba
1028Murillo J GlickJapan2024-04-21Truhlar And Truhlar Attys NEW90Amy Elsner
1029Aruna X GillianRussia2024-04-21Feiner Bros RENEWAL20Bernardo Dominic
1030Rodrigues E VocelkaUnited Kingdom2024-04-17Feiner Bros PROPOSAL83Anna Fali
1031Jefferson G NestleSpain2024-04-08Commercial Press NEGOTIATION78Amy Elsner
1032Jeanfrancois H GlickUnited Kingdom2024-04-19Rangoni Of Florence QUALIFIED65Anna Fali
1033James G WieserFrance2024-03-29Rangoni Of Florence NEGOTIATION49Amy Elsner
1034Kaitlin F GlickUnited Kingdom2024-04-06Chemel, James L Cpa RENEWAL8Xuxue Feng
1035Jeanfrancois O WhobreySpain2024-04-17Morlong Associates NEGOTIATION0Onyama Limba
1036Aruna X AmigonAustralia2024-03-28Feltz Printing Service QUALIFIED46Asiya Javayant
1037Arvin S CaudyArgentina2024-04-23Feltz Printing Service PROPOSAL62Asiya Javayant
1038Murillo W PerinGermany2024-04-06Chemel, James L Cpa PROPOSAL95Bernardo Dominic
1039Murillo C StockhamGermany2024-04-09Buckley Miller Wright RENEWAL55Asiya Javayant
1040Aika N FollerFrance2024-04-12Printing Dimensions UNQUALIFIED15Asiya Javayant
1041Julie B StensethJapan2024-04-23Commercial Press PROPOSAL24Stephen Shaw
1042Kadeem I GauchoIndia2024-03-31Chemel, James L Cpa NEGOTIATION78Xuxue Feng
1043Antonio C SlusarskiFrance2024-03-28Commercial Press NEW61Ivan Magalhaes
1044Costa G FollerCanada2024-04-13Chapman, Ross E Esq NEGOTIATION65Onyama Limba
1045Leja W VocelkaGermany2024-04-09Rangoni Of Florence NEW53Onyama Limba
1046Izzy A KuskoBrazil2024-04-04Morlong Associates RENEWAL9Amy Elsner
1047Claire H WieserGermany2024-04-05Printing Dimensions NEGOTIATION60Elwin Sharvill
1048Jeanfrancois P GarufiGermany2024-04-09Rousseaux, Michael Esq UNQUALIFIED28Xuxue Feng
1049Rodrigues X OldroydFrance2024-04-19Dorl, James J Esq QUALIFIED76Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Deepesh L MaletUnited KingdomXuxue Feng QUALIFIED
Juan X FigeroaUnited KingdomOnyama Limba NEGOTIATION
Kadeem I RimGermanyAsiya Javayant PROPOSAL
Jeanfrancois F RimJapanElwin Sharvill NEW
Costa J GlickCanadaAmy Elsner RENEWAL
Munro G ShinkoBrazilOnyama Limba PROPOSAL
Stacey J PoquetteBrazilIoni Bowcher RENEWAL
Jefferson M PoquetteFranceOnyama Limba UNQUALIFIED
Aditya A MorascaAustraliaIoni Bowcher NEW
Murillo W VocelkaCanadaIvan Magalhaes UNQUALIFIED
Stacey W FlosiRussiaOnyama Limba NEGOTIATION
Wickens A SlusarskiRussiaAmy Elsner NEW
Stacey T SergiItalyIvan Magalhaes PROPOSAL
Jeanfrancois G SaylorsGermanyBernardo Dominic RENEWAL
Aika P PaprockiSpainBernardo Dominic NEGOTIATION
Mujtaba U SlusarskiJapanStephen Shaw QUALIFIED
Mujtaba B InouyeAustraliaElwin Sharvill QUALIFIED
Kaitlin T PaprockiSpainBernardo Dominic NEGOTIATION
Claire L GillianJapanBernardo Dominic QUALIFIED
Mayumi M KolmetzIndiaStephen Shaw NEGOTIATION
Munro X MarrierJapanXuxue Feng NEGOTIATION
Greenwood U CaudySpainAsiya Javayant NEW
Silvio Q DarakjyFranceIvan Magalhaes QUALIFIED
Mayumi Y FlosiUnited KingdomElwin Sharvill NEW
Antonio U OstroskyFranceAmy Elsner RENEWAL
James X SaylorsJapanXuxue Feng UNQUALIFIED
Jefferson M MacleadUnited KingdomAmy Elsner RENEWAL
Leon U GlickJapanAsiya Javayant RENEWAL
Cody A ChuiFranceIvan Magalhaes NEW
Munro N MarrierRussiaXuxue Feng QUALIFIED
Ashley S InouyeBrazilAnna Fali PROPOSAL
Julie Y ChuiArgentinaIvan Magalhaes NEGOTIATION
Murillo C NestleIndiaStephen Shaw NEW
Jones U BowleyJapanAsiya Javayant RENEWAL
Nicolas I StockhamJapanIvan Magalhaes NEGOTIATION
Maisha C SlusarskiFranceElwin Sharvill UNQUALIFIED
Jones B RimGermanyIvan Magalhaes NEW
Kaitlin M RoysterFranceXuxue Feng UNQUALIFIED
Greenwood G KuskoItalyAsiya Javayant PROPOSAL
Adams Z RutaJapanAsiya Javayant RENEWAL
David K PaprockiIndiaBernardo Dominic QUALIFIED
Chavez Y RoysterRussiaOnyama Limba QUALIFIED
James Z NickaArgentinaAmy Elsner NEW
Faith M RutaBrazilIoni Bowcher UNQUALIFIED
Stacey A GauchoAustraliaAnna Fali UNQUALIFIED
Cody S RimRussiaElwin Sharvill QUALIFIED
Alejandro M OldroydUnited KingdomBernardo Dominic UNQUALIFIED
Rodrigues G WaycottCanadaAmy Elsner RENEWAL
Misaki P WaycottBrazilAmy Elsner NEW
Darci W StockhamSpainElwin Sharvill RENEWAL
Frozen Columns
Name
David J Tollner
Nicolas J Stockham
Jefferson I Schemmer
Alejandro R Stenseth
Aika D Tollner
Leja H Darakjy
David K Kusko
Chavez V Morasca
Jennifer G Doe
Costa X Morasca
Morrow U Rulapaugh
Izzy Q Kusko
Ashley R Malet
Jeanfrancois Y Oldroyd
Alejandro M Gaucho
Rodrigues V Butt
Julie M Maclead
Cody A Doe
Maisha U Tollner
Kadeem E Sergi
Salvatore D Tollner
David I Bolognia
Adams M Kusko
Kaitlin E Sergi
Emily S Stockham
Salvatore H Stockham
Maria A Slusarski
Kaitlin O Garufi
Ashley V Caldarera
Wickens D Venere
Clifford W Saylors
Aruna K Gillian
Tony L Ostrosky
Kadeem I Dilliard
Aika L Ferencz
Silvio A Vocelka
Octavia Z Venere
Aruna M Bolognia
Mujtaba L Ferencz
Aika L Maclead
Salvatore G Ostrosky
Francesco O Rulapaugh
Aika I Inouye
Darci Z Rulapaugh
Cody A Poquette
Nicolas G Caldarera
James P Whobrey
Alejandro M Whobrey
Greenwood M Nestle
Claire C Bowley
IdCountryDate
1000Brazil2024-03-26
1001Spain2024-04-02
1002United Kingdom2024-03-29
1003France2024-04-11
1004Japan2024-04-15
1005Australia2024-03-31
1006Brazil2024-04-21
1007Russia2024-03-28
1008Germany2024-03-31
1009Argentina2024-04-10
1010Australia2024-04-17
1011Spain2024-03-28
1012Germany2024-03-31
1013Brazil2024-03-31
1014Russia2024-04-24
1015Brazil2024-04-07
1016United Kingdom2024-04-03
1017Spain2024-04-22
1018Germany2024-04-10
1019Japan2024-04-15
1020Russia2024-03-31
1021Italy2024-04-06
1022Spain2024-04-21
1023Brazil2024-04-12
1024Italy2024-04-04
1025Russia2024-04-18
1026France2024-04-24
1027India2024-04-06
1028Italy2024-04-02
1029Canada2024-04-24
1030Germany2024-04-14
1031France2024-04-21
1032Spain2024-04-10
1033India2024-04-03
1034India2024-04-17
1035Japan2024-04-08
1036United Kingdom2024-04-06
1037Brazil2024-04-06
1038India2024-04-18
1039Argentina2024-04-05
1040India2024-04-21
1041Italy2024-04-11
1042Japan2024-04-14
1043Spain2024-04-23
1044Spain2024-03-28
1045Japan2024-04-21
1046Russia2024-03-29
1047Australia2024-03-29
1048Spain2024-04-21
1049Canada2024-04-11

On-Demand Data

NameIdCountryDate
Jefferson Y Kolmetz1000France2024-04-15
Costa O Rim1001Italy2024-04-12
Greenwood E Shinko1002Japan2024-04-01
Wickens A Oldroyd1003Argentina2024-03-29
Mujtaba Z Ostrosky1004Spain2024-04-22
James B Garufi1005France2024-04-21
Julie O Stenseth1006India2024-04-07
James F Bolognia1007France2024-04-16
Jones G Venere1008Russia2024-04-24
Kaitlin I Perin1009France2024-03-28
Munro O Oldroyd1010Brazil2024-04-07
Francesco A Chui1011Italy2024-04-15
Nicolas S Tollner1012Italy2024-04-02
Salvatore Z Maclead1013Russia2024-03-28
Aditya S Sergi1014United Kingdom2024-04-20
Claire L Malet1015Germany2024-04-17
Arvin Q Dilliard1016Japan2024-03-27
Alejandro L Rim1017Russia2024-04-04
Emily R Foller1018Brazil2024-04-20
Aditya G Albares1019France2024-04-04
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Juan T BriddickFranceAmy Elsner NEW
Francesco B GauchoUnited KingdomStephen Shaw QUALIFIED
Cody F OldroydArgentinaStephen Shaw PROPOSAL
Aruna W RulapaughIndiaBernardo Dominic UNQUALIFIED
Deepesh G InouyeRussiaElwin Sharvill NEGOTIATION
Deepesh I RimArgentinaXuxue Feng NEGOTIATION
Maisha C CaudyBrazilIvan Magalhaes UNQUALIFIED
Jefferson T ShinkoRussiaAsiya Javayant UNQUALIFIED
Cody L StockhamRussiaIoni Bowcher RENEWAL
Darci M ButtFranceAsiya Javayant NEW
Ivar G CaudyCanadaElwin Sharvill PROPOSAL
Stacey K AlbaresJapanElwin Sharvill UNQUALIFIED
Claire R AmigonIndiaIoni Bowcher QUALIFIED
Arvin Z RimJapanStephen Shaw RENEWAL
Mayumi O KuskoItalyAmy Elsner PROPOSAL
Chavez Z MorascaSpainBernardo Dominic PROPOSAL
Rodrigues H ButtUnited KingdomOnyama Limba UNQUALIFIED
Aditya L WaycottSpainIoni Bowcher NEW
Jennifer V FerenczIndiaXuxue Feng RENEWAL
Ricardo C ShinkoJapanXuxue Feng QUALIFIED
Mayumi O DoeIndiaOnyama Limba NEW
Maisha U BowleyIndiaOnyama Limba NEGOTIATION
Tony X ButtArgentinaIvan Magalhaes UNQUALIFIED
Smith W GillianItalyAnna Fali PROPOSAL
Leja V FerenczGermanyAsiya Javayant UNQUALIFIED
Salvatore I ButtItalyIoni Bowcher NEW
Chavez S VenereItalyAnna Fali QUALIFIED
Ashley E OstroskySpainAnna Fali PROPOSAL
Silvio S SaylorsFranceStephen Shaw NEW
Faith J FigeroaRussiaAsiya Javayant RENEWAL
Jeanfrancois Z FlosiIndiaIvan Magalhaes RENEWAL
Francesco S GlickRussiaXuxue Feng RENEWAL
Ricardo Z RutaGermanyStephen Shaw NEGOTIATION
Julie J IturbideFranceXuxue Feng NEGOTIATION
Wickens B GauchoItalyXuxue Feng NEW
Mayumi X ChuiCanadaAnna Fali NEGOTIATION
Stacey K TollnerArgentinaIvan Magalhaes NEGOTIATION
Aditya P CaudyFranceAmy Elsner RENEWAL
Cody Z KolmetzRussiaAmy Elsner QUALIFIED
Faith B NestleItalyAnna Fali 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>