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
Smith E BologniaSpainBernardo Dominic NEW
David P VocelkaIndiaIoni Bowcher NEGOTIATION
Morrow E MaletBrazilAmy Elsner RENEWAL
Stacey P BowleyCanadaXuxue Feng RENEWAL
Adams N RutaSpainAsiya Javayant RENEWAL
Ricardo N MorascaSpainAnna Fali PROPOSAL
Alejandro T OldroydItalyAnna Fali RENEWAL
Jeanfrancois L WaycottArgentinaXuxue Feng PROPOSAL
Aruna D VenereBrazilIoni Bowcher UNQUALIFIED
Cody C WaycottFranceAnna Fali NEW
Rodrigues A NickaCanadaBernardo Dominic PROPOSAL
Ricardo N InouyeRussiaIvan Magalhaes NEGOTIATION
Aruna K OldroydRussiaIvan Magalhaes PROPOSAL
Stacey K BologniaSpainBernardo Dominic QUALIFIED
Jeanfrancois N OstroskyArgentinaXuxue Feng QUALIFIED
Adams H PoquetteArgentinaAmy Elsner NEW
Leon L PerinJapanAsiya Javayant UNQUALIFIED
Leon Q SchemmerAustraliaElwin Sharvill NEGOTIATION
Arvin E CaudyCanadaStephen Shaw PROPOSAL
Octavia D DarakjyArgentinaXuxue Feng UNQUALIFIED
Tony X PoquetteJapanAmy Elsner NEW
Aruna B VenereAustraliaAnna Fali NEGOTIATION
Ashley Q NestleFranceXuxue Feng PROPOSAL
Maria W BowleyRussiaStephen Shaw NEGOTIATION
Murillo Q ChuiIndiaAnna Fali RENEWAL
Julie X WieserJapanXuxue Feng NEW
Greenwood E GlickItalyElwin Sharvill NEGOTIATION
Ivar E WieserFranceIoni Bowcher NEGOTIATION
Nicolas Z RulapaughUnited KingdomOnyama Limba NEGOTIATION
Francesco P StockhamGermanyIoni Bowcher NEGOTIATION
Claire W NestleGermanyStephen Shaw QUALIFIED
Leja D InouyeBrazilOnyama Limba UNQUALIFIED
Maria T MaletItalyXuxue Feng PROPOSAL
Darci L AlbaresBrazilStephen Shaw NEW
Morrow V SergiBrazilAsiya Javayant PROPOSAL
Costa O StockhamAustraliaAnna Fali RENEWAL
Isabel H NestleJapanAnna Fali UNQUALIFIED
Jennifer T CaudyBrazilIvan Magalhaes QUALIFIED
Aditya T GlickJapanElwin Sharvill UNQUALIFIED
Alejandro X GauchoCanadaIvan Magalhaes PROPOSAL
Emily U AlbaresCanadaAmy Elsner NEW
Costa G NestleUnited KingdomAsiya Javayant NEW
Murillo D IturbideItalyAsiya Javayant RENEWAL
Silvio A WaycottCanadaStephen Shaw NEW
David B ChuiRussiaBernardo Dominic QUALIFIED
Aditya W ShinkoFranceAnna Fali RENEWAL
Ivar D WaycottSpainAnna Fali UNQUALIFIED
Nicolas G GauchoItalyStephen Shaw QUALIFIED
Costa H RoysterRussiaOnyama Limba NEW
Jeanfrancois D KolmetzBrazilAnna Fali UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Wickens L FerenczGermanyBernardo Dominic PROPOSAL
Aruna E MaletBrazilOnyama Limba NEGOTIATION
Johnson W GlickArgentinaOnyama Limba UNQUALIFIED
Misaki L ShinkoBrazilAnna Fali UNQUALIFIED
Deepesh D VocelkaFranceElwin Sharvill NEGOTIATION
Munro G PerinJapanBernardo Dominic NEW
Alejandro Z MorascaFranceAmy Elsner UNQUALIFIED
Jennifer Y CaldareraBrazilAsiya Javayant NEGOTIATION
Arvin X RoysterGermanyBernardo Dominic NEGOTIATION
Faith V CaudyBrazilAnna Fali RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Aditya O ShinkoArgentina2024-04-01Rangoni Of Florence RENEWAL95Ioni Bowcher
1001Cody Y FerenczJapan2024-03-26Printing Dimensions RENEWAL70Ivan Magalhaes
1002Ashley I CaldareraJapan2024-03-30Commercial Press NEW4Amy Elsner
1003Morrow V RulapaughFrance2024-03-31Truhlar And Truhlar Attys NEGOTIATION20Asiya Javayant
1004Munro X BowleyFrance2024-03-26Rousseaux, Michael Esq QUALIFIED34Asiya Javayant
1005Jennifer B InouyeIndia2024-04-15King, Christopher A Esq UNQUALIFIED86Amy Elsner
1006Tony Q AmigonBrazil2024-03-26Morlong Associates UNQUALIFIED75Xuxue Feng
1007Morrow E WieserJapan2024-04-21Buckley Miller Wright NEGOTIATION66Stephen Shaw
1008Ivar Z GillianBrazil2024-04-24Benton, John B Jr PROPOSAL93Anna Fali
1009David U CaldareraArgentina2024-03-30Feltz Printing Service RENEWAL64Elwin Sharvill
1010Isabel C DarakjyUnited Kingdom2024-04-02Chemel, James L Cpa NEW7Bernardo Dominic
1011Arvin J KolmetzArgentina2024-04-14Chapman, Ross E Esq NEGOTIATION45Onyama Limba
1012Julie V NestleItaly2024-04-17Dorl, James J Esq NEGOTIATION75Ioni Bowcher
1013Cody D FerenczGermany2024-04-18Printing Dimensions NEW58Ivan Magalhaes
1014Juan Z SlusarskiAustralia2024-04-14Printing Dimensions UNQUALIFIED19Onyama Limba
1015Juan K MorascaArgentina2024-04-21Feiner Bros PROPOSAL38Asiya Javayant
1016Juan B RutaItaly2024-04-05Feiner Bros QUALIFIED64Ivan Magalhaes
1017Rodrigues W RulapaughCanada2024-04-22Dorl, James J Esq PROPOSAL47Ioni Bowcher
1018Misaki O FerenczFrance2024-03-29Rousseaux, Michael Esq NEW63Amy Elsner
1019Misaki J GarufiItaly2024-04-07Morlong Associates NEW67Onyama Limba
1020Sinclair F StensethGermany2024-04-04Buckley Miller Wright QUALIFIED64Asiya Javayant
1021Tony G GauchoSpain2024-03-31Morlong Associates PROPOSAL1Xuxue Feng
1022Morrow L MorascaBrazil2024-04-12Printing Dimensions QUALIFIED74Amy Elsner
1023Sinclair W ButtUnited Kingdom2024-04-19King, Christopher A Esq QUALIFIED82Anna Fali
1024Jones E StockhamGermany2024-04-16Feiner Bros PROPOSAL86Ivan Magalhaes
1025Cody M ChuiFrance2024-04-06Commercial Press QUALIFIED56Asiya Javayant
1026Aruna Z ChuiSpain2024-03-31Morlong Associates QUALIFIED39Amy Elsner
1027Cody L PaprockiFrance2024-04-03Benton, John B Jr NEW73Amy Elsner
1028Adams C SlusarskiJapan2024-04-16Dorl, James J Esq NEW24Asiya Javayant
1029Ricardo J BriddickRussia2024-03-26Chanay, Jeffrey A Esq NEW84Elwin Sharvill
1030Isabel O MorascaFrance2024-04-10Dorl, James J Esq PROPOSAL53Amy Elsner
1031Johnson O WhobreyAustralia2024-04-22Chanay, Jeffrey A Esq NEW46Bernardo Dominic
1032Faith N StockhamGermany2024-04-12Benton, John B Jr QUALIFIED36Stephen Shaw
1033Mayumi I BologniaBrazil2024-04-10Feltz Printing Service UNQUALIFIED3Ivan Magalhaes
1034Jennifer R IturbideItaly2024-04-07Benton, John B Jr RENEWAL74Bernardo Dominic
1035Mayumi I SlusarskiBrazil2024-04-21Commercial Press NEGOTIATION88Onyama Limba
1036Leja S FlosiGermany2024-04-13Dorl, James J Esq NEGOTIATION1Anna Fali
1037Costa I FigeroaIndia2024-04-16Morlong Associates RENEWAL59Xuxue Feng
1038David M BriddickBrazil2024-04-14Dorl, James J Esq PROPOSAL7Bernardo Dominic
1039Sinclair X BologniaSpain2024-03-27Buckley Miller Wright NEGOTIATION17Ioni Bowcher
1040David J MaletArgentina2024-04-24Commercial Press NEW34Stephen Shaw
1041Juan B PerinCanada2024-04-20Rousseaux, Michael Esq UNQUALIFIED57Ivan Magalhaes
1042Jones C GillianCanada2024-04-20Chanay, Jeffrey A Esq UNQUALIFIED60Ivan Magalhaes
1043Emily X AlbaresUnited Kingdom2024-03-30Chanay, Jeffrey A Esq QUALIFIED45Anna Fali
1044Smith S VocelkaRussia2024-04-18Morlong Associates NEW56Ivan Magalhaes
1045Izzy S MacleadSpain2024-04-07Benton, John B Jr NEW46Anna Fali
1046Munro A FigeroaGermany2024-03-29Chemel, James L Cpa QUALIFIED55Bernardo Dominic
1047Mayumi W AmigonAustralia2024-04-08Buckley Miller Wright NEW53Amy Elsner
1048Darci H IturbideItaly2024-03-28Chanay, Jeffrey A Esq QUALIFIED0Xuxue Feng
1049Antonio Q RimRussia2024-04-03King, Christopher A Esq PROPOSAL42Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Clifford J GarufiIndiaIoni Bowcher NEGOTIATION
James P RoysterBrazilStephen Shaw PROPOSAL
Mujtaba E OstroskyIndiaAsiya Javayant RENEWAL
Munro A TollnerGermanyAsiya Javayant NEW
Misaki N CaldareraArgentinaStephen Shaw NEGOTIATION
Munro W GillianRussiaAmy Elsner NEGOTIATION
Leja Z DilliardGermanyAsiya Javayant QUALIFIED
Greenwood J MaletItalyIoni Bowcher QUALIFIED
Munro C OstroskyJapanIvan Magalhaes QUALIFIED
Faith N DoeSpainAsiya Javayant RENEWAL
Francesco Q ChuiSpainOnyama Limba RENEWAL
Ivar Z FerenczIndiaBernardo Dominic RENEWAL
Leja C PoquetteArgentinaIoni Bowcher RENEWAL
Francesco Y AlbaresBrazilXuxue Feng UNQUALIFIED
Ricardo K SchemmerGermanyOnyama Limba QUALIFIED
Cody G MorascaArgentinaIoni Bowcher PROPOSAL
Darci J MaletItalyAmy Elsner NEW
Costa S PaprockiRussiaBernardo Dominic PROPOSAL
Mayumi G AmigonSpainXuxue Feng QUALIFIED
Jones Z BowleyFranceElwin Sharvill PROPOSAL
Octavia O ChuiIndiaBernardo Dominic NEW
Aika K TollnerArgentinaAnna Fali NEW
Francesco D WaycottSpainAsiya Javayant NEW
Isabel L DilliardArgentinaIoni Bowcher RENEWAL
Maria C DoeCanadaStephen Shaw UNQUALIFIED
Silvio N OldroydBrazilBernardo Dominic QUALIFIED
Silvio T AmigonItalyAsiya Javayant QUALIFIED
Rodrigues W TollnerAustraliaIoni Bowcher PROPOSAL
Emily D MorascaIndiaIoni Bowcher QUALIFIED
Maria P BowleySpainAnna Fali NEGOTIATION
Adams O MaletRussiaAmy Elsner NEW
Wickens A RoysterArgentinaBernardo Dominic RENEWAL
Deepesh L VenereAustraliaIoni Bowcher NEGOTIATION
Ashley H VenereGermanyAnna Fali NEGOTIATION
Clifford C WhobreyIndiaIvan Magalhaes PROPOSAL
Jones A SchemmerSpainAnna Fali NEW
Ashley J RulapaughRussiaStephen Shaw UNQUALIFIED
Maisha S InouyeArgentinaElwin Sharvill QUALIFIED
Izzy H RoysterBrazilElwin Sharvill NEW
Aditya K NickaBrazilOnyama Limba NEGOTIATION
Alejandro T KolmetzUnited KingdomAsiya Javayant RENEWAL
Rodrigues S OldroydCanadaStephen Shaw NEGOTIATION
Adams Y VocelkaCanadaBernardo Dominic NEW
Antonio R CampainSpainAmy Elsner PROPOSAL
Francesco S ShinkoCanadaBernardo Dominic QUALIFIED
Rodrigues K CaldareraFranceAsiya Javayant QUALIFIED
Greenwood Z IturbideArgentinaElwin Sharvill UNQUALIFIED
Mayumi U NickaJapanIoni Bowcher RENEWAL
Munro Y MaletFranceAmy Elsner PROPOSAL
Chavez E BriddickJapanXuxue Feng PROPOSAL
Frozen Columns
Name
Morrow I Bolognia
Rodrigues W Sergi
Aika L Ferencz
Ashley Z Rim
Salvatore R Nestle
Munro R Rim
Murillo F Waycott
Misaki N Butt
Nicolas K Marrier
Leon N Nicka
Aika L Wieser
Leja I Iturbide
Mujtaba Q Caudy
Izzy J Maclead
Munro P Bowley
Wickens E Wieser
Smith C Figeroa
Leon K Bowley
Cody V Malet
Faith T Schemmer
Kaitlin R Rim
Julie U Wieser
Jeanfrancois M Venere
Octavia I Briddick
Morrow D Campain
Ricardo F Dilliard
Isabel B Nicka
Aika V Nicka
Sinclair V Whobrey
Costa D Kusko
Deepesh G Royster
Murillo B Chui
Mujtaba J Royster
Faith L Kolmetz
Murillo E Albares
Tony E Kolmetz
Adams F Schemmer
Jefferson V Waycott
Arvin K Perin
Darci Z Bolognia
Smith U Sergi
Ricardo Q Caldarera
Misaki Y Saylors
Murillo Y Ruta
Kaitlin Q Whobrey
Misaki B Caudy
Adams Q Paprocki
Claire K Morasca
Morrow O Bowley
Tony Q Darakjy
IdCountryDate
1000Spain2024-04-02
1001Spain2024-04-03
1002Japan2024-04-14
1003Spain2024-04-02
1004Japan2024-04-03
1005Canada2024-04-20
1006India2024-04-16
1007France2024-04-21
1008Brazil2024-04-16
1009Italy2024-04-08
1010Spain2024-04-21
1011Australia2024-04-07
1012Spain2024-04-21
1013Argentina2024-04-13
1014Argentina2024-04-07
1015Germany2024-04-12
1016Russia2024-04-12
1017Russia2024-04-19
1018United Kingdom2024-04-21
1019Japan2024-04-16
1020Argentina2024-03-31
1021Canada2024-04-17
1022Canada2024-03-28
1023Argentina2024-04-07
1024Russia2024-03-29
1025Argentina2024-03-29
1026France2024-03-30
1027Argentina2024-04-16
1028France2024-04-05
1029India2024-04-01
1030Spain2024-04-15
1031Argentina2024-04-19
1032France2024-03-29
1033United Kingdom2024-04-11
1034Brazil2024-04-12
1035Canada2024-04-05
1036Germany2024-04-09
1037Germany2024-04-07
1038France2024-03-28
1039Brazil2024-04-03
1040France2024-04-23
1041Canada2024-04-10
1042Russia2024-04-06
1043Russia2024-04-04
1044India2024-04-02
1045Spain2024-03-30
1046Brazil2024-04-11
1047Japan2024-03-30
1048Spain2024-04-23
1049France2024-04-08

On-Demand Data

NameIdCountryDate
Alejandro V Shinko1000Japan2024-04-09
Deepesh V Nestle1001Argentina2024-04-19
Isabel I Perin1002Italy2024-04-06
Mujtaba O Marrier1003Brazil2024-04-18
Octavia U Maclead1004Spain2024-04-20
Mujtaba M Ostrosky1005India2024-04-01
Ricardo C Gaucho1006United Kingdom2024-04-19
Aika Q Oldroyd1007Japan2024-04-22
Jeanfrancois N Shinko1008Canada2024-04-16
Stacey C Oldroyd1009Italy2024-04-11
Maria T Gaucho1010Australia2024-03-28
Smith K Kusko1011Italy2024-04-02
Cody C Kusko1012Brazil2024-04-12
Adams N Ostrosky1013Japan2024-03-27
Faith P Shinko1014Russia2024-03-31
Murillo Z Maclead1015Russia2024-03-28
Silvio Z Stockham1016Canada2024-04-18
Clifford B Glick1017United Kingdom2024-04-20
Isabel D Whobrey1018Argentina2024-04-04
Adams X Flosi1019Germany2024-04-22
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Jefferson K DarakjyBrazilXuxue Feng UNQUALIFIED
Costa W MarrierJapanAsiya Javayant RENEWAL
Adams W RutaCanadaElwin Sharvill NEGOTIATION
Ricardo P BriddickBrazilElwin Sharvill PROPOSAL
Murillo T WaycottIndiaIoni Bowcher NEGOTIATION
Salvatore F BowleyCanadaStephen Shaw PROPOSAL
Octavia X StockhamBrazilStephen Shaw NEW
Jennifer C DoeAustraliaStephen Shaw QUALIFIED
Misaki M WieserBrazilElwin Sharvill NEGOTIATION
Maisha A PaprockiAustraliaAnna Fali QUALIFIED
Maria U TollnerFranceAmy Elsner QUALIFIED
Maisha L OldroydSpainAsiya Javayant RENEWAL
Greenwood Q SlusarskiSpainIvan Magalhaes NEW
Francesco V IturbideGermanyXuxue Feng QUALIFIED
Sinclair E ShinkoSpainIoni Bowcher UNQUALIFIED
Stacey E RulapaughJapanIoni Bowcher NEW
Alejandro S ChuiItalyIvan Magalhaes QUALIFIED
Stacey E NickaGermanyAmy Elsner RENEWAL
Faith U MorascaBrazilAmy Elsner RENEWAL
Munro R AlbaresRussiaXuxue Feng RENEWAL
Claire A StensethArgentinaIvan Magalhaes RENEWAL
Jennifer J OldroydRussiaAmy Elsner RENEWAL
Julie Y VenereCanadaAmy Elsner NEGOTIATION
Maria R BologniaJapanIoni Bowcher PROPOSAL
Munro G StensethIndiaBernardo Dominic UNQUALIFIED
Kadeem G MarrierItalyElwin Sharvill PROPOSAL
Adams C SaylorsAustraliaAsiya Javayant NEGOTIATION
Sinclair H GarufiUnited KingdomAnna Fali UNQUALIFIED
Aruna K OldroydArgentinaXuxue Feng UNQUALIFIED
Sinclair D BowleyBrazilBernardo Dominic RENEWAL
Isabel C NestleFranceBernardo Dominic RENEWAL
Maisha J StockhamFranceAmy Elsner PROPOSAL
Silvio W RutaAustraliaElwin Sharvill RENEWAL
Wickens Y DarakjyFranceAsiya Javayant QUALIFIED
Tony Q RoysterJapanAmy Elsner RENEWAL
Alejandro O RulapaughFranceXuxue Feng NEW
Maria J RulapaughArgentinaIvan Magalhaes NEGOTIATION
Jones T SlusarskiRussiaIoni Bowcher NEW
Francesco C GarufiGermanyXuxue Feng QUALIFIED
Chavez P VenereFranceBernardo Dominic UNQUALIFIED

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