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
Munro I NestleBrazilStephen Shaw PROPOSAL
Faith C VocelkaItalyAnna Fali QUALIFIED
Jefferson Y ChuiGermanyOnyama Limba NEW
Alejandro Z CampainRussiaIoni Bowcher QUALIFIED
Izzy I WaycottCanadaAsiya Javayant NEW
Ashley U GauchoJapanBernardo Dominic RENEWAL
Wickens S CaldareraAustraliaElwin Sharvill QUALIFIED
Leja M GillianAustraliaOnyama Limba UNQUALIFIED
Costa R BriddickBrazilStephen Shaw NEW
Sinclair Z KuskoUnited KingdomXuxue Feng QUALIFIED
Maisha Z StensethCanadaXuxue Feng UNQUALIFIED
Arvin J NickaJapanAnna Fali NEGOTIATION
Adams Y FerenczArgentinaAmy Elsner QUALIFIED
Maisha X TollnerFranceXuxue Feng PROPOSAL
Octavia B CaldareraFranceBernardo Dominic RENEWAL
Ashley T MacleadFranceBernardo Dominic PROPOSAL
Antonio Q MaletRussiaElwin Sharvill NEGOTIATION
Isabel F RoysterCanadaIoni Bowcher QUALIFIED
Morrow E FerenczAustraliaElwin Sharvill PROPOSAL
Salvatore K VenereIndiaXuxue Feng RENEWAL
Aruna G IturbideArgentinaIoni Bowcher NEGOTIATION
Nicolas V PoquetteCanadaStephen Shaw QUALIFIED
Francesco X DoeCanadaOnyama Limba UNQUALIFIED
Cody A AmigonJapanStephen Shaw UNQUALIFIED
Costa X BowleyBrazilOnyama Limba RENEWAL
Octavia R AlbaresRussiaElwin Sharvill NEGOTIATION
Emily C AmigonUnited KingdomIvan Magalhaes NEW
Mujtaba X DoeGermanyAmy Elsner PROPOSAL
Ricardo D KuskoRussiaXuxue Feng NEW
Aika B WieserGermanyAnna Fali QUALIFIED
Johnson E OstroskyArgentinaXuxue Feng PROPOSAL
Tony W ButtFranceIvan Magalhaes RENEWAL
Rodrigues T GarufiFranceBernardo Dominic PROPOSAL
Antonio J ShinkoBrazilAsiya Javayant RENEWAL
Jennifer R RutaAustraliaOnyama Limba NEW
Jefferson F AlbaresGermanyIoni Bowcher UNQUALIFIED
Emily R MorascaSpainElwin Sharvill PROPOSAL
Ivar R ButtCanadaXuxue Feng PROPOSAL
Tony T AlbaresFranceBernardo Dominic QUALIFIED
Ricardo N SlusarskiBrazilOnyama Limba UNQUALIFIED
Greenwood V WhobreyBrazilIvan Magalhaes PROPOSAL
Wickens Q KolmetzIndiaAmy Elsner UNQUALIFIED
Sinclair T PaprockiIndiaStephen Shaw RENEWAL
Tony R MacleadIndiaAsiya Javayant RENEWAL
Juan I WhobreyUnited KingdomAsiya Javayant NEGOTIATION
Antonio R OldroydItalyBernardo Dominic RENEWAL
Darci N FlosiUnited KingdomXuxue Feng NEW
Munro U SchemmerItalyAmy Elsner RENEWAL
Greenwood Y ShinkoSpainXuxue Feng QUALIFIED
Aditya G RimCanadaIvan Magalhaes NEW
Horizontal
NameCountryRepresentativeStatus
Aditya I SlusarskiSpainElwin Sharvill RENEWAL
Misaki S IturbideItalyAnna Fali NEW
Julie V BowleyRussiaOnyama Limba RENEWAL
Darci U GlickRussiaIoni Bowcher RENEWAL
Chavez T GillianJapanAsiya Javayant NEW
Jennifer L BologniaRussiaOnyama Limba QUALIFIED
Faith J MaletGermanyIoni Bowcher NEGOTIATION
Mayumi Y GillianGermanyIvan Magalhaes NEW
Greenwood C VenereArgentinaAsiya Javayant PROPOSAL
Greenwood X MaletIndiaOnyama Limba PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Aika Q BologniaBrazil2024-05-04Truhlar And Truhlar Attys RENEWAL8Asiya Javayant
1001Jones M MaletGermany2024-05-18Feltz Printing Service NEGOTIATION22Bernardo Dominic
1002Octavia V TollnerSpain2024-05-05Dorl, James J Esq NEGOTIATION27Stephen Shaw
1003Maisha Q FlosiGermany2024-04-26Printing Dimensions NEGOTIATION81Ioni Bowcher
1004Nicolas O SaylorsRussia2024-04-28Buckley Miller Wright RENEWAL67Onyama Limba
1005Misaki S RoysterGermany2024-04-21Buckley Miller Wright UNQUALIFIED76Xuxue Feng
1006Octavia Y MacleadBrazil2024-05-11Feiner Bros PROPOSAL35Ioni Bowcher
1007Silvio I DoeGermany2024-04-23Truhlar And Truhlar Attys QUALIFIED13Anna Fali
1008Munro Q BologniaGermany2024-04-24Morlong Associates NEW60Stephen Shaw
1009Arvin Y RoysterSpain2024-05-18Truhlar And Truhlar Attys QUALIFIED25Elwin Sharvill
1010Aika T KuskoRussia2024-05-07King, Christopher A Esq NEW85Amy Elsner
1011Jefferson V PerinJapan2024-05-01Rangoni Of Florence UNQUALIFIED87Anna Fali
1012Sinclair S SergiUnited Kingdom2024-05-12Commercial Press PROPOSAL99Ivan Magalhaes
1013Munro Q VocelkaFrance2024-05-04Feltz Printing Service QUALIFIED56Stephen Shaw
1014Sinclair D PaprockiCanada2024-05-16Rousseaux, Michael Esq UNQUALIFIED88Xuxue Feng
1015Darci G SergiRussia2024-05-07Truhlar And Truhlar Attys NEGOTIATION70Xuxue Feng
1016Sinclair H MaletCanada2024-04-25Printing Dimensions UNQUALIFIED93Anna Fali
1017Costa O ChuiItaly2024-05-02Rousseaux, Michael Esq RENEWAL83Ivan Magalhaes
1018Maisha G DilliardJapan2024-04-26Feltz Printing Service NEW88Stephen Shaw
1019Leon U WieserGermany2024-05-20Feiner Bros RENEWAL11Bernardo Dominic
1020Kaitlin L MaletJapan2024-05-03Chanay, Jeffrey A Esq QUALIFIED82Anna Fali
1021Ricardo A KuskoItaly2024-04-30Truhlar And Truhlar Attys UNQUALIFIED98Amy Elsner
1022Faith V ChuiBrazil2024-05-08Chapman, Ross E Esq QUALIFIED99Ivan Magalhaes
1023Smith O OldroydFrance2024-05-08Buckley Miller Wright NEW94Amy Elsner
1024Silvio U OstroskySpain2024-04-22Chapman, Ross E Esq RENEWAL39Bernardo Dominic
1025Izzy F RutaRussia2024-04-24Buckley Miller Wright UNQUALIFIED2Amy Elsner
1026Mujtaba Z DarakjyIndia2024-04-24Printing Dimensions NEW76Xuxue Feng
1027Stacey B PaprockiUnited Kingdom2024-05-18King, Christopher A Esq UNQUALIFIED43Stephen Shaw
1028Tony N GlickIndia2024-05-17Chapman, Ross E Esq UNQUALIFIED5Asiya Javayant
1029Aika K RulapaughCanada2024-04-23Truhlar And Truhlar Attys UNQUALIFIED37Amy Elsner
1030Aruna M VenereJapan2024-05-04Feiner Bros RENEWAL7Xuxue Feng
1031Faith Z KolmetzJapan2024-05-01King, Christopher A Esq QUALIFIED39Anna Fali
1032Nicolas O SaylorsAustralia2024-04-23Chanay, Jeffrey A Esq NEW53Amy Elsner
1033Leon C PaprockiFrance2024-05-05Buckley Miller Wright PROPOSAL46Elwin Sharvill
1034Murillo C TollnerUnited Kingdom2024-04-29King, Christopher A Esq UNQUALIFIED86Onyama Limba
1035Nicolas Y NickaUnited Kingdom2024-05-04Printing Dimensions NEW56Amy Elsner
1036Costa H MacleadIndia2024-05-10Buckley Miller Wright RENEWAL30Amy Elsner
1037Claire D GlickRussia2024-04-29Feltz Printing Service QUALIFIED3Bernardo Dominic
1038Maisha F RimGermany2024-05-06Chemel, James L Cpa PROPOSAL35Onyama Limba
1039Jefferson Z FlosiJapan2024-05-01Rousseaux, Michael Esq RENEWAL96Onyama Limba
1040Adams K NestleSpain2024-04-22Chemel, James L Cpa QUALIFIED7Ioni Bowcher
1041Leon I WaycottIndia2024-05-20Chapman, Ross E Esq QUALIFIED14Onyama Limba
1042Kaitlin V FerenczFrance2024-05-07Feltz Printing Service QUALIFIED74Stephen Shaw
1043Maria B GlickFrance2024-05-14Feltz Printing Service RENEWAL69Elwin Sharvill
1044Aika P RimAustralia2024-05-10Commercial Press RENEWAL66Xuxue Feng
1045Munro Y DarakjyGermany2024-05-04Feiner Bros NEGOTIATION14Asiya Javayant
1046Wickens V DarakjyIndia2024-04-30Chapman, Ross E Esq PROPOSAL23Ivan Magalhaes
1047Jeanfrancois I PoquetteArgentina2024-04-26Morlong Associates NEW36Amy Elsner
1048Adams M CaudyArgentina2024-05-20Chapman, Ross E Esq QUALIFIED0Ivan Magalhaes
1049Sinclair S SchemmerAustralia2024-05-15Chemel, James L Cpa PROPOSAL30Elwin Sharvill
Frozen Rows
NameCountryRepresentativeStatus
Nicolas H MarrierSpainElwin Sharvill RENEWAL
Aditya O VenereFranceAmy Elsner NEGOTIATION
Claire J WhobreyAustraliaIoni Bowcher PROPOSAL
Faith F WaycottSpainOnyama Limba PROPOSAL
Francesco S KolmetzUnited KingdomBernardo Dominic QUALIFIED
Antonio S BriddickArgentinaStephen Shaw UNQUALIFIED
Juan T MaletArgentinaAsiya Javayant QUALIFIED
Jefferson E NestleSpainXuxue Feng NEW
Antonio J IturbideCanadaOnyama Limba PROPOSAL
Tony Y GarufiJapanOnyama Limba QUALIFIED
Julie A CaudyBrazilStephen Shaw RENEWAL
Misaki F SergiGermanyStephen Shaw RENEWAL
Johnson W BowleyCanadaXuxue Feng RENEWAL
Cody Q PerinBrazilAmy Elsner RENEWAL
Nicolas V StensethArgentinaIvan Magalhaes NEW
Kadeem L KuskoBrazilOnyama Limba PROPOSAL
Leon Q StensethCanadaAsiya Javayant NEGOTIATION
Tony M KolmetzRussiaBernardo Dominic NEGOTIATION
Jefferson K SchemmerGermanyBernardo Dominic UNQUALIFIED
Faith E WaycottJapanIoni Bowcher UNQUALIFIED
Munro O FollerRussiaIvan Magalhaes NEW
Octavia S MaletUnited KingdomElwin Sharvill QUALIFIED
Kaitlin D AlbaresCanadaXuxue Feng RENEWAL
James S OstroskyCanadaStephen Shaw RENEWAL
Maria L FlosiBrazilAnna Fali NEW
Deepesh D FollerSpainAsiya Javayant NEGOTIATION
Kaitlin M MacleadRussiaAsiya Javayant PROPOSAL
Aika S ShinkoItalyOnyama Limba QUALIFIED
Emily V PoquetteIndiaStephen Shaw NEGOTIATION
Deepesh O GlickFranceOnyama Limba NEW
Cody F WhobreyUnited KingdomStephen Shaw RENEWAL
Wickens O MacleadArgentinaElwin Sharvill NEW
Costa J WaycottUnited KingdomOnyama Limba PROPOSAL
Claire F ShinkoJapanBernardo Dominic RENEWAL
Cody M StensethUnited KingdomBernardo Dominic PROPOSAL
Clifford F WaycottBrazilAsiya Javayant PROPOSAL
Aditya M DoeAustraliaAnna Fali UNQUALIFIED
Jones F StensethItalyBernardo Dominic NEW
Misaki F CaldareraRussiaIoni Bowcher QUALIFIED
Mayumi Q MacleadFranceIvan Magalhaes NEGOTIATION
Faith W FlosiItalyBernardo Dominic UNQUALIFIED
Izzy W ShinkoJapanXuxue Feng QUALIFIED
Costa M RoysterSpainElwin Sharvill NEW
Deepesh S RoysterRussiaElwin Sharvill RENEWAL
Octavia Q MaletAustraliaIvan Magalhaes QUALIFIED
Jefferson C ChuiUnited KingdomAnna Fali NEGOTIATION
Clifford Q AlbaresBrazilIoni Bowcher NEW
Mayumi Q OstroskyBrazilIvan Magalhaes UNQUALIFIED
Mujtaba E CampainFranceOnyama Limba UNQUALIFIED
Maisha V RimArgentinaAsiya Javayant RENEWAL
Frozen Columns
Name
Jefferson Y Nicka
Octavia U Gaucho
Smith J Briddick
Sinclair W Bolognia
Juan J Slusarski
Salvatore H Whobrey
Mayumi Q Doe
Nicolas M Caldarera
Kadeem H Darakjy
Isabel S Malet
Francesco W Poquette
Salvatore T Ostrosky
Tony S Caldarera
Leja D Rulapaugh
Arvin S Bolognia
Aruna S Venere
Jennifer B Nicka
Mujtaba F Ostrosky
Tony Z Glick
Ricardo N Saylors
Rodrigues O Chui
Murillo R Darakjy
Jennifer D Royster
Nicolas X Caldarera
Kadeem I Saylors
Maisha N Amigon
Ricardo Z Slusarski
Adams C Inouye
Salvatore U Figeroa
Alejandro Q Flosi
Aditya M Darakjy
Jones O Briddick
Aditya Y Kusko
Isabel V Morasca
Jennifer L Stenseth
Salvatore L Inouye
David G Whobrey
Tony B Dilliard
Kaitlin B Briddick
Arvin Y Waycott
Smith J Royster
Emily J Garufi
Jennifer Q Whobrey
Morrow M Albares
Sinclair E Perin
James R Morasca
Costa C Shinko
Antonio L Paprocki
Maisha K Caldarera
Claire G Garufi
IdCountryDate
1000Australia2024-04-21
1001United Kingdom2024-05-16
1002Australia2024-04-28
1003Canada2024-05-20
1004Italy2024-05-16
1005Spain2024-05-17
1006Russia2024-05-02
1007Germany2024-05-14
1008Italy2024-05-06
1009Italy2024-04-26
1010Japan2024-05-13
1011Italy2024-04-24
1012Japan2024-04-25
1013Brazil2024-05-10
1014United Kingdom2024-05-18
1015Spain2024-05-11
1016Brazil2024-05-02
1017Japan2024-05-19
1018Argentina2024-05-05
1019United Kingdom2024-04-24
1020Canada2024-04-21
1021India2024-05-05
1022United Kingdom2024-05-07
1023India2024-05-18
1024United Kingdom2024-04-22
1025Argentina2024-04-26
1026Canada2024-04-29
1027Australia2024-05-17
1028Japan2024-04-29
1029Germany2024-05-19
1030Italy2024-05-03
1031Spain2024-05-20
1032France2024-04-28
1033Canada2024-05-03
1034Brazil2024-05-10
1035Brazil2024-05-02
1036Italy2024-05-12
1037United Kingdom2024-05-03
1038Russia2024-04-22
1039United Kingdom2024-04-23
1040Argentina2024-05-20
1041Canada2024-05-01
1042Argentina2024-05-15
1043United Kingdom2024-04-24
1044Germany2024-04-26
1045Australia2024-05-15
1046India2024-05-12
1047Spain2024-05-11
1048United Kingdom2024-05-14
1049Germany2024-05-20

