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 L SaylorsBrazilAmy Elsner RENEWAL
Octavia P MorascaJapanElwin Sharvill RENEWAL
Arvin R OldroydAustraliaAnna Fali RENEWAL
Isabel U AlbaresBrazilAmy Elsner RENEWAL
Aika A CaldareraIndiaIvan Magalhaes RENEWAL
Munro R FlosiIndiaBernardo Dominic RENEWAL
Julie U SergiArgentinaElwin Sharvill PROPOSAL
Mujtaba J RoysterUnited KingdomXuxue Feng RENEWAL
Arvin A RutaFranceIoni Bowcher NEW
Julie Y WaycottSpainOnyama Limba NEGOTIATION
Maisha Q MaletJapanAnna Fali NEGOTIATION
Stacey X RoysterGermanyAnna Fali PROPOSAL
Aika L DarakjyRussiaAnna Fali UNQUALIFIED
Mujtaba L GauchoCanadaOnyama Limba NEGOTIATION
Smith K MaletFranceXuxue Feng QUALIFIED
Cody E WaycottJapanXuxue Feng QUALIFIED
Isabel L MorascaGermanyXuxue Feng RENEWAL
Claire D KuskoCanadaIoni Bowcher RENEWAL
Silvio P NickaUnited KingdomIvan Magalhaes QUALIFIED
Jeanfrancois K SchemmerSpainStephen Shaw PROPOSAL
Ricardo Y DoeSpainElwin Sharvill NEW
James P KolmetzFranceAnna Fali UNQUALIFIED
Chavez V MorascaFranceIvan Magalhaes QUALIFIED
Leja V ShinkoGermanyBernardo Dominic PROPOSAL
James O SlusarskiBrazilBernardo Dominic PROPOSAL
Maisha B SergiArgentinaOnyama Limba NEGOTIATION
Jefferson L GlickArgentinaElwin Sharvill NEW
Clifford O GillianIndiaElwin Sharvill RENEWAL
Adams S OldroydJapanIvan Magalhaes UNQUALIFIED
Rodrigues U WaycottArgentinaOnyama Limba UNQUALIFIED
Wickens Q SchemmerIndiaBernardo Dominic UNQUALIFIED
Ivar Z IturbideAustraliaOnyama Limba QUALIFIED
Cody J GarufiRussiaAnna Fali NEGOTIATION
Nicolas N RutaCanadaAnna Fali QUALIFIED
Claire T RutaUnited KingdomAmy Elsner UNQUALIFIED
Mujtaba N MorascaIndiaStephen Shaw UNQUALIFIED
Kaitlin A DoeUnited KingdomIvan Magalhaes PROPOSAL
Mayumi Y VocelkaRussiaOnyama Limba PROPOSAL
Costa N SchemmerItalyXuxue Feng UNQUALIFIED
Jones V DarakjyItalyElwin Sharvill QUALIFIED
Kadeem E PerinItalyAmy Elsner NEW
Alejandro B TollnerJapanXuxue Feng UNQUALIFIED
Stacey P DoeRussiaOnyama Limba RENEWAL
Darci Q MacleadFranceAmy Elsner NEW
Leon P NestleGermanyElwin Sharvill NEW
Salvatore V OstroskyUnited KingdomXuxue Feng QUALIFIED
Costa J ButtCanadaXuxue Feng UNQUALIFIED
Silvio R MorascaJapanAsiya Javayant RENEWAL
Mujtaba K PoquetteAustraliaXuxue Feng UNQUALIFIED
Leon L FlosiBrazilElwin Sharvill QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Darci Y FerenczFranceAmy Elsner NEW
Costa S DarakjyFranceIoni Bowcher PROPOSAL
Francesco Y MaletJapanAsiya Javayant UNQUALIFIED
Murillo G VenereItalyElwin Sharvill RENEWAL
Mujtaba L VocelkaAustraliaOnyama Limba QUALIFIED
Nicolas V AlbaresBrazilIoni Bowcher NEW
Tony L SchemmerSpainAsiya Javayant QUALIFIED
Morrow Q FlosiBrazilIvan Magalhaes RENEWAL
Jeanfrancois I FerenczGermanyAsiya Javayant RENEWAL
David U DilliardRussiaAnna Fali NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jennifer F SergiAustralia2024-04-10Benton, John B Jr NEGOTIATION10Stephen Shaw
1001Julie Q FollerAustralia2024-04-12Dorl, James J Esq NEW39Amy Elsner
1002Murillo H AlbaresIndia2024-05-02Chemel, James L Cpa PROPOSAL82Elwin Sharvill
1003Smith O GillianAustralia2024-04-05King, Christopher A Esq NEGOTIATION27Amy Elsner
1004Isabel F WaycottCanada2024-04-29Rangoni Of Florence QUALIFIED15Onyama Limba
1005Faith M DoeFrance2024-04-05Feltz Printing Service RENEWAL35Asiya Javayant
1006Darci U SaylorsGermany2024-04-25Chemel, James L Cpa NEGOTIATION3Anna Fali
1007Mujtaba L GauchoIndia2024-04-11Morlong Associates NEW28Asiya Javayant
1008Silvio X MarrierCanada2024-04-27King, Christopher A Esq NEGOTIATION77Onyama Limba
1009Aruna U VenereRussia2024-04-08Chapman, Ross E Esq UNQUALIFIED96Asiya Javayant
1010Darci H SergiRussia2024-05-03Dorl, James J Esq NEW56Asiya Javayant
1011Wickens W ShinkoUnited Kingdom2024-04-22Chemel, James L Cpa PROPOSAL22Amy Elsner
1012Emily R FlosiIndia2024-04-25Morlong Associates UNQUALIFIED58Stephen Shaw
1013Clifford N SlusarskiArgentina2024-04-30Truhlar And Truhlar Attys NEW72Ivan Magalhaes
1014Maisha F KuskoItaly2024-04-05Feiner Bros NEW18Stephen Shaw
1015Ivar B CaudyRussia2024-04-13King, Christopher A Esq NEGOTIATION51Anna Fali
1016Kadeem P WhobreyUnited Kingdom2024-04-13Truhlar And Truhlar Attys RENEWAL94Ioni Bowcher
1017Misaki M BowleyItaly2024-04-04Truhlar And Truhlar Attys QUALIFIED29Anna Fali
1018Cody E KuskoArgentina2024-04-23Feltz Printing Service NEW38Anna Fali
1019Sinclair H MaletAustralia2024-04-10Truhlar And Truhlar Attys UNQUALIFIED81Ivan Magalhaes
1020Costa K RimAustralia2024-04-25Printing Dimensions NEW48Anna Fali
1021Maisha D FlosiCanada2024-04-23Rousseaux, Michael Esq NEGOTIATION72Bernardo Dominic
1022Adams Y BologniaJapan2024-04-16King, Christopher A Esq UNQUALIFIED49Ivan Magalhaes
1023Wickens W CampainItaly2024-04-12Rousseaux, Michael Esq NEW80Bernardo Dominic
1024Tony J RimSpain2024-05-03Chapman, Ross E Esq NEGOTIATION82Amy Elsner
1025Mayumi Z PaprockiRussia2024-04-21Morlong Associates PROPOSAL37Ivan Magalhaes
1026Aruna S DoeAustralia2024-04-07Benton, John B Jr NEW3Ivan Magalhaes
1027Greenwood A SlusarskiJapan2024-04-20Printing Dimensions UNQUALIFIED70Stephen Shaw
1028Salvatore H TollnerCanada2024-04-27Rangoni Of Florence NEW60Ivan Magalhaes
1029Octavia A InouyeIndia2024-04-05Morlong Associates QUALIFIED90Amy Elsner
1030Octavia U DilliardUnited Kingdom2024-04-04Printing Dimensions NEW45Ivan Magalhaes
1031Costa R GauchoJapan2024-04-13Printing Dimensions NEGOTIATION46Elwin Sharvill
1032Deepesh T CampainAustralia2024-04-27Truhlar And Truhlar Attys NEW65Ivan Magalhaes
1033Jennifer P SergiJapan2024-04-19Feiner Bros NEW94Elwin Sharvill
1034Aruna G FerenczIndia2024-04-07Printing Dimensions QUALIFIED73Asiya Javayant
1035Smith X DilliardBrazil2024-04-21Chemel, James L Cpa NEGOTIATION47Xuxue Feng
1036Emily X OldroydIndia2024-04-09Truhlar And Truhlar Attys NEGOTIATION18Ioni Bowcher
1037Munro R OldroydSpain2024-04-04Morlong Associates NEGOTIATION23Asiya Javayant
1038Greenwood K BowleyItaly2024-04-29Rousseaux, Michael Esq NEW35Ivan Magalhaes
1039Wickens K GauchoFrance2024-04-28Chemel, James L Cpa NEW15Ioni Bowcher
1040Aditya J SlusarskiJapan2024-04-09Buckley Miller Wright NEW46Ioni Bowcher
1041Wickens A MorascaCanada2024-04-20Rousseaux, Michael Esq NEW24Asiya Javayant
1042Rodrigues R FigeroaItaly2024-05-02Morlong Associates QUALIFIED32Stephen Shaw
1043Antonio R DilliardRussia2024-04-13Truhlar And Truhlar Attys QUALIFIED62Xuxue Feng
1044Clifford F IturbideAustralia2024-04-18Truhlar And Truhlar Attys NEGOTIATION25Amy Elsner
1045Julie C MorascaBrazil2024-05-02Chanay, Jeffrey A Esq PROPOSAL92Elwin Sharvill
1046Mujtaba G NestleAustralia2024-04-21Dorl, James J Esq NEGOTIATION53Onyama Limba
1047Cody Y NestleAustralia2024-04-26Chapman, Ross E Esq NEW72Ivan Magalhaes
1048Chavez M SaylorsBrazil2024-04-25Buckley Miller Wright RENEWAL28Elwin Sharvill
1049Aruna S GillianBrazil2024-04-27Feiner Bros QUALIFIED29Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
Antonio H StockhamJapanXuxue Feng NEW
Leja R SchemmerAustraliaIoni Bowcher UNQUALIFIED
Maisha D AmigonBrazilOnyama Limba UNQUALIFIED
Morrow G CaldareraArgentinaIvan Magalhaes QUALIFIED
Aditya X ButtAustraliaBernardo Dominic PROPOSAL
Rodrigues O SergiGermanyElwin Sharvill RENEWAL
Costa U ShinkoSpainAmy Elsner QUALIFIED
Adams H FerenczItalyOnyama Limba NEW
Darci P CaudyRussiaIoni Bowcher QUALIFIED
Greenwood E FerenczCanadaAnna Fali PROPOSAL
Aditya M CampainJapanIvan Magalhaes NEGOTIATION
Chavez T PerinAustraliaIoni Bowcher QUALIFIED
Darci G GillianFranceElwin Sharvill PROPOSAL
Octavia A DoeJapanIoni Bowcher UNQUALIFIED
Leon Q WhobreyUnited KingdomBernardo Dominic NEGOTIATION
Morrow V TollnerGermanyXuxue Feng QUALIFIED
Deepesh L GillianIndiaIvan Magalhaes UNQUALIFIED
Misaki E SaylorsFranceAsiya Javayant RENEWAL
Johnson Z RulapaughCanadaIvan Magalhaes QUALIFIED
Ashley R NickaAustraliaIoni Bowcher NEW
Kaitlin E CampainFranceIoni Bowcher NEGOTIATION
Juan D KolmetzRussiaStephen Shaw PROPOSAL
Izzy M AlbaresIndiaOnyama Limba RENEWAL
Ricardo G RulapaughCanadaAsiya Javayant NEGOTIATION
Ashley T KolmetzIndiaAsiya Javayant NEGOTIATION
Silvio P ChuiFranceAmy Elsner PROPOSAL
Emily T GlickIndiaStephen Shaw NEGOTIATION
Murillo U GauchoIndiaAnna Fali PROPOSAL
Isabel D GarufiBrazilElwin Sharvill RENEWAL
Rodrigues D CaldareraJapanIoni Bowcher NEW
James K InouyeIndiaAnna Fali UNQUALIFIED
Izzy Z DoeJapanAmy Elsner NEGOTIATION
Chavez Y KuskoCanadaElwin Sharvill UNQUALIFIED
Ricardo P GauchoCanadaOnyama Limba UNQUALIFIED
Mayumi R MacleadRussiaXuxue Feng PROPOSAL
Kaitlin O WhobreyIndiaStephen Shaw UNQUALIFIED
Emily F DilliardCanadaAsiya Javayant NEW
Murillo W VocelkaCanadaAsiya Javayant UNQUALIFIED
David S DilliardArgentinaXuxue Feng UNQUALIFIED
James E OstroskyRussiaAnna Fali QUALIFIED
Salvatore D WhobreyBrazilStephen Shaw RENEWAL
Aika D StensethCanadaAmy Elsner PROPOSAL
Aruna L VocelkaSpainXuxue Feng UNQUALIFIED
Julie K VocelkaArgentinaIvan Magalhaes QUALIFIED
Salvatore N PoquetteSpainElwin Sharvill RENEWAL
Leon X BologniaGermanyAnna Fali NEGOTIATION
Arvin S RimFranceXuxue Feng QUALIFIED
Sinclair V OstroskySpainAsiya Javayant UNQUALIFIED
Johnson M AlbaresGermanyBernardo Dominic NEW
Jennifer I StensethJapanOnyama Limba NEGOTIATION
Frozen Columns
Name
Salvatore P Nicka
Jeanfrancois Q Inouye
Clifford H Ostrosky
Ricardo S Gillian
Izzy K Bowley
Salvatore W Inouye
Aruna H Paprocki
Ricardo Z Darakjy
Jennifer Q Foller
Johnson G Malet
Ivar J Glick
Jones O Bowley
Morrow I Gillian
Leon T Bolognia
Greenwood M Nestle
Arvin D Morasca
Stacey H Glick
Ashley O Marrier
Emily A Inouye
Aditya O Darakjy
Isabel D Ruta
Jefferson U Glick
Rodrigues W Campain
Faith T Poquette
Leja E Maclead
Silvio Q Rim
Alejandro D Vocelka
Jones P Ruta
Aika R Figeroa
Izzy U Bolognia
Jefferson O Wieser
Chavez F Stenseth
Tony O Perin
Francesco W Campain
Francesco E Dilliard
Sinclair E Stenseth
Julie K Campain
Emily T Whobrey
David L Nestle
Deepesh L Waycott
Isabel G Nestle
Juan P Ostrosky
Maisha N Stockham
Isabel G Ostrosky
Wickens X Whobrey
Maria L Nicka
Sinclair X Chui
Salvatore G Darakjy
Stacey W Darakjy
David H Waycott
IdCountryDate
1000India2024-04-30
1001Italy2024-04-14
1002Italy2024-04-09
1003Japan2024-04-06
1004Japan2024-04-27
1005Russia2024-04-20
1006Australia2024-04-09
1007Italy2024-04-22
1008Brazil2024-04-06
1009Japan2024-04-20
1010Argentina2024-04-17
1011France2024-05-03
1012Canada2024-04-08
1013Spain2024-04-14
1014Spain2024-04-30
1015India2024-04-14
1016Australia2024-04-11
1017Japan2024-04-14
1018Russia2024-05-02
1019Brazil2024-04-13
1020United Kingdom2024-04-12
1021France2024-04-18
1022India2024-04-15
1023India2024-04-09
1024Italy2024-04-28
1025Brazil2024-04-17
1026Japan2024-04-17
1027Japan2024-04-08
1028Argentina2024-05-03
1029Brazil2024-04-22
1030India2024-04-13
1031Germany2024-04-06
1032France2024-04-27
1033Spain2024-04-10
1034Canada2024-04-18
1035Russia2024-04-30
1036Canada2024-04-23
1037Japan2024-04-23
1038Russia2024-04-22
1039Russia2024-04-21
1040Japan2024-04-15
1041Russia2024-04-08
1042Russia2024-04-13
1043United Kingdom2024-05-03
1044Brazil2024-04-04
1045Brazil2024-05-02
1046Spain2024-04-22
1047France2024-04-14
1048Russia2024-04-16
1049Argentina2024-04-22

