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
Nicolas B DarakjyAustraliaIvan Magalhaes PROPOSAL
David Z FlosiBrazilOnyama Limba NEGOTIATION
Alejandro Y SergiUnited KingdomIoni Bowcher NEGOTIATION
Greenwood Q InouyeBrazilXuxue Feng QUALIFIED
Cody M BowleyUnited KingdomIoni Bowcher NEGOTIATION
Leon N GillianFranceAmy Elsner UNQUALIFIED
Stacey O BowleyArgentinaElwin Sharvill UNQUALIFIED
Rodrigues N MacleadGermanyElwin Sharvill QUALIFIED
Kaitlin C IturbideSpainStephen Shaw NEW
Arvin A GlickSpainStephen Shaw UNQUALIFIED
Arvin E RimCanadaStephen Shaw UNQUALIFIED
Johnson T CaldareraUnited KingdomStephen Shaw NEGOTIATION
Mayumi B FlosiJapanStephen Shaw NEGOTIATION
Smith H BowleyArgentinaXuxue Feng QUALIFIED
Johnson H RoysterFranceAsiya Javayant RENEWAL
Mujtaba S PaprockiAustraliaIoni Bowcher QUALIFIED
Claire N StockhamArgentinaStephen Shaw PROPOSAL
Nicolas E MaletCanadaIoni Bowcher PROPOSAL
Munro I WaycottJapanIoni Bowcher UNQUALIFIED
Mujtaba J WieserGermanyOnyama Limba PROPOSAL
Adams D MaletUnited KingdomStephen Shaw PROPOSAL
Rodrigues F VenereGermanyOnyama Limba NEGOTIATION
David T IturbideFranceAsiya Javayant NEW
Julie K GarufiGermanyStephen Shaw RENEWAL
Chavez S PerinSpainXuxue Feng RENEWAL
Stacey P MacleadCanadaElwin Sharvill RENEWAL
Ricardo G NickaIndiaElwin Sharvill RENEWAL
Faith F DilliardItalyBernardo Dominic NEGOTIATION
Julie M GarufiUnited KingdomAsiya Javayant UNQUALIFIED
Silvio D VenereJapanIvan Magalhaes NEW
Smith Q PaprockiSpainStephen Shaw NEGOTIATION
Adams M ButtUnited KingdomAmy Elsner PROPOSAL
Johnson D FollerBrazilIvan Magalhaes RENEWAL
Kadeem K GlickGermanyIoni Bowcher PROPOSAL
Salvatore W GarufiArgentinaOnyama Limba RENEWAL
Claire W DilliardSpainAsiya Javayant UNQUALIFIED
Mujtaba D MorascaSpainAmy Elsner QUALIFIED
Cody K KolmetzJapanAsiya Javayant QUALIFIED
Clifford N StockhamGermanyBernardo Dominic QUALIFIED
Kadeem P GarufiSpainStephen Shaw RENEWAL
Faith F TollnerCanadaAsiya Javayant PROPOSAL
Arvin G AlbaresArgentinaAmy Elsner NEW
Antonio R SlusarskiItalyIoni Bowcher NEGOTIATION
Morrow F FigeroaCanadaElwin Sharvill RENEWAL
Antonio N NestleSpainStephen Shaw UNQUALIFIED
Cody N WaycottJapanAsiya Javayant UNQUALIFIED
Morrow C RulapaughRussiaIvan Magalhaes PROPOSAL
Stacey T DoeJapanBernardo Dominic NEW
Silvio U AmigonItalyOnyama Limba RENEWAL
Clifford K MorascaItalyElwin Sharvill NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Maisha R DilliardGermanyBernardo Dominic PROPOSAL
Costa F NickaAustraliaXuxue Feng NEW
Emily J DoeCanadaAnna Fali RENEWAL
Jennifer X PaprockiGermanyElwin Sharvill RENEWAL
Isabel U MarrierArgentinaBernardo Dominic NEW
Chavez N DoeRussiaElwin Sharvill RENEWAL
Darci J PoquetteBrazilStephen Shaw NEGOTIATION
Deepesh P RutaIndiaXuxue Feng QUALIFIED
Kaitlin H GlickRussiaAsiya Javayant NEGOTIATION
Sinclair R AmigonIndiaAmy Elsner QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000David W BriddickGermany2024-04-10Feiner Bros QUALIFIED4Onyama Limba
1001Claire U BologniaGermany2024-04-09Rangoni Of Florence PROPOSAL48Xuxue Feng
1002Ashley H ShinkoBrazil2024-03-31Chapman, Ross E Esq UNQUALIFIED34Elwin Sharvill
1003Tony C GillianFrance2024-04-02Chemel, James L Cpa UNQUALIFIED47Asiya Javayant
1004Jennifer A NickaAustralia2024-04-04Truhlar And Truhlar Attys PROPOSAL34Asiya Javayant
1005Maisha G BowleyRussia2024-04-25Morlong Associates PROPOSAL33Ioni Bowcher
1006Sinclair O StockhamAustralia2024-04-28Chapman, Ross E Esq PROPOSAL88Bernardo Dominic
1007Rodrigues O VocelkaRussia2024-04-24Chapman, Ross E Esq NEGOTIATION69Asiya Javayant
1008Johnson D MaletCanada2024-03-31Chanay, Jeffrey A Esq NEGOTIATION94Onyama Limba
1009James Q VenereSpain2024-04-19Rangoni Of Florence NEW37Onyama Limba
1010Juan W VocelkaJapan2024-04-18Morlong Associates PROPOSAL78Xuxue Feng
1011Sinclair M SchemmerBrazil2024-04-15Chanay, Jeffrey A Esq QUALIFIED74Onyama Limba
1012Rodrigues M CaldareraUnited Kingdom2024-04-20Dorl, James J Esq UNQUALIFIED57Anna Fali
1013Ashley U PerinCanada2024-04-25Commercial Press RENEWAL11Anna Fali
1014Murillo Q TollnerItaly2024-04-15Rangoni Of Florence UNQUALIFIED45Ioni Bowcher
1015Leja W DilliardFrance2024-04-24Buckley Miller Wright NEW0Bernardo Dominic
1016Misaki C GlickBrazil2024-04-27Buckley Miller Wright NEGOTIATION84Bernardo Dominic
1017Munro A DarakjyGermany2024-04-24Rangoni Of Florence RENEWAL23Asiya Javayant
1018Aika X TollnerCanada2024-04-24Feiner Bros NEW74Amy Elsner
1019Leon B CaudyJapan2024-04-25Chapman, Ross E Esq NEGOTIATION39Onyama Limba
1020Leon I SaylorsSpain2024-03-30Dorl, James J Esq UNQUALIFIED94Elwin Sharvill
1021Kadeem O GlickArgentina2024-04-14Chemel, James L Cpa UNQUALIFIED24Amy Elsner
1022Nicolas E NickaCanada2024-04-23Rangoni Of Florence NEW18Elwin Sharvill
1023Maria J SlusarskiSpain2024-04-28Rousseaux, Michael Esq QUALIFIED95Anna Fali
1024Costa S KolmetzCanada2024-04-12Rangoni Of Florence NEW61Asiya Javayant
1025Adams P ChuiBrazil2024-04-17Dorl, James J Esq PROPOSAL82Asiya Javayant
1026Greenwood X GarufiGermany2024-04-12Buckley Miller Wright RENEWAL50Asiya Javayant
1027Antonio Z IturbideAustralia2024-04-26Morlong Associates NEGOTIATION56Ioni Bowcher
1028Adams L FlosiArgentina2024-04-07Buckley Miller Wright PROPOSAL26Xuxue Feng
1029Chavez D TollnerRussia2024-04-01Morlong Associates NEGOTIATION82Amy Elsner
1030Aditya P RimCanada2024-04-08Commercial Press RENEWAL96Asiya Javayant
1031Murillo F VocelkaRussia2024-04-05Buckley Miller Wright NEGOTIATION77Elwin Sharvill
1032Rodrigues C SergiArgentina2024-04-09Rousseaux, Michael Esq QUALIFIED90Onyama Limba
1033Ricardo L SaylorsFrance2024-04-11Commercial Press UNQUALIFIED59Onyama Limba
1034Johnson I WaycottRussia2024-04-10Benton, John B Jr NEGOTIATION60Asiya Javayant
1035Cody E OldroydFrance2024-04-11Chanay, Jeffrey A Esq PROPOSAL63Anna Fali
1036Jeanfrancois W PoquetteItaly2024-04-05Benton, John B Jr PROPOSAL88Elwin Sharvill
1037Wickens B AlbaresGermany2024-04-07King, Christopher A Esq RENEWAL3Onyama Limba
1038Johnson Q OldroydFrance2024-04-10Printing Dimensions UNQUALIFIED57Ioni Bowcher
1039Isabel N SaylorsRussia2024-04-12Morlong Associates NEGOTIATION78Onyama Limba
1040Rodrigues G SchemmerItaly2024-04-04Rangoni Of Florence RENEWAL78Asiya Javayant
1041Salvatore I PaprockiGermany2024-04-13Feltz Printing Service PROPOSAL41Ioni Bowcher
1042Kaitlin I FlosiFrance2024-04-07Dorl, James J Esq QUALIFIED18Amy Elsner
1043Nicolas D ChuiIndia2024-04-10Commercial Press UNQUALIFIED36Amy Elsner
1044Stacey C CaldareraSpain2024-04-22Rousseaux, Michael Esq NEGOTIATION55Bernardo Dominic
1045Aditya Z GlickAustralia2024-04-20Dorl, James J Esq QUALIFIED76Asiya Javayant
1046Deepesh X StockhamCanada2024-03-31Dorl, James J Esq UNQUALIFIED60Asiya Javayant
1047Wickens V VenereFrance2024-04-10Buckley Miller Wright NEW20Ivan Magalhaes
1048Francesco U DoeIndia2024-03-31Feltz Printing Service RENEWAL59Ioni Bowcher
1049Greenwood K InouyeItaly2024-04-25Buckley Miller Wright QUALIFIED48Elwin Sharvill
Frozen Rows
NameCountryRepresentativeStatus
Darci K StockhamGermanyAmy Elsner UNQUALIFIED
Julie F MaletIndiaIoni Bowcher NEW
Chavez V ChuiUnited KingdomStephen Shaw RENEWAL
Izzy I RulapaughBrazilOnyama Limba QUALIFIED
Greenwood U WhobreyArgentinaIoni Bowcher NEW
Aruna X CampainCanadaAmy Elsner PROPOSAL
Isabel L InouyeIndiaAnna Fali PROPOSAL
Greenwood W KolmetzItalyStephen Shaw NEGOTIATION
Leja L GlickSpainAnna Fali UNQUALIFIED
Leja H FlosiFranceBernardo Dominic NEGOTIATION
Aruna E RulapaughIndiaAsiya Javayant PROPOSAL
Aditya U AmigonSpainAmy Elsner PROPOSAL
Francesco W CampainCanadaIvan Magalhaes QUALIFIED
Costa Q GauchoAustraliaElwin Sharvill UNQUALIFIED
Ivar X WhobreyJapanAnna Fali PROPOSAL
Mayumi S VenereSpainAmy Elsner UNQUALIFIED
Julie H VocelkaBrazilXuxue Feng PROPOSAL
Arvin I WaycottBrazilAsiya Javayant UNQUALIFIED
Faith I PerinJapanBernardo Dominic QUALIFIED
Arvin I PerinIndiaXuxue Feng QUALIFIED
Juan O NickaArgentinaOnyama Limba PROPOSAL
Leon W ChuiSpainIvan Magalhaes NEW
Smith A MaletRussiaOnyama Limba PROPOSAL
Arvin J StensethIndiaElwin Sharvill NEGOTIATION
Wickens G RimAustraliaAmy Elsner NEW
Rodrigues V MaletCanadaBernardo Dominic RENEWAL
Ashley B NestleUnited KingdomElwin Sharvill QUALIFIED
Wickens X SaylorsGermanyStephen Shaw QUALIFIED
Mujtaba P CaudyCanadaXuxue Feng PROPOSAL
David J OstroskyBrazilAmy Elsner RENEWAL
Mayumi I DarakjyGermanyOnyama Limba RENEWAL
Sinclair E CampainIndiaXuxue Feng PROPOSAL
Kaitlin E ButtSpainBernardo Dominic RENEWAL
Smith J BriddickIndiaIvan Magalhaes RENEWAL
Leja K TollnerJapanStephen Shaw UNQUALIFIED
Jones M DilliardSpainIvan Magalhaes RENEWAL
Stacey E SaylorsCanadaElwin Sharvill NEW
Adams U PerinArgentinaStephen Shaw QUALIFIED
Leja E FerenczItalyIvan Magalhaes UNQUALIFIED
Jones Y CaldareraBrazilIoni Bowcher NEW
Silvio X GauchoAustraliaOnyama Limba QUALIFIED
Jennifer M MaletJapanAmy Elsner RENEWAL
Juan P RimGermanyIvan Magalhaes QUALIFIED
Tony C MaletGermanyAsiya Javayant QUALIFIED
Johnson S SlusarskiGermanyAmy Elsner NEW
Munro Q SchemmerJapanIoni Bowcher RENEWAL
Ricardo G MacleadUnited KingdomAsiya Javayant UNQUALIFIED
Murillo I NickaItalyXuxue Feng NEW
Tony X CampainCanadaBernardo Dominic NEGOTIATION
Tony W MacleadIndiaIoni Bowcher NEW
Frozen Columns
Name
Isabel C Campain
Tony O Caudy
Maria T Iturbide
Rodrigues U Ostrosky
Francesco O Gaucho
Chavez M Gillian
Francesco H Ruta
James C Garufi
Ashley H Bolognia
Johnson P Shinko
Kadeem L Caudy
Ricardo S Doe
Rodrigues V Flosi
Jeanfrancois T Chui
Kadeem M Rim
Emily B Sergi
Murillo O Ruta
Emily X Maclead
James U Amigon
Maisha I Chui
Johnson J Tollner
Ricardo J Inouye
Darci R Perin
Jeanfrancois M Inouye
Misaki D Oldroyd
Misaki T Rulapaugh
Maria O Kusko
Emily C Marrier
Leja H Darakjy
Arvin A Malet
Francesco O Caldarera
Stacey G Glick
Jefferson U Ruta
Cody J Shinko
Ashley R Marrier
Claire Q Briddick
Kadeem N Oldroyd
Tony Y Albares
Ricardo S Briddick
Isabel P Rim
Munro O Stenseth
Claire J Ostrosky
Emily Y Shinko
Misaki H Gillian
Ashley Y Caldarera
Ashley U Nestle
Maisha H Nicka
Izzy T Vocelka
Leja P Ruta
Deepesh B Kolmetz
IdCountryDate
1000Argentina2024-04-20
1001Argentina2024-04-05
1002France2024-04-10
1003Argentina2024-04-11
1004Germany2024-04-28
1005Russia2024-04-16
1006France2024-04-05
1007Japan2024-04-23
1008Germany2024-04-18
1009Russia2024-04-04
1010United Kingdom2024-03-31
1011Brazil2024-04-02
1012Japan2024-04-17
1013Japan2024-04-11
1014Brazil2024-04-07
1015Italy2024-04-17
1016Russia2024-04-25
1017Italy2024-04-27
1018United Kingdom2024-04-17
1019Canada2024-04-10
1020Germany2024-04-24
1021India2024-04-16
1022Spain2024-04-17
1023United Kingdom2024-04-05
1024Brazil2024-04-14
1025United Kingdom2024-04-07
1026India2024-04-17
1027Russia2024-04-14
1028Brazil2024-04-26
1029Germany2024-04-13
1030Germany2024-03-30
1031Brazil2024-04-03
1032Spain2024-04-12
1033Canada2024-04-25
1034Brazil2024-04-07
1035Italy2024-04-22
1036France2024-04-05
1037India2024-04-07
1038Canada2024-04-02
1039India2024-04-06
1040Spain2024-04-02
1041France2024-04-07
1042Spain2024-04-26
1043Italy2024-04-12
1044Australia2024-04-19
1045Italy2024-04-20
1046Argentina2024-04-03
1047Spain2024-04-11
1048Italy2024-04-14
1049France2024-04-10

