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
Rodrigues H WhobreyIndiaAmy Elsner QUALIFIED
Salvatore R BriddickSpainBernardo Dominic NEW
Cody K GillianBrazilIvan Magalhaes UNQUALIFIED
Leon D SchemmerUnited KingdomAnna Fali PROPOSAL
David E CampainItalyBernardo Dominic NEGOTIATION
Wickens C GillianIndiaIoni Bowcher RENEWAL
Izzy O MaletBrazilAsiya Javayant NEGOTIATION
Sinclair M PoquetteFranceOnyama Limba NEGOTIATION
Misaki M FollerGermanyBernardo Dominic QUALIFIED
Wickens G FlosiCanadaAmy Elsner NEGOTIATION
Tony Q GarufiBrazilIoni Bowcher UNQUALIFIED
Arvin X InouyeAustraliaAsiya Javayant NEGOTIATION
Johnson R DilliardFranceIoni Bowcher QUALIFIED
Leja P RulapaughUnited KingdomIvan Magalhaes UNQUALIFIED
Sinclair K AlbaresArgentinaIoni Bowcher PROPOSAL
Ricardo X FigeroaSpainOnyama Limba QUALIFIED
Aika C FlosiArgentinaAmy Elsner UNQUALIFIED
Leja X GauchoFranceStephen Shaw NEW
Maisha W InouyeArgentinaOnyama Limba RENEWAL
Misaki Y GillianFranceAnna Fali PROPOSAL
Johnson D SaylorsUnited KingdomIoni Bowcher NEW
Juan E DilliardUnited KingdomXuxue Feng NEW
Salvatore W BriddickBrazilBernardo Dominic NEW
Wickens Z MacleadSpainAnna Fali PROPOSAL
Mujtaba Z FlosiRussiaXuxue Feng NEW
Sinclair V StensethRussiaAnna Fali PROPOSAL
Aruna G MarrierIndiaAsiya Javayant UNQUALIFIED
Silvio H NickaJapanStephen Shaw UNQUALIFIED
Ricardo M IturbideSpainAsiya Javayant RENEWAL
Stacey D PoquetteIndiaAsiya Javayant PROPOSAL
Aika J DarakjySpainElwin Sharvill NEW
Adams Y BowleyCanadaStephen Shaw NEW
Leja D KolmetzSpainAnna Fali PROPOSAL
Cody A StockhamBrazilIoni Bowcher UNQUALIFIED
Alejandro L RulapaughItalyXuxue Feng UNQUALIFIED
Morrow B RulapaughIndiaOnyama Limba RENEWAL
Leja X MaletGermanyAsiya Javayant QUALIFIED
Deepesh U GlickSpainElwin Sharvill PROPOSAL
Arvin P StockhamUnited KingdomIvan Magalhaes QUALIFIED
Isabel X OldroydFranceIoni Bowcher RENEWAL
Isabel E AmigonJapanBernardo Dominic NEW
Aika Y PerinJapanBernardo Dominic NEW
Misaki T WhobreyAustraliaStephen Shaw NEGOTIATION
Maisha V DarakjyGermanyOnyama Limba RENEWAL
David D CaldareraIndiaOnyama Limba UNQUALIFIED
Ricardo U RimItalyOnyama Limba UNQUALIFIED
Darci B FerenczIndiaAsiya Javayant PROPOSAL
Maria Q OldroydGermanyStephen Shaw RENEWAL
Clifford E GillianFranceStephen Shaw QUALIFIED
Faith S SlusarskiArgentinaAnna Fali PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Izzy H GarufiGermanyXuxue Feng UNQUALIFIED
Ashley P GillianJapanAmy Elsner PROPOSAL
Leja N BowleyUnited KingdomElwin Sharvill RENEWAL
Johnson L NickaGermanyElwin Sharvill QUALIFIED
Greenwood E NickaAustraliaAnna Fali PROPOSAL
Silvio G BowleyUnited KingdomOnyama Limba NEW
Rodrigues S OstroskyFranceStephen Shaw NEW
Misaki G VenereSpainAmy Elsner UNQUALIFIED
Jeanfrancois M WaycottSpainXuxue Feng PROPOSAL
Jennifer U SaylorsRussiaAnna Fali PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Costa J ShinkoRussia2024-04-10Morlong Associates QUALIFIED45Onyama Limba
1001Juan Z MaletGermany2024-04-15Rangoni Of Florence NEW95Ivan Magalhaes
1002Emily P VocelkaSpain2024-04-19Chanay, Jeffrey A Esq NEGOTIATION23Xuxue Feng
1003Silvio N NestleSpain2024-04-17Benton, John B Jr PROPOSAL50Bernardo Dominic
1004Johnson S TollnerUnited Kingdom2024-04-19Chanay, Jeffrey A Esq RENEWAL10Anna Fali
1005Chavez D ButtArgentina2024-04-07Chemel, James L Cpa RENEWAL34Ivan Magalhaes
1006Murillo K GarufiUnited Kingdom2024-04-20Printing Dimensions RENEWAL76Ivan Magalhaes
1007Morrow Z GlickSpain2024-04-07Commercial Press PROPOSAL52Amy Elsner
1008Clifford P BologniaRussia2024-04-12Feiner Bros QUALIFIED86Xuxue Feng
1009Faith W FlosiJapan2024-04-03King, Christopher A Esq RENEWAL16Asiya Javayant
1010Salvatore V CampainIndia2024-04-08Morlong Associates UNQUALIFIED24Onyama Limba
1011Leja U MaletItaly2024-04-04Chemel, James L Cpa PROPOSAL76Amy Elsner
1012Misaki K KuskoJapan2024-04-26Feltz Printing Service NEGOTIATION56Anna Fali
1013Ricardo T FollerFrance2024-04-28Chemel, James L Cpa QUALIFIED51Elwin Sharvill
1014Emily U DarakjyCanada2024-04-09Rousseaux, Michael Esq NEGOTIATION99Ioni Bowcher
1015Ricardo P MaletGermany2024-04-10Dorl, James J Esq RENEWAL71Onyama Limba
1016Alejandro Q KolmetzRussia2024-04-01Benton, John B Jr PROPOSAL88Stephen Shaw
1017Maisha P KuskoArgentina2024-04-19Commercial Press RENEWAL20Asiya Javayant
1018Deepesh V StensethAustralia2024-04-04Chanay, Jeffrey A Esq UNQUALIFIED66Anna Fali
1019Jeanfrancois N CaudyBrazil2024-04-15Printing Dimensions NEW84Anna Fali
1020Faith L PerinSpain2024-04-05Morlong Associates NEGOTIATION79Ivan Magalhaes
1021Smith Y MacleadAustralia2024-04-11Commercial Press NEW82Anna Fali
1022James Q WaycottSpain2024-04-14Chapman, Ross E Esq QUALIFIED97Ivan Magalhaes
1023Adams O PoquetteIndia2024-04-10Chapman, Ross E Esq NEGOTIATION84Ioni Bowcher
1024Stacey N RimArgentina2024-04-09Buckley Miller Wright QUALIFIED74Anna Fali
1025Alejandro A BowleyBrazil2024-04-28Buckley Miller Wright NEGOTIATION82Anna Fali
1026Darci D GillianGermany2024-04-05Dorl, James J Esq PROPOSAL77Anna Fali
1027Jeanfrancois M SlusarskiFrance2024-04-04Chapman, Ross E Esq UNQUALIFIED7Amy Elsner
1028Jennifer R SlusarskiArgentina2024-04-09Rangoni Of Florence RENEWAL44Amy Elsner
1029David L CampainItaly2024-04-15Buckley Miller Wright UNQUALIFIED92Xuxue Feng
1030Faith L WieserUnited Kingdom2024-04-27Truhlar And Truhlar Attys PROPOSAL29Stephen Shaw
1031Silvio W CaudyRussia2024-04-21Rangoni Of Florence QUALIFIED8Ivan Magalhaes
1032Nicolas S TollnerAustralia2024-04-02King, Christopher A Esq UNQUALIFIED18Ivan Magalhaes
1033Emily O WaycottUnited Kingdom2024-04-30Printing Dimensions PROPOSAL7Amy Elsner
1034Leja M NestleBrazil2024-04-30Feiner Bros NEW99Elwin Sharvill
1035Greenwood M KuskoUnited Kingdom2024-04-04Commercial Press PROPOSAL47Stephen Shaw
1036Cody O MaletArgentina2024-04-08Chanay, Jeffrey A Esq NEW71Elwin Sharvill
1037Adams I MorascaItaly2024-04-09Chemel, James L Cpa RENEWAL98Onyama Limba
1038Claire Y RulapaughUnited Kingdom2024-04-28Rangoni Of Florence RENEWAL30Ioni Bowcher
1039Smith D DarakjyBrazil2024-04-23Rangoni Of Florence UNQUALIFIED59Ioni Bowcher
1040Mujtaba N PaprockiAustralia2024-04-03Chapman, Ross E Esq UNQUALIFIED10Amy Elsner
1041Octavia C CaldareraAustralia2024-04-11Feltz Printing Service NEW98Ivan Magalhaes
1042Juan K WhobreyBrazil2024-04-04Dorl, James J Esq QUALIFIED98Bernardo Dominic
1043Izzy M WaycottRussia2024-04-27Chemel, James L Cpa UNQUALIFIED6Anna Fali
1044Leon R InouyeBrazil2024-04-24Feiner Bros NEW12Anna Fali
1045Arvin C RoysterItaly2024-04-16Feiner Bros RENEWAL20Elwin Sharvill
1046Kadeem Y GillianCanada2024-04-24Chanay, Jeffrey A Esq UNQUALIFIED10Elwin Sharvill
1047Izzy S PoquetteItaly2024-04-03Chemel, James L Cpa UNQUALIFIED16Asiya Javayant
1048Costa R TollnerCanada2024-04-12Chapman, Ross E Esq QUALIFIED90Ioni Bowcher
1049Ricardo R RutaCanada2024-04-13Commercial Press NEGOTIATION38Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
Murillo W OldroydUnited KingdomStephen Shaw NEGOTIATION
Octavia O PaprockiFranceAnna Fali UNQUALIFIED
Johnson T RimJapanStephen Shaw QUALIFIED
Juan I AlbaresItalyBernardo Dominic QUALIFIED
Alejandro L KuskoCanadaElwin Sharvill NEW
Clifford F BologniaFranceElwin Sharvill PROPOSAL
Julie Z RoysterBrazilXuxue Feng RENEWAL
Rodrigues R WieserBrazilIvan Magalhaes UNQUALIFIED
Octavia D InouyeSpainAsiya Javayant PROPOSAL
Alejandro U MaletRussiaIvan Magalhaes NEGOTIATION
Cody R NestleAustraliaXuxue Feng RENEWAL
Kaitlin M StockhamIndiaIoni Bowcher RENEWAL
Mayumi E MaletGermanyAmy Elsner NEGOTIATION
Aika F InouyeFranceBernardo Dominic QUALIFIED
Johnson E SaylorsGermanyIoni Bowcher NEW
Jones R DoeJapanStephen Shaw RENEWAL
Jennifer X SaylorsCanadaElwin Sharvill RENEWAL
Silvio C FigeroaRussiaBernardo Dominic NEGOTIATION
Kadeem Y PoquetteAustraliaOnyama Limba RENEWAL
Wickens Y SlusarskiIndiaIoni Bowcher PROPOSAL
Jeanfrancois L PaprockiAustraliaAmy Elsner PROPOSAL
Salvatore J ChuiSpainIvan Magalhaes PROPOSAL
Stacey U RutaFranceIoni Bowcher NEW
Ashley W PoquetteAustraliaAmy Elsner QUALIFIED
Jeanfrancois B CampainSpainOnyama Limba UNQUALIFIED
Claire A RimIndiaOnyama Limba RENEWAL
Juan D RulapaughJapanOnyama Limba UNQUALIFIED
Stacey J VocelkaUnited KingdomOnyama Limba NEGOTIATION
Clifford F RulapaughCanadaStephen Shaw UNQUALIFIED
Sinclair E OldroydSpainAnna Fali RENEWAL
Rodrigues J WieserAustraliaAsiya Javayant RENEWAL
Nicolas T WaycottArgentinaOnyama Limba NEGOTIATION
Costa Q RimBrazilIvan Magalhaes NEGOTIATION
James J ShinkoBrazilAmy Elsner RENEWAL
Ricardo Y PaprockiFranceOnyama Limba NEW
Jefferson X VocelkaSpainAnna Fali NEW
Kadeem Z SaylorsBrazilAmy Elsner NEGOTIATION
Kaitlin D MaletItalyOnyama Limba RENEWAL
Arvin D CaudyRussiaAnna Fali NEW
Jones E ShinkoJapanElwin Sharvill PROPOSAL
Morrow A WhobreyItalyAmy Elsner NEGOTIATION
Aditya L AlbaresIndiaAsiya Javayant NEGOTIATION
Ricardo W BowleyAustraliaIoni Bowcher UNQUALIFIED
Aruna Z GillianRussiaIoni Bowcher NEGOTIATION
Juan A RoysterCanadaAnna Fali NEGOTIATION
Wickens K KolmetzAustraliaXuxue Feng RENEWAL
Leja L PoquetteAustraliaElwin Sharvill UNQUALIFIED
Ricardo D WaycottArgentinaAnna Fali QUALIFIED
Francesco L RimJapanAmy Elsner QUALIFIED
Jones J FollerUnited KingdomBernardo Dominic QUALIFIED
Frozen Columns
Name
Jefferson T Darakjy
James M Kolmetz
Johnson R Gillian
Francesco Q Inouye
Munro J Doe
Jefferson E Flosi
Francesco L Caldarera
Faith M Malet
Maria F Ferencz
Morrow P Venere
Greenwood B Stockham
Leja V Maclead
Darci I Rim
Tony D Bowley
Jennifer O Briddick
Misaki W Ostrosky
Arvin C Amigon
Deepesh W Figeroa
Tony P Sergi
Silvio R Bolognia
Stacey A Bolognia
Silvio T Rim
Cody F Vocelka
Izzy M Dilliard
Jones E Marrier
Kadeem A Ruta
Salvatore L Flosi
Tony A Morasca
Munro X Nestle
Ricardo L Gaucho
Julie R Gillian
Mujtaba Z Kolmetz
Aika Q Chui
Nicolas K Malet
Misaki U Foller
Leon S Gillian
Leon U Gillian
Cody L Morasca
Jeanfrancois W Glick
Tony A Rim
Maisha W Doe
Arvin J Stockham
Clifford P Ruta
Salvatore S Oldroyd
Ashley Y Albares
Wickens P Marrier
Mujtaba L Morasca
Maisha Q Butt
David P Stockham
Sinclair W Chui
IdCountryDate
1000Argentina2024-04-07
1001India2024-04-11
1002Russia2024-04-02
1003Brazil2024-04-14
1004Canada2024-04-04
1005Canada2024-04-20
1006Canada2024-04-13
1007Brazil2024-04-23
1008Argentina2024-04-14
1009Japan2024-04-29
1010India2024-04-20
1011Italy2024-04-06
1012Japan2024-04-15
1013Italy2024-04-29
1014Italy2024-04-20
1015France2024-04-04
1016Argentina2024-04-30
1017Brazil2024-04-02
1018Russia2024-04-28
1019Australia2024-04-05
1020Italy2024-04-10
1021France2024-04-05
1022Japan2024-04-04
1023Australia2024-04-01
1024Russia2024-04-13
1025Germany2024-04-22
1026Russia2024-04-02
1027Russia2024-04-05
1028Japan2024-04-30
1029France2024-04-10
1030United Kingdom2024-04-27
1031Australia2024-04-09
1032Italy2024-04-17
1033Germany2024-04-08
1034Italy2024-04-17
1035Brazil2024-04-26
1036Germany2024-04-25
1037France2024-04-15
1038Russia2024-04-09
1039Australia2024-04-22
1040France2024-04-27
1041France2024-04-29
1042France2024-04-05
1043Spain2024-04-09
1044Russia2024-04-03
1045Spain2024-04-08
1046Italy2024-04-27
1047Spain2024-04-02
1048Canada2024-04-16
1049Germany2024-04-17