On-Demand Data

NameIdCountryDate
Izzy S Garufi1000Italy2024-04-30
Kadeem R Iturbide1001Australia2024-04-23
Sinclair W Gillian1002United Kingdom2024-05-03
Jefferson L Chui1003Italy2024-05-11
Silvio A Briddick1004Brazil2024-04-29
Munro A Tollner1005France2024-05-13
Nicolas X Royster1006Spain2024-04-28
Johnson H Bowley1007Canada2024-05-15
Greenwood L Whobrey1008Germany2024-05-20
Izzy U Glick1009United Kingdom2024-05-16
Murillo D Nestle1010Italy2024-05-09
Aruna R Caudy1011Brazil2024-04-24
Silvio L Caudy1012Spain2024-05-04
Maisha D Vocelka1013Argentina2024-05-03
Izzy Z Poquette1014Spain2024-05-04
Costa W Saylors1015Brazil2024-04-21
Faith P Doe1016Russia2024-05-17
Chavez E Malet1017Argentina2024-05-13
Claire Q Darakjy1018Germany2024-04-26
Jennifer R Chui1019France2024-04-24
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Wickens J GlickArgentinaXuxue Feng QUALIFIED
Leon W BowleyAustraliaIoni Bowcher RENEWAL
Juan R CaudyJapanXuxue Feng RENEWAL
Isabel Q BologniaAustraliaXuxue Feng NEGOTIATION
Cody K OstroskyJapanXuxue Feng UNQUALIFIED
Maisha R WieserUnited KingdomElwin Sharvill UNQUALIFIED
Darci L CampainRussiaXuxue Feng NEGOTIATION
Clifford J WieserSpainIoni Bowcher UNQUALIFIED
David Z GillianSpainElwin Sharvill NEW
Mayumi I KolmetzUnited KingdomAmy Elsner UNQUALIFIED
Kadeem D WieserJapanElwin Sharvill NEW
Greenwood E CaudyAustraliaElwin Sharvill UNQUALIFIED
Johnson Y MaletRussiaBernardo Dominic UNQUALIFIED
Arvin I StockhamRussiaXuxue Feng NEGOTIATION
Mayumi V OldroydUnited KingdomStephen Shaw NEW
Greenwood C WieserUnited KingdomXuxue Feng PROPOSAL
Leon R OldroydSpainStephen Shaw PROPOSAL
Costa R RoysterJapanElwin Sharvill PROPOSAL
Wickens I GauchoBrazilAnna Fali UNQUALIFIED
Misaki I GarufiSpainAnna Fali NEW
Deepesh K NickaIndiaOnyama Limba RENEWAL
Kadeem O RutaCanadaAnna Fali UNQUALIFIED
Faith E GauchoFranceElwin Sharvill NEW
Cody M NickaItalyIvan Magalhaes RENEWAL
Julie Q MaletArgentinaIvan Magalhaes PROPOSAL
Clifford V VenereUnited KingdomBernardo Dominic QUALIFIED
Jones V RimArgentinaAsiya Javayant PROPOSAL
Juan Y SlusarskiIndiaAsiya Javayant QUALIFIED
Antonio O CampainRussiaAmy Elsner NEW
Ivar M DoeUnited KingdomElwin Sharvill RENEWAL
Nicolas M GlickFranceAnna Fali UNQUALIFIED
Jeanfrancois I VocelkaArgentinaAnna Fali RENEWAL
Munro W NickaFranceIvan Magalhaes NEW
Isabel T OldroydArgentinaBernardo Dominic RENEWAL
Faith C NestleUnited KingdomBernardo Dominic PROPOSAL
Ivar O ButtIndiaElwin Sharvill PROPOSAL
Mujtaba X FerenczBrazilStephen Shaw NEGOTIATION
Maria U RutaFranceOnyama Limba NEW
Francesco C MaletRussiaStephen Shaw NEGOTIATION
Smith Y KuskoAustraliaXuxue Feng 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>