Locale

Change the locale of the datepicker, schedule and client side validation messages.

Language
English
English
English
French
German
German
German
Italian
Korean
Spanish
Catalan
Dutch
Portuguese
Portuguese
Arabic
Arabic
Bulgarian
Czech
Greek
Persian
Finnish
Danish
Hindi
Indonesian
Croatian
Japanese
Hungarian
Hebrew
Georgian
Central Kurdish
Khmer
Kyrgyz
Kazakh
Lithuanian
Latvian
Malay
Norwegian
Polish
Romanian
Russian
Slovak
Slovenian
Serbian
Serbian
Swedish
Thai
Turkish
Ukrainian
Vietnamese
Chinese
Chinese

Input Style

Themes

PrimeOne
Saga Saga
Vela Vela
Arya Arya
Bootstrap
bootstrap4-blue-light Bootstrap Blue
bootstrap4-purple-light Bootstrap Purple
bootstrap4-blue-dark Bootstrap Blue
bootstrap4-purple-dark Bootstrap Purple
Material Design
material-indigo-light Indigo
material-deeppurple-light' Deep Purple
material-indigo-dark Indigo
material-deeppurple-dark' Deep Purple
Material Design Compact
material-indigo-light Indigo
material-deeppurple-light' Deep Purple
material-indigo-dark Indigo
material-deeppurple-dark' Deep Purple

DataTable Scroll

Both vertical and horizontal scrolling of the data is supported with optional frozen rows-columns and on-demand loading features.

