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
Leon J InouyeItalyAsiya Javayant QUALIFIED
Julie O PerinItalyAsiya Javayant NEW
Costa I NestleJapanElwin Sharvill UNQUALIFIED
Greenwood V GauchoRussiaOnyama Limba NEGOTIATION
Alejandro B DilliardBrazilIvan Magalhaes QUALIFIED
Leja Q MaletArgentinaOnyama Limba RENEWAL
Isabel X MaletJapanBernardo Dominic NEW
Salvatore L SchemmerSpainXuxue Feng NEGOTIATION
Nicolas Q CaudyBrazilAmy Elsner QUALIFIED
Francesco G SlusarskiJapanStephen Shaw UNQUALIFIED
Wickens L SergiArgentinaStephen Shaw NEGOTIATION
Clifford Q AlbaresRussiaAnna Fali QUALIFIED
Faith G StockhamGermanyElwin Sharvill RENEWAL
Maria F MaletArgentinaBernardo Dominic NEW
Antonio W PaprockiJapanOnyama Limba QUALIFIED
Nicolas V IturbideArgentinaXuxue Feng QUALIFIED
Ivar C DoeAustraliaAnna Fali NEW
Jefferson P GauchoIndiaAmy Elsner QUALIFIED
Jennifer R MarrierFranceStephen Shaw RENEWAL
Aditya H NestleAustraliaAnna Fali NEGOTIATION
Octavia U StockhamAustraliaOnyama Limba NEGOTIATION
Wickens K FollerItalyXuxue Feng PROPOSAL
Alejandro V CampainCanadaIoni Bowcher RENEWAL
Greenwood Q AlbaresUnited KingdomOnyama Limba NEGOTIATION
Maria P MaletBrazilOnyama Limba NEGOTIATION
Francesco U MaletUnited KingdomIvan Magalhaes UNQUALIFIED
Emily C WhobreySpainXuxue Feng NEW
Leja Q GarufiItalyBernardo Dominic NEW
Ashley G MaletSpainIvan Magalhaes PROPOSAL
Maisha Y VenereGermanyElwin Sharvill PROPOSAL
Arvin S InouyeSpainXuxue Feng UNQUALIFIED
Johnson W RutaJapanIvan Magalhaes QUALIFIED
Adams W NestleAustraliaXuxue Feng PROPOSAL
Maria K VenereAustraliaIoni Bowcher RENEWAL
Aruna X DarakjyArgentinaAmy Elsner NEGOTIATION
Greenwood H NestleBrazilBernardo Dominic QUALIFIED
Chavez H RulapaughIndiaElwin Sharvill QUALIFIED
Sinclair A DilliardIndiaBernardo Dominic RENEWAL
Johnson O VocelkaIndiaElwin Sharvill NEW
David T SlusarskiCanadaXuxue Feng PROPOSAL
Jones Z ButtGermanyStephen Shaw PROPOSAL
Smith P GauchoBrazilAnna Fali RENEWAL
Munro G CampainRussiaAsiya Javayant QUALIFIED
Jeanfrancois J IturbideCanadaAmy Elsner PROPOSAL
Adams O FollerItalyAnna Fali NEGOTIATION
Ivar A FerenczBrazilElwin Sharvill NEGOTIATION
Greenwood I GlickBrazilIvan Magalhaes UNQUALIFIED
Claire H GlickFranceAmy Elsner NEGOTIATION
Kadeem U DilliardRussiaBernardo Dominic NEW
David P VocelkaJapanElwin Sharvill NEW
Horizontal
NameCountryRepresentativeStatus
Murillo R SaylorsJapanAnna Fali NEW
Adams M ShinkoItalyIvan Magalhaes PROPOSAL
Wickens J FlosiIndiaAmy Elsner UNQUALIFIED
Izzy T FigeroaSpainAmy Elsner PROPOSAL
Kadeem V MacleadGermanyAsiya Javayant NEGOTIATION
Smith Y SaylorsCanadaIvan Magalhaes UNQUALIFIED
Nicolas M DarakjyUnited KingdomAnna Fali UNQUALIFIED
Misaki D SlusarskiAustraliaElwin Sharvill NEGOTIATION
Mujtaba K CampainFranceAnna Fali UNQUALIFIED
Greenwood N SlusarskiSpainAsiya Javayant PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Smith B KuskoBrazil2024-04-11King, Christopher A Esq NEW34Elwin Sharvill
1001James Z AmigonIndia2024-04-21Chanay, Jeffrey A Esq RENEWAL27Elwin Sharvill
1002Stacey G PaprockiFrance2024-04-10Dorl, James J Esq RENEWAL66Ivan Magalhaes
1003Sinclair W AmigonIndia2024-04-10Rousseaux, Michael Esq NEW98Ivan Magalhaes
1004Misaki K ButtItaly2024-04-05Rangoni Of Florence NEW43Amy Elsner
1005Stacey L MorascaItaly2024-04-01Truhlar And Truhlar Attys QUALIFIED35Ioni Bowcher
1006Faith F AlbaresCanada2024-04-01Dorl, James J Esq RENEWAL87Asiya Javayant
1007Jones W ButtBrazil2024-04-20Morlong Associates NEGOTIATION45Bernardo Dominic
1008Aditya H AlbaresArgentina2024-03-27Rangoni Of Florence RENEWAL68Bernardo Dominic
1009Murillo R GillianUnited Kingdom2024-04-21Dorl, James J Esq PROPOSAL23Anna Fali
1010Leja B MorascaIndia2024-04-08King, Christopher A Esq NEW56Bernardo Dominic
1011Greenwood O PerinGermany2024-03-31Buckley Miller Wright PROPOSAL43Stephen Shaw
1012Ivar U SchemmerCanada2024-04-14Benton, John B Jr NEW43Amy Elsner
1013Maisha O MacleadRussia2024-04-03Feltz Printing Service NEGOTIATION38Ivan Magalhaes
1014Claire Z VocelkaIndia2024-04-21Chanay, Jeffrey A Esq NEGOTIATION20Onyama Limba
1015Arvin B BriddickFrance2024-04-23Chapman, Ross E Esq NEW43Asiya Javayant
1016Morrow S VenereBrazil2024-03-31Chanay, Jeffrey A Esq NEGOTIATION45Amy Elsner
1017Mujtaba H GarufiFrance2024-04-16Rangoni Of Florence PROPOSAL0Ioni Bowcher
1018Cody Y StensethBrazil2024-04-10Commercial Press QUALIFIED76Xuxue Feng
1019Aruna P AlbaresFrance2024-03-28Feltz Printing Service QUALIFIED16Onyama Limba
1020Aditya Q WhobreyFrance2024-04-04Commercial Press QUALIFIED45Onyama Limba
1021Izzy Q KolmetzBrazil2024-04-11Feltz Printing Service NEW67Elwin Sharvill
1022Morrow O ButtRussia2024-04-08Buckley Miller Wright RENEWAL46Stephen Shaw
1023Jennifer P FollerUnited Kingdom2024-04-01Benton, John B Jr NEW47Stephen Shaw
1024Sinclair N PoquetteUnited Kingdom2024-04-13Feltz Printing Service NEGOTIATION67Ivan Magalhaes
1025Costa J RulapaughUnited Kingdom2024-04-16Chanay, Jeffrey A Esq NEW31Xuxue Feng
1026Kadeem K AmigonAustralia2024-04-08Commercial Press NEW51Anna Fali
1027Adams U CaldareraBrazil2024-04-14Chemel, James L Cpa UNQUALIFIED26Anna Fali
1028Isabel O CaudyJapan2024-04-05Chemel, James L Cpa NEW89Onyama Limba
1029Jefferson R PoquetteIndia2024-04-07Rangoni Of Florence NEW12Amy Elsner
1030Juan G BowleyUnited Kingdom2024-04-01Benton, John B Jr RENEWAL3Ivan Magalhaes
1031Aditya V NickaRussia2024-03-31Feltz Printing Service NEW22Ivan Magalhaes
1032Ricardo Z CaudyGermany2024-03-30Chemel, James L Cpa NEGOTIATION27Onyama Limba
1033Stacey R OstroskyUnited Kingdom2024-04-16Feiner Bros QUALIFIED65Onyama Limba
1034Kaitlin F ChuiIndia2024-04-20Rangoni Of Florence PROPOSAL32Ivan Magalhaes
1035Izzy C MaletBrazil2024-04-07Feltz Printing Service RENEWAL63Stephen Shaw
1036Isabel N GarufiBrazil2024-04-15Chemel, James L Cpa QUALIFIED53Elwin Sharvill
1037Johnson T WieserFrance2024-04-21Benton, John B Jr NEW11Anna Fali
1038Leja N MaletItaly2024-04-24Morlong Associates NEW47Ioni Bowcher
1039Aika H OldroydCanada2024-04-07Buckley Miller Wright NEGOTIATION78Asiya Javayant
1040Darci V FerenczJapan2024-04-02Benton, John B Jr NEGOTIATION10Asiya Javayant
1041Cody S MacleadSpain2024-04-17Dorl, James J Esq NEW18Ivan Magalhaes
1042Emily S WaycottGermany2024-04-14Rangoni Of Florence NEW94Onyama Limba
1043Cody Q WaycottGermany2024-04-16Morlong Associates NEW17Xuxue Feng
1044Kaitlin E DilliardArgentina2024-04-06Chemel, James L Cpa NEGOTIATION21Bernardo Dominic
1045Mayumi Q CaudyIndia2024-04-17Chapman, Ross E Esq RENEWAL52Elwin Sharvill
1046Salvatore H DoeJapan2024-04-03Dorl, James J Esq RENEWAL24Stephen Shaw
1047Cody S CaudyArgentina2024-04-08Commercial Press RENEWAL92Onyama Limba
1048Ashley S WaycottJapan2024-04-20Printing Dimensions RENEWAL92Amy Elsner
1049Jefferson K SaylorsUnited Kingdom2024-04-18Printing Dimensions NEW90Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Silvio A ButtJapanBernardo Dominic NEW
Julie F AlbaresJapanOnyama Limba RENEWAL
Salvatore H StockhamFranceStephen Shaw NEW
Misaki M NickaArgentinaAsiya Javayant RENEWAL
Murillo C OstroskySpainAsiya Javayant QUALIFIED
Clifford X IturbideJapanAnna Fali QUALIFIED
Alejandro W KuskoUnited KingdomAsiya Javayant PROPOSAL
Maisha E KolmetzRussiaAsiya Javayant PROPOSAL
Jennifer H MaletCanadaAsiya Javayant NEGOTIATION
Ricardo I SergiJapanElwin Sharvill UNQUALIFIED
Munro Q MorascaCanadaBernardo Dominic PROPOSAL
Jeanfrancois U WhobreyCanadaStephen Shaw RENEWAL
Antonio I AmigonArgentinaIoni Bowcher RENEWAL
Salvatore G FlosiFranceAnna Fali QUALIFIED
Morrow D WaycottRussiaAsiya Javayant RENEWAL
Adams O GauchoJapanAmy Elsner UNQUALIFIED
Faith V BriddickGermanyOnyama Limba RENEWAL
Ivar T ButtGermanyElwin Sharvill NEGOTIATION
Tony S KolmetzJapanXuxue Feng PROPOSAL
Maria A RutaGermanyAmy Elsner NEGOTIATION
Jeanfrancois B NickaArgentinaAmy Elsner UNQUALIFIED
Misaki M CaldareraItalyOnyama Limba RENEWAL
Jeanfrancois M RoysterCanadaAmy Elsner RENEWAL
Silvio K SaylorsAustraliaOnyama Limba NEGOTIATION
Aika F KolmetzJapanIoni Bowcher QUALIFIED
Octavia U InouyeJapanStephen Shaw QUALIFIED
Antonio J CaldareraUnited KingdomOnyama Limba PROPOSAL
Adams J DoeRussiaXuxue Feng QUALIFIED
Chavez Z WieserRussiaBernardo Dominic QUALIFIED
Rodrigues E NestleCanadaAsiya Javayant QUALIFIED
Darci N GillianBrazilAmy Elsner RENEWAL
Misaki Y VocelkaArgentinaAsiya Javayant QUALIFIED
Tony T StensethRussiaBernardo Dominic NEW
Octavia K RoysterIndiaStephen Shaw UNQUALIFIED
Greenwood F OstroskyGermanyIoni Bowcher QUALIFIED
Sinclair Q MaletFranceElwin Sharvill UNQUALIFIED
Salvatore W VocelkaUnited KingdomElwin Sharvill NEGOTIATION
David J MaletSpainStephen Shaw RENEWAL
Juan F GillianRussiaIoni Bowcher NEW
Francesco S AmigonJapanIvan Magalhaes PROPOSAL
David W PoquetteJapanAnna Fali NEGOTIATION
Francesco I DoeSpainAnna Fali NEGOTIATION
Kaitlin Z OldroydUnited KingdomAmy Elsner RENEWAL
Octavia E FigeroaItalyStephen Shaw NEW
Deepesh M StockhamJapanIoni Bowcher RENEWAL
Alejandro R BowleyItalyBernardo Dominic PROPOSAL
Nicolas Z KuskoIndiaBernardo Dominic RENEWAL
Darci J NestleRussiaIvan Magalhaes PROPOSAL
Stacey M StockhamJapanBernardo Dominic RENEWAL
Kaitlin N KolmetzGermanyAnna Fali NEGOTIATION
Frozen Columns
Name
Ricardo N Vocelka
James D Perin
Isabel G Gillian
Stacey D Dilliard
Ashley F Vocelka
James C Butt
Claire W Stockham
Faith T Shinko
Stacey J Oldroyd
Leon H Glick
Salvatore C Briddick
Stacey S Kolmetz
Aditya V Slusarski
Greenwood H Kusko
Aditya L Caldarera
Stacey P Paprocki
Jennifer O Figeroa
Nicolas N Briddick
Aditya G Kolmetz
Ashley T Slusarski
Kaitlin D Amigon
Wickens M Bolognia
Francesco P Stockham
Mujtaba B Royster
Jones Z Gaucho
Greenwood D Maclead
Izzy Q Rim
Aika J Waycott
Cody I Nicka
Faith J Butt
Faith X Glick
Greenwood U Venere
Johnson N Marrier
Antonio U Shinko
Stacey C Flosi
Silvio G Slusarski
Jennifer T Doe
Leja I Paprocki
Julie Z Doe
Antonio K Waycott
Jones S Inouye
Jeanfrancois J Morasca
Francesco G Bowley
Salvatore H Rim
Darci Y Ferencz
Kadeem N Stenseth
Rodrigues O Albares
Darci Y Malet
Darci R Sergi
Alejandro P Glick
IdCountryDate
1000France2024-04-04
1001Canada2024-04-21
1002Italy2024-03-27
1003Canada2024-04-23
1004Spain2024-04-08
1005India2024-04-17
1006India2024-04-05
1007India2024-04-04
1008Spain2024-04-13
1009Australia2024-04-01
1010United Kingdom2024-04-13
1011France2024-04-12
1012United Kingdom2024-03-31
1013Brazil2024-04-04
1014India2024-03-30
1015Argentina2024-04-10
1016United Kingdom2024-03-26
1017Canada2024-04-05
1018United Kingdom2024-04-10
1019Japan2024-04-10
1020Australia2024-04-22
1021United Kingdom2024-04-13
1022Australia2024-04-11
1023Italy2024-03-31
1024Australia2024-04-14
1025Canada2024-04-05
1026Italy2024-04-16
1027Argentina2024-03-31
1028Canada2024-04-11
1029France2024-04-02
1030France2024-03-27
1031Russia2024-04-21
1032India2024-04-06
1033Canada2024-04-09
1034Japan2024-04-18
1035Germany2024-03-26
1036Germany2024-04-16
1037Russia2024-04-11
1038Spain2024-04-07
1039Spain2024-04-14
1040India2024-04-11
1041United Kingdom2024-04-07
1042Italy2024-04-09
1043Argentina2024-04-11
1044Russia2024-04-21
1045Australia2024-03-31
1046United Kingdom2024-03-30
1047Brazil2024-03-27
1048Canada2024-04-14
1049Italy2024-03-31