On-Demand Data

NameIdCountryDate
Faith Z Garufi1000Russia2024-04-16
Smith W Flosi1001United Kingdom2024-04-11
Silvio D Chui1002United Kingdom2024-04-09
Leon Q Darakjy1003Germany2024-04-17
Mayumi T Ferencz1004Japan2024-04-25
Chavez R Venere1005Spain2024-04-11
Julie W Whobrey1006United Kingdom2024-04-16
Izzy C Bowley1007Japan2024-05-03
Francesco C Vocelka1008Argentina2024-04-15
Octavia Q Wieser1009Brazil2024-04-20
Johnson B Gaucho1010Japan2024-04-04
Salvatore H Nestle1011Canada2024-04-17
Smith D Venere1012Japan2024-04-23
Silvio O Wieser1013France2024-04-20
Jennifer Y Schemmer1014Canada2024-04-08
Smith B Whobrey1015United Kingdom2024-04-29
Costa S Stenseth1016Argentina2024-04-15
Antonio L Stockham1017France2024-04-08
Smith T Gaucho1018Japan2024-04-19
Mayumi W Schemmer1019Japan2024-04-09
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Silvio O RutaIndiaIoni Bowcher UNQUALIFIED
Kadeem J SaylorsCanadaAsiya Javayant RENEWAL
Stacey J BowleyArgentinaAmy Elsner RENEWAL
Cody H SaylorsBrazilAsiya Javayant UNQUALIFIED
Arvin P SchemmerSpainAmy Elsner UNQUALIFIED
Salvatore S RulapaughRussiaIoni Bowcher PROPOSAL
Mujtaba N FerenczBrazilXuxue Feng UNQUALIFIED
Clifford D RimItalyAmy Elsner NEW
Kadeem H SlusarskiBrazilElwin Sharvill NEGOTIATION
Clifford P KolmetzArgentinaElwin Sharvill RENEWAL
Alejandro I CaldareraCanadaAmy Elsner PROPOSAL
James W ShinkoGermanyBernardo Dominic NEGOTIATION
Francesco H VenereJapanElwin Sharvill QUALIFIED
Sinclair Q SergiArgentinaIoni Bowcher PROPOSAL
Mayumi K CaldareraItalyBernardo Dominic NEW
Jeanfrancois I GlickCanadaAnna Fali QUALIFIED
Rodrigues K RutaArgentinaStephen Shaw QUALIFIED
Alejandro U RoysterJapanAmy Elsner RENEWAL
Sinclair F PerinIndiaAmy Elsner RENEWAL
Adams F PoquetteIndiaAnna Fali RENEWAL
Clifford A StensethAustraliaAmy Elsner PROPOSAL
James A BowleyIndiaAnna Fali QUALIFIED
Mujtaba S MaletArgentinaElwin Sharvill NEW
Smith I RoysterCanadaStephen Shaw RENEWAL
Nicolas X TollnerRussiaOnyama Limba PROPOSAL
Mujtaba X OldroydGermanyAsiya Javayant UNQUALIFIED
Clifford I SergiArgentinaAnna Fali NEGOTIATION
Maisha K WaycottGermanyAsiya Javayant RENEWAL
Adams M DoeArgentinaOnyama Limba QUALIFIED
Ricardo X ShinkoSpainIvan Magalhaes RENEWAL
Ricardo M VocelkaArgentinaXuxue Feng UNQUALIFIED
Ricardo O VocelkaUnited KingdomOnyama Limba RENEWAL
Ricardo L MaletArgentinaAnna Fali NEGOTIATION
Costa T FigeroaArgentinaAnna Fali QUALIFIED
Sinclair K WhobreyCanadaBernardo Dominic PROPOSAL
Silvio V MorascaItalyIvan Magalhaes QUALIFIED
Faith V CaudyArgentinaBernardo Dominic RENEWAL
Stacey R ShinkoArgentinaIvan Magalhaes NEW
Deepesh Q AlbaresItalyElwin Sharvill UNQUALIFIED
Morrow C MaletRussiaStephen Shaw 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>