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
Silvio P MacleadCanadaElwin Sharvill NEW
Aditya K WaycottBrazilBernardo Dominic QUALIFIED
Misaki D BriddickGermanyElwin Sharvill NEGOTIATION
Wickens B RoysterGermanyBernardo Dominic NEGOTIATION
Isabel E IturbideAustraliaBernardo Dominic PROPOSAL
Maisha R WhobreyArgentinaAmy Elsner RENEWAL
Ashley O MaletFranceOnyama Limba QUALIFIED
Morrow Z AlbaresGermanyIoni Bowcher QUALIFIED
Faith D ShinkoCanadaIvan Magalhaes UNQUALIFIED
David Z AlbaresFranceIoni Bowcher PROPOSAL
Claire H InouyeUnited KingdomElwin Sharvill QUALIFIED
Arvin Y CaldareraItalyIoni Bowcher QUALIFIED
Claire Y OstroskyUnited KingdomBernardo Dominic RENEWAL
Mujtaba I VocelkaIndiaXuxue Feng UNQUALIFIED
Aika M NestleAustraliaAsiya Javayant NEGOTIATION
Isabel M AlbaresFranceAnna Fali UNQUALIFIED
Costa P RutaCanadaOnyama Limba NEW
Isabel U FollerAustraliaIvan Magalhaes UNQUALIFIED
Wickens L SergiCanadaIvan Magalhaes UNQUALIFIED
Francesco D GarufiItalyIoni Bowcher UNQUALIFIED
Mayumi C FerenczUnited KingdomElwin Sharvill NEGOTIATION
James L RoysterAustraliaStephen Shaw RENEWAL
Cody I SergiIndiaXuxue Feng QUALIFIED
Ashley W StensethCanadaBernardo Dominic QUALIFIED
Murillo R MacleadUnited KingdomIvan Magalhaes QUALIFIED
Smith Q MarrierFranceAnna Fali PROPOSAL
Kadeem D RoysterItalyAsiya Javayant QUALIFIED
Stacey D MaletItalyXuxue Feng QUALIFIED
James O VocelkaCanadaAnna Fali NEGOTIATION
Misaki M PerinFranceIvan Magalhaes QUALIFIED
Costa M GauchoUnited KingdomXuxue Feng QUALIFIED
Jefferson I BriddickGermanyIvan Magalhaes PROPOSAL
Cody R StockhamAustraliaOnyama Limba RENEWAL
Faith S GarufiCanadaIoni Bowcher UNQUALIFIED
Leja B SaylorsAustraliaStephen Shaw NEGOTIATION
Leon X RimRussiaIvan Magalhaes PROPOSAL
Julie U StensethArgentinaStephen Shaw NEGOTIATION
Ashley Z PoquetteJapanAsiya Javayant NEW
Mayumi I MorascaSpainIvan Magalhaes UNQUALIFIED
Leon G WieserAustraliaAsiya Javayant RENEWAL
Greenwood E WhobreyUnited KingdomAsiya Javayant RENEWAL
Emily D PerinUnited KingdomElwin Sharvill UNQUALIFIED
Aruna N WaycottCanadaElwin Sharvill QUALIFIED
Julie Z ChuiItalyIoni Bowcher QUALIFIED
Julie C WaycottAustraliaIoni Bowcher UNQUALIFIED
Kaitlin Y StensethJapanIoni Bowcher NEW
Smith C DilliardJapanIoni Bowcher PROPOSAL
Antonio R StockhamGermanyAmy Elsner UNQUALIFIED
Deepesh F OstroskyGermanyAnna Fali NEW
Costa I CaldareraRussiaAmy Elsner NEW
Horizontal
NameCountryRepresentativeStatus
Isabel R BriddickAustraliaAnna Fali PROPOSAL
Chavez C WhobreyAustraliaIoni Bowcher PROPOSAL
Juan I GlickCanadaOnyama Limba NEW
Emily P SchemmerBrazilIoni Bowcher RENEWAL
Ricardo Q WhobreyAustraliaAsiya Javayant RENEWAL
Kadeem K SergiJapanIoni Bowcher PROPOSAL
Faith R WhobreyRussiaXuxue Feng NEGOTIATION
Juan P WieserGermanyXuxue Feng UNQUALIFIED
Munro P FerenczJapanAmy Elsner RENEWAL
Julie Y MarrierCanadaAmy Elsner NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jefferson R MaletSpain2024-04-22Commercial Press QUALIFIED39Ioni Bowcher
1001David S FerenczBrazil2024-03-31Benton, John B Jr PROPOSAL97Anna Fali
1002Jefferson H WaycottCanada2024-04-11Feiner Bros QUALIFIED67Onyama Limba
1003Maisha V GauchoArgentina2024-04-15Rousseaux, Michael Esq UNQUALIFIED71Amy Elsner
1004Darci G GlickFrance2024-04-14Printing Dimensions NEW51Asiya Javayant
1005Mayumi X FlosiArgentina2024-03-29Rousseaux, Michael Esq NEW50Xuxue Feng
1006Mujtaba Z CaudyIndia2024-04-05Dorl, James J Esq NEGOTIATION44Ivan Magalhaes
1007Darci E BologniaAustralia2024-04-01Rangoni Of Florence NEW22Amy Elsner
1008Johnson D CaudyRussia2024-04-26Truhlar And Truhlar Attys NEW73Bernardo Dominic
1009Sinclair S KuskoFrance2024-04-19Feltz Printing Service RENEWAL17Elwin Sharvill
1010Julie K WaycottJapan2024-04-09Buckley Miller Wright RENEWAL71Xuxue Feng
1011Julie P RulapaughSpain2024-04-25Feltz Printing Service PROPOSAL86Xuxue Feng
1012Rodrigues E RulapaughCanada2024-03-30Feiner Bros RENEWAL80Onyama Limba
1013Stacey V CampainJapan2024-03-29Morlong Associates UNQUALIFIED17Onyama Limba
1014Silvio B IturbideSpain2024-03-28Benton, John B Jr QUALIFIED21Elwin Sharvill
1015Kadeem A MarrierAustralia2024-04-03Commercial Press NEW45Ioni Bowcher
1016Julie W GarufiRussia2024-03-28Benton, John B Jr RENEWAL5Bernardo Dominic
1017Costa X WieserBrazil2024-03-30Benton, John B Jr QUALIFIED65Asiya Javayant
1018Ashley W ShinkoCanada2024-04-26Chanay, Jeffrey A Esq UNQUALIFIED92Bernardo Dominic
1019Leon G TollnerIndia2024-03-30Chemel, James L Cpa RENEWAL65Onyama Limba
1020Maria K GarufiIndia2024-04-03Chanay, Jeffrey A Esq PROPOSAL41Amy Elsner
1021Jones Y GauchoUnited Kingdom2024-04-20Chapman, Ross E Esq NEW39Anna Fali
1022Julie K FollerSpain2024-04-09Rangoni Of Florence NEGOTIATION6Amy Elsner
1023Silvio L MarrierCanada2024-04-09Buckley Miller Wright QUALIFIED50Amy Elsner
1024Jones S PaprockiArgentina2024-04-15Chanay, Jeffrey A Esq RENEWAL75Stephen Shaw
1025Silvio N SlusarskiFrance2024-03-31Truhlar And Truhlar Attys UNQUALIFIED94Xuxue Feng
1026Munro W BowleySpain2024-04-19Printing Dimensions NEW44Xuxue Feng
1027Julie E WieserFrance2024-04-04Feiner Bros RENEWAL2Asiya Javayant
1028Emily T ButtBrazil2024-04-24King, Christopher A Esq RENEWAL42Elwin Sharvill
1029Darci D RimSpain2024-04-19Chanay, Jeffrey A Esq QUALIFIED2Asiya Javayant
1030Nicolas W GlickSpain2024-04-26Feltz Printing Service PROPOSAL13Ivan Magalhaes
1031Aditya M OldroydSpain2024-04-02Feiner Bros QUALIFIED93Bernardo Dominic
1032James B NestleUnited Kingdom2024-04-24Commercial Press NEGOTIATION98Onyama Limba
1033Ricardo Y DoeSpain2024-04-08Morlong Associates NEW42Anna Fali
1034Antonio H MaletBrazil2024-04-14Rousseaux, Michael Esq QUALIFIED20Xuxue Feng
1035Kadeem D BriddickItaly2024-03-30Feltz Printing Service QUALIFIED60Anna Fali
1036Tony G NestleFrance2024-04-22King, Christopher A Esq NEGOTIATION70Amy Elsner
1037Costa R KolmetzAustralia2024-04-23Rousseaux, Michael Esq RENEWAL23Onyama Limba
1038Aika K NestleIndia2024-04-08Benton, John B Jr PROPOSAL85Anna Fali
1039Jones W MacleadCanada2024-04-12Dorl, James J Esq RENEWAL59Anna Fali
1040Kaitlin G SergiGermany2024-04-19Morlong Associates QUALIFIED24Onyama Limba
1041Izzy K WaycottArgentina2024-04-25Rousseaux, Michael Esq RENEWAL75Asiya Javayant
1042Mayumi N SlusarskiAustralia2024-04-21Buckley Miller Wright QUALIFIED24Bernardo Dominic
1043Munro E InouyeBrazil2024-04-07Feltz Printing Service NEW10Bernardo Dominic
1044Juan P SchemmerArgentina2024-04-12Feiner Bros NEGOTIATION52Ioni Bowcher
1045Aruna K NickaArgentina2024-04-03Chemel, James L Cpa NEGOTIATION11Asiya Javayant
1046Ricardo Y GlickUnited Kingdom2024-04-22Chanay, Jeffrey A Esq PROPOSAL62Xuxue Feng
1047Adams G NestleItaly2024-04-04Chanay, Jeffrey A Esq NEW45Stephen Shaw
1048David Z StensethAustralia2024-04-02Truhlar And Truhlar Attys QUALIFIED31Xuxue Feng
1049Izzy X GillianIndia2024-04-19Benton, John B Jr PROPOSAL15Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Morrow A GillianUnited KingdomElwin Sharvill NEW
Wickens S KuskoIndiaElwin Sharvill QUALIFIED
Murillo M SaylorsIndiaIoni Bowcher NEGOTIATION
Leon W VenereIndiaBernardo Dominic NEGOTIATION
Antonio G DarakjyAustraliaIvan Magalhaes RENEWAL
Maisha U ShinkoFranceOnyama Limba RENEWAL
Ivar U IturbideRussiaAsiya Javayant QUALIFIED
Rodrigues V AlbaresGermanyXuxue Feng NEW
Cody G AmigonItalyIvan Magalhaes NEW
David K OldroydJapanElwin Sharvill UNQUALIFIED
Tony K FollerRussiaAmy Elsner NEW
Munro Y NestleCanadaElwin Sharvill PROPOSAL
Alejandro P AmigonFranceAmy Elsner NEGOTIATION
Johnson O AlbaresFranceAmy Elsner NEW
Faith S AmigonSpainIvan Magalhaes RENEWAL
Kaitlin Q RutaUnited KingdomAmy Elsner NEGOTIATION
Claire D MorascaSpainBernardo Dominic UNQUALIFIED
Izzy Q MaletCanadaBernardo Dominic RENEWAL
Faith Y FigeroaSpainStephen Shaw NEGOTIATION
Aditya P MacleadRussiaElwin Sharvill NEGOTIATION
Leon M NestleFranceAnna Fali NEW
Stacey Y InouyeFranceXuxue Feng PROPOSAL
Jeanfrancois K IturbideSpainOnyama Limba NEGOTIATION
Octavia J GauchoUnited KingdomElwin Sharvill NEGOTIATION
Salvatore L SaylorsCanadaStephen Shaw RENEWAL
Octavia S MaletIndiaOnyama Limba NEGOTIATION
Claire I SaylorsCanadaAmy Elsner UNQUALIFIED
Octavia B SergiUnited KingdomStephen Shaw RENEWAL
Ashley A RulapaughGermanyAmy Elsner PROPOSAL
Ricardo V ButtBrazilBernardo Dominic QUALIFIED
Aditya R RulapaughArgentinaStephen Shaw NEW
Cody D MorascaGermanyAmy Elsner NEGOTIATION
Kaitlin G BriddickUnited KingdomElwin Sharvill QUALIFIED
Chavez W WhobreyFranceOnyama Limba NEGOTIATION
Smith O NestleFranceStephen Shaw RENEWAL
Chavez U KolmetzSpainXuxue Feng NEGOTIATION
Salvatore Q GarufiIndiaIoni Bowcher UNQUALIFIED
Misaki S IturbideUnited KingdomXuxue Feng PROPOSAL
Rodrigues E DoeIndiaAsiya Javayant NEW
Chavez B VenereRussiaStephen Shaw NEGOTIATION
Ashley Y OldroydBrazilAsiya Javayant QUALIFIED
Stacey F StensethGermanyStephen Shaw RENEWAL
Leja S PoquetteCanadaAnna Fali UNQUALIFIED
Claire N NestleCanadaElwin Sharvill QUALIFIED
Mayumi R RutaCanadaAnna Fali RENEWAL
Jefferson P DoeGermanyAsiya Javayant QUALIFIED
Alejandro D RimBrazilIoni Bowcher NEW
Aika P ChuiCanadaIoni Bowcher RENEWAL
Cody E FollerGermanyStephen Shaw UNQUALIFIED
Maria X AlbaresItalyIvan Magalhaes NEGOTIATION
Frozen Columns
Name
Jefferson G Amigon
David P Saylors
Jennifer U Iturbide
Jennifer M Doe
Johnson D Malet
Maria A Gaucho
Cody B Malet
Izzy S Tollner
Julie L Rim
Sinclair E Caldarera
Antonio Q Foller
Francesco R Dilliard
Aruna K Vocelka
Johnson H Ferencz
Claire E Poquette
Rodrigues Q Doe
Juan E Iturbide
Juan B Waycott
Aditya L Dilliard
Isabel Z Caldarera
Aika I Poquette
Aditya J Ruta
Emily M Flosi
Ivar M Foller
Faith K Foller
Nicolas O Oldroyd
Adams M Perin
Alejandro L Maclead
Silvio I Dilliard
Jennifer D Wieser
David Z Gillian
Chavez X Kolmetz
Misaki J Butt
Adams W Venere
Maria L Campain
Jones Y Inouye
Ricardo M Venere
Mujtaba P Amigon
Ashley Q Briddick
Greenwood J Perin
Cody J Briddick
Leja R Malet
David N Foller
Aruna X Tollner
Leon N Garufi
Smith J Oldroyd
Jefferson I Morasca
Leja E Inouye
Maria Y Poquette
Leja R Wieser
IdCountryDate
1000France2024-04-21
1001India2024-04-17
1002Canada2024-04-05
1003Brazil2024-04-16
1004India2024-03-30
1005United Kingdom2024-04-23
1006United Kingdom2024-04-05
1007Japan2024-04-17
1008Italy2024-04-26
1009Australia2024-04-09
1010United Kingdom2024-04-04
1011Japan2024-04-18
1012Russia2024-04-14
1013Argentina2024-04-21
1014Russia2024-04-01
1015Australia2024-04-08
1016Russia2024-04-16
1017France2024-04-22
1018United Kingdom2024-04-03
1019Australia2024-04-15
1020India2024-03-31
1021Japan2024-04-09
1022Brazil2024-04-13
1023Australia2024-04-04
1024Italy2024-04-08
1025Brazil2024-04-20
1026Italy2024-04-20
1027Spain2024-04-07
1028Spain2024-04-16
1029United Kingdom2024-04-02
1030United Kingdom2024-04-23
1031Brazil2024-04-08
1032Germany2024-04-17
1033Spain2024-04-21
1034United Kingdom2024-03-28
1035Germany2024-04-15
1036Japan2024-04-26
1037Spain2024-04-12
1038Brazil2024-04-19
1039Brazil2024-04-12
1040Russia2024-04-04
1041Canada2024-03-31
1042Germany2024-04-26
1043Germany2024-03-29
1044Russia2024-04-10
1045Russia2024-04-21
1046Russia2024-04-24
1047India2024-04-10
1048Germany2024-04-08
1049Spain2024-04-19