On-Demand Data

NameIdCountryDate
Jefferson W Perin1000Canada2024-04-24
Kadeem D Chui1001Canada2024-04-05
Izzy C Caudy1002Germany2024-04-11
Aika J Royster1003Canada2024-04-24
Faith R Morasca1004Japan2024-04-04
Clifford X Wieser1005Spain2024-04-21
Maria G Iturbide1006Argentina2024-04-17
Aika F Ferencz1007India2024-04-09
Sinclair P Figeroa1008Spain2024-04-15
Ricardo A Gillian1009India2024-04-13
Faith A Paprocki1010France2024-04-19
Sinclair V Nestle1011Russia2024-04-16
Mujtaba K Waycott1012India2024-04-29
Ricardo D Marrier1013Russia2024-04-20
Clifford C Marrier1014Spain2024-04-14
Claire T Saylors1015Brazil2024-04-22
Munro K Rim1016Argentina2024-04-25
Misaki T Oldroyd1017Australia2024-04-09
Sinclair T Ruta1018Australia2024-04-03
Antonio U Doe1019Brazil2024-04-22
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aika G PaprockiRussiaAmy Elsner RENEWAL
Murillo X RulapaughArgentinaBernardo Dominic NEGOTIATION
Chavez S RutaFranceBernardo Dominic UNQUALIFIED
Francesco L VocelkaFranceIvan Magalhaes NEGOTIATION
Alejandro O PerinAustraliaAsiya Javayant NEW
Chavez X MarrierUnited KingdomStephen Shaw UNQUALIFIED
Johnson D BologniaCanadaAsiya Javayant UNQUALIFIED
Aruna B StensethGermanyAmy Elsner NEGOTIATION
Ivar Y ShinkoSpainStephen Shaw QUALIFIED
Julie U ButtItalyXuxue Feng QUALIFIED
Sinclair C PoquetteSpainBernardo Dominic NEGOTIATION
Chavez W MaletBrazilStephen Shaw RENEWAL
Morrow V GlickJapanOnyama Limba NEGOTIATION
Isabel P RutaBrazilOnyama Limba NEW
Claire M NickaIndiaXuxue Feng PROPOSAL
Morrow E RutaUnited KingdomAsiya Javayant UNQUALIFIED
Nicolas T VocelkaArgentinaAnna Fali UNQUALIFIED
Nicolas P SaylorsBrazilAnna Fali NEGOTIATION
Salvatore X RutaCanadaElwin Sharvill QUALIFIED
Johnson W CampainIndiaStephen Shaw NEW
Jefferson Z OstroskyUnited KingdomAsiya Javayant QUALIFIED
Ashley J KuskoJapanIoni Bowcher RENEWAL
Misaki Z OstroskyArgentinaElwin Sharvill UNQUALIFIED
Tony K DilliardCanadaBernardo Dominic NEGOTIATION
Jones U DoeRussiaIvan Magalhaes PROPOSAL
Deepesh D FollerAustraliaIvan Magalhaes UNQUALIFIED
Smith J GarufiBrazilXuxue Feng QUALIFIED
Nicolas X MacleadFranceAmy Elsner RENEWAL
Salvatore M WieserGermanyOnyama Limba QUALIFIED
Costa G DoeFranceBernardo Dominic UNQUALIFIED
Jeanfrancois G NickaItalyIvan Magalhaes UNQUALIFIED
Aditya O VenereBrazilAnna Fali NEGOTIATION
Mayumi H TollnerIndiaXuxue Feng UNQUALIFIED
Leja T WaycottIndiaAmy Elsner UNQUALIFIED
Leja A ChuiJapanBernardo Dominic RENEWAL
Octavia H GarufiAustraliaIoni Bowcher NEGOTIATION
Murillo M InouyeGermanyStephen Shaw UNQUALIFIED
Munro V RimSpainIvan Magalhaes RENEWAL
Maria G RimGermanyOnyama Limba PROPOSAL
Chavez A ChuiSpainElwin Sharvill PROPOSAL

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