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
Jefferson E WaycottArgentinaStephen Shaw UNQUALIFIED
Costa U MorascaRussiaAnna Fali NEW
Izzy A SaylorsGermanyBernardo Dominic QUALIFIED
Emily C BriddickGermanyBernardo Dominic PROPOSAL
Octavia C RulapaughCanadaIoni Bowcher RENEWAL
Ivar Y WieserGermanyIoni Bowcher NEGOTIATION
Leja B AlbaresSpainIoni Bowcher NEGOTIATION
Greenwood C AmigonIndiaAsiya Javayant RENEWAL
Ricardo T AlbaresAustraliaOnyama Limba QUALIFIED
Nicolas R FlosiFranceXuxue Feng PROPOSAL
Darci L GlickRussiaAmy Elsner NEW
Greenwood O CaldareraItalyElwin Sharvill PROPOSAL
Isabel I BriddickIndiaAsiya Javayant QUALIFIED
Salvatore Z WaycottSpainAnna Fali NEW
Mayumi F WieserCanadaStephen Shaw NEW
Deepesh V MorascaGermanyIvan Magalhaes NEGOTIATION
James E KolmetzSpainBernardo Dominic NEW
Tony G CaudyCanadaAnna Fali NEW
Juan S ChuiFranceElwin Sharvill NEW
Antonio C PerinSpainXuxue Feng NEW
Tony V FerenczCanadaBernardo Dominic RENEWAL
Kadeem V RutaItalyIoni Bowcher NEGOTIATION
Aika B NestleCanadaBernardo Dominic UNQUALIFIED
Wickens Z SlusarskiIndiaOnyama Limba NEGOTIATION
Munro M PaprockiItalyIoni Bowcher QUALIFIED
Ricardo G CaldareraGermanyAnna Fali PROPOSAL
Claire R DarakjyAustraliaIoni Bowcher UNQUALIFIED
Darci Y ShinkoJapanOnyama Limba UNQUALIFIED
Leon O GauchoCanadaAsiya Javayant PROPOSAL
Jones E KuskoGermanyAmy Elsner UNQUALIFIED
James U NestleItalyIvan Magalhaes UNQUALIFIED
Jefferson C MacleadGermanyAsiya Javayant PROPOSAL
Sinclair U MaletItalyXuxue Feng UNQUALIFIED
Antonio T StockhamCanadaIoni Bowcher RENEWAL
Antonio T WieserItalyBernardo Dominic RENEWAL
Kadeem G IturbideFranceStephen Shaw PROPOSAL
Darci C GarufiFranceXuxue Feng RENEWAL
Rodrigues Y CaudySpainElwin Sharvill NEGOTIATION
Misaki U TollnerItalyAmy Elsner NEGOTIATION
Nicolas S GillianIndiaAnna Fali NEGOTIATION
Wickens O FlosiFranceXuxue Feng NEGOTIATION
Clifford R CampainFranceOnyama Limba QUALIFIED
Rodrigues J StockhamItalyOnyama Limba UNQUALIFIED
Costa R ShinkoArgentinaAmy Elsner NEW
James T GillianItalyIoni Bowcher PROPOSAL
Clifford K StensethUnited KingdomStephen Shaw RENEWAL
Aika B CampainGermanyAmy Elsner UNQUALIFIED
Clifford K SaylorsFranceElwin Sharvill UNQUALIFIED
Misaki L MaletArgentinaBernardo Dominic PROPOSAL
Octavia J RulapaughAustraliaOnyama Limba RENEWAL
Horizontal
NameCountryRepresentativeStatus
Izzy K PoquetteAustraliaIoni Bowcher QUALIFIED
Faith Y RulapaughAustraliaAmy Elsner NEGOTIATION
Mujtaba R MorascaGermanyXuxue Feng NEGOTIATION
Misaki D RulapaughFranceIoni Bowcher NEW
Smith N FigeroaGermanyXuxue Feng NEGOTIATION
Ashley K PaprockiCanadaAnna Fali NEW
Ashley J InouyeFranceAmy Elsner RENEWAL
James S GauchoFranceAnna Fali NEW
Tony D StensethIndiaAnna Fali UNQUALIFIED
Salvatore V AlbaresAustraliaElwin Sharvill RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Cody F KolmetzAustralia2024-04-24Rangoni Of Florence QUALIFIED35Ivan Magalhaes
1001Morrow P OldroydItaly2024-03-29Truhlar And Truhlar Attys NEGOTIATION52Anna Fali
1002Ricardo T RutaUnited Kingdom2024-04-08Feiner Bros PROPOSAL86Anna Fali
1003David U ChuiRussia2024-04-10Rousseaux, Michael Esq NEW20Asiya Javayant
1004Ivar P DarakjyIndia2024-04-14Chanay, Jeffrey A Esq RENEWAL97Amy Elsner
1005Mujtaba X MarrierBrazil2024-04-20Dorl, James J Esq NEGOTIATION21Elwin Sharvill
1006David R MacleadJapan2024-04-10King, Christopher A Esq PROPOSAL51Elwin Sharvill
1007Chavez A ShinkoItaly2024-04-01Buckley Miller Wright UNQUALIFIED76Bernardo Dominic
1008Adams E MaletFrance2024-04-08King, Christopher A Esq UNQUALIFIED55Amy Elsner
1009Tony P FerenczFrance2024-04-16Benton, John B Jr RENEWAL48Onyama Limba
1010Silvio Y PoquetteBrazil2024-04-24Dorl, James J Esq NEW40Bernardo Dominic
1011Alejandro I GauchoItaly2024-04-07Chanay, Jeffrey A Esq PROPOSAL64Stephen Shaw
1012Ricardo X AmigonAustralia2024-04-13Morlong Associates RENEWAL76Stephen Shaw
1013Faith I GauchoBrazil2024-04-24Rangoni Of Florence RENEWAL17Bernardo Dominic
1014Murillo H StockhamGermany2024-03-31Chemel, James L Cpa NEW96Stephen Shaw
1015Darci Q WaycottIndia2024-04-05Morlong Associates NEGOTIATION58Stephen Shaw
1016Juan B FollerUnited Kingdom2024-03-28Feltz Printing Service RENEWAL16Elwin Sharvill
1017Aika I CaldareraFrance2024-04-12Feiner Bros QUALIFIED86Bernardo Dominic
1018Salvatore X WieserUnited Kingdom2024-04-07Benton, John B Jr UNQUALIFIED59Ioni Bowcher
1019Aika Z PaprockiSpain2024-04-23Rangoni Of Florence UNQUALIFIED1Anna Fali
1020Mayumi L RulapaughFrance2024-04-02Buckley Miller Wright UNQUALIFIED78Anna Fali
1021Adams W TollnerGermany2024-03-29Commercial Press NEW67Amy Elsner
1022Costa B NickaRussia2024-03-28Printing Dimensions NEGOTIATION48Asiya Javayant
1023Claire Z GauchoIndia2024-04-22Rousseaux, Michael Esq PROPOSAL26Asiya Javayant
1024Juan R GillianFrance2024-04-19Buckley Miller Wright QUALIFIED27Onyama Limba
1025Aika Y GillianIndia2024-04-02Truhlar And Truhlar Attys NEW51Stephen Shaw
1026Kadeem Y ChuiRussia2024-04-22Morlong Associates RENEWAL32Amy Elsner
1027Misaki D NickaIndia2024-04-04Feiner Bros NEGOTIATION14Xuxue Feng
1028Jeanfrancois X WhobreyJapan2024-04-02Truhlar And Truhlar Attys PROPOSAL8Stephen Shaw
1029Cody A RimFrance2024-04-19Feiner Bros RENEWAL25Xuxue Feng
1030Jeanfrancois W FerenczJapan2024-04-09Buckley Miller Wright PROPOSAL68Ioni Bowcher
1031Arvin M GillianItaly2024-04-16Chanay, Jeffrey A Esq PROPOSAL36Ioni Bowcher
1032Leja X PoquetteJapan2024-04-05Printing Dimensions PROPOSAL30Elwin Sharvill
1033Aditya I SchemmerRussia2024-04-03Feiner Bros NEW9Ioni Bowcher
1034Greenwood S DarakjyBrazil2024-03-30Feiner Bros UNQUALIFIED86Amy Elsner
1035Ivar S WaycottGermany2024-04-01Feltz Printing Service QUALIFIED87Asiya Javayant
1036Morrow W GauchoGermany2024-04-06Dorl, James J Esq PROPOSAL5Bernardo Dominic
1037Izzy R CaldareraItaly2024-04-23Feltz Printing Service QUALIFIED12Ioni Bowcher
1038Jones K BowleyJapan2024-04-10Rangoni Of Florence UNQUALIFIED33Elwin Sharvill
1039Morrow Q GlickJapan2024-04-16Commercial Press NEGOTIATION12Asiya Javayant
1040Aditya N OstroskyAustralia2024-04-08Morlong Associates UNQUALIFIED97Stephen Shaw
1041Greenwood L CaldareraBrazil2024-03-31Morlong Associates PROPOSAL87Anna Fali
1042Salvatore X CaldareraItaly2024-04-15Chanay, Jeffrey A Esq RENEWAL62Asiya Javayant
1043Mujtaba N RulapaughGermany2024-04-19Rangoni Of Florence NEW37Onyama Limba
1044Faith T RutaGermany2024-04-02King, Christopher A Esq NEW38Ioni Bowcher
1045Alejandro R OstroskyAustralia2024-04-06Chemel, James L Cpa UNQUALIFIED67Ioni Bowcher
1046Izzy C RimRussia2024-04-20Feltz Printing Service PROPOSAL70Ioni Bowcher
1047Darci K SchemmerJapan2024-04-23Commercial Press NEW36Stephen Shaw
1048David S FollerFrance2024-04-10Rousseaux, Michael Esq QUALIFIED22Ioni Bowcher
1049Rodrigues L CaldareraFrance2024-03-30Commercial Press NEGOTIATION41Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Mayumi M IturbideArgentinaBernardo Dominic UNQUALIFIED
Ivar S DarakjyBrazilBernardo Dominic NEW
Maisha W MacleadCanadaXuxue Feng NEW
Aditya A ShinkoIndiaXuxue Feng RENEWAL
Leon M FlosiSpainIoni Bowcher RENEWAL
Arvin Q VocelkaItalyStephen Shaw UNQUALIFIED
Morrow V MaletGermanyStephen Shaw QUALIFIED
Claire W DilliardJapanAmy Elsner PROPOSAL
Mayumi H BriddickIndiaOnyama Limba QUALIFIED
Aika X MaletAustraliaIvan Magalhaes RENEWAL
Clifford I ButtRussiaAsiya Javayant NEGOTIATION
Adams W BologniaAustraliaElwin Sharvill QUALIFIED
Ricardo R FlosiRussiaAsiya Javayant PROPOSAL
Sinclair N SergiGermanyIoni Bowcher PROPOSAL
Stacey Q WhobreyRussiaOnyama Limba RENEWAL
Ricardo Z GauchoBrazilAnna Fali QUALIFIED
Isabel V VenereUnited KingdomAsiya Javayant RENEWAL
Faith T IturbideCanadaIvan Magalhaes QUALIFIED
Sinclair Y IturbideIndiaStephen Shaw UNQUALIFIED
Mayumi D RimArgentinaXuxue Feng PROPOSAL
Jennifer G SchemmerSpainAnna Fali QUALIFIED
Rodrigues Z ChuiRussiaIvan Magalhaes QUALIFIED
Rodrigues O BowleyAustraliaBernardo Dominic UNQUALIFIED
Octavia P VocelkaBrazilIoni Bowcher NEW
Jeanfrancois Y RimBrazilAsiya Javayant QUALIFIED
Ricardo A InouyeBrazilIvan Magalhaes QUALIFIED
Sinclair E InouyeGermanyXuxue Feng NEW
Chavez W AlbaresArgentinaXuxue Feng QUALIFIED
Jefferson M DoeItalyIvan Magalhaes NEW
Jefferson W FlosiCanadaStephen Shaw UNQUALIFIED
Jennifer P DarakjyItalyElwin Sharvill NEW
Maisha Z BologniaCanadaIoni Bowcher PROPOSAL
Juan A RutaAustraliaXuxue Feng UNQUALIFIED
Silvio Y MorascaAustraliaXuxue Feng PROPOSAL
Maria Z BowleySpainOnyama Limba UNQUALIFIED
Julie Q BowleyArgentinaIvan Magalhaes QUALIFIED
Salvatore C BriddickItalyOnyama Limba QUALIFIED
Chavez M RutaAustraliaElwin Sharvill NEW
Kaitlin W GauchoCanadaXuxue Feng UNQUALIFIED
Ashley I WieserAustraliaAmy Elsner UNQUALIFIED
Aditya M AlbaresIndiaStephen Shaw PROPOSAL
Jefferson Z IturbideSpainAmy Elsner UNQUALIFIED
Ivar J DilliardAustraliaAsiya Javayant RENEWAL
Aruna O CaldareraCanadaXuxue Feng QUALIFIED
Chavez N OldroydArgentinaIoni Bowcher RENEWAL
Aruna N WhobreyCanadaAnna Fali RENEWAL
Julie T NestleIndiaElwin Sharvill RENEWAL
Aika L VocelkaIndiaAmy Elsner NEW
Isabel T ButtSpainBernardo Dominic UNQUALIFIED
Arvin L FlosiCanadaOnyama Limba QUALIFIED
Frozen Columns
Name
Chavez Q Dilliard
Claire P Saylors
Darci F Albares
Rodrigues P Slusarski
Greenwood I Oldroyd
Izzy R Slusarski
Clifford I Campain
Antonio E Saylors
Faith R Iturbide
Faith V Wieser
Maisha H Malet
Aika M Marrier
Silvio U Bowley
Ricardo U Malet
Juan Y Doe
Deepesh I Doe
Juan A Shinko
Maria U Perin
Jones H Vocelka
Deepesh Q Vocelka
Jones Y Stenseth
Leon M Marrier
Sinclair N Bowley
Claire R Albares
Julie K Flosi
Jeanfrancois I Briddick
Jones S Albares
Leon N Rim
James O Maclead
Isabel O Figeroa
Aika A Shinko
Kadeem V Foller
Izzy C Ruta
Adams H Rulapaugh
Ashley J Figeroa
Mayumi C Saylors
Sinclair U Caldarera
Johnson C Poquette
Leon N Waycott
Mayumi Z Wieser
Jefferson V Briddick
Emily O Caldarera
Murillo Y Nicka
Antonio Z Butt
James D Figeroa
Kaitlin Q Oldroyd
Aditya H Campain
Octavia C Nestle
David G Darakjy
Maria K Ruta
IdCountryDate
1000India2024-04-06
1001India2024-04-19
1002Brazil2024-04-03
1003Argentina2024-04-24
1004France2024-04-15
1005Russia2024-04-01
1006Brazil2024-04-17
1007Argentina2024-04-19
1008United Kingdom2024-03-27
1009Brazil2024-03-31
1010Argentina2024-03-26
1011Spain2024-04-24
1012France2024-04-08
1013Germany2024-04-18
1014Japan2024-03-27
1015Brazil2024-04-22
1016Canada2024-04-23
1017Canada2024-03-27
1018France2024-04-11
1019Brazil2024-04-21
1020France2024-04-08
1021United Kingdom2024-04-02
1022India2024-03-26
1023Germany2024-04-09
1024Japan2024-04-08
1025Germany2024-03-30
1026France2024-03-29
1027Australia2024-03-26
1028Japan2024-04-06
1029Canada2024-04-09
1030Argentina2024-04-08
1031Brazil2024-04-16
1032Japan2024-04-21
1033Spain2024-03-28
1034Russia2024-04-22
1035India2024-03-30
1036Brazil2024-04-07
1037Spain2024-04-08
1038Argentina2024-04-21
1039Italy2024-04-10
1040France2024-04-07
1041Italy2024-04-04
1042Australia2024-04-23
1043Canada2024-04-05
1044Russia2024-04-15
1045India2024-03-29
1046India2024-03-30
1047Italy2024-03-26
1048Russia2024-04-21
1049Japan2024-03-26

