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
Stacey K PaprockiFranceXuxue Feng PROPOSAL
David G SergiArgentinaIoni Bowcher NEW
Ashley A MaletJapanAsiya Javayant RENEWAL
Ricardo W RimFranceOnyama Limba RENEWAL
Maria Z GauchoArgentinaStephen Shaw UNQUALIFIED
Jeanfrancois J KuskoFranceElwin Sharvill UNQUALIFIED
Francesco E ShinkoSpainBernardo Dominic QUALIFIED
Alejandro S StensethRussiaOnyama Limba NEGOTIATION
Jeanfrancois N MarrierBrazilXuxue Feng RENEWAL
Jennifer D CaudyGermanyXuxue Feng NEW
Ricardo W StensethFranceIoni Bowcher RENEWAL
Octavia Y AmigonFranceAsiya Javayant RENEWAL
Sinclair S InouyeCanadaAmy Elsner RENEWAL
Silvio V SergiSpainIoni Bowcher PROPOSAL
James S NickaUnited KingdomAnna Fali NEGOTIATION
Juan I PoquetteItalyElwin Sharvill NEW
Johnson F FollerAustraliaIvan Magalhaes NEGOTIATION
James V OstroskySpainIvan Magalhaes PROPOSAL
Juan N NestleUnited KingdomElwin Sharvill NEW
Octavia K IturbideGermanyXuxue Feng QUALIFIED
Costa O SergiArgentinaIvan Magalhaes NEW
Isabel R FlosiFranceElwin Sharvill NEGOTIATION
Antonio G FlosiAustraliaIoni Bowcher RENEWAL
Ricardo F WaycottCanadaIoni Bowcher NEW
Adams L MarrierFranceBernardo Dominic NEW
Salvatore C BowleyGermanyXuxue Feng NEGOTIATION
Francesco A MaletIndiaBernardo Dominic UNQUALIFIED
Ivar E IturbideBrazilXuxue Feng RENEWAL
Alejandro G SchemmerArgentinaBernardo Dominic NEW
Jefferson A DarakjyItalyAmy Elsner PROPOSAL
Deepesh W BowleyArgentinaIvan Magalhaes RENEWAL
Ashley L MarrierSpainBernardo Dominic NEGOTIATION
Alejandro V PoquetteArgentinaElwin Sharvill PROPOSAL
Claire N StockhamGermanyStephen Shaw RENEWAL
Nicolas C ButtIndiaIoni Bowcher NEW
Izzy C RoysterJapanIoni Bowcher RENEWAL
Ashley X SergiRussiaAnna Fali QUALIFIED
Greenwood X ChuiUnited KingdomAsiya Javayant NEW
Ricardo O OldroydBrazilAsiya Javayant UNQUALIFIED
Leon P FigeroaFranceOnyama Limba UNQUALIFIED
Cody P GarufiRussiaElwin Sharvill NEGOTIATION
Faith M InouyeGermanyAmy Elsner QUALIFIED
Maria G BowleyIndiaAmy Elsner NEGOTIATION
Clifford X TollnerAustraliaAsiya Javayant QUALIFIED
Munro S MarrierJapanAnna Fali QUALIFIED
Jefferson R MarrierJapanIoni Bowcher NEW
Mayumi S KolmetzAustraliaStephen Shaw UNQUALIFIED
Izzy O StockhamBrazilBernardo Dominic UNQUALIFIED
Izzy S BowleyGermanyBernardo Dominic QUALIFIED
Arvin C DarakjyJapanElwin Sharvill PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Murillo A SlusarskiJapanElwin Sharvill UNQUALIFIED
Claire M OstroskyItalyElwin Sharvill UNQUALIFIED
Ricardo T RutaRussiaStephen Shaw NEGOTIATION
Cody N DoeSpainAmy Elsner NEW
Cody S RoysterArgentinaXuxue Feng UNQUALIFIED
Misaki C SaylorsCanadaAnna Fali QUALIFIED
Costa Y NickaUnited KingdomIoni Bowcher UNQUALIFIED
Ricardo M GarufiGermanyAsiya Javayant UNQUALIFIED
Jennifer P RulapaughItalyBernardo Dominic RENEWAL
Leja I ChuiCanadaXuxue Feng NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Cody Y GauchoArgentina2024-04-10Feltz Printing Service PROPOSAL91Ioni Bowcher
1001Ashley P MorascaAustralia2024-04-19Rangoni Of Florence PROPOSAL68Ioni Bowcher
1002Silvio U PoquetteItaly2024-04-04Commercial Press RENEWAL20Elwin Sharvill
1003Tony K RimBrazil2024-04-14Chapman, Ross E Esq NEW2Elwin Sharvill
1004Leon C RoysterGermany2024-04-14Printing Dimensions NEGOTIATION48Elwin Sharvill
1005Octavia Q GauchoJapan2024-04-23Chemel, James L Cpa NEW11Anna Fali
1006Deepesh D ChuiFrance2024-04-16Chapman, Ross E Esq RENEWAL96Xuxue Feng
1007Kadeem T CampainRussia2024-04-16Dorl, James J Esq QUALIFIED34Amy Elsner
1008Adams G BowleyIndia2024-04-14Chapman, Ross E Esq QUALIFIED21Ioni Bowcher
1009Nicolas A PerinGermany2024-04-05Feltz Printing Service PROPOSAL52Xuxue Feng
1010Juan G MaletGermany2024-04-23Truhlar And Truhlar Attys PROPOSAL35Stephen Shaw
1011Costa G OldroydItaly2024-04-23Chanay, Jeffrey A Esq NEW95Asiya Javayant
1012Octavia M RoysterFrance2024-04-22Feltz Printing Service QUALIFIED62Stephen Shaw
1013Mayumi G SchemmerIndia2024-03-30Feltz Printing Service RENEWAL95Amy Elsner
1014Johnson I PoquetteCanada2024-04-25Commercial Press UNQUALIFIED55Bernardo Dominic
1015Munro Y BologniaSpain2024-04-13Commercial Press QUALIFIED60Ivan Magalhaes
1016Silvio U WhobreyAustralia2024-04-14Rangoni Of Florence UNQUALIFIED43Bernardo Dominic
1017Ashley O RoysterSpain2024-04-02Chapman, Ross E Esq PROPOSAL52Onyama Limba
1018Stacey B ButtAustralia2024-04-10Benton, John B Jr PROPOSAL52Elwin Sharvill
1019Mujtaba A PoquetteGermany2024-04-05Morlong Associates NEW72Stephen Shaw
1020Francesco S WaycottArgentina2024-04-16Morlong Associates NEGOTIATION71Asiya Javayant
1021Rodrigues J RoysterArgentina2024-03-29Rangoni Of Florence NEGOTIATION88Amy Elsner
1022Leon A StensethUnited Kingdom2024-04-10Feiner Bros UNQUALIFIED45Ioni Bowcher
1023Chavez G KuskoArgentina2024-04-06Benton, John B Jr QUALIFIED16Elwin Sharvill
1024Aditya U GarufiArgentina2024-04-18Commercial Press NEW22Asiya Javayant
1025Ashley S GarufiFrance2024-04-19Benton, John B Jr PROPOSAL33Xuxue Feng
1026Ashley A VocelkaArgentina2024-04-24Feltz Printing Service UNQUALIFIED69Onyama Limba
1027Octavia D MaletItaly2024-04-16Printing Dimensions QUALIFIED34Bernardo Dominic
1028Emily H SaylorsSpain2024-03-29Commercial Press NEW50Xuxue Feng
1029Emily D SlusarskiAustralia2024-04-01King, Christopher A Esq RENEWAL57Ioni Bowcher
1030Aditya T RoysterArgentina2024-04-01Chanay, Jeffrey A Esq QUALIFIED71Onyama Limba
1031Cody D CaldareraArgentina2024-04-19Printing Dimensions QUALIFIED25Asiya Javayant
1032Aika S PaprockiAustralia2024-03-30Chapman, Ross E Esq RENEWAL34Elwin Sharvill
1033Jefferson C NickaBrazil2024-04-21Feltz Printing Service UNQUALIFIED13Ivan Magalhaes
1034Chavez I WaycottGermany2024-04-14Benton, John B Jr QUALIFIED56Elwin Sharvill
1035Johnson T WieserSpain2024-04-07Benton, John B Jr RENEWAL88Asiya Javayant
1036Alejandro Y GlickItaly2024-04-18Morlong Associates UNQUALIFIED81Onyama Limba
1037Nicolas R NickaItaly2024-04-13Chapman, Ross E Esq PROPOSAL36Anna Fali
1038Adams F BowleyIndia2024-04-01Commercial Press UNQUALIFIED1Asiya Javayant
1039Greenwood R CampainUnited Kingdom2024-04-08Benton, John B Jr QUALIFIED56Elwin Sharvill
1040Deepesh R RimArgentina2024-04-18Benton, John B Jr QUALIFIED91Stephen Shaw
1041Greenwood B GlickArgentina2024-04-11Benton, John B Jr PROPOSAL71Ivan Magalhaes
1042Arvin W MorascaAustralia2024-04-01Rousseaux, Michael Esq NEGOTIATION76Elwin Sharvill
1043Ashley U CaudyItaly2024-04-11Feltz Printing Service NEGOTIATION73Onyama Limba
1044Ashley X GarufiGermany2024-04-15Rousseaux, Michael Esq NEW12Amy Elsner
1045Octavia W KuskoFrance2024-04-01Morlong Associates RENEWAL95Xuxue Feng
1046Adams B KuskoItaly2024-04-03Chemel, James L Cpa NEW37Amy Elsner
1047Mujtaba G KuskoUnited Kingdom2024-03-28Printing Dimensions UNQUALIFIED82Ioni Bowcher
1048Ricardo O GillianUnited Kingdom2024-04-12Dorl, James J Esq PROPOSAL14Ioni Bowcher
1049Rodrigues W DilliardSpain2024-04-04Buckley Miller Wright QUALIFIED87Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Mayumi R FerenczFranceAsiya Javayant NEW
Silvio E SchemmerJapanIvan Magalhaes RENEWAL
Aditya R ChuiAustraliaAmy Elsner RENEWAL
Greenwood L SchemmerCanadaAmy Elsner QUALIFIED
Aditya Y IturbideUnited KingdomAmy Elsner QUALIFIED
Morrow L SergiBrazilXuxue Feng QUALIFIED
Jennifer F FerenczSpainOnyama Limba UNQUALIFIED
Misaki V OstroskyFranceAmy Elsner RENEWAL
James B SchemmerBrazilStephen Shaw RENEWAL
Aditya G SergiSpainElwin Sharvill RENEWAL
Kadeem P AmigonCanadaAmy Elsner RENEWAL
Ricardo C AmigonCanadaStephen Shaw QUALIFIED
Salvatore R BologniaRussiaAsiya Javayant NEGOTIATION
Rodrigues Y PaprockiJapanXuxue Feng QUALIFIED
Rodrigues R MacleadFranceAmy Elsner UNQUALIFIED
Leon B IturbideBrazilIoni Bowcher NEW
Darci T StockhamUnited KingdomAnna Fali PROPOSAL
James K SchemmerJapanStephen Shaw UNQUALIFIED
Salvatore C KolmetzSpainIvan Magalhaes NEW
Aruna E AlbaresArgentinaAsiya Javayant NEW
Stacey W GlickJapanElwin Sharvill PROPOSAL
James H GlickAustraliaBernardo Dominic NEGOTIATION
Julie E WhobreyUnited KingdomStephen Shaw NEGOTIATION
Wickens A OldroydIndiaBernardo Dominic NEGOTIATION
James A KuskoRussiaElwin Sharvill PROPOSAL
Morrow K DilliardSpainIvan Magalhaes NEW
Leja C BriddickItalyIoni Bowcher NEW
Alejandro E ChuiUnited KingdomAmy Elsner RENEWAL
Octavia R FollerArgentinaIoni Bowcher QUALIFIED
Emily H ShinkoArgentinaAnna Fali QUALIFIED
Ashley J SergiFranceAnna Fali NEW
Isabel W FlosiRussiaAnna Fali UNQUALIFIED
Wickens V AmigonBrazilAmy Elsner NEW
Izzy G FollerBrazilAnna Fali RENEWAL
Alejandro Z ButtGermanyAnna Fali RENEWAL
Murillo O PaprockiAustraliaOnyama Limba NEW
Aika J RimAustraliaOnyama Limba NEW
Ashley Q BologniaArgentinaStephen Shaw PROPOSAL
Aruna O VocelkaJapanAsiya Javayant NEW
Mayumi L DilliardBrazilAnna Fali QUALIFIED
James Z GauchoRussiaAmy Elsner UNQUALIFIED
Silvio X StensethArgentinaStephen Shaw NEGOTIATION
Rodrigues B DoeSpainAsiya Javayant PROPOSAL
Morrow B ShinkoItalyStephen Shaw NEW
Jones S CaldareraArgentinaIoni Bowcher NEW
Aruna B FollerArgentinaAsiya Javayant NEW
Alejandro F GillianArgentinaAnna Fali NEGOTIATION
Morrow Z RoysterJapanStephen Shaw NEGOTIATION
Aika W MaletSpainStephen Shaw PROPOSAL
Salvatore T AlbaresFranceStephen Shaw QUALIFIED
Frozen Columns
Name
Mayumi Q Inouye
Nicolas K Malet
Nicolas D Doe
Darci R Poquette
Emily J Inouye
Stacey B Stenseth
Leja U Flosi
Claire W Kusko
Mayumi W Albares
Deepesh V Kolmetz
Izzy A Vocelka
Maisha F Albares
Isabel V Flosi
Aruna R Ferencz
Francesco N Malet
Silvio V Ferencz
Jeanfrancois Q Rulapaugh
Mujtaba N Poquette
Izzy H Shinko
Kaitlin Y Kusko
Wickens A Dilliard
Tony N Ferencz
Murillo K Garufi
Antonio N Bolognia
Maria Q Flosi
Munro L Stenseth
Kadeem X Briddick
Chavez X Kolmetz
Claire I Foller
Aruna J Marrier
Darci F Campain
Jeanfrancois B Gillian
Jones X Slusarski
Jeanfrancois Y Oldroyd
Stacey D Rim
Salvatore N Tollner
Maisha H Ferencz
Murillo P Glick
Darci F Royster
Izzy B Butt
Faith H Vocelka
Deepesh V Slusarski
Leja R Rulapaugh
Ashley M Maclead
Aruna Q Stenseth
Stacey Z Flosi
Maria L Royster
Aditya I Foller
Greenwood V Rim
Smith D Campain
IdCountryDate
1000France2024-04-09
1001Japan2024-03-31
1002Australia2024-04-19
1003Italy2024-04-19
1004Russia2024-04-19
1005Canada2024-04-14
1006France2024-04-23
1007Canada2024-04-21
1008Spain2024-04-04
1009Germany2024-04-16
1010Germany2024-04-04
1011Germany2024-04-19
1012France2024-04-22
1013Japan2024-04-04
1014Russia2024-04-12
1015Italy2024-03-31
1016Italy2024-04-26
1017Canada2024-04-05
1018Germany2024-04-12
1019Australia2024-04-25
1020Australia2024-04-04
1021Brazil2024-04-05
1022Canada2024-04-10
1023Canada2024-03-28
1024Spain2024-04-08
1025Canada2024-04-25
1026Australia2024-04-13
1027India2024-04-15
1028Japan2024-04-15
1029Spain2024-04-18
1030Brazil2024-04-12
1031Argentina2024-04-20
1032Italy2024-04-10
1033Australia2024-04-11
1034United Kingdom2024-04-03
1035Japan2024-04-21
1036Japan2024-04-10
1037Canada2024-04-21
1038Canada2024-04-11
1039Canada2024-04-17
1040Argentina2024-04-04
1041India2024-04-02
1042Argentina2024-04-05
1043Spain2024-03-29
1044Canada2024-04-08
1045Italy2024-04-23
1046Brazil2024-04-20
1047United Kingdom2024-04-20
1048Japan2024-04-04
1049Spain2024-04-19