On-Demand Data

NameIdCountryDate
Ashley V Vocelka1000Germany2024-03-30
Munro D Saylors1001Brazil2024-04-01
Cody H Vocelka1002Spain2024-04-10
Emily C Malet1003France2024-04-19
Francesco I Morasca1004Brazil2024-04-01
Leja L Gaucho1005Japan2024-04-18
Costa Q Campain1006Italy2024-04-24
Jennifer E Amigon1007Germany2024-03-29
Salvatore Y Wieser1008Canada2024-04-17
Jennifer D Vocelka1009Spain2024-04-17
Silvio U Rim1010United Kingdom2024-04-16
Aruna W Caldarera1011United Kingdom2024-03-30
Claire O Poquette1012Canada2024-04-09
Aika T Malet1013Argentina2024-03-28
Ricardo M Wieser1014United Kingdom2024-04-13
Deepesh S Gaucho1015Argentina2024-04-05
Wickens K Inouye1016Italy2024-04-02
Arvin P Bolognia1017United Kingdom2024-04-03
Mujtaba D Kusko1018Russia2024-04-09
Leon C Saylors1019Argentina2024-04-07
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aditya Q CampainArgentinaStephen Shaw UNQUALIFIED
Greenwood T GarufiCanadaIvan Magalhaes PROPOSAL
Aditya F FigeroaCanadaAnna Fali PROPOSAL
Deepesh B OldroydRussiaBernardo Dominic QUALIFIED
Johnson F PoquetteArgentinaElwin Sharvill RENEWAL
Ricardo D GauchoIndiaOnyama Limba NEGOTIATION
Francesco S WaycottCanadaIvan Magalhaes QUALIFIED
Wickens U InouyeAustraliaElwin Sharvill QUALIFIED
Cody B GarufiIndiaXuxue Feng QUALIFIED
Kaitlin K GillianRussiaAsiya Javayant RENEWAL
Tony U SergiCanadaAnna Fali NEGOTIATION
Faith G RutaRussiaAsiya Javayant NEW
Faith G MacleadSpainStephen Shaw RENEWAL
Leja M GauchoAustraliaAmy Elsner NEGOTIATION
David K FerenczGermanyIvan Magalhaes NEGOTIATION
Chavez D ButtCanadaIoni Bowcher UNQUALIFIED
Emily E NestleBrazilXuxue Feng PROPOSAL
Aditya D ShinkoJapanIvan Magalhaes RENEWAL
Aruna N SchemmerUnited KingdomStephen Shaw UNQUALIFIED
Faith F AlbaresSpainAsiya Javayant PROPOSAL
Aditya B WaycottGermanyElwin Sharvill RENEWAL
Clifford Q DilliardRussiaElwin Sharvill PROPOSAL
Francesco H SergiIndiaOnyama Limba QUALIFIED
Morrow B SergiSpainElwin Sharvill UNQUALIFIED
Juan O ButtIndiaAnna Fali UNQUALIFIED
Kadeem B ButtFranceIoni Bowcher NEW
Ricardo C ChuiSpainOnyama Limba PROPOSAL
Kadeem V RimArgentinaIoni Bowcher PROPOSAL
Claire K VenereGermanyAmy Elsner NEW
Mujtaba H GillianBrazilIoni Bowcher NEGOTIATION
Kadeem R StensethCanadaAsiya Javayant QUALIFIED
Stacey U MarrierRussiaElwin Sharvill RENEWAL
Isabel H ButtBrazilIvan Magalhaes PROPOSAL
Silvio Z KuskoRussiaAsiya Javayant PROPOSAL
Alejandro H SaylorsAustraliaXuxue Feng QUALIFIED
Mujtaba M SchemmerRussiaAmy Elsner RENEWAL
Wickens Z RoysterSpainElwin Sharvill QUALIFIED
Ricardo S DarakjyFranceElwin Sharvill RENEWAL
Darci E KuskoArgentinaAmy Elsner NEW
Aditya P NickaIndiaElwin Sharvill NEGOTIATION

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