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
Juan B RimAustraliaXuxue Feng NEGOTIATION
Aika C MorascaUnited KingdomAnna Fali QUALIFIED
Silvio R VenereUnited KingdomOnyama Limba PROPOSAL
Deepesh E StensethJapanIoni Bowcher NEGOTIATION
Chavez K MaletAustraliaIvan Magalhaes NEW
Clifford N RoysterAustraliaAmy Elsner PROPOSAL
Izzy P VenereFranceXuxue Feng NEGOTIATION
Aditya O ChuiUnited KingdomAsiya Javayant UNQUALIFIED
Rodrigues O FigeroaSpainBernardo Dominic QUALIFIED
Isabel M WaycottSpainAsiya Javayant UNQUALIFIED
Johnson Q KolmetzCanadaStephen Shaw PROPOSAL
Maria W PaprockiFranceAsiya Javayant PROPOSAL
Aruna W GauchoIndiaBernardo Dominic NEGOTIATION
Misaki C KolmetzFranceAsiya Javayant UNQUALIFIED
Arvin Z GlickSpainIvan Magalhaes QUALIFIED
Tony V CaudyBrazilAsiya Javayant PROPOSAL
Maria V SlusarskiSpainElwin Sharvill UNQUALIFIED
Claire H MacleadFranceBernardo Dominic NEGOTIATION
Clifford E SlusarskiJapanXuxue Feng UNQUALIFIED
Mayumi O GillianItalyIoni Bowcher NEW
Juan O FollerJapanIvan Magalhaes NEGOTIATION
Kaitlin V GarufiFranceOnyama Limba RENEWAL
Jennifer J GarufiFranceElwin Sharvill RENEWAL
Francesco C RulapaughItalyAsiya Javayant RENEWAL
Izzy F TollnerArgentinaOnyama Limba NEW
Alejandro J AmigonJapanIoni Bowcher PROPOSAL
Jefferson L WhobreyItalyIoni Bowcher NEGOTIATION
Alejandro D InouyeFranceAnna Fali UNQUALIFIED
Ricardo Y CaudyJapanStephen Shaw NEGOTIATION
Johnson M OstroskyCanadaIvan Magalhaes NEGOTIATION
Maria U BologniaSpainAsiya Javayant NEGOTIATION
Julie O StockhamJapanStephen Shaw UNQUALIFIED
Aditya P AmigonUnited KingdomOnyama Limba NEGOTIATION
Aika W KuskoAustraliaOnyama Limba QUALIFIED
Aditya E GlickSpainOnyama Limba UNQUALIFIED
Kadeem J MaletAustraliaXuxue Feng NEGOTIATION
Faith G GarufiCanadaElwin Sharvill RENEWAL
Misaki K NestleSpainAmy Elsner NEGOTIATION
Morrow I AmigonJapanBernardo Dominic NEW
Jones D FigeroaIndiaAsiya Javayant NEGOTIATION
Greenwood U WhobreyFranceAnna Fali NEW
David T BriddickSpainAmy Elsner PROPOSAL
Antonio Z WaycottRussiaIvan Magalhaes QUALIFIED
Johnson J SchemmerRussiaIoni Bowcher PROPOSAL
Salvatore H FerenczRussiaIoni Bowcher QUALIFIED
Aika Y DarakjyRussiaAnna Fali NEGOTIATION
Tony F MarrierIndiaStephen Shaw UNQUALIFIED
Ivar W GarufiJapanStephen Shaw UNQUALIFIED
Maisha W MaletRussiaOnyama Limba UNQUALIFIED
Cody I VenereFranceAsiya Javayant NEW
Horizontal
NameCountryRepresentativeStatus
Chavez L WieserRussiaAnna Fali NEGOTIATION
Nicolas D DoeUnited KingdomAnna Fali NEW
Chavez E GlickUnited KingdomOnyama Limba QUALIFIED
David G DilliardItalyAnna Fali NEGOTIATION
David I OstroskyBrazilOnyama Limba NEW
Morrow J InouyeItalyIoni Bowcher UNQUALIFIED
Arvin J AlbaresBrazilAnna Fali UNQUALIFIED
Stacey Y WieserRussiaStephen Shaw NEW
Aruna F SaylorsArgentinaElwin Sharvill NEW
Adams C FerenczUnited KingdomAnna Fali UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Antonio X ButtGermany2024-04-10Chanay, Jeffrey A Esq RENEWAL57Amy Elsner
1001Mayumi J ShinkoJapan2024-04-05Feiner Bros UNQUALIFIED8Elwin Sharvill
1002Costa H FlosiGermany2024-04-27Benton, John B Jr PROPOSAL4Ivan Magalhaes
1003Juan K BowleySpain2024-04-03Benton, John B Jr RENEWAL50Stephen Shaw
1004Juan O MaletArgentina2024-04-01Morlong Associates NEW81Bernardo Dominic
1005Faith T BriddickFrance2024-04-13Morlong Associates PROPOSAL13Onyama Limba
1006Wickens X DilliardBrazil2024-04-18Dorl, James J Esq QUALIFIED4Ioni Bowcher
1007Aditya H SergiIndia2024-04-28Chanay, Jeffrey A Esq RENEWAL92Onyama Limba
1008Tony R BologniaArgentina2024-04-11Truhlar And Truhlar Attys PROPOSAL5Amy Elsner
1009Arvin Z KuskoSpain2024-04-21Chemel, James L Cpa QUALIFIED26Xuxue Feng
1010Stacey K VenereSpain2024-04-03Morlong Associates UNQUALIFIED86Xuxue Feng
1011Juan L MarrierIndia2024-04-22Rousseaux, Michael Esq PROPOSAL65Asiya Javayant
1012Tony O SergiBrazil2024-04-15Chemel, James L Cpa NEGOTIATION6Stephen Shaw
1013Mayumi M PaprockiBrazil2024-04-26Chemel, James L Cpa QUALIFIED6Elwin Sharvill
1014Claire Z AmigonArgentina2024-04-06Morlong Associates PROPOSAL11Xuxue Feng
1015David R VenereAustralia2024-04-14Rangoni Of Florence QUALIFIED11Onyama Limba
1016Isabel C FlosiSpain2024-04-28Commercial Press RENEWAL85Stephen Shaw
1017Greenwood A GillianAustralia2024-04-13Rousseaux, Michael Esq NEGOTIATION28Amy Elsner
1018Cody A MacleadSpain2024-04-14Truhlar And Truhlar Attys RENEWAL95Bernardo Dominic
1019Izzy L PoquetteBrazil2024-04-26Buckley Miller Wright UNQUALIFIED25Anna Fali
1020Francesco Z GarufiCanada2024-04-11Feiner Bros NEW66Amy Elsner
1021Clifford O MarrierFrance2024-03-30Benton, John B Jr RENEWAL31Anna Fali
1022Costa Z SlusarskiAustralia2024-04-14Feltz Printing Service RENEWAL83Xuxue Feng
1023Izzy A NestleItaly2024-04-07King, Christopher A Esq RENEWAL77Anna Fali
1024Aditya V OstroskyGermany2024-04-17Dorl, James J Esq QUALIFIED79Amy Elsner
1025Adams K AmigonRussia2024-04-14Feltz Printing Service NEW69Xuxue Feng
1026Johnson X AlbaresUnited Kingdom2024-04-25King, Christopher A Esq NEGOTIATION54Anna Fali
1027Greenwood E KolmetzArgentina2024-04-05Feiner Bros RENEWAL7Elwin Sharvill
1028Smith A IturbideAustralia2024-04-06Dorl, James J Esq QUALIFIED85Amy Elsner
1029Maisha F PaprockiBrazil2024-04-03King, Christopher A Esq NEW71Ivan Magalhaes
1030Ivar Y MorascaUnited Kingdom2024-04-10King, Christopher A Esq NEW10Onyama Limba
1031Stacey K WhobreyGermany2024-04-08Morlong Associates PROPOSAL89Amy Elsner
1032Isabel H NestleArgentina2024-04-12Rangoni Of Florence RENEWAL63Xuxue Feng
1033Jeanfrancois I DarakjyFrance2024-04-05Rangoni Of Florence UNQUALIFIED26Anna Fali
1034Rodrigues N OldroydRussia2024-03-31Chapman, Ross E Esq NEW72Ioni Bowcher
1035Arvin P NestleAustralia2024-04-02Chapman, Ross E Esq NEGOTIATION36Ivan Magalhaes
1036Murillo N KolmetzJapan2024-04-03Chanay, Jeffrey A Esq QUALIFIED95Asiya Javayant
1037Julie V RoysterIndia2024-04-26Feiner Bros PROPOSAL36Bernardo Dominic
1038Jennifer E NestleItaly2024-04-18Feiner Bros PROPOSAL78Xuxue Feng
1039Aditya R GlickBrazil2024-04-08Printing Dimensions UNQUALIFIED46Xuxue Feng
1040Jeanfrancois P BologniaArgentina2024-04-24King, Christopher A Esq NEW44Asiya Javayant
1041David U VenereFrance2024-04-09Feltz Printing Service PROPOSAL82Xuxue Feng
1042Sinclair D CaudyRussia2024-04-19Printing Dimensions NEW26Ioni Bowcher
1043Darci I NickaUnited Kingdom2024-04-14Dorl, James J Esq PROPOSAL74Ioni Bowcher
1044Jones F BowleyBrazil2024-04-01Morlong Associates NEW22Bernardo Dominic
1045Greenwood E MaletRussia2024-04-13Chanay, Jeffrey A Esq PROPOSAL12Stephen Shaw
1046Emily X RimUnited Kingdom2024-04-20Printing Dimensions QUALIFIED34Asiya Javayant
1047Ricardo H VenereBrazil2024-04-07Benton, John B Jr PROPOSAL81Ivan Magalhaes
1048Adams K StensethIndia2024-04-27Truhlar And Truhlar Attys RENEWAL53Bernardo Dominic
1049Greenwood H AlbaresBrazil2024-04-28Printing Dimensions NEGOTIATION71Ioni Bowcher
Frozen Rows
NameCountryRepresentativeStatus
Juan Y ShinkoCanadaElwin Sharvill PROPOSAL
Isabel D StockhamJapanAsiya Javayant QUALIFIED
Jeanfrancois T SaylorsUnited KingdomIvan Magalhaes NEW
Aika Y SaylorsJapanAsiya Javayant PROPOSAL
Jefferson S WhobreyIndiaBernardo Dominic PROPOSAL
Sinclair U FerenczBrazilOnyama Limba UNQUALIFIED
Leon B SergiFranceIoni Bowcher NEGOTIATION
Greenwood A OldroydRussiaAnna Fali NEW
Wickens E FerenczCanadaBernardo Dominic NEGOTIATION
Emily U GlickArgentinaAnna Fali RENEWAL
Isabel N RutaUnited KingdomOnyama Limba NEGOTIATION
Salvatore E KolmetzJapanElwin Sharvill QUALIFIED
James N KolmetzRussiaElwin Sharvill PROPOSAL
Murillo J IturbideRussiaAmy Elsner NEW
Sinclair G RutaIndiaBernardo Dominic UNQUALIFIED
Silvio S RimRussiaAnna Fali QUALIFIED
Mujtaba G SlusarskiSpainIvan Magalhaes NEW
Faith I FlosiJapanIvan Magalhaes RENEWAL
Aditya L MaletSpainBernardo Dominic PROPOSAL
Arvin D BologniaCanadaXuxue Feng UNQUALIFIED
Tony Q FollerItalyAmy Elsner UNQUALIFIED
Aika H ButtCanadaElwin Sharvill UNQUALIFIED
Leja J OstroskyGermanyXuxue Feng PROPOSAL
Clifford J SergiFranceAnna Fali RENEWAL
Aika K CampainGermanyAmy Elsner RENEWAL
Jennifer E FigeroaIndiaElwin Sharvill QUALIFIED
Maria W NickaItalyIoni Bowcher NEW
Wickens O CaudySpainXuxue Feng RENEWAL
Jennifer N AlbaresSpainStephen Shaw NEW
Rodrigues Z MacleadAustraliaElwin Sharvill QUALIFIED
Ivar H DilliardBrazilBernardo Dominic UNQUALIFIED
Nicolas O BologniaBrazilStephen Shaw PROPOSAL
Leja L MaletGermanyXuxue Feng NEGOTIATION
Kaitlin R RutaArgentinaBernardo Dominic RENEWAL
Silvio J MaletJapanElwin Sharvill NEW
Antonio W KuskoGermanyOnyama Limba QUALIFIED
Ricardo Z SergiSpainAsiya Javayant NEGOTIATION
Munro X OldroydUnited KingdomAsiya Javayant UNQUALIFIED
Greenwood R DarakjyRussiaAnna Fali QUALIFIED
Claire I GlickItalyAnna Fali QUALIFIED
Kadeem S MarrierArgentinaIvan Magalhaes PROPOSAL
David X CaudyItalyIoni Bowcher UNQUALIFIED
Kaitlin G GlickAustraliaAsiya Javayant UNQUALIFIED
Claire C TollnerArgentinaElwin Sharvill UNQUALIFIED
Wickens E InouyeRussiaAmy Elsner PROPOSAL
Jefferson U OldroydSpainAmy Elsner UNQUALIFIED
Silvio K DilliardGermanyAmy Elsner NEGOTIATION
Jennifer Z PaprockiGermanyAsiya Javayant RENEWAL
Ricardo M MarrierFranceAmy Elsner NEW
Kaitlin T AlbaresIndiaStephen Shaw RENEWAL
Frozen Columns
Name
Chavez D Briddick
Maria R Bowley
Silvio E Rim
Deepesh Z Flosi
Ashley G Shinko
Rodrigues A Malet
Stacey B Venere
Izzy Q Dilliard
Mayumi O Paprocki
Murillo W Wieser
Deepesh E Perin
Morrow T Schemmer
Munro A Ferencz
Ashley H Dilliard
Greenwood M Poquette
Juan V Malet
Ricardo E Oldroyd
Maria R Ruta
Nicolas P Garufi
Greenwood X Rim
Kaitlin N Amigon
David O Gaucho
Juan N Rulapaugh
Salvatore G Inouye
Deepesh O Bolognia
Aika D Figeroa
Chavez P Tollner
Smith O Nicka
Leon X Amigon
Ricardo Y Perin
Jones D Saylors
Darci J Foller
Costa I Tollner
Smith D Briddick
Mayumi D Slusarski
Misaki O Stockham
Mayumi I Bowley
Wickens R Perin
Claire M Whobrey
Silvio V Schemmer
Jennifer Q Sergi
Smith M Shinko
James Y Kolmetz
Adams X Gaucho
Leon U Figeroa
Darci C Dilliard
Kadeem S Flosi
Izzy X Doe
Maisha D Perin
Adams J Doe
IdCountryDate
1000Japan2024-04-15
1001Italy2024-04-24
1002Argentina2024-04-26
1003Spain2024-04-14
1004Canada2024-04-11
1005United Kingdom2024-04-17
1006Japan2024-04-09
1007France2024-04-23
1008Canada2024-04-01
1009Russia2024-04-26
1010Brazil2024-04-28
1011Italy2024-04-27
1012Germany2024-04-26
1013Brazil2024-04-25
1014Canada2024-04-13
1015Italy2024-04-09
1016France2024-04-03
1017Australia2024-04-05
1018Brazil2024-04-05
1019Argentina2024-04-20
1020Russia2024-04-26
1021Japan2024-04-07
1022Brazil2024-03-30
1023France2024-04-04
1024Russia2024-04-07
1025Spain2024-04-12
1026Spain2024-04-11
1027India2024-04-13
1028Brazil2024-04-13
1029United Kingdom2024-04-04
1030Canada2024-04-10
1031Italy2024-04-26
1032Australia2024-04-03
1033Italy2024-04-21
1034Germany2024-04-16
1035Italy2024-04-05
1036Germany2024-04-18
1037Spain2024-04-02
1038France2024-04-09
1039Spain2024-04-11
1040France2024-03-31
1041Brazil2024-04-16
1042Russia2024-04-26
1043Argentina2024-04-06
1044United Kingdom2024-04-22
1045Germany2024-04-17
1046Canada2024-04-16
1047India2024-04-25
1048United Kingdom2024-04-09
1049Spain2024-04-11