On-Demand Data

NameIdCountryDate
Francesco G Vocelka1000France2024-04-21
Darci J Chui1001Spain2024-04-12
Aruna J Gillian1002United Kingdom2024-04-06
Rodrigues R Butt1003India2024-04-17
Costa M Doe1004Brazil2024-04-15
Maria U Malet1005Japan2024-04-09
Kaitlin W Campain1006United Kingdom2024-04-23
Emily L Campain1007Italy2024-04-16
James U Caudy1008India2024-04-03
Smith Y Nestle1009Argentina2024-03-26
Alejandro Y Sergi1010India2024-04-21
Costa I Caudy1011France2024-04-12
Leja W Morasca1012United Kingdom2024-04-21
Octavia B Schemmer1013Italy2024-04-02
David S Bowley1014Italy2024-04-24
Deepesh L Flosi1015Brazil2024-03-26
Stacey L Royster1016France2024-04-20
Costa V Bolognia1017Russia2024-04-23
Mujtaba F Marrier1018Japan2024-03-28
Cody Z Inouye1019Brazil2024-03-30
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Faith Q KolmetzArgentinaAmy Elsner NEGOTIATION
Mayumi A VenereItalyXuxue Feng UNQUALIFIED
James P MaletGermanyAnna Fali PROPOSAL
Ivar C RutaGermanyAsiya Javayant QUALIFIED
Arvin Q ShinkoFranceAmy Elsner NEW
Munro I IturbideFranceBernardo Dominic UNQUALIFIED
Salvatore L VocelkaRussiaXuxue Feng NEGOTIATION
Darci U ButtBrazilAmy Elsner PROPOSAL
Francesco H DarakjyAustraliaAsiya Javayant NEGOTIATION
Jeanfrancois R ButtRussiaIvan Magalhaes UNQUALIFIED
Cody L FlosiBrazilElwin Sharvill UNQUALIFIED
Jefferson J BriddickIndiaAnna Fali QUALIFIED
Claire S VenereSpainBernardo Dominic RENEWAL
Aruna B NickaUnited KingdomIoni Bowcher UNQUALIFIED
Alejandro G SaylorsJapanIoni Bowcher QUALIFIED
Alejandro N BologniaAustraliaXuxue Feng QUALIFIED
Costa W StockhamIndiaIvan Magalhaes NEW
Mayumi N AmigonIndiaAmy Elsner UNQUALIFIED
Francesco P SlusarskiBrazilIoni Bowcher QUALIFIED
Mujtaba W NickaUnited KingdomAsiya Javayant RENEWAL
Aruna R WhobreyItalyAsiya Javayant RENEWAL
Ricardo K InouyeUnited KingdomStephen Shaw QUALIFIED
Ashley X GarufiItalyAsiya Javayant NEGOTIATION
Misaki N CampainJapanBernardo Dominic NEGOTIATION
Clifford B CampainJapanElwin Sharvill NEW
Maria Z SchemmerRussiaOnyama Limba RENEWAL
Costa B RutaArgentinaStephen Shaw NEGOTIATION
Mayumi H FlosiRussiaStephen Shaw RENEWAL
Mayumi Q PaprockiRussiaXuxue Feng NEW
Aika U BriddickFranceAnna Fali QUALIFIED
Murillo R AmigonCanadaOnyama Limba NEGOTIATION
Aditya H FollerItalyOnyama Limba PROPOSAL
James K RimBrazilIoni Bowcher QUALIFIED
Munro S MaletIndiaBernardo Dominic NEW
Johnson Q ChuiSpainStephen Shaw RENEWAL
Costa X ButtArgentinaXuxue Feng NEGOTIATION
Kaitlin Q GarufiItalyIoni Bowcher RENEWAL
Mayumi I GauchoUnited KingdomIoni Bowcher NEW
Tony Q WieserIndiaXuxue Feng RENEWAL
Faith K CampainJapanIoni Bowcher QUALIFIED

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