On-Demand Data

NameIdCountryDate
Jeanfrancois B Amigon1000Germany2024-04-24
Murillo F Caudy1001Brazil2024-04-03
Tony P Briddick1002Canada2024-04-16
Mayumi W Glick1003Argentina2024-04-04
Isabel K Morasca1004Canada2024-04-11
Stacey S Shinko1005Italy2024-04-04
Jennifer X Caldarera1006Russia2024-03-31
Aruna N Campain1007Brazil2024-04-27
James L Stenseth1008Italy2024-04-22
Emily Q Nestle1009Argentina2024-04-19
Greenwood Z Venere1010United Kingdom2024-04-24
Chavez P Stockham1011Argentina2024-04-26
Francesco S Tollner1012Brazil2024-04-09
Antonio E Dilliard1013Italy2024-04-11
David F Ruta1014France2024-04-11
Octavia U Venere1015India2024-04-07
Stacey W Stenseth1016Germany2024-04-15
Sinclair C Poquette1017Italy2024-04-09
Smith L Ostrosky1018Japan2024-04-16
Arvin M Oldroyd1019Canada2024-04-23
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Cody Q FigeroaJapanOnyama Limba NEW
Leja P RulapaughAustraliaBernardo Dominic RENEWAL
Faith P KolmetzUnited KingdomStephen Shaw NEW
Claire P MorascaCanadaBernardo Dominic NEGOTIATION
Sinclair M CaldareraRussiaAnna Fali NEW
Kaitlin Y DilliardArgentinaBernardo Dominic QUALIFIED
Arvin J KuskoBrazilBernardo Dominic PROPOSAL
Stacey B WieserJapanOnyama Limba PROPOSAL
Wickens I PaprockiJapanIoni Bowcher QUALIFIED
Faith X DilliardIndiaAsiya Javayant RENEWAL
Faith B ShinkoGermanyAmy Elsner PROPOSAL
Jennifer V RimRussiaIvan Magalhaes NEW
Misaki T FlosiFranceXuxue Feng RENEWAL
Kaitlin T MaletUnited KingdomAnna Fali RENEWAL
Clifford N SchemmerJapanStephen Shaw NEGOTIATION
Silvio V FollerFranceStephen Shaw PROPOSAL
Jeanfrancois G RutaCanadaOnyama Limba NEGOTIATION
Jefferson Q FollerGermanyElwin Sharvill NEW
Ivar H GlickGermanyXuxue Feng RENEWAL
Wickens B OldroydJapanElwin Sharvill PROPOSAL
Ricardo B TollnerFranceIvan Magalhaes NEGOTIATION
Murillo F MorascaRussiaIoni Bowcher UNQUALIFIED
Deepesh T GillianUnited KingdomIoni Bowcher RENEWAL
Johnson V MarrierGermanyStephen Shaw NEGOTIATION
Munro R IturbideCanadaElwin Sharvill QUALIFIED
Nicolas U ShinkoRussiaElwin Sharvill NEGOTIATION
Claire M MacleadGermanyAnna Fali PROPOSAL
David Z MarrierArgentinaStephen Shaw RENEWAL
Smith B GillianCanadaOnyama Limba PROPOSAL
James N SaylorsRussiaIvan Magalhaes NEW
Faith O OstroskyJapanIvan Magalhaes NEGOTIATION
Arvin Q GauchoFranceElwin Sharvill NEGOTIATION
Murillo C RutaGermanyAsiya Javayant NEGOTIATION
Johnson K PoquetteRussiaElwin Sharvill NEW
Alejandro A OstroskyJapanIvan Magalhaes QUALIFIED
Costa K SaylorsCanadaBernardo Dominic NEGOTIATION
Salvatore H AlbaresBrazilAmy Elsner QUALIFIED
Ivar L GauchoFranceBernardo Dominic QUALIFIED
Mayumi O PaprockiJapanAnna Fali NEGOTIATION
Leon S RulapaughIndiaStephen Shaw UNQUALIFIED

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