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
Wickens P StensethJapanAnna Fali NEW
Costa J StockhamUnited KingdomIoni Bowcher NEGOTIATION
Alejandro P RimJapanOnyama Limba UNQUALIFIED
James G WhobreyBrazilAmy Elsner NEW
Adams C VenereItalyOnyama Limba NEW
Salvatore O SlusarskiIndiaAnna Fali NEW
Sinclair E SchemmerFranceAnna Fali NEGOTIATION
Adams O VenereItalyBernardo Dominic UNQUALIFIED
Aika H KolmetzIndiaBernardo Dominic UNQUALIFIED
Rodrigues P CaldareraJapanOnyama Limba UNQUALIFIED
Ivar Y WaycottSpainBernardo Dominic PROPOSAL
Kaitlin A GillianAustraliaBernardo Dominic UNQUALIFIED
Ivar N RutaAustraliaAnna Fali NEW
Claire R GarufiAustraliaBernardo Dominic RENEWAL
Deepesh X VocelkaFranceBernardo Dominic QUALIFIED
Misaki M MaletBrazilAmy Elsner RENEWAL
Mayumi F CampainSpainAsiya Javayant NEGOTIATION
Maisha A OldroydItalyBernardo Dominic UNQUALIFIED
Ricardo Z OldroydGermanyAnna Fali PROPOSAL
Smith J AmigonItalyAmy Elsner RENEWAL
Aika R WhobreyJapanIvan Magalhaes UNQUALIFIED
Julie N VenereItalyElwin Sharvill PROPOSAL
Jeanfrancois W FollerRussiaElwin Sharvill PROPOSAL
Izzy E MacleadJapanAnna Fali NEGOTIATION
Wickens V StockhamArgentinaAsiya Javayant QUALIFIED
Wickens M VocelkaRussiaAsiya Javayant UNQUALIFIED
Mayumi P FigeroaArgentinaXuxue Feng NEGOTIATION
Kaitlin X DoeSpainIvan Magalhaes UNQUALIFIED
Chavez S RutaAustraliaOnyama Limba PROPOSAL
Jefferson N MacleadSpainIvan Magalhaes NEW
Claire G BowleyCanadaIoni Bowcher RENEWAL
Mujtaba N MacleadSpainOnyama Limba PROPOSAL
Leon L WieserJapanAsiya Javayant UNQUALIFIED
Leon O NestleGermanyBernardo Dominic UNQUALIFIED
Tony U ButtJapanBernardo Dominic UNQUALIFIED
Leja C NestleBrazilAmy Elsner UNQUALIFIED
Kadeem K SergiGermanyStephen Shaw PROPOSAL
Sinclair R FigeroaArgentinaBernardo Dominic PROPOSAL
Arvin E MorascaBrazilAnna Fali NEGOTIATION
Ricardo Q RoysterArgentinaXuxue Feng NEW
Stacey R MorascaFranceIvan Magalhaes QUALIFIED
David J StockhamJapanXuxue Feng PROPOSAL
Silvio O BologniaIndiaAmy Elsner PROPOSAL
Alejandro H ButtArgentinaXuxue Feng NEW
David L WaycottFranceAnna Fali UNQUALIFIED
Juan G BologniaJapanStephen Shaw NEGOTIATION
Rodrigues K PerinSpainAnna Fali NEW
Aditya A RutaAustraliaAnna Fali NEW
Aditya L MacleadFranceIvan Magalhaes RENEWAL
Maisha D CaudyJapanElwin Sharvill NEW
Horizontal
NameCountryRepresentativeStatus
Ricardo O AlbaresRussiaXuxue Feng QUALIFIED
Aditya N MaletCanadaIvan Magalhaes NEGOTIATION
Tony G BologniaFranceXuxue Feng NEW
Ashley Z FerenczSpainAmy Elsner NEGOTIATION
Juan I PoquetteBrazilBernardo Dominic NEGOTIATION
Nicolas E RimCanadaElwin Sharvill PROPOSAL
Alejandro R GauchoBrazilIoni Bowcher UNQUALIFIED
Juan I FigeroaGermanyElwin Sharvill QUALIFIED
Rodrigues C DilliardArgentinaBernardo Dominic NEW
Arvin Y OstroskyIndiaStephen Shaw RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Octavia R AmigonItaly2024-04-17Dorl, James J Esq RENEWAL31Bernardo Dominic
1001Faith E MacleadGermany2024-04-04Truhlar And Truhlar Attys UNQUALIFIED44Xuxue Feng
1002Julie Z TollnerAustralia2024-04-08Rousseaux, Michael Esq UNQUALIFIED59Amy Elsner
1003Antonio I AlbaresFrance2024-04-15Morlong Associates NEGOTIATION39Anna Fali
1004Silvio P MaletArgentina2024-04-17King, Christopher A Esq PROPOSAL18Amy Elsner
1005David N SlusarskiIndia2024-03-25Chapman, Ross E Esq QUALIFIED86Asiya Javayant
1006Mayumi D PerinSpain2024-04-04Chanay, Jeffrey A Esq PROPOSAL2Bernardo Dominic
1007Izzy X RulapaughItaly2024-03-27Feiner Bros UNQUALIFIED17Amy Elsner
1008Isabel K PaprockiGermany2024-04-12Rousseaux, Michael Esq PROPOSAL19Asiya Javayant
1009Antonio O CaldareraIndia2024-04-20Chemel, James L Cpa UNQUALIFIED80Ioni Bowcher
1010Jeanfrancois K FollerCanada2024-04-16Feiner Bros NEGOTIATION7Elwin Sharvill
1011Isabel F CaldareraAustralia2024-03-26Commercial Press NEW99Stephen Shaw
1012Leja G PerinBrazil2024-04-13Buckley Miller Wright PROPOSAL75Elwin Sharvill
1013Kadeem E MaletAustralia2024-04-19Chemel, James L Cpa UNQUALIFIED98Ivan Magalhaes
1014Antonio C BowleyAustralia2024-03-26King, Christopher A Esq NEW86Xuxue Feng
1015Smith H KolmetzJapan2024-03-25Chapman, Ross E Esq NEGOTIATION84Asiya Javayant
1016Johnson Z GarufiCanada2024-04-21Feltz Printing Service RENEWAL77Amy Elsner
1017Kaitlin O NestleIndia2024-04-01Morlong Associates NEGOTIATION42Anna Fali
1018Johnson O KolmetzAustralia2024-03-25Morlong Associates PROPOSAL28Ioni Bowcher
1019Nicolas C GillianJapan2024-04-08Dorl, James J Esq RENEWAL20Ivan Magalhaes
1020Adams M FigeroaIndia2024-03-24Chanay, Jeffrey A Esq QUALIFIED6Ivan Magalhaes
1021Jennifer M InouyeItaly2024-04-13Chemel, James L Cpa RENEWAL19Stephen Shaw
1022Wickens B GarufiItaly2024-03-29Commercial Press NEGOTIATION34Bernardo Dominic
1023Tony A KuskoFrance2024-04-21Feltz Printing Service NEGOTIATION76Bernardo Dominic
1024Adams Z KuskoGermany2024-04-04King, Christopher A Esq RENEWAL9Onyama Limba
1025Adams V DarakjyFrance2024-04-17Dorl, James J Esq PROPOSAL28Asiya Javayant
1026Claire A WhobreyIndia2024-03-29Chemel, James L Cpa PROPOSAL69Xuxue Feng
1027Misaki E CaldareraItaly2024-03-31Printing Dimensions QUALIFIED22Asiya Javayant
1028Kaitlin Z PaprockiUnited Kingdom2024-03-28Truhlar And Truhlar Attys QUALIFIED76Ioni Bowcher
1029Munro R ButtUnited Kingdom2024-04-20Chemel, James L Cpa QUALIFIED68Onyama Limba
1030Clifford I MorascaRussia2024-04-09Dorl, James J Esq NEGOTIATION95Anna Fali
1031Wickens G ChuiCanada2024-04-07Feltz Printing Service UNQUALIFIED52Asiya Javayant
1032Johnson I MaletFrance2024-04-21Rangoni Of Florence QUALIFIED95Ioni Bowcher
1033Mayumi H SlusarskiAustralia2024-03-31Rousseaux, Michael Esq RENEWAL97Elwin Sharvill
1034Juan G RulapaughArgentina2024-03-29Morlong Associates RENEWAL2Anna Fali
1035Emily X ButtIndia2024-04-20Commercial Press NEW12Ioni Bowcher
1036Julie L ButtCanada2024-04-06Commercial Press QUALIFIED85Bernardo Dominic
1037Tony Z DarakjyJapan2024-04-21Chemel, James L Cpa NEW68Amy Elsner
1038Jeanfrancois V CaldareraAustralia2024-03-26Commercial Press QUALIFIED45Xuxue Feng
1039Misaki Z SchemmerJapan2024-04-13Rangoni Of Florence PROPOSAL99Onyama Limba
1040Maisha D SergiGermany2024-04-01Buckley Miller Wright UNQUALIFIED2Elwin Sharvill
1041Isabel D GauchoUnited Kingdom2024-03-28Truhlar And Truhlar Attys PROPOSAL23Ioni Bowcher
1042Costa J SergiJapan2024-04-09Feiner Bros NEGOTIATION69Amy Elsner
1043Ashley X DoeCanada2024-04-18Benton, John B Jr NEGOTIATION3Anna Fali
1044Morrow M RoysterJapan2024-04-18Chapman, Ross E Esq NEW32Ivan Magalhaes
1045Chavez J BriddickArgentina2024-04-12Printing Dimensions UNQUALIFIED99Onyama Limba
1046Aika T SaylorsArgentina2024-04-11Buckley Miller Wright UNQUALIFIED18Bernardo Dominic
1047Chavez V FerenczSpain2024-03-24Feiner Bros QUALIFIED7Anna Fali
1048Ivar F GlickUnited Kingdom2024-04-06Rousseaux, Michael Esq UNQUALIFIED18Elwin Sharvill
1049Ricardo T NestleItaly2024-04-02Benton, John B Jr RENEWAL66Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Chavez O StockhamSpainStephen Shaw PROPOSAL
Cody I RutaAustraliaElwin Sharvill PROPOSAL
Jeanfrancois Z GarufiIndiaAnna Fali QUALIFIED
Ivar V NestleBrazilAsiya Javayant PROPOSAL
Francesco Q FigeroaJapanXuxue Feng UNQUALIFIED
Stacey A StockhamUnited KingdomAmy Elsner UNQUALIFIED
Smith D VocelkaFranceBernardo Dominic UNQUALIFIED
Jennifer Y DoeUnited KingdomStephen Shaw UNQUALIFIED
David U BologniaArgentinaAnna Fali NEW
Izzy A RulapaughGermanyOnyama Limba RENEWAL
Jeanfrancois Y WhobreyItalyAsiya Javayant QUALIFIED
Smith B PoquetteItalyXuxue Feng NEGOTIATION
Maria S KolmetzJapanIvan Magalhaes UNQUALIFIED
Octavia V KolmetzBrazilAnna Fali QUALIFIED
Nicolas D GauchoJapanElwin Sharvill PROPOSAL
Aika K PerinFranceOnyama Limba RENEWAL
James F SergiSpainOnyama Limba RENEWAL
Munro Q GauchoArgentinaStephen Shaw QUALIFIED
Ivar R AmigonAustraliaElwin Sharvill UNQUALIFIED
Arvin A FollerRussiaElwin Sharvill NEGOTIATION
Maria H AlbaresGermanyAnna Fali QUALIFIED
Tony Y MaletArgentinaOnyama Limba QUALIFIED
Johnson B FollerFranceIoni Bowcher UNQUALIFIED
Adams H CaudyCanadaOnyama Limba QUALIFIED
Murillo L VocelkaRussiaAsiya Javayant NEGOTIATION
Mayumi Z MarrierAustraliaAsiya Javayant RENEWAL
David C VocelkaIndiaElwin Sharvill QUALIFIED
Ricardo H CaldareraJapanIoni Bowcher UNQUALIFIED
Silvio L AmigonCanadaElwin Sharvill UNQUALIFIED
Rodrigues F MarrierSpainAnna Fali NEW
Aditya A CaudyIndiaBernardo Dominic PROPOSAL
Morrow X RimAustraliaXuxue Feng NEGOTIATION
Ivar T GauchoUnited KingdomAnna Fali QUALIFIED
Maisha R RoysterCanadaBernardo Dominic NEGOTIATION
Faith T TollnerBrazilOnyama Limba PROPOSAL
Wickens P PaprockiArgentinaElwin Sharvill QUALIFIED
Johnson X CaldareraFranceStephen Shaw PROPOSAL
Nicolas E SergiItalyIvan Magalhaes QUALIFIED
Stacey M MorascaItalyStephen Shaw UNQUALIFIED
Adams Z FigeroaIndiaOnyama Limba NEGOTIATION
Leja A VocelkaRussiaIoni Bowcher NEGOTIATION
Ashley D WaycottSpainStephen Shaw RENEWAL
Kadeem E GillianAustraliaAsiya Javayant PROPOSAL
Jeanfrancois J RimFranceOnyama Limba PROPOSAL
Sinclair Q VocelkaFranceAnna Fali NEGOTIATION
Emily A InouyeIndiaAnna Fali RENEWAL
Kaitlin G MaletSpainBernardo Dominic UNQUALIFIED
Jeanfrancois J MacleadSpainAnna Fali QUALIFIED
Darci H StensethItalyAsiya Javayant PROPOSAL
Julie K MaletFranceElwin Sharvill QUALIFIED
Frozen Columns
Name
Ashley X Perin
Emily O Butt
Tony F Ostrosky
Chavez Q Ferencz
Octavia V Malet
Greenwood D Paprocki
Kadeem H Venere
Leja O Sergi
Isabel X Foller
Ricardo P Gillian
Francesco E Venere
Faith T Figeroa
Stacey T Vocelka
Alejandro S Ferencz
Leja N Gaucho
Juan P Maclead
Adams C Maclead
Claire W Schemmer
Mayumi W Chui
Chavez E Shinko
Kaitlin N Caldarera
Antonio V Rulapaugh
Leon J Ferencz
Clifford O Shinko
Misaki R Tollner
Salvatore A Rim
Alejandro K Rulapaugh
Darci W Chui
Wickens R Albares
Ricardo Q Gaucho
Chavez N Perin
Mujtaba D Flosi
Aika K Royster
Stacey Z Nestle
Leon R Butt
Johnson B Briddick
Chavez L Ostrosky
Smith Q Garufi
Morrow D Iturbide
Mujtaba N Kusko
Murillo Z Figeroa
David Z Butt
Mayumi P Gaucho
Ivar P Figeroa
David L Darakjy
Smith G Waycott
Costa A Inouye
Kadeem L Tollner
David D Ostrosky
Claire R Glick
IdCountryDate
1000Australia2024-04-04
1001Brazil2024-04-20
1002Canada2024-03-31
1003Germany2024-04-16
1004United Kingdom2024-04-03
1005Brazil2024-04-15
1006Germany2024-04-06
1007United Kingdom2024-04-13
1008Canada2024-03-28
1009Canada2024-04-09
1010Brazil2024-04-21
1011India2024-04-01
1012Brazil2024-03-25
1013Italy2024-04-07
1014Spain2024-03-25
1015France2024-03-30
1016Russia2024-03-30
1017Argentina2024-04-06
1018Russia2024-03-29
1019Brazil2024-04-19
1020Italy2024-04-09
1021Russia2024-04-21
1022Germany2024-04-16
1023Russia2024-04-04
1024Germany2024-04-11
1025Spain2024-04-01
1026Italy2024-03-27
1027Brazil2024-04-09
1028Germany2024-04-17
1029Spain2024-04-15
1030United Kingdom2024-03-25
1031Spain2024-04-12
1032Australia2024-04-02
1033Spain2024-04-07
1034India2024-03-27
1035India2024-03-28
1036Brazil2024-04-20
1037Australia2024-04-07
1038Japan2024-04-22
1039Canada2024-03-24
1040Japan2024-03-24
1041Italy2024-03-24
1042Russia2024-04-13
1043Russia2024-04-17
1044France2024-04-16
1045Italy2024-04-04
1046Italy2024-04-21
1047Argentina2024-04-01
1048Brazil2024-04-09
1049Australia2024-03-28

On-Demand Data

NameIdCountryDate
Greenwood A Campain1000India2024-04-01
Leja M Venere1001Germany2024-04-16
Aruna G Kusko1002France2024-04-04
Jones R Vocelka1003Australia2024-04-20
Emily J Bowley1004Germany2024-04-17
Jefferson A Tollner1005Brazil2024-03-29
Ricardo J Foller1006Spain2024-03-29
Arvin W Waycott1007France2024-04-09
Johnson M Ferencz1008Argentina2024-04-01
Kaitlin V Marrier1009Australia2024-03-25
Jones F Ostrosky1010Germany2024-03-24
James H Amigon1011United Kingdom2024-04-16
Jones T Royster1012Italy2024-03-28
Francesco N Maclead1013Brazil2024-03-30
Izzy T Glick1014Japan2024-03-29
Francesco V Stockham1015Germany2024-04-18
Wickens M Chui1016Japan2024-03-27
Costa U Chui1017Japan2024-04-21
Kadeem B Shinko1018United Kingdom2024-03-29
Izzy R Schemmer1019France2024-04-03
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
David B SlusarskiSpainIoni Bowcher UNQUALIFIED
Julie V StensethGermanyElwin Sharvill RENEWAL
Clifford M DoeAustraliaXuxue Feng RENEWAL
Octavia R ChuiBrazilIoni Bowcher RENEWAL
Kadeem W StockhamIndiaAsiya Javayant PROPOSAL
Adams F FigeroaSpainXuxue Feng NEW
Stacey P CaldareraRussiaAnna Fali NEW
Izzy S NickaJapanStephen Shaw RENEWAL
James T IturbideAustraliaAnna Fali UNQUALIFIED
Emily M BriddickRussiaXuxue Feng QUALIFIED
Isabel H KolmetzIndiaStephen Shaw UNQUALIFIED
Antonio E BowleyAustraliaStephen Shaw RENEWAL
Ivar U DoeFranceOnyama Limba PROPOSAL
Octavia V VocelkaIndiaOnyama Limba NEW
Francesco P MaletFranceOnyama Limba NEGOTIATION
Ashley Y PaprockiSpainStephen Shaw NEW
Kaitlin M FerenczJapanElwin Sharvill QUALIFIED
Ashley A FollerIndiaAnna Fali NEW
Salvatore P GillianUnited KingdomAmy Elsner NEW
Salvatore U PoquetteRussiaAnna Fali RENEWAL
Morrow U CaudyAustraliaIvan Magalhaes RENEWAL
Salvatore C VenereItalyAnna Fali UNQUALIFIED
Alejandro Z IturbideJapanElwin Sharvill PROPOSAL
Sinclair L PerinIndiaStephen Shaw NEW
Clifford K VocelkaItalyStephen Shaw NEW
Julie Y ButtArgentinaAnna Fali PROPOSAL
Salvatore D DoeGermanyXuxue Feng UNQUALIFIED
Silvio J KuskoCanadaIoni Bowcher UNQUALIFIED
Claire R ShinkoAustraliaXuxue Feng QUALIFIED
Octavia Y GlickCanadaBernardo Dominic RENEWAL
Deepesh T StockhamIndiaElwin Sharvill QUALIFIED
David F MarrierFranceStephen Shaw PROPOSAL
Aditya W MarrierGermanyStephen Shaw NEGOTIATION
Leja T ChuiUnited KingdomStephen Shaw RENEWAL
Clifford C KolmetzUnited KingdomElwin Sharvill NEW
Salvatore Z DarakjySpainAmy Elsner UNQUALIFIED
Claire A SaylorsIndiaOnyama Limba QUALIFIED
Tony E InouyeFranceElwin Sharvill UNQUALIFIED
Murillo H NestleUnited KingdomIoni Bowcher RENEWAL
Izzy X AmigonUnited KingdomAmy Elsner RENEWAL

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