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
Sinclair U MacleadFranceAsiya Javayant PROPOSAL
Aruna L WieserArgentinaBernardo Dominic PROPOSAL
Francesco G InouyeItalyElwin Sharvill RENEWAL
Kaitlin O OldroydArgentinaIvan Magalhaes RENEWAL
Jeanfrancois P FigeroaFranceOnyama Limba UNQUALIFIED
Emily T GlickSpainElwin Sharvill UNQUALIFIED
James F WaycottIndiaIoni Bowcher NEGOTIATION
Emily K TollnerBrazilIoni Bowcher QUALIFIED
Silvio E ButtFranceOnyama Limba NEW
Emily B ChuiGermanyBernardo Dominic UNQUALIFIED
Salvatore Y KolmetzJapanBernardo Dominic QUALIFIED
Maisha A RoysterBrazilIoni Bowcher UNQUALIFIED
Wickens T NestleUnited KingdomIoni Bowcher QUALIFIED
Faith M ButtIndiaAmy Elsner RENEWAL
Emily Q MorascaIndiaBernardo Dominic RENEWAL
Octavia O SaylorsItalyXuxue Feng UNQUALIFIED
Claire Q PoquetteSpainAmy Elsner RENEWAL
Jones W WaycottRussiaIoni Bowcher NEW
Aika A RutaBrazilIoni Bowcher RENEWAL
Chavez R BologniaAustraliaXuxue Feng NEGOTIATION
Maisha G SchemmerItalyBernardo Dominic RENEWAL
James Q OstroskyUnited KingdomXuxue Feng PROPOSAL
Mayumi J WhobreyGermanyOnyama Limba NEW
Jennifer R GlickIndiaBernardo Dominic RENEWAL
Leon Y BriddickSpainXuxue Feng PROPOSAL
Jones U WieserIndiaElwin Sharvill NEW
Claire A DarakjySpainAsiya Javayant NEW
Mayumi K FlosiArgentinaStephen Shaw NEW
Francesco B FigeroaJapanOnyama Limba PROPOSAL
Silvio K RimGermanyOnyama Limba NEW
Murillo Q InouyeItalyIvan Magalhaes PROPOSAL
Antonio I MaletGermanyAnna Fali NEGOTIATION
David R KolmetzRussiaXuxue Feng UNQUALIFIED
Alejandro X MacleadCanadaAmy Elsner NEW
Stacey J ChuiRussiaAmy Elsner PROPOSAL
Octavia O SaylorsBrazilElwin Sharvill PROPOSAL
Francesco O MarrierIndiaStephen Shaw UNQUALIFIED
Jennifer S MacleadBrazilIoni Bowcher QUALIFIED
Nicolas Z GarufiBrazilAsiya Javayant PROPOSAL
Isabel S NickaUnited KingdomBernardo Dominic NEGOTIATION
Rodrigues O NestleJapanIoni Bowcher NEGOTIATION
Aditya I TollnerRussiaAsiya Javayant NEGOTIATION
James R RulapaughCanadaAmy Elsner NEW
Tony P FigeroaArgentinaAnna Fali NEGOTIATION
Smith O GauchoSpainOnyama Limba QUALIFIED
Jefferson Q InouyeIndiaOnyama Limba NEGOTIATION
Juan U MaletArgentinaIoni Bowcher UNQUALIFIED
Clifford G SchemmerBrazilIvan Magalhaes QUALIFIED
Arvin E KuskoBrazilElwin Sharvill NEGOTIATION
Francesco Z NickaSpainBernardo Dominic RENEWAL
Horizontal
NameCountryRepresentativeStatus
Ashley Y OstroskyIndiaStephen Shaw NEW
Isabel Y MorascaUnited KingdomIoni Bowcher NEGOTIATION
Sinclair M OstroskySpainStephen Shaw NEW
Clifford N SchemmerCanadaAnna Fali RENEWAL
Ashley Y VocelkaUnited KingdomXuxue Feng QUALIFIED
Johnson L SchemmerIndiaAnna Fali PROPOSAL
Antonio Y CaldareraSpainStephen Shaw NEW
Jennifer F NickaIndiaIoni Bowcher UNQUALIFIED
Stacey A WhobreyCanadaOnyama Limba NEW
Wickens T VocelkaIndiaAmy Elsner NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Alejandro N CaudyAustralia2024-04-13Feiner Bros NEGOTIATION4Asiya Javayant
1001Leja V SaylorsSpain2024-04-19Printing Dimensions NEW80Ivan Magalhaes
1002Jennifer D MarrierJapan2024-04-30Truhlar And Truhlar Attys NEGOTIATION69Ivan Magalhaes
1003Juan S StensethAustralia2024-04-14Chanay, Jeffrey A Esq RENEWAL56Anna Fali
1004Salvatore V StockhamSpain2024-04-11Chapman, Ross E Esq NEW65Xuxue Feng
1005Aika G WaycottAustralia2024-04-19Chapman, Ross E Esq PROPOSAL79Xuxue Feng
1006Smith H MaletSpain2024-04-09Truhlar And Truhlar Attys NEW99Anna Fali
1007Chavez A CaldareraRussia2024-04-25Printing Dimensions NEGOTIATION7Anna Fali
1008Maisha Z SlusarskiGermany2024-05-01Chapman, Ross E Esq PROPOSAL16Ioni Bowcher
1009Darci Z MarrierArgentina2024-04-08Truhlar And Truhlar Attys QUALIFIED90Ioni Bowcher
1010Claire J AmigonJapan2024-04-21Rangoni Of Florence RENEWAL77Bernardo Dominic
1011Emily Y FerenczGermany2024-04-27Feiner Bros UNQUALIFIED6Bernardo Dominic
1012Jeanfrancois L NickaGermany2024-04-23Commercial Press RENEWAL83Stephen Shaw
1013Clifford G NestleAustralia2024-04-03Rangoni Of Florence RENEWAL75Ioni Bowcher
1014Maisha E RoysterIndia2024-04-28Printing Dimensions PROPOSAL21Amy Elsner
1015David Y GillianItaly2024-04-23Feiner Bros UNQUALIFIED28Ivan Magalhaes
1016Greenwood J FerenczSpain2024-04-11Commercial Press QUALIFIED26Elwin Sharvill
1017Stacey I PerinAustralia2024-04-11Chapman, Ross E Esq UNQUALIFIED31Stephen Shaw
1018Johnson C RutaSpain2024-04-07Chapman, Ross E Esq NEGOTIATION8Asiya Javayant
1019James G BowleyRussia2024-04-14Feiner Bros NEW93Onyama Limba
1020Arvin I OldroydJapan2024-04-05Buckley Miller Wright QUALIFIED9Anna Fali
1021David K AmigonCanada2024-04-10King, Christopher A Esq NEGOTIATION54Asiya Javayant
1022Alejandro A VocelkaJapan2024-04-29Dorl, James J Esq NEW86Anna Fali
1023Izzy S IturbideUnited Kingdom2024-04-06Truhlar And Truhlar Attys NEGOTIATION51Ivan Magalhaes
1024Aditya A FigeroaCanada2024-04-11Morlong Associates RENEWAL35Bernardo Dominic
1025James W BriddickFrance2024-04-05Morlong Associates UNQUALIFIED97Stephen Shaw
1026Adams M WieserUnited Kingdom2024-05-01Morlong Associates QUALIFIED44Stephen Shaw
1027Juan X AmigonArgentina2024-04-28Printing Dimensions RENEWAL73Stephen Shaw
1028Kaitlin W AmigonRussia2024-04-04Feltz Printing Service RENEWAL82Onyama Limba
1029Kadeem X WaycottRussia2024-04-22Printing Dimensions QUALIFIED23Asiya Javayant
1030Francesco J ButtRussia2024-04-18Feltz Printing Service UNQUALIFIED10Amy Elsner
1031Rodrigues P MaletFrance2024-04-27Chapman, Ross E Esq NEGOTIATION16Onyama Limba
1032Leja H FerenczCanada2024-04-21Benton, John B Jr QUALIFIED52Elwin Sharvill
1033Octavia B WaycottRussia2024-04-04Printing Dimensions RENEWAL57Anna Fali
1034Leja Y FerenczGermany2024-04-25Feltz Printing Service UNQUALIFIED64Elwin Sharvill
1035Smith J StensethCanada2024-04-25Truhlar And Truhlar Attys UNQUALIFIED60Elwin Sharvill
1036Juan G FollerItaly2024-04-14Chemel, James L Cpa QUALIFIED91Stephen Shaw
1037Isabel V RutaArgentina2024-04-26Benton, John B Jr UNQUALIFIED66Asiya Javayant
1038Ashley N DoeAustralia2024-04-27King, Christopher A Esq UNQUALIFIED30Asiya Javayant
1039Jefferson I KuskoFrance2024-04-02Dorl, James J Esq UNQUALIFIED59Amy Elsner
1040Murillo H MacleadSpain2024-05-01Buckley Miller Wright PROPOSAL77Onyama Limba
1041Kadeem R FlosiJapan2024-04-15Chanay, Jeffrey A Esq PROPOSAL68Onyama Limba
1042Maisha N PaprockiFrance2024-04-20King, Christopher A Esq NEW63Bernardo Dominic
1043Ashley K KuskoArgentina2024-04-25Printing Dimensions NEGOTIATION68Bernardo Dominic
1044Cody Z MacleadFrance2024-04-20Feiner Bros NEW92Amy Elsner
1045Jones C DarakjyIndia2024-04-10King, Christopher A Esq NEGOTIATION21Ioni Bowcher
1046Wickens E WieserRussia2024-04-24Commercial Press UNQUALIFIED14Onyama Limba
1047Rodrigues Q NickaAustralia2024-04-30Buckley Miller Wright QUALIFIED4Amy Elsner
1048Aditya W AlbaresBrazil2024-04-21King, Christopher A Esq RENEWAL87Ivan Magalhaes
1049Izzy X StensethJapan2024-04-18Benton, John B Jr UNQUALIFIED12Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Jones S FollerBrazilAmy Elsner NEGOTIATION
Greenwood X CaudyFranceElwin Sharvill QUALIFIED
Ricardo U NestleSpainAmy Elsner RENEWAL
Rodrigues I PaprockiBrazilAnna Fali QUALIFIED
Mujtaba G ShinkoFranceBernardo Dominic UNQUALIFIED
Kadeem K NickaGermanyAnna Fali UNQUALIFIED
Cody Y CampainJapanAmy Elsner NEGOTIATION
Greenwood K ButtGermanyOnyama Limba UNQUALIFIED
Alejandro S MaletCanadaElwin Sharvill UNQUALIFIED
Ricardo V KolmetzRussiaAnna Fali NEW
Jones S NickaUnited KingdomXuxue Feng NEGOTIATION
Stacey C FerenczAustraliaStephen Shaw UNQUALIFIED
Julie H FollerFranceAnna Fali NEW
Deepesh F GillianCanadaElwin Sharvill NEGOTIATION
Kaitlin Z RoysterAustraliaXuxue Feng NEGOTIATION
Ricardo Q KolmetzFranceAnna Fali PROPOSAL
Julie L DilliardSpainAsiya Javayant PROPOSAL
Salvatore Y RutaRussiaXuxue Feng PROPOSAL
Emily V SaylorsRussiaElwin Sharvill PROPOSAL
Ivar W ChuiJapanXuxue Feng RENEWAL
Izzy H StensethFranceAmy Elsner NEGOTIATION
Wickens U SlusarskiSpainElwin Sharvill RENEWAL
Aditya X CaldareraAustraliaBernardo Dominic RENEWAL
Aruna O WhobreyFranceXuxue Feng NEGOTIATION
Stacey I SchemmerBrazilBernardo Dominic QUALIFIED
Jennifer I WhobreyUnited KingdomOnyama Limba RENEWAL
Jones W GauchoIndiaAnna Fali QUALIFIED
Aruna T SaylorsBrazilIoni Bowcher NEW
Jefferson T VocelkaFranceAmy Elsner RENEWAL
Tony R ChuiArgentinaAsiya Javayant QUALIFIED
Wickens F BriddickSpainIvan Magalhaes NEW
Faith G BowleyUnited KingdomStephen Shaw PROPOSAL
Jefferson X DoeItalyXuxue Feng UNQUALIFIED
Murillo O GarufiIndiaAmy Elsner QUALIFIED
Arvin L MaletAustraliaXuxue Feng RENEWAL
Aruna K FlosiIndiaIvan Magalhaes QUALIFIED
Ivar H VenereIndiaAmy Elsner QUALIFIED
Chavez F SchemmerRussiaIoni Bowcher RENEWAL
Izzy V AlbaresFranceStephen Shaw PROPOSAL
Munro L WieserIndiaOnyama Limba QUALIFIED
David I OstroskyAustraliaOnyama Limba RENEWAL
Aditya C NickaJapanIvan Magalhaes PROPOSAL
Izzy V RutaJapanIvan Magalhaes NEGOTIATION
Misaki X MorascaItalyOnyama Limba UNQUALIFIED
Julie D WaycottItalyXuxue Feng NEW
Julie G FerenczIndiaAmy Elsner RENEWAL
Aika Z WhobreySpainAmy Elsner NEW
Deepesh I BologniaIndiaStephen Shaw RENEWAL
Mayumi S NestleFranceBernardo Dominic NEGOTIATION
Rodrigues K FlosiJapanAsiya Javayant NEW
Frozen Columns
Name
James X Whobrey
Francesco Q Schemmer
Salvatore W Gillian
Clifford I Caldarera
Adams Y Slusarski
Deepesh J Kusko
Julie V Nicka
Aika U Foller
Chavez B Caldarera
Misaki F Royster
Morrow A Saylors
Alejandro L Briddick
Maisha H Darakjy
Izzy B Iturbide
Octavia H Briddick
Nicolas R Perin
Leja E Doe
Deepesh X Saylors
Ashley A Caldarera
James W Maclead
Ricardo W Vocelka
Claire K Marrier
Ashley I Paprocki
David A Malet
Smith D Royster
Octavia A Gaucho
Maisha Q Ostrosky
Deepesh Q Bolognia
Munro S Garufi
Juan E Stockham
Octavia J Schemmer
Sinclair D Royster
Jones D Briddick
Misaki P Gaucho
Murillo A Caudy
Nicolas X Marrier
Clifford J Inouye
Francesco W Malet
Munro D Flosi
Arvin D Kusko
Nicolas U Sergi
Nicolas E Garufi
Kadeem E Glick
Claire Q Butt
Maria P Foller
Aika G Perin
Morrow Y Darakjy
Jennifer R Albares
Nicolas P Inouye
Cody Z Tollner
IdCountryDate
1000India2024-05-01
1001Italy2024-04-04
1002India2024-04-21
1003Germany2024-04-30
1004Canada2024-04-11
1005Argentina2024-04-27
1006Brazil2024-04-08
1007Argentina2024-04-13
1008Japan2024-04-02
1009Russia2024-04-23
1010Germany2024-04-02
1011Russia2024-04-26
1012Australia2024-04-10
1013France2024-04-15
1014Italy2024-04-02
1015Japan2024-04-09
1016Brazil2024-04-02
1017France2024-04-21
1018Russia2024-04-23
1019Germany2024-04-08
1020Italy2024-04-15
1021Brazil2024-04-05
1022Argentina2024-04-19
1023United Kingdom2024-04-25
1024France2024-04-15
1025Italy2024-04-11
1026Argentina2024-04-05
1027United Kingdom2024-04-11
1028Germany2024-04-02
1029Australia2024-04-20
1030France2024-04-02
1031Australia2024-04-16
1032Brazil2024-04-22
1033Italy2024-04-14
1034India2024-04-25
1035Russia2024-04-18
1036Canada2024-04-23
1037Russia2024-04-25
1038Italy2024-04-19
1039Italy2024-04-22
1040Argentina2024-04-27
1041Russia2024-04-10
1042Germany2024-04-20
1043Italy2024-04-19
1044India2024-04-18
1045Australia2024-04-23
1046United Kingdom2024-04-17
1047Spain2024-04-25
1048Canada2024-04-27
1049Canada2024-04-04