On-Demand Data

NameIdCountryDate
Misaki Z Flosi1000Italy2024-04-02
Costa R Perin1001Germany2024-04-11
Maisha D Butt1002France2024-04-10
Costa W Gaucho1003France2024-04-13
Adams Y Marrier1004Brazil2024-04-09
Cody H Saylors1005Italy2024-04-21
Chavez V Marrier1006Australia2024-04-09
Mujtaba R Schemmer1007United Kingdom2024-04-04
Cody D Gillian1008Russia2024-04-10
Johnson G Kolmetz1009Russia2024-04-21
Octavia D Vocelka1010France2024-03-31
Greenwood I Waycott1011France2024-04-20
Octavia B Slusarski1012France2024-04-02
Darci Q Bowley1013Japan2024-04-01
Mujtaba D Rulapaugh1014Italy2024-04-23
Deepesh E Royster1015Russia2024-04-24
Mayumi H Gaucho1016Argentina2024-04-21
Francesco K Paprocki1017Spain2024-04-11
Jeanfrancois D Rim1018Spain2024-04-17
Mayumi F Venere1019Brazil2024-04-03
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Johnson L SlusarskiIndiaElwin Sharvill PROPOSAL
Salvatore Z MaletArgentinaAmy Elsner PROPOSAL
Francesco J FollerJapanElwin Sharvill PROPOSAL
Leon T MarrierUnited KingdomElwin Sharvill RENEWAL
Deepesh C ShinkoUnited KingdomXuxue Feng PROPOSAL
Arvin X RulapaughIndiaOnyama Limba RENEWAL
Kaitlin S DoeGermanyIvan Magalhaes RENEWAL
Kadeem L IturbideJapanIoni Bowcher NEW
Sinclair J DarakjyArgentinaAsiya Javayant PROPOSAL
Isabel F NestleFranceAmy Elsner UNQUALIFIED
Arvin X FerenczArgentinaIvan Magalhaes RENEWAL
Alejandro S MacleadSpainIoni Bowcher QUALIFIED
Costa M TollnerRussiaIvan Magalhaes NEW
Kaitlin G StockhamIndiaAmy Elsner NEW
Julie K RimBrazilXuxue Feng PROPOSAL
David M SaylorsGermanyAnna Fali NEW
Leon A AlbaresCanadaAnna Fali NEW
Darci G FollerJapanOnyama Limba RENEWAL
Murillo Z WhobreyItalyIvan Magalhaes PROPOSAL
Maisha A AlbaresCanadaAsiya Javayant RENEWAL
Costa O DoeItalyStephen Shaw RENEWAL
Ashley H NickaCanadaIvan Magalhaes PROPOSAL
Jeanfrancois Y FollerSpainOnyama Limba RENEWAL
Alejandro V SchemmerSpainAsiya Javayant UNQUALIFIED
Salvatore Z NickaItalyAnna Fali RENEWAL
Faith X FollerBrazilAmy Elsner QUALIFIED
Izzy G CaldareraUnited KingdomElwin Sharvill NEGOTIATION
Morrow X GarufiBrazilAsiya Javayant RENEWAL
Julie K MarrierFranceElwin Sharvill RENEWAL
Stacey N StockhamUnited KingdomIoni Bowcher NEGOTIATION
Silvio C SergiBrazilStephen Shaw UNQUALIFIED
Antonio R MacleadItalyElwin Sharvill QUALIFIED
Mujtaba O StensethFranceElwin Sharvill UNQUALIFIED
Ricardo B GarufiAustraliaAnna Fali QUALIFIED
Juan Q GarufiRussiaAsiya Javayant NEGOTIATION
Salvatore R GlickGermanyOnyama Limba PROPOSAL
Aika F StockhamFranceStephen Shaw RENEWAL
Adams T PerinFranceElwin Sharvill PROPOSAL
Izzy Z RulapaughCanadaBernardo Dominic RENEWAL
Aika Z PerinJapanIvan Magalhaes 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>