Vertical
NameCountryRepresentativeStatus
James K AlbaresSpainBernardo Dominic PROPOSAL
Stacey F SergiFranceAnna Fali RENEWAL
Sinclair F MaletItalyElwin Sharvill RENEWAL
Jones U GlickCanadaOnyama Limba PROPOSAL
Claire B RimJapanStephen Shaw RENEWAL
Chavez U StensethGermanyIoni Bowcher UNQUALIFIED
Mujtaba Q PoquetteItalyAsiya Javayant UNQUALIFIED
Sinclair L PoquetteCanadaBernardo Dominic NEGOTIATION
Leon W TollnerCanadaStephen Shaw QUALIFIED
Greenwood U MacleadGermanyAsiya Javayant QUALIFIED
Adams E MorascaRussiaOnyama Limba NEGOTIATION
Deepesh E FerenczRussiaAnna Fali PROPOSAL
Adams E StensethItalyBernardo Dominic NEW
Wickens G OldroydJapanBernardo Dominic QUALIFIED
Nicolas D RimItalyIvan Magalhaes QUALIFIED
Jones C DarakjyJapanIoni Bowcher UNQUALIFIED
Izzy J FerenczArgentinaElwin Sharvill NEGOTIATION
Morrow C OldroydUnited KingdomXuxue Feng UNQUALIFIED
Johnson C ChuiAustraliaIoni Bowcher PROPOSAL
Octavia L PaprockiItalyOnyama Limba PROPOSAL
Jefferson L VocelkaArgentinaOnyama Limba RENEWAL
Octavia K RulapaughSpainIvan Magalhaes PROPOSAL
Smith E WaycottRussiaElwin Sharvill QUALIFIED
Cody M KuskoAustraliaAsiya Javayant PROPOSAL
Silvio P RulapaughRussiaIoni Bowcher NEW
Leja D PoquetteBrazilElwin Sharvill NEW
Juan E MarrierSpainOnyama Limba QUALIFIED
Julie G MorascaGermanyIvan Magalhaes NEGOTIATION
Ivar T StensethGermanyStephen Shaw RENEWAL
Smith W MaletRussiaXuxue Feng RENEWAL
Misaki H FigeroaGermanyAsiya Javayant UNQUALIFIED
Juan S GillianUnited KingdomBernardo Dominic QUALIFIED
Octavia V FigeroaGermanyAsiya Javayant UNQUALIFIED
Deepesh A MorascaBrazilIvan Magalhaes PROPOSAL
Kaitlin G MarrierCanadaAnna Fali NEW
Faith M WhobreyIndiaIvan Magalhaes NEGOTIATION
Wickens Q BowleyAustraliaStephen Shaw RENEWAL
Deepesh K VenereFranceStephen Shaw RENEWAL
David C RulapaughIndiaAsiya Javayant NEW
Francesco O NickaCanadaElwin Sharvill NEGOTIATION
Faith L StensethFranceXuxue Feng PROPOSAL
Deepesh C BowleyItalyIvan Magalhaes NEW
Leja J InouyeIndiaElwin Sharvill QUALIFIED
Mayumi B GauchoCanadaAmy Elsner PROPOSAL
Greenwood B FlosiJapanElwin Sharvill UNQUALIFIED
Silvio J PerinIndiaStephen Shaw QUALIFIED
Octavia K ShinkoGermanyElwin Sharvill RENEWAL
Darci P GillianFranceBernardo Dominic NEGOTIATION
Murillo N AlbaresCanadaAmy Elsner RENEWAL
Mayumi M SergiJapanXuxue Feng NEW
Horizontal
NameCountryRepresentativeStatus
Maisha T CaudyCanadaOnyama Limba UNQUALIFIED
Chavez R RoysterArgentinaElwin Sharvill NEGOTIATION
Tony D OstroskyAustraliaXuxue Feng RENEWAL
Aika U DilliardCanadaAsiya Javayant PROPOSAL
Chavez C MaletRussiaIoni Bowcher RENEWAL
Jeanfrancois L StockhamUnited KingdomAsiya Javayant UNQUALIFIED
Silvio R SaylorsRussiaAsiya Javayant NEW
Deepesh A OldroydRussiaAmy Elsner QUALIFIED
Octavia O BowleyFranceAnna Fali UNQUALIFIED
Jones N FlosiBrazilAmy Elsner UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Ashley X ShinkoGermany2025-05-22Rangoni Of Florence QUALIFIED19Elwin Sharvill
1001Ivar H BologniaGermany2025-06-05Buckley Miller Wright RENEWAL30Ioni Bowcher
1002Salvatore R PerinCanada2025-05-20Benton, John B Jr NEW69Ivan Magalhaes
1003Claire G DoeIndia2025-05-23Benton, John B Jr UNQUALIFIED54Onyama Limba
1004Nicolas U DoeBrazil2025-06-11Chanay, Jeffrey A Esq NEGOTIATION73Bernardo Dominic
1005Juan R MaletRussia2025-06-04Benton, John B Jr RENEWAL83Xuxue Feng
1006Tony O GauchoUnited Kingdom2025-05-28Printing Dimensions UNQUALIFIED62Asiya Javayant
1007Stacey S RutaGermany2025-06-11Printing Dimensions NEGOTIATION96Asiya Javayant
1008Maria S GauchoFrance2025-06-07Chemel, James L Cpa NEGOTIATION88Ivan Magalhaes
1009Salvatore S StockhamSpain2025-06-13Commercial Press NEW48Bernardo Dominic
1010James H MaletItaly2025-05-19Morlong Associates QUALIFIED93Amy Elsner
1011Ashley F BriddickAustralia2025-05-22Truhlar And Truhlar Attys UNQUALIFIED71Asiya Javayant
1012Deepesh Z DarakjyUnited Kingdom2025-06-02Feltz Printing Service NEW25Asiya Javayant
1013Ivar P FerenczFrance2025-05-29Feltz Printing Service QUALIFIED56Onyama Limba
1014Morrow N KuskoIndia2025-05-26Chapman, Ross E Esq QUALIFIED69Stephen Shaw
1015Ricardo K DilliardArgentina2025-05-25Benton, John B Jr NEW12Bernardo Dominic
1016David Z RoysterRussia2025-06-04Truhlar And Truhlar Attys QUALIFIED28Elwin Sharvill
1017Maria C SergiAustralia2025-05-24Printing Dimensions RENEWAL46Amy Elsner
1018Kadeem V SergiFrance2025-05-29King, Christopher A Esq NEGOTIATION81Asiya Javayant
1019Jefferson E FlosiRussia2025-05-26Buckley Miller Wright UNQUALIFIED95Ioni Bowcher
1020Jefferson L FlosiCanada2025-05-21Feiner Bros NEW38Elwin Sharvill
1021Alejandro D NickaCanada2025-06-14King, Christopher A Esq QUALIFIED45Asiya Javayant
1022Jefferson H MaletUnited Kingdom2025-06-08Chemel, James L Cpa NEGOTIATION83Xuxue Feng
1023Juan F GlickUnited Kingdom2025-06-15Benton, John B Jr QUALIFIED28Xuxue Feng
1024Leja G RimAustralia2025-05-26Printing Dimensions PROPOSAL55Bernardo Dominic
1025Julie E VocelkaArgentina2025-06-09Benton, John B Jr RENEWAL96Ioni Bowcher
1026Aika F SlusarskiJapan2025-06-08Feiner Bros RENEWAL97Anna Fali
1027Sinclair Y CaldareraAustralia2025-06-09Feiner Bros QUALIFIED43Anna Fali
1028Salvatore W WaycottRussia2025-05-24King, Christopher A Esq UNQUALIFIED47Ivan Magalhaes
1029Darci I FerenczCanada2025-05-22Benton, John B Jr RENEWAL96Xuxue Feng
1030Deepesh O DilliardRussia2025-05-31Commercial Press NEW60Ioni Bowcher
1031Isabel W BologniaItaly2025-05-30Dorl, James J Esq UNQUALIFIED13Anna Fali
1032Clifford P ButtUnited Kingdom2025-06-05Rangoni Of Florence NEGOTIATION70Elwin Sharvill
1033Isabel E FerenczItaly2025-06-07Buckley Miller Wright NEGOTIATION37Ivan Magalhaes
1034Ricardo J RimUnited Kingdom2025-05-21Truhlar And Truhlar Attys NEGOTIATION64Xuxue Feng
1035Maisha Z MorascaBrazil2025-05-26Benton, John B Jr UNQUALIFIED26Elwin Sharvill
1036Nicolas H WaycottJapan2025-05-21Truhlar And Truhlar Attys RENEWAL73Onyama Limba
1037Emily V AlbaresAustralia2025-05-30Feltz Printing Service RENEWAL1Anna Fali
1038Maisha G MacleadSpain2025-06-12Chemel, James L Cpa RENEWAL99Stephen Shaw
1039Leon M SchemmerJapan2025-06-13Rangoni Of Florence UNQUALIFIED96Ivan Magalhaes
1040Leon G BriddickFrance2025-06-10Rousseaux, Michael Esq RENEWAL50Bernardo Dominic
1041Ricardo H NestleItaly2025-05-28Truhlar And Truhlar Attys NEW3Elwin Sharvill
1042Morrow N InouyeCanada2025-06-15Feltz Printing Service NEW20Stephen Shaw
1043Misaki R GauchoBrazil2025-05-31Buckley Miller Wright NEGOTIATION51Asiya Javayant
1044Arvin A ChuiJapan2025-06-16Morlong Associates NEGOTIATION47Stephen Shaw
1045Sinclair D OldroydArgentina2025-06-07Rangoni Of Florence NEGOTIATION0Ivan Magalhaes
1046Kadeem S CaudyRussia2025-05-22Feiner Bros NEGOTIATION78Elwin Sharvill
1047Tony A SergiIndia2025-06-08Truhlar And Truhlar Attys QUALIFIED59Stephen Shaw
1048Smith X ChuiSpain2025-05-23Printing Dimensions QUALIFIED50Elwin Sharvill
1049Jennifer Z OldroydBrazil2025-06-04Feltz Printing Service UNQUALIFIED92Asiya Javayant
Frozen Rows
NameCountryRepresentativeStatus
Sinclair A IturbideBrazilAmy Elsner NEGOTIATION
Antonio B PerinGermanyStephen Shaw RENEWAL
Clifford Q StockhamBrazilElwin Sharvill NEW
Aika B VocelkaItalyElwin Sharvill NEW
Jeanfrancois K CampainItalyAnna Fali NEGOTIATION
Aika W GauchoUnited KingdomOnyama Limba UNQUALIFIED
Wickens F StockhamItalyBernardo Dominic NEGOTIATION
Jeanfrancois Q SaylorsBrazilIvan Magalhaes RENEWAL
Arvin Z MaletArgentinaStephen Shaw PROPOSAL
Jones V BowleyCanadaIvan Magalhaes NEW
Munro S FlosiFranceXuxue Feng NEW
Darci U CaudySpainIvan Magalhaes UNQUALIFIED
Aika V OldroydCanadaAmy Elsner RENEWAL
Murillo I CaldareraUnited KingdomIoni Bowcher UNQUALIFIED
Misaki B MorascaSpainIvan Magalhaes NEW
Maria T KuskoItalyAmy Elsner NEW
Aruna V WaycottJapanOnyama Limba QUALIFIED
Jefferson C ShinkoUnited KingdomAsiya Javayant NEW
Maria I FollerRussiaStephen Shaw UNQUALIFIED
Sinclair Z IturbideRussiaAmy Elsner NEW
Sinclair W CaldareraArgentinaBernardo Dominic NEGOTIATION
Faith Q AlbaresArgentinaIvan Magalhaes QUALIFIED
Clifford C FollerRussiaAsiya Javayant UNQUALIFIED
Mujtaba W AlbaresAustraliaIoni Bowcher NEW
Emily I SergiFranceElwin Sharvill NEW
Mayumi R VenereGermanyAsiya Javayant RENEWAL
Adams Y ButtIndiaIoni Bowcher UNQUALIFIED
Juan B ChuiRussiaIvan Magalhaes UNQUALIFIED
Leon N PerinFranceAnna Fali UNQUALIFIED
Smith S WaycottUnited KingdomOnyama Limba RENEWAL
Arvin P WhobreyRussiaStephen Shaw RENEWAL
Octavia F MaletArgentinaXuxue Feng QUALIFIED
Darci B BologniaBrazilIvan Magalhaes UNQUALIFIED
Claire W PerinCanadaOnyama Limba QUALIFIED
Jefferson J DilliardArgentinaAsiya Javayant RENEWAL
Murillo E BriddickSpainElwin Sharvill NEGOTIATION
Mujtaba N NestleRussiaIoni Bowcher NEGOTIATION
Clifford O BriddickSpainAmy Elsner RENEWAL
Maria F MaletFranceElwin Sharvill UNQUALIFIED
Octavia W WaycottSpainIoni Bowcher UNQUALIFIED
Silvio I InouyeAustraliaAmy Elsner NEGOTIATION
Smith I NickaBrazilAmy Elsner UNQUALIFIED
Stacey T RutaSpainAnna Fali RENEWAL
Sinclair O WaycottIndiaAnna Fali PROPOSAL
Aika T PaprockiSpainOnyama Limba UNQUALIFIED
Silvio S RutaUnited KingdomAnna Fali UNQUALIFIED
Leon H MaletRussiaAmy Elsner RENEWAL
Claire L GillianGermanyAmy Elsner NEGOTIATION
Smith B NestleBrazilIvan Magalhaes NEW
Mujtaba M TollnerGermanyOnyama Limba RENEWAL
Frozen Columns
Name
Clifford Y Gaucho
Rodrigues S Dilliard
Ivar P Nicka
Juan L Albares
Alejandro X Saylors
Juan C Royster
Arvin T Kusko
Jefferson T Foller
Smith F Venere
Costa T Vocelka
Aditya D Saylors
Francesco F Ostrosky
Aika S Nestle
Aditya I Bowley
Octavia Y Briddick
Morrow F Stockham
Johnson Y Inouye
Kaitlin F Campain
Jefferson F Foller
Faith T Ostrosky
Emily X Vocelka
Kadeem W Ostrosky
Wickens Y Royster
Kaitlin W Campain
Jefferson U Slusarski
Sinclair Z Ruta
Alejandro K Malet
Ivar Q Tollner
Julie N Shinko
Sinclair Q Whobrey
Jennifer F Bowley
Alejandro Q Poquette
Greenwood Q Rulapaugh
Morrow S Venere
Antonio I Oldroyd
Ivar K Paprocki
Kadeem F Inouye
Rodrigues A Marrier
Jones B Nestle
Munro V Briddick
Jeanfrancois P Waycott
David E Iturbide
Salvatore G Wieser
Emily U Dilliard
Aditya O Tollner
Tony M Inouye
Greenwood H Stockham
Francesco Y Oldroyd
Nicolas F Doe
Misaki U Stockham
IdCountryDate
1000Argentina2025-05-26
1001India2025-05-29
1002Argentina2025-05-31
1003Argentina2025-05-25
1004France2025-05-31
1005Germany2025-06-04
1006Spain2025-06-08
1007Germany2025-05-30
1008Brazil2025-05-20
1009Canada2025-05-31
1010Spain2025-05-20
1011Germany2025-05-24
1012India2025-06-13
1013Australia2025-05-22
1014United Kingdom2025-06-02
1015Germany2025-06-08
1016Russia2025-05-28
1017India2025-06-04
1018Japan2025-05-27
1019Argentina2025-05-28
1020Spain2025-06-13
1021Spain2025-05-29
1022United Kingdom2025-05-30
1023Argentina2025-05-18
1024Germany2025-05-26
1025India2025-05-18
1026Russia2025-06-07
1027Germany2025-05-19
1028Brazil2025-06-16
1029Russia2025-05-30
1030Germany2025-06-12
1031India2025-05-24
1032United Kingdom2025-06-16
1033Brazil2025-05-31
1034United Kingdom2025-05-30
1035India2025-06-13
1036India2025-05-20
1037Argentina2025-06-10
1038India2025-05-23
1039Canada2025-05-22
1040Germany2025-06-02
1041Brazil2025-06-05
1042Australia2025-05-27
1043Italy2025-05-21
1044Canada2025-05-21
1045Spain2025-06-14
1046Canada2025-06-04
1047Argentina2025-05-31
1048Germany2025-05-31
1049France2025-06-14