On-Demand Data

NameIdCountryDate
Salvatore G Saylors1000Italy2024-04-07
Johnson E Saylors1001Japan2024-04-06
David A Wieser1002Japan2024-04-04
Izzy Y Doe1003France2024-04-22
Sinclair A Butt1004Russia2024-04-03
Mujtaba A Darakjy1005Brazil2024-04-18
Octavia J Royster1006Australia2024-04-23
Leja Y Slusarski1007Spain2024-04-03
Ivar P Tollner1008United Kingdom2024-04-19
Julie P Doe1009Brazil2024-04-15
Emily R Albares1010Japan2024-04-09
Deepesh S Wieser1011Germany2024-04-22
Morrow A Foller1012Australia2024-04-13
Darci Q Morasca1013Italy2024-04-11
James X Oldroyd1014Australia2024-04-16
Izzy I Chui1015India2024-04-18
Deepesh J Ostrosky1016Russia2024-04-04
Jeanfrancois P Morasca1017Germany2024-04-10
Octavia A Maclead1018Argentina2024-04-19
Julie F Albares1019Germany2024-04-21
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
James X WhobreyBrazilXuxue Feng QUALIFIED
Mayumi Y DarakjyAustraliaOnyama Limba NEW
Johnson D MaletSpainBernardo Dominic NEW
James C VenereJapanOnyama Limba NEW
Jones W GlickRussiaAsiya Javayant NEW
Julie P PoquetteCanadaAnna Fali QUALIFIED
Izzy C PaprockiItalyAmy Elsner PROPOSAL
Ivar B AlbaresRussiaOnyama Limba RENEWAL
Rodrigues P PoquetteAustraliaOnyama Limba PROPOSAL
Ashley V FlosiJapanStephen Shaw NEW
Leja K WhobreyArgentinaBernardo Dominic PROPOSAL
Cody Y GlickIndiaStephen Shaw NEW
Aditya U WieserFranceIoni Bowcher PROPOSAL
Aditya Q KuskoBrazilAsiya Javayant NEGOTIATION
Maisha J TollnerItalyIoni Bowcher RENEWAL
Cody X SlusarskiUnited KingdomStephen Shaw QUALIFIED
Isabel H BowleyBrazilAmy Elsner RENEWAL
Faith I WaycottItalyXuxue Feng PROPOSAL
Jones O GarufiCanadaOnyama Limba NEGOTIATION
Octavia S SergiFranceAsiya Javayant PROPOSAL
Jennifer T MaletRussiaAnna Fali UNQUALIFIED
Maria R BologniaArgentinaBernardo Dominic NEW
Munro K InouyeAustraliaOnyama Limba RENEWAL
Maria N GillianIndiaStephen Shaw UNQUALIFIED
Aruna X VenereRussiaIoni Bowcher NEGOTIATION
Aika J SergiFranceElwin Sharvill NEW
Sinclair Z NestleArgentinaIvan Magalhaes NEGOTIATION
Izzy I CampainAustraliaElwin Sharvill UNQUALIFIED
Chavez N FlosiSpainStephen Shaw PROPOSAL
Alejandro J BowleyArgentinaXuxue Feng NEGOTIATION
Adams U OstroskyCanadaAsiya Javayant NEW
Stacey I SlusarskiGermanyStephen Shaw NEW
Misaki O KolmetzSpainAnna Fali RENEWAL
Juan I ButtCanadaIoni Bowcher QUALIFIED
Jeanfrancois B ShinkoGermanyStephen Shaw RENEWAL
Tony U WaycottUnited KingdomStephen Shaw PROPOSAL
Ashley F BriddickCanadaBernardo Dominic QUALIFIED
Costa V WhobreyGermanyAsiya Javayant NEGOTIATION
Jones W ButtSpainIoni Bowcher NEGOTIATION
Arvin U PaprockiAustraliaOnyama Limba NEGOTIATION

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