On-Demand Data

NameIdCountryDate
Aruna B Ruta1000Italy2024-04-20
Deepesh F Perin1001Germany2024-04-08
Jones D Schemmer1002Australia2024-04-14
Adams U Gaucho1003Brazil2024-04-09
Deepesh B Saylors1004Italy2024-04-20
Jennifer F Doe1005United Kingdom2024-04-08
Munro O Bolognia1006Italy2024-04-15
Mayumi S Ferencz1007Italy2024-04-21
James B Bolognia1008Russia2024-03-30
Murillo S Vocelka1009Italy2024-04-10
Juan G Amigon1010Argentina2024-04-04
Cody D Wieser1011India2024-04-09
Ricardo Q Poquette1012Japan2024-04-23
Octavia O Amigon1013Argentina2024-04-07
Arvin X Stenseth1014Spain2024-04-10
Maria A Chui1015Japan2024-03-31
Silvio F Briddick1016Italy2024-04-25
Francesco R Amigon1017United Kingdom2024-04-03
Darci U Morasca1018Japan2024-04-16
Kaitlin E Butt1019Brazil2024-04-20
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Octavia Q MacleadGermanyOnyama Limba NEW
Octavia R RoysterFranceIoni Bowcher NEGOTIATION
Izzy K CaldareraAustraliaIvan Magalhaes QUALIFIED
Cody M StensethJapanAsiya Javayant UNQUALIFIED
Claire E FerenczRussiaXuxue Feng RENEWAL
Chavez R AlbaresIndiaBernardo Dominic NEW
Wickens P MacleadJapanOnyama Limba PROPOSAL
Cody X WaycottFranceAnna Fali NEGOTIATION
Chavez M FigeroaUnited KingdomXuxue Feng QUALIFIED
Jefferson F InouyeCanadaIoni Bowcher NEGOTIATION
Claire K RimRussiaAmy Elsner QUALIFIED
Sinclair W GauchoSpainStephen Shaw UNQUALIFIED
Leja C OstroskyFranceStephen Shaw QUALIFIED
Murillo H StensethJapanAmy Elsner NEW
Rodrigues P StensethFranceAnna Fali PROPOSAL
Juan W SlusarskiIndiaElwin Sharvill PROPOSAL
Kadeem P BowleyAustraliaElwin Sharvill NEGOTIATION
Mayumi R FerenczJapanAnna Fali PROPOSAL
Costa K GauchoGermanyXuxue Feng PROPOSAL
Octavia I MorascaArgentinaXuxue Feng RENEWAL
Ashley Z PerinBrazilAmy Elsner NEW
Adams J SlusarskiJapanStephen Shaw NEGOTIATION
Ricardo B GarufiRussiaOnyama Limba QUALIFIED
Smith V MarrierCanadaXuxue Feng PROPOSAL
Alejandro N ButtSpainIoni Bowcher RENEWAL
Ricardo E WhobreyCanadaAsiya Javayant UNQUALIFIED
Kadeem S AmigonItalyXuxue Feng PROPOSAL
Murillo W MaletSpainAsiya Javayant QUALIFIED
Isabel G BriddickJapanAmy Elsner NEGOTIATION
Claire L TollnerArgentinaAmy Elsner PROPOSAL
Ricardo F WieserArgentinaAmy Elsner UNQUALIFIED
Ashley D GarufiUnited KingdomBernardo Dominic NEGOTIATION
Julie W WieserRussiaAsiya Javayant NEW
Jeanfrancois F KuskoFranceStephen Shaw QUALIFIED
Octavia S ButtJapanOnyama Limba RENEWAL
Deepesh O GlickAustraliaBernardo Dominic NEW
Munro X AlbaresFranceAmy Elsner RENEWAL
Cody T MorascaAustraliaAsiya Javayant QUALIFIED
Aika Q OldroydJapanBernardo Dominic NEGOTIATION
Stacey E PaprockiFranceAmy Elsner 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>