On-Demand Data

NameIdCountryDate
Cody H Iturbide1000India2025-06-02
Smith M Doe1001Canada2025-05-18
Ivar Q Bowley1002Germany2025-05-27
Rodrigues F Flosi1003United Kingdom2025-06-05
Clifford X Ferencz1004Japan2025-05-29
Costa X Butt1005Brazil2025-06-16
Ashley C Bowley1006Japan2025-05-21
Clifford B Rim1007Argentina2025-05-22
Rodrigues T Tollner1008Australia2025-06-05
Ashley V Kusko1009Spain2025-05-27
Francesco E Albares1010Brazil2025-06-12
Alejandro R Caldarera1011Japan2025-06-14
Izzy K Bowley1012Spain2025-06-10
Silvio M Tollner1013France2025-06-16
Salvatore N Maclead1014Italy2025-05-25
Johnson Z Gaucho1015Spain2025-06-01
Murillo V Kusko1016Brazil2025-05-19
Mayumi R Kusko1017France2025-05-21
Johnson Y Royster1018Australia2025-05-23
Jones U Inouye1019India2025-06-10
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Emily P DarakjySpainAmy Elsner PROPOSAL
Cody T VocelkaBrazilAnna Fali QUALIFIED
Jones X StockhamAustraliaXuxue Feng NEW
Mujtaba M IturbideIndiaAnna Fali PROPOSAL
Chavez W GarufiIndiaAnna Fali PROPOSAL
Chavez N VenereUnited KingdomAnna Fali PROPOSAL
Leja D StockhamFranceAsiya Javayant NEW
Wickens W MarrierIndiaAmy Elsner NEGOTIATION
Misaki B TollnerItalyAsiya Javayant UNQUALIFIED
James K MacleadIndiaAmy Elsner RENEWAL
Tony S MorascaIndiaAnna Fali PROPOSAL
Arvin U FollerRussiaStephen Shaw NEW
Kadeem J MaletIndiaStephen Shaw NEGOTIATION
Munro L ChuiAustraliaStephen Shaw RENEWAL
Ivar Z FigeroaFranceAsiya Javayant RENEWAL
Chavez R BriddickSpainIvan Magalhaes QUALIFIED
Darci D SaylorsRussiaStephen Shaw PROPOSAL
Aditya N FlosiItalyAsiya Javayant NEGOTIATION
Munro W OstroskyArgentinaOnyama Limba UNQUALIFIED
Alejandro S DilliardArgentinaAnna Fali PROPOSAL
Misaki Y GillianIndiaStephen Shaw NEW
Costa Q WieserItalyIvan Magalhaes NEW
Costa U TollnerArgentinaXuxue Feng UNQUALIFIED
Faith K VenereRussiaIoni Bowcher RENEWAL
Kaitlin W VocelkaSpainElwin Sharvill NEGOTIATION
Jennifer L MacleadSpainStephen Shaw NEGOTIATION
Chavez Q RimRussiaElwin Sharvill RENEWAL
Maisha D OstroskyJapanAmy Elsner QUALIFIED
Octavia U PoquetteItalyAmy Elsner NEW
Jones K FerenczFranceElwin Sharvill RENEWAL
Smith T SlusarskiArgentinaStephen Shaw PROPOSAL
Francesco Y WaycottBrazilBernardo Dominic QUALIFIED
Murillo D MaletFranceXuxue Feng PROPOSAL
Cody G KolmetzCanadaIvan Magalhaes RENEWAL
Isabel A NickaItalyAmy Elsner NEGOTIATION
Leon T RutaAustraliaOnyama Limba NEGOTIATION
Mujtaba W PoquetteJapanStephen Shaw NEGOTIATION
Maisha I KuskoSpainOnyama Limba NEW
Clifford C VocelkaBrazilIvan Magalhaes QUALIFIED
Aika X FlosiBrazilAmy Elsner RENEWAL

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