On-Demand Data

NameIdCountryDate
Isabel N Bowley1000Japan2024-04-29
David Y Morasca1001Germany2024-04-07
Alejandro S Royster1002Italy2024-04-15
Cody S Perin1003Australia2024-04-28
Isabel B Stockham1004Japan2024-04-04
Smith T Paprocki1005Argentina2024-04-25
Julie E Bowley1006Argentina2024-04-13
Aditya H Albares1007Canada2024-04-09
Aika M Ruta1008France2024-04-03
Cody H Dilliard1009India2024-04-03
Maisha U Wieser1010France2024-04-13
Chavez F Kolmetz1011Canada2024-04-23
Ashley G Oldroyd1012France2024-04-14
Smith O Waycott1013Italy2024-04-12
James V Saylors1014India2024-04-14
Wickens N Glick1015Argentina2024-04-04
Octavia Q Bowley1016Germany2024-04-21
Juan A Stockham1017Brazil2024-04-07
Julie G Inouye1018Japan2024-05-01
Rodrigues Q Stockham1019Italy2024-04-21
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Kadeem E RutaBrazilAsiya Javayant NEGOTIATION
Antonio Q PerinAustraliaAmy Elsner PROPOSAL
Adams F DilliardSpainBernardo Dominic PROPOSAL
Cody Q VocelkaJapanAnna Fali NEW
Isabel M WaycottRussiaXuxue Feng RENEWAL
Johnson K VenereBrazilStephen Shaw NEW
Rodrigues D MarrierGermanyBernardo Dominic NEW
Ivar C GlickSpainIvan Magalhaes RENEWAL
Alejandro O NestleUnited KingdomBernardo Dominic PROPOSAL
Mayumi J FerenczAustraliaIvan Magalhaes PROPOSAL
James U StensethBrazilAmy Elsner NEW
Julie H RimIndiaAsiya Javayant QUALIFIED
Chavez Y MaletJapanXuxue Feng PROPOSAL
Octavia D SchemmerItalyAnna Fali PROPOSAL
Wickens C TollnerFranceIvan Magalhaes QUALIFIED
Adams F StockhamCanadaAnna Fali NEGOTIATION
Mayumi V ShinkoFranceXuxue Feng QUALIFIED
Deepesh L StockhamFranceAmy Elsner RENEWAL
Sinclair G OstroskySpainStephen Shaw RENEWAL
Mayumi J NickaUnited KingdomOnyama Limba UNQUALIFIED
Juan O IturbideSpainIoni Bowcher QUALIFIED
Kaitlin X ChuiItalyIoni Bowcher NEGOTIATION
Ricardo C MacleadRussiaIoni Bowcher RENEWAL
Sinclair Q BologniaGermanyBernardo Dominic RENEWAL
Maria F DilliardBrazilAnna Fali RENEWAL
Smith F KuskoJapanAnna Fali RENEWAL
Leon W BriddickBrazilStephen Shaw RENEWAL
Stacey F BowleyBrazilBernardo Dominic PROPOSAL
Aika V SergiIndiaIvan Magalhaes NEW
Kadeem M GarufiIndiaStephen Shaw QUALIFIED
Mayumi P AmigonUnited KingdomXuxue Feng NEW
Rodrigues D KolmetzGermanyElwin Sharvill UNQUALIFIED
Salvatore Z NestleSpainXuxue Feng RENEWAL
Jefferson F CaudyJapanAsiya Javayant RENEWAL
David U OstroskyArgentinaAnna Fali UNQUALIFIED
Ivar W RutaIndiaAnna Fali RENEWAL
Munro J BowleyUnited KingdomOnyama Limba NEW
Jefferson R DilliardCanadaAsiya Javayant RENEWAL
Stacey B OstroskyAustraliaAsiya Javayant QUALIFIED
Chavez X CampainCanadaElwin Sharvill 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>