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
David I TollnerIndiaAsiya Javayant NEW
Kadeem B StockhamAustraliaIvan Magalhaes QUALIFIED
Chavez S WieserJapanOnyama Limba NEGOTIATION
Deepesh O WaycottIndiaStephen Shaw PROPOSAL
Kaitlin J TollnerGermanyElwin Sharvill PROPOSAL
Costa F FlosiBrazilBernardo Dominic QUALIFIED
Wickens I RulapaughCanadaElwin Sharvill NEW
James G KuskoCanadaBernardo Dominic PROPOSAL
Kaitlin D PoquetteGermanyAsiya Javayant PROPOSAL
Alejandro H CaudyIndiaAsiya Javayant RENEWAL
Mayumi A NestleAustraliaIoni Bowcher PROPOSAL
Julie R RulapaughItalyIoni Bowcher PROPOSAL
Ricardo R WaycottIndiaIoni Bowcher QUALIFIED
Izzy F IturbideItalyStephen Shaw NEW
Costa C GlickSpainXuxue Feng QUALIFIED
David G KuskoItalyIvan Magalhaes NEGOTIATION
Leon K RulapaughFranceAnna Fali RENEWAL
Jones U StockhamBrazilBernardo Dominic UNQUALIFIED
David M RulapaughJapanIoni Bowcher UNQUALIFIED
Clifford W GarufiBrazilElwin Sharvill NEGOTIATION
Alejandro M KolmetzGermanyAnna Fali UNQUALIFIED
Julie Q OldroydIndiaStephen Shaw RENEWAL
Stacey Y BologniaBrazilElwin Sharvill NEGOTIATION
Nicolas L VenereRussiaAnna Fali PROPOSAL
James T RutaFranceStephen Shaw NEGOTIATION
Faith I GarufiFranceIvan Magalhaes RENEWAL
Jefferson R PoquetteCanadaIoni Bowcher NEW
Aditya U KolmetzItalyElwin Sharvill UNQUALIFIED
Chavez P MacleadAustraliaOnyama Limba UNQUALIFIED
Jefferson R OstroskyAustraliaOnyama Limba NEGOTIATION
Chavez R CaudyFranceIoni Bowcher QUALIFIED
Aruna E StensethCanadaOnyama Limba QUALIFIED
Aika G KuskoArgentinaXuxue Feng QUALIFIED
Faith X MaletBrazilXuxue Feng QUALIFIED
Johnson Y DarakjyAustraliaBernardo Dominic UNQUALIFIED
Murillo M RutaRussiaAsiya Javayant UNQUALIFIED
Aika D ChuiJapanElwin Sharvill QUALIFIED
Jones B FlosiUnited KingdomBernardo Dominic NEW
Jeanfrancois C DilliardRussiaAnna Fali QUALIFIED
Jennifer C KuskoSpainIoni Bowcher RENEWAL
Jeanfrancois I BowleyFranceAmy Elsner NEGOTIATION
Ricardo B FerenczAustraliaIoni Bowcher NEGOTIATION
Misaki A BowleySpainAmy Elsner NEW
Jones N OstroskyFranceIvan Magalhaes PROPOSAL
Leja O TollnerSpainBernardo Dominic NEGOTIATION
Cody G BologniaItalyIvan Magalhaes UNQUALIFIED
Tony S MacleadBrazilBernardo Dominic QUALIFIED
Juan U RulapaughAustraliaIoni Bowcher QUALIFIED
Kadeem V VenereJapanAmy Elsner QUALIFIED
Rodrigues T ChuiIndiaXuxue Feng NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Salvatore Y BologniaSpainElwin Sharvill QUALIFIED
Wickens G InouyeAustraliaElwin Sharvill NEGOTIATION
Francesco E OstroskyGermanyAsiya Javayant PROPOSAL
David Z RoysterGermanyOnyama Limba PROPOSAL
Chavez Q StockhamFranceBernardo Dominic UNQUALIFIED
Greenwood K SergiIndiaAsiya Javayant NEW
Antonio J DoeBrazilXuxue Feng NEW
Costa R MaletItalyIoni Bowcher UNQUALIFIED
Ashley J BowleyFranceAnna Fali RENEWAL
Izzy T DilliardArgentinaBernardo Dominic PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jennifer I CaudySpain2024-04-02Rangoni Of Florence NEGOTIATION48Ivan Magalhaes
1001Faith M AlbaresCanada2024-04-09Chapman, Ross E Esq UNQUALIFIED29Xuxue Feng
1002Jefferson R WhobreyGermany2024-04-21Commercial Press NEGOTIATION58Onyama Limba
1003Nicolas I SergiCanada2024-04-19Printing Dimensions RENEWAL87Elwin Sharvill
1004Cody I VocelkaFrance2024-04-23Commercial Press NEW84Anna Fali
1005Ricardo I AmigonJapan2024-04-17Printing Dimensions QUALIFIED21Anna Fali
1006Cody B VenereCanada2024-04-18Benton, John B Jr NEW16Ivan Magalhaes
1007Johnson F GillianAustralia2024-04-06Benton, John B Jr UNQUALIFIED61Elwin Sharvill
1008James U InouyeIndia2024-03-28Rangoni Of Florence RENEWAL22Stephen Shaw
1009Maisha Q StockhamFrance2024-03-30Printing Dimensions PROPOSAL54Ioni Bowcher
1010Costa Y DarakjyArgentina2024-04-12Chapman, Ross E Esq RENEWAL25Anna Fali
1011Munro I SchemmerAustralia2024-04-19Buckley Miller Wright NEW61Ioni Bowcher
1012James D TollnerCanada2024-03-28Rangoni Of Florence UNQUALIFIED75Elwin Sharvill
1013Kaitlin X MorascaSpain2024-04-17Buckley Miller Wright RENEWAL49Elwin Sharvill
1014Aika J BologniaGermany2024-04-15Rangoni Of Florence QUALIFIED15Elwin Sharvill
1015Claire Z KolmetzIndia2024-04-16Chemel, James L Cpa NEGOTIATION43Stephen Shaw
1016James D RulapaughBrazil2024-04-10Buckley Miller Wright UNQUALIFIED79Xuxue Feng
1017Mujtaba J CaudyUnited Kingdom2024-04-09Feltz Printing Service NEW3Xuxue Feng
1018Jones J MorascaJapan2024-03-30Morlong Associates PROPOSAL74Ivan Magalhaes
1019Francesco R DilliardAustralia2024-04-12Morlong Associates NEGOTIATION25Amy Elsner
1020Leja X WieserUnited Kingdom2024-04-22Rousseaux, Michael Esq QUALIFIED40Onyama Limba
1021Izzy O InouyeUnited Kingdom2024-04-22Buckley Miller Wright QUALIFIED36Anna Fali
1022Jefferson C NickaCanada2024-03-31Chemel, James L Cpa RENEWAL16Bernardo Dominic
1023Silvio F GarufiBrazil2024-04-09Morlong Associates RENEWAL97Elwin Sharvill
1024Darci V RoysterRussia2024-04-19Feltz Printing Service UNQUALIFIED83Asiya Javayant
1025Morrow G DoeRussia2024-04-10Rangoni Of Florence PROPOSAL12Stephen Shaw
1026Clifford D PaprockiRussia2024-04-21Commercial Press NEW43Stephen Shaw
1027Chavez X NestleGermany2024-03-27Morlong Associates NEW82Elwin Sharvill
1028Salvatore J PoquetteCanada2024-04-08Morlong Associates NEGOTIATION62Anna Fali
1029Deepesh O VocelkaSpain2024-04-03Buckley Miller Wright QUALIFIED46Anna Fali
1030Tony C ButtAustralia2024-04-06Printing Dimensions RENEWAL71Xuxue Feng
1031Aika M WieserGermany2024-03-28Buckley Miller Wright UNQUALIFIED27Xuxue Feng
1032Wickens B WaycottSpain2024-04-21Commercial Press UNQUALIFIED93Elwin Sharvill
1033James D TollnerAustralia2024-04-05King, Christopher A Esq UNQUALIFIED39Asiya Javayant
1034Cody C FollerGermany2024-04-11Dorl, James J Esq NEW8Anna Fali
1035Misaki X PaprockiBrazil2024-04-02Chapman, Ross E Esq RENEWAL19Amy Elsner
1036Kadeem T DilliardSpain2024-04-12Dorl, James J Esq NEGOTIATION80Anna Fali
1037Aruna G CaudyGermany2024-04-05Buckley Miller Wright NEW76Ioni Bowcher
1038Deepesh U ButtBrazil2024-04-03Chapman, Ross E Esq PROPOSAL31Amy Elsner
1039Alejandro Q MaletCanada2024-04-04Truhlar And Truhlar Attys UNQUALIFIED95Stephen Shaw
1040Julie X GauchoSpain2024-04-16Printing Dimensions RENEWAL64Onyama Limba
1041Maisha A GlickItaly2024-04-11Benton, John B Jr NEW33Onyama Limba
1042Jones F OstroskyItaly2024-04-14Feiner Bros UNQUALIFIED43Onyama Limba
1043Francesco Y NestleArgentina2024-04-04Dorl, James J Esq PROPOSAL7Anna Fali
1044Chavez B VenereItaly2024-04-19Feiner Bros UNQUALIFIED15Amy Elsner
1045Johnson Y MarrierArgentina2024-04-03Printing Dimensions NEW70Ioni Bowcher
1046Darci F CaudyCanada2024-04-02Feiner Bros UNQUALIFIED61Anna Fali
1047Arvin T WieserGermany2024-04-04Feiner Bros NEGOTIATION9Ioni Bowcher
1048Adams P VocelkaGermany2024-04-17Feltz Printing Service UNQUALIFIED74Stephen Shaw
1049Izzy Q DarakjyAustralia2024-04-22Rousseaux, Michael Esq UNQUALIFIED98Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Murillo I OldroydGermanyOnyama Limba QUALIFIED
Wickens F VenereBrazilElwin Sharvill NEW
Arvin X OstroskyIndiaAmy Elsner NEW
Emily X FlosiGermanyAnna Fali QUALIFIED
Aika Q DarakjyAustraliaStephen Shaw NEW
Aika R GarufiAustraliaAnna Fali PROPOSAL
Greenwood X RulapaughItalyIvan Magalhaes UNQUALIFIED
James X MorascaUnited KingdomAnna Fali NEGOTIATION
Ricardo B FlosiIndiaAsiya Javayant UNQUALIFIED
Misaki Z StockhamRussiaXuxue Feng QUALIFIED
Sinclair O OstroskyIndiaAnna Fali NEGOTIATION
Maria T VenereUnited KingdomIvan Magalhaes RENEWAL
Aditya N BriddickJapanAmy Elsner UNQUALIFIED
Izzy O GarufiRussiaAmy Elsner PROPOSAL
Wickens E InouyeCanadaStephen Shaw NEGOTIATION
Misaki V MaletUnited KingdomStephen Shaw NEW
Francesco M BowleyGermanyIvan Magalhaes NEW
Maisha G RimItalyAmy Elsner RENEWAL
Alejandro M WaycottFranceStephen Shaw UNQUALIFIED
Jefferson K RulapaughRussiaStephen Shaw UNQUALIFIED
Munro K MaletAustraliaOnyama Limba RENEWAL
Murillo Y ChuiItalyAmy Elsner PROPOSAL
James E SchemmerAustraliaOnyama Limba QUALIFIED
Isabel K SchemmerItalyStephen Shaw QUALIFIED
Smith L SaylorsIndiaOnyama Limba UNQUALIFIED
Leja T KuskoUnited KingdomStephen Shaw QUALIFIED
Kaitlin X PaprockiRussiaAsiya Javayant NEW
Maisha X MorascaAustraliaAnna Fali NEW
Cody U PerinBrazilAmy Elsner QUALIFIED
Leon I CaldareraSpainBernardo Dominic NEW
Julie V VocelkaFranceAsiya Javayant NEGOTIATION
Munro Q FerenczRussiaAsiya Javayant NEGOTIATION
Juan C ChuiRussiaAnna Fali NEGOTIATION
Salvatore M IturbideItalyBernardo Dominic NEW
Kaitlin Y PerinSpainElwin Sharvill QUALIFIED
Isabel V KuskoUnited KingdomOnyama Limba PROPOSAL
James E SlusarskiFranceStephen Shaw QUALIFIED
Leja R MaletGermanyAsiya Javayant NEGOTIATION
Johnson G AlbaresSpainStephen Shaw UNQUALIFIED
Morrow M FollerCanadaAmy Elsner NEW
Maisha F DoeGermanyElwin Sharvill PROPOSAL
Adams L GauchoUnited KingdomIvan Magalhaes NEW
Mayumi Y MacleadCanadaOnyama Limba NEGOTIATION
Julie Q MaletArgentinaBernardo Dominic QUALIFIED
Costa K FerenczSpainOnyama Limba NEW
Maria I FlosiJapanBernardo Dominic PROPOSAL
Alejandro O PaprockiGermanyAsiya Javayant PROPOSAL
Octavia S GlickFranceIoni Bowcher QUALIFIED
Kadeem C RulapaughBrazilStephen Shaw RENEWAL
Jeanfrancois G MarrierFranceXuxue Feng QUALIFIED
Frozen Columns
Name
Wickens Z Slusarski
Tony Y Inouye
Leja C Venere
Maisha B Maclead
Izzy C Marrier
Leja T Schemmer
Cody X Wieser
Wickens W Doe
Aruna K Gillian
Ricardo U Caldarera
Sinclair V Waycott
Aika R Gillian
Jones O Inouye
Aika C Caldarera
Rodrigues Y Malet
Mayumi W Albares
Julie X Caldarera
Maisha G Briddick
Juan M Poquette
Adams E Poquette
Arvin F Inouye
Tony K Shinko
Costa Z Dilliard
Darci T Paprocki
Adams K Malet
Jeanfrancois V Ostrosky
Jeanfrancois S Dilliard
Faith O Slusarski
Misaki S Shinko
Adams L Dilliard
Jeanfrancois V Vocelka
Tony O Gaucho
Murillo T Dilliard
Greenwood A Venere
Sinclair M Inouye
Maisha U Schemmer
Leon Y Rulapaugh
Chavez X Morasca
Izzy E Glick
Alejandro W Saylors
Maisha X Glick
Aika J Whobrey
Jennifer J Saylors
Jennifer N Kolmetz
Jefferson C Gillian
Jeanfrancois R Tollner
Antonio B Ferencz
Cody V Albares
Izzy P Rim
Tony U Oldroyd
IdCountryDate
1000Canada2024-04-21
1001Russia2024-04-19
1002Germany2024-03-27
1003Argentina2024-04-22
1004Canada2024-03-31
1005Australia2024-04-22
1006Brazil2024-04-06
1007Argentina2024-03-28
1008Germany2024-04-03
1009Argentina2024-04-12
1010Italy2024-04-09
1011Germany2024-04-22
1012Germany2024-03-26
1013France2024-04-10
1014Canada2024-03-27
1015Italy2024-04-06
1016Canada2024-03-30
1017United Kingdom2024-04-14
1018Australia2024-04-20
1019Japan2024-04-08
1020Spain2024-03-31
1021United Kingdom2024-04-16
1022Canada2024-04-03
1023Argentina2024-04-09
1024Italy2024-04-13
1025France2024-04-01
1026Brazil2024-04-17
1027Spain2024-04-22
1028United Kingdom2024-03-26
1029Canada2024-03-27
1030Japan2024-04-10
1031Canada2024-04-07
1032Italy2024-04-04
1033Canada2024-04-13
1034France2024-04-04
1035Canada2024-03-28
1036Spain2024-03-27
1037Argentina2024-03-27
1038India2024-04-13
1039United Kingdom2024-04-03
1040Canada2024-04-15
1041Russia2024-03-28
1042Australia2024-04-17
1043Italy2024-04-21
1044Australia2024-04-01
1045Argentina2024-04-14
1046Brazil2024-04-12
1047France2024-03-31
1048India2024-04-20
1049United Kingdom2024-04-04

On-Demand Data

NameIdCountryDate
Nicolas M Butt1000Canada2024-03-29
Sinclair Y Darakjy1001Australia2024-04-16
Izzy G Rim1002Germany2024-04-24
Izzy L Iturbide1003Italy2024-04-15
Jennifer X Bowley1004Argentina2024-04-07
Murillo K Stockham1005United Kingdom2024-04-23
Ricardo G Butt1006Argentina2024-04-20
Jennifer U Venere1007United Kingdom2024-04-23
Isabel H Royster1008France2024-04-21
Octavia E Paprocki1009Argentina2024-04-03
Jeanfrancois N Venere1010Australia2024-04-14
Aika Z Stockham1011Brazil2024-04-19
Chavez C Bowley1012Russia2024-04-17
Francesco J Nestle1013Australia2024-04-05
Ivar G Rulapaugh1014Japan2024-04-24
Antonio Y Butt1015France2024-04-14
Alejandro D Schemmer1016Spain2024-04-09
Kaitlin C Amigon1017Australia2024-04-17
Jones W Flosi1018Canada2024-04-04
Johnson F Waycott1019Russia2024-04-13
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Costa X MacleadGermanyAnna Fali PROPOSAL
Jeanfrancois Y StockhamGermanyStephen Shaw QUALIFIED
Murillo K PoquetteJapanAmy Elsner UNQUALIFIED
Munro P IturbideBrazilIvan Magalhaes QUALIFIED
Stacey X MorascaAustraliaIvan Magalhaes QUALIFIED
Isabel L BowleyGermanyIoni Bowcher RENEWAL
Smith L IturbideArgentinaBernardo Dominic RENEWAL
Sinclair E FigeroaJapanOnyama Limba PROPOSAL
Morrow X SchemmerCanadaIvan Magalhaes UNQUALIFIED
Faith C RimGermanyAsiya Javayant QUALIFIED
Juan Z ShinkoBrazilIoni Bowcher NEGOTIATION
Ivar L SlusarskiArgentinaXuxue Feng RENEWAL
Sinclair S RutaAustraliaOnyama Limba RENEWAL
Silvio B KuskoIndiaAsiya Javayant NEGOTIATION
Alejandro T PerinUnited KingdomBernardo Dominic RENEWAL
Ivar F ButtAustraliaIoni Bowcher RENEWAL
Kadeem Z MaletBrazilBernardo Dominic UNQUALIFIED
Kaitlin B TollnerRussiaOnyama Limba QUALIFIED
Jefferson H SlusarskiJapanAmy Elsner UNQUALIFIED
Emily V SchemmerRussiaStephen Shaw NEGOTIATION
Ashley X NestleJapanBernardo Dominic QUALIFIED
Aika D KuskoUnited KingdomAmy Elsner NEGOTIATION
Murillo M FlosiUnited KingdomAsiya Javayant NEGOTIATION
Mayumi D DoeCanadaIvan Magalhaes NEGOTIATION
Stacey L FlosiRussiaOnyama Limba QUALIFIED
Emily W CaldareraSpainIvan Magalhaes NEW
Izzy F SlusarskiSpainAsiya Javayant RENEWAL
Aika D ButtArgentinaAnna Fali UNQUALIFIED
Stacey Q AmigonFranceAmy Elsner NEGOTIATION
Jeanfrancois K BologniaArgentinaAnna Fali PROPOSAL
Isabel I AlbaresSpainAmy Elsner NEW
David C BriddickGermanyElwin Sharvill NEW
Emily Z AmigonCanadaAsiya Javayant PROPOSAL
Morrow R VocelkaFranceAsiya Javayant QUALIFIED
Stacey D DilliardCanadaElwin Sharvill RENEWAL
Costa M GillianIndiaIoni Bowcher UNQUALIFIED
James P PaprockiUnited KingdomAnna Fali RENEWAL
Jennifer T KuskoArgentinaAmy Elsner NEGOTIATION
Silvio G MorascaGermanyAmy Elsner PROPOSAL
Arvin W GlickGermanyIoni Bowcher NEW

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