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
Maisha L RimRussiaIvan Magalhaes PROPOSAL
Kaitlin R MorascaRussiaAsiya Javayant UNQUALIFIED
Jeanfrancois R BowleyArgentinaOnyama Limba RENEWAL
Ivar Q SchemmerArgentinaBernardo Dominic QUALIFIED
Johnson Y TollnerArgentinaOnyama Limba NEW
Greenwood S BriddickSpainAsiya Javayant NEW
Salvatore C ChuiGermanyIvan Magalhaes NEW
Morrow L FerenczSpainAmy Elsner NEW
Leja H KuskoIndiaIoni Bowcher PROPOSAL
Stacey Z DilliardFranceIoni Bowcher NEGOTIATION
Kadeem U FlosiAustraliaBernardo Dominic NEW
Alejandro N DilliardBrazilIvan Magalhaes RENEWAL
Jones R NestleRussiaIoni Bowcher NEGOTIATION
Rodrigues A DarakjyBrazilXuxue Feng QUALIFIED
Stacey S CaldareraBrazilXuxue Feng RENEWAL
Aruna X MorascaFranceAnna Fali QUALIFIED
Ricardo H FollerItalyElwin Sharvill NEGOTIATION
Murillo C GarufiSpainStephen Shaw NEW
Morrow H CaldareraSpainOnyama Limba QUALIFIED
Octavia N MarrierRussiaAsiya Javayant RENEWAL
Jones V GarufiAustraliaAsiya Javayant PROPOSAL
Misaki Y ButtCanadaXuxue Feng PROPOSAL
Sinclair N CampainArgentinaAnna Fali NEGOTIATION
Octavia M AlbaresJapanElwin Sharvill PROPOSAL
Jones Q MaletSpainIvan Magalhaes UNQUALIFIED
Mayumi J ShinkoFranceBernardo Dominic NEW
Jones N ButtItalyIvan Magalhaes PROPOSAL
Darci C FigeroaUnited KingdomAmy Elsner NEW
Jones E KuskoCanadaStephen Shaw NEW
Chavez G DarakjyRussiaIoni Bowcher QUALIFIED
Kaitlin A FollerRussiaAmy Elsner UNQUALIFIED
Mujtaba V ShinkoAustraliaElwin Sharvill NEW
Kaitlin R AmigonJapanBernardo Dominic NEGOTIATION
Greenwood E WaycottCanadaIvan Magalhaes PROPOSAL
Clifford M GarufiCanadaIvan Magalhaes RENEWAL
Morrow Y FerenczAustraliaIoni Bowcher NEW
Morrow K FigeroaIndiaAsiya Javayant NEW
Faith G FlosiSpainAmy Elsner RENEWAL
Aika S VocelkaIndiaOnyama Limba NEW
Smith A GlickUnited KingdomElwin Sharvill PROPOSAL
Misaki A OldroydGermanyBernardo Dominic PROPOSAL
Claire Q DoeAustraliaAmy Elsner PROPOSAL
Arvin G ChuiFranceAmy Elsner NEGOTIATION
Jefferson C KolmetzFranceStephen Shaw QUALIFIED
Kadeem J MarrierFranceXuxue Feng QUALIFIED
Emily S InouyeGermanyAsiya Javayant NEW
Costa T MarrierSpainAmy Elsner UNQUALIFIED
Ashley K PerinFranceStephen Shaw RENEWAL
Munro T ChuiCanadaIoni Bowcher NEGOTIATION
Darci C BologniaJapanXuxue Feng RENEWAL
Horizontal
NameCountryRepresentativeStatus
Misaki F VocelkaJapanAsiya Javayant NEW
Kadeem Z BologniaCanadaElwin Sharvill UNQUALIFIED
Francesco U KuskoItalyIoni Bowcher UNQUALIFIED
Maisha Y BowleyUnited KingdomAsiya Javayant NEW
Clifford A NickaIndiaAsiya Javayant QUALIFIED
Ricardo G WhobreyCanadaIoni Bowcher NEW
Juan I WhobreyArgentinaIvan Magalhaes RENEWAL
Tony J BriddickIndiaIoni Bowcher RENEWAL
Deepesh J DarakjyFranceAsiya Javayant UNQUALIFIED
Isabel M FerenczFranceStephen Shaw PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Aditya E WaycottIndia2024-04-27Feiner Bros NEGOTIATION64Elwin Sharvill
1001Johnson R FerenczGermany2024-04-13Feltz Printing Service NEW14Xuxue Feng
1002Maisha A CaudyIndia2024-04-01Morlong Associates PROPOSAL60Asiya Javayant
1003Jennifer J InouyeArgentina2024-04-19Feltz Printing Service UNQUALIFIED97Anna Fali
1004Jefferson E SchemmerCanada2024-04-15Benton, John B Jr UNQUALIFIED46Xuxue Feng
1005Arvin B MorascaCanada2024-04-15Chemel, James L Cpa UNQUALIFIED64Asiya Javayant
1006Rodrigues H MarrierIndia2024-03-30Feiner Bros RENEWAL83Xuxue Feng
1007Izzy Z PerinJapan2024-04-25Truhlar And Truhlar Attys QUALIFIED46Xuxue Feng
1008Maria K DarakjyAustralia2024-04-12Feiner Bros NEGOTIATION86Stephen Shaw
1009David K DarakjyJapan2024-03-30Rangoni Of Florence RENEWAL74Elwin Sharvill
1010Clifford O StensethCanada2024-04-09Rousseaux, Michael Esq RENEWAL81Stephen Shaw
1011Wickens I AmigonGermany2024-04-06Chemel, James L Cpa NEGOTIATION8Amy Elsner
1012Emily C OldroydArgentina2024-04-25Morlong Associates RENEWAL94Bernardo Dominic
1013Aditya M RimJapan2024-04-26Chapman, Ross E Esq NEW91Stephen Shaw
1014Ricardo J SlusarskiArgentina2024-04-23Benton, John B Jr NEW21Onyama Limba
1015Arvin M GarufiRussia2024-04-19Printing Dimensions PROPOSAL56Stephen Shaw
1016Faith R MaletArgentina2024-04-25Feltz Printing Service PROPOSAL53Bernardo Dominic
1017Tony A DilliardCanada2024-04-21Chemel, James L Cpa PROPOSAL93Elwin Sharvill
1018Clifford T GillianAustralia2024-04-18Printing Dimensions NEW45Anna Fali
1019Ashley S OldroydIndia2024-03-30Dorl, James J Esq UNQUALIFIED94Ivan Magalhaes
1020Alejandro N MacleadIndia2024-04-10Buckley Miller Wright RENEWAL71Elwin Sharvill
1021Antonio L SlusarskiJapan2024-04-07King, Christopher A Esq RENEWAL73Asiya Javayant
1022Jones V AmigonAustralia2024-04-25Dorl, James J Esq PROPOSAL17Ivan Magalhaes
1023Antonio S VenereBrazil2024-03-29Chapman, Ross E Esq NEW65Anna Fali
1024Smith B FigeroaRussia2024-04-01Dorl, James J Esq QUALIFIED62Onyama Limba
1025Ivar J SlusarskiAustralia2024-04-13Benton, John B Jr QUALIFIED33Anna Fali
1026Julie D FigeroaJapan2024-03-30Rangoni Of Florence RENEWAL95Ivan Magalhaes
1027Emily T DarakjyGermany2024-04-18Chapman, Ross E Esq RENEWAL64Bernardo Dominic
1028Sinclair U ShinkoBrazil2024-04-20Rousseaux, Michael Esq PROPOSAL69Ioni Bowcher
1029Silvio O RimFrance2024-03-30Dorl, James J Esq UNQUALIFIED11Elwin Sharvill
1030Arvin J MarrierUnited Kingdom2024-04-24Dorl, James J Esq UNQUALIFIED79Xuxue Feng
1031Leon P OstroskyUnited Kingdom2024-04-10Rousseaux, Michael Esq QUALIFIED87Amy Elsner
1032Jones S MarrierBrazil2024-04-09Truhlar And Truhlar Attys UNQUALIFIED3Anna Fali
1033James G MaletUnited Kingdom2024-04-25King, Christopher A Esq RENEWAL99Ivan Magalhaes
1034Tony P OstroskyUnited Kingdom2024-04-13Dorl, James J Esq NEGOTIATION93Xuxue Feng
1035Emily H BriddickSpain2024-04-11Feiner Bros NEGOTIATION3Stephen Shaw
1036Tony D WhobreySpain2024-04-01Buckley Miller Wright PROPOSAL73Ioni Bowcher
1037Faith Y NestleBrazil2024-04-23Commercial Press RENEWAL74Anna Fali
1038Kaitlin F DarakjySpain2024-04-01Chemel, James L Cpa NEW56Elwin Sharvill
1039Maisha C AmigonSpain2024-04-18Feltz Printing Service NEGOTIATION84Ivan Magalhaes
1040Aditya Q VenereBrazil2024-04-16Rangoni Of Florence QUALIFIED87Ioni Bowcher
1041Mayumi R IturbideArgentina2024-04-23Rangoni Of Florence RENEWAL8Bernardo Dominic
1042Leja N AmigonSpain2024-04-09Benton, John B Jr NEW27Ioni Bowcher
1043Leon U FigeroaCanada2024-04-27Chapman, Ross E Esq RENEWAL2Onyama Limba
1044Leon R NestleSpain2024-04-03Dorl, James J Esq NEW9Bernardo Dominic
1045Leon F NestleFrance2024-04-23Commercial Press QUALIFIED58Xuxue Feng
1046Misaki V MaletGermany2024-04-06Chapman, Ross E Esq RENEWAL56Ioni Bowcher
1047Johnson S SaylorsIndia2024-04-13Benton, John B Jr RENEWAL81Onyama Limba
1048Tony W WhobreySpain2024-03-30Benton, John B Jr UNQUALIFIED51Asiya Javayant
1049Darci P RoysterJapan2024-04-02Morlong Associates NEW48Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Maria T ButtSpainBernardo Dominic RENEWAL
Kaitlin U RimCanadaStephen Shaw QUALIFIED
Smith P MaletJapanAsiya Javayant NEGOTIATION
Jennifer B NestleAustraliaAnna Fali NEGOTIATION
Jeanfrancois X FollerUnited KingdomAmy Elsner RENEWAL
Faith B CaldareraRussiaIvan Magalhaes NEGOTIATION
Jennifer S WieserBrazilIvan Magalhaes RENEWAL
Isabel N StensethGermanyAsiya Javayant NEGOTIATION
Wickens U RimGermanyAmy Elsner QUALIFIED
Ricardo M GarufiArgentinaOnyama Limba RENEWAL
Chavez N OstroskyJapanElwin Sharvill UNQUALIFIED
Johnson X BriddickAustraliaIvan Magalhaes NEW
Ashley K WieserJapanIvan Magalhaes RENEWAL
Munro F OstroskyIndiaAmy Elsner RENEWAL
Smith W PoquetteSpainIoni Bowcher NEW
Octavia O GauchoJapanXuxue Feng RENEWAL
Jefferson N MaletUnited KingdomBernardo Dominic PROPOSAL
Alejandro D AmigonUnited KingdomStephen Shaw QUALIFIED
Tony X MarrierArgentinaXuxue Feng QUALIFIED
Nicolas O GillianCanadaElwin Sharvill QUALIFIED
Darci G NickaItalyIoni Bowcher QUALIFIED
Salvatore N FerenczAustraliaAmy Elsner UNQUALIFIED
Smith M MaletRussiaIoni Bowcher UNQUALIFIED
Clifford G MaletItalyXuxue Feng UNQUALIFIED
Isabel I TollnerIndiaIoni Bowcher NEW
Juan G RoysterUnited KingdomBernardo Dominic UNQUALIFIED
Faith W WhobreyArgentinaOnyama Limba NEGOTIATION
Tony H RoysterItalyAmy Elsner QUALIFIED
Chavez U DarakjyArgentinaIoni Bowcher NEGOTIATION
Johnson O RulapaughUnited KingdomStephen Shaw NEW
Johnson G AlbaresIndiaIvan Magalhaes NEW
Antonio S DilliardBrazilStephen Shaw UNQUALIFIED
Nicolas X DoeFranceAsiya Javayant UNQUALIFIED
Johnson W AlbaresIndiaIvan Magalhaes RENEWAL
Ricardo R MaletSpainStephen Shaw UNQUALIFIED
Alejandro C DarakjyRussiaOnyama Limba NEW
Silvio T IturbideRussiaElwin Sharvill PROPOSAL
Tony P FerenczItalyOnyama Limba NEW
Claire E BologniaRussiaAmy Elsner QUALIFIED
Maisha D PaprockiRussiaBernardo Dominic QUALIFIED
Kaitlin T GlickCanadaElwin Sharvill NEGOTIATION
Juan M WieserAustraliaXuxue Feng UNQUALIFIED
Octavia C OstroskyFranceAnna Fali UNQUALIFIED
Chavez V RutaUnited KingdomOnyama Limba UNQUALIFIED
Aika Q PoquetteItalyAnna Fali QUALIFIED
Jones F FigeroaFranceIvan Magalhaes QUALIFIED
Jeanfrancois W MacleadCanadaIoni Bowcher UNQUALIFIED
Ivar F WaycottBrazilXuxue Feng UNQUALIFIED
Cody W WieserAustraliaXuxue Feng RENEWAL
Arvin F SergiArgentinaAsiya Javayant RENEWAL
Frozen Columns
Name
Faith D Rim
Sinclair A Paprocki
Salvatore N Garufi
Ivar G Nicka
Claire B Royster
Johnson Y Iturbide
Julie V Oldroyd
Misaki H Ferencz
Jefferson N Bolognia
Claire F Ruta
Rodrigues O Caldarera
Jones V Ferencz
Aruna C Dilliard
Isabel N Morasca
Clifford F Perin
Maria B Ostrosky
Costa E Briddick
Munro T Malet
Alejandro A Figeroa
Adams V Doe
Emily S Foller
Murillo A Vocelka
Stacey M Morasca
Faith G Venere
Salvatore J Bowley
Darci F Campain
Juan P Paprocki
Juan R Caudy
Isabel U Sergi
Misaki J Slusarski
Faith U Nicka
Jeanfrancois V Paprocki
Greenwood A Darakjy
Darci K Schemmer
David M Shinko
Misaki Q Doe
Silvio N Amigon
James K Venere
Greenwood N Caudy
Greenwood T Nicka
Wickens R Butt
Izzy E Paprocki
Leon X Royster
Stacey U Schemmer
Sinclair A Rulapaugh
Alejandro P Slusarski
Jeanfrancois L Marrier
Juan L Kolmetz
Rodrigues L Morasca
Stacey W Kusko
IdCountryDate
1000Canada2024-04-02
1001Australia2024-04-11
1002Spain2024-04-02
1003Japan2024-04-14
1004Japan2024-04-22
1005Russia2024-04-02
1006France2024-04-19
1007India2024-04-11
1008Argentina2024-04-23
1009Japan2024-03-30
1010Australia2024-04-22
1011Italy2024-04-12
1012France2024-03-30
1013Australia2024-04-26
1014Argentina2024-04-01
1015Brazil2024-04-21
1016Brazil2024-03-30
1017Japan2024-03-31
1018Italy2024-04-09
1019Japan2024-04-11
1020Spain2024-04-22
1021Canada2024-04-05
1022Spain2024-03-30
1023Spain2024-04-07
1024Russia2024-04-18
1025Russia2024-04-11
1026Australia2024-04-17
1027Brazil2024-04-22
1028Russia2024-04-25
1029Brazil2024-04-06
1030Russia2024-04-08
1031Brazil2024-04-17
1032Spain2024-04-14
1033United Kingdom2024-04-17
1034France2024-04-04
1035Italy2024-04-04
1036Australia2024-04-10
1037France2024-04-12
1038Russia2024-03-30
1039Brazil2024-04-05
1040India2024-04-01
1041Canada2024-04-20
1042Australia2024-04-04
1043India2024-04-18
1044France2024-04-09
1045Canada2024-04-26
1046India2024-04-19
1047Spain2024-04-27
1048Argentina2024-04-09
1049Japan2024-03-29

On-Demand Data

NameIdCountryDate
Aditya I Nestle1000Russia2024-04-21
Maria B Slusarski1001Italy2024-04-04
Aika I Figeroa1002Brazil2024-04-15
Cody D Shinko1003Argentina2024-04-14
Jefferson C Malet1004United Kingdom2024-04-04
Smith P Rulapaugh1005Brazil2024-04-16
Kadeem O Saylors1006Italy2024-04-25
Morrow F Stenseth1007Russia2024-04-05
Wickens E Briddick1008France2024-04-24
Aditya K Bowley1009Italy2024-04-26
Cody L Waycott1010Italy2024-04-05
Deepesh Q Royster1011Australia2024-04-18
Kadeem D Iturbide1012Germany2024-04-04
Murillo F Flosi1013France2024-04-12
Munro C Foller1014Australia2024-04-06
Francesco G Bolognia1015Brazil2024-04-24
Aruna H Royster1016Russia2024-04-14
Octavia N Dilliard1017Russia2024-04-25
Murillo V Stenseth1018France2024-04-15
Jennifer K Bolognia1019Brazil2024-04-18
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Leon O PoquetteArgentinaXuxue Feng RENEWAL
Julie U ChuiIndiaXuxue Feng NEW
David A CaudyGermanyAsiya Javayant NEGOTIATION
Stacey Z MorascaUnited KingdomXuxue Feng UNQUALIFIED
Chavez A RoysterUnited KingdomXuxue Feng NEGOTIATION
Clifford R BowleyUnited KingdomOnyama Limba PROPOSAL
Antonio A VocelkaBrazilAnna Fali NEW
Aruna U PaprockiAustraliaXuxue Feng NEW
Ricardo K StockhamCanadaIoni Bowcher QUALIFIED
Morrow C WaycottItalyAmy Elsner NEW
Antonio D AmigonCanadaXuxue Feng RENEWAL
Stacey G WhobreySpainBernardo Dominic PROPOSAL
Munro A NestleBrazilBernardo Dominic RENEWAL
Silvio A KuskoIndiaXuxue Feng NEGOTIATION
Murillo B RoysterSpainAmy Elsner UNQUALIFIED
Maria N MaletAustraliaIoni Bowcher NEGOTIATION
James H PoquetteCanadaOnyama Limba RENEWAL
Deepesh Q DoeAustraliaIoni Bowcher NEGOTIATION
Munro P WaycottItalyElwin Sharvill QUALIFIED
Tony E MacleadIndiaOnyama Limba NEGOTIATION
Aika O RimSpainOnyama Limba PROPOSAL
Leja W SergiRussiaAnna Fali NEGOTIATION
Chavez B NestleIndiaElwin Sharvill NEGOTIATION
Maisha I KolmetzGermanyAsiya Javayant NEGOTIATION
Morrow Z GarufiItalyElwin Sharvill NEW
Jennifer P NestleFranceBernardo Dominic NEW
Juan D GauchoUnited KingdomIvan Magalhaes UNQUALIFIED
Tony X StockhamFranceIoni Bowcher PROPOSAL
Mayumi F SaylorsIndiaStephen Shaw UNQUALIFIED
Clifford S GarufiIndiaAsiya Javayant NEGOTIATION
Leon T ButtGermanyBernardo Dominic NEW
Julie K AmigonUnited KingdomOnyama Limba NEGOTIATION
Munro T SaylorsRussiaBernardo Dominic NEGOTIATION
Juan Y ChuiGermanyIoni Bowcher RENEWAL
Kaitlin C RimUnited KingdomIvan Magalhaes NEW
Mujtaba Y GauchoUnited KingdomOnyama Limba RENEWAL
Ashley S WaycottItalyAnna Fali PROPOSAL
Julie I BowleySpainIvan Magalhaes NEGOTIATION
Jeanfrancois J SaylorsRussiaElwin Sharvill UNQUALIFIED
Deepesh G StockhamIndiaIoni 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>