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
Francesco Z InouyeSpainBernardo Dominic UNQUALIFIED
Cody M CaldareraBrazilElwin Sharvill RENEWAL
Faith Z RoysterJapanStephen Shaw QUALIFIED
Greenwood G ButtFranceAmy Elsner QUALIFIED
Mayumi H AmigonItalyStephen Shaw QUALIFIED
Kaitlin D FerenczGermanyStephen Shaw QUALIFIED
Francesco M DoeArgentinaIoni Bowcher UNQUALIFIED
Adams F BriddickBrazilIoni Bowcher NEGOTIATION
Costa V ChuiCanadaStephen Shaw QUALIFIED
Munro W WaycottBrazilAsiya Javayant NEW
Aika L StensethItalyElwin Sharvill NEW
Smith L BriddickJapanOnyama Limba PROPOSAL
Kadeem O KuskoAustraliaIvan Magalhaes PROPOSAL
Octavia L BriddickJapanElwin Sharvill QUALIFIED
Kadeem I VenereIndiaAnna Fali RENEWAL
Octavia U StockhamSpainOnyama Limba NEGOTIATION
Morrow A StensethGermanyAnna Fali NEGOTIATION
Salvatore Q NickaIndiaAsiya Javayant NEGOTIATION
Leja E BowleyRussiaElwin Sharvill NEGOTIATION
Leja U ChuiGermanyOnyama Limba QUALIFIED
Faith I StensethRussiaXuxue Feng PROPOSAL
Emily M PaprockiJapanElwin Sharvill RENEWAL
Aruna P OldroydRussiaOnyama Limba NEGOTIATION
Leon V RulapaughGermanyElwin Sharvill RENEWAL
Claire B OstroskyAustraliaAnna Fali PROPOSAL
Juan P AlbaresCanadaStephen Shaw NEGOTIATION
Johnson O StensethBrazilStephen Shaw NEW
Mujtaba G FollerUnited KingdomXuxue Feng PROPOSAL
Jeanfrancois G FigeroaUnited KingdomIvan Magalhaes NEGOTIATION
David L VocelkaGermanyElwin Sharvill RENEWAL
Faith O TollnerItalyAnna Fali PROPOSAL
Adams X ButtUnited KingdomAsiya Javayant NEW
Aika J DilliardAustraliaStephen Shaw PROPOSAL
Emily N AlbaresArgentinaStephen Shaw QUALIFIED
Munro X FerenczUnited KingdomElwin Sharvill NEW
Mayumi Z GlickUnited KingdomAnna Fali PROPOSAL
Maisha H ShinkoArgentinaAmy Elsner PROPOSAL
Francesco B ShinkoIndiaAnna Fali UNQUALIFIED
Alejandro U StensethUnited KingdomIvan Magalhaes QUALIFIED
Mayumi N AlbaresIndiaOnyama Limba UNQUALIFIED
Silvio B MorascaJapanAnna Fali UNQUALIFIED
Kadeem M CaudyAustraliaXuxue Feng NEGOTIATION
Rodrigues V ChuiSpainStephen Shaw RENEWAL
Ashley M RoysterBrazilBernardo Dominic RENEWAL
Francesco A OldroydFranceAmy Elsner UNQUALIFIED
Isabel K SchemmerUnited KingdomIoni Bowcher UNQUALIFIED
Arvin I IturbideGermanyIvan Magalhaes RENEWAL
Claire Y DarakjyIndiaAmy Elsner UNQUALIFIED
Ricardo R GillianUnited KingdomIvan Magalhaes PROPOSAL
Ashley P GillianCanadaIvan Magalhaes NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Mayumi P FlosiIndiaElwin Sharvill RENEWAL
Wickens M WhobreyUnited KingdomStephen Shaw RENEWAL
Emily F GlickJapanAsiya Javayant NEW
Ivar E ChuiUnited KingdomAmy Elsner QUALIFIED
Silvio O InouyeItalyOnyama Limba PROPOSAL
Octavia P AmigonJapanBernardo Dominic PROPOSAL
Greenwood X WaycottItalyStephen Shaw PROPOSAL
Antonio E PoquetteRussiaStephen Shaw QUALIFIED
Jeanfrancois E ButtCanadaAmy Elsner UNQUALIFIED
Jeanfrancois M IturbideRussiaElwin Sharvill PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jennifer K BologniaRussia2024-05-18Chanay, Jeffrey A Esq RENEWAL9Ivan Magalhaes
1001Francesco Z BologniaJapan2024-06-02Buckley Miller Wright NEGOTIATION58Onyama Limba
1002Costa N VocelkaAustralia2024-06-04Commercial Press NEW9Elwin Sharvill
1003Ivar O KolmetzCanada2024-06-05Chemel, James L Cpa NEGOTIATION51Stephen Shaw
1004Mujtaba I PoquetteCanada2024-06-12King, Christopher A Esq NEW0Stephen Shaw
1005Kadeem X FerenczBrazil2024-05-24Feltz Printing Service RENEWAL82Anna Fali
1006Stacey E ButtCanada2024-05-16Chanay, Jeffrey A Esq UNQUALIFIED14Xuxue Feng
1007Arvin V ButtGermany2024-06-02Chapman, Ross E Esq RENEWAL55Amy Elsner
1008Darci A WieserAustralia2024-05-31Chapman, Ross E Esq RENEWAL64Ioni Bowcher
1009Faith P AmigonSpain2024-05-21Commercial Press NEW40Bernardo Dominic
1010Greenwood A SergiFrance2024-06-02Feiner Bros QUALIFIED59Bernardo Dominic
1011Faith N MaletSpain2024-05-15Chanay, Jeffrey A Esq PROPOSAL68Anna Fali
1012Mayumi D AlbaresIndia2024-06-09Chapman, Ross E Esq PROPOSAL72Asiya Javayant
1013Isabel M SaylorsCanada2024-05-23Feiner Bros RENEWAL36Amy Elsner
1014Kadeem Q TollnerItaly2024-05-28King, Christopher A Esq UNQUALIFIED80Ioni Bowcher
1015Jefferson H WieserFrance2024-05-27Feiner Bros UNQUALIFIED56Amy Elsner
1016Johnson O KuskoAustralia2024-05-19Morlong Associates PROPOSAL2Stephen Shaw
1017Alejandro E DoeAustralia2024-05-19Morlong Associates PROPOSAL47Ioni Bowcher
1018James D FigeroaFrance2024-06-13Chapman, Ross E Esq NEGOTIATION94Amy Elsner
1019Antonio Q DoeArgentina2024-05-26Printing Dimensions NEW35Elwin Sharvill
1020Smith F GlickFrance2024-05-29Truhlar And Truhlar Attys PROPOSAL80Xuxue Feng
1021Darci O StensethGermany2024-06-02Rousseaux, Michael Esq NEGOTIATION0Ioni Bowcher
1022Aruna J ShinkoItaly2024-05-29Rangoni Of Florence QUALIFIED49Asiya Javayant
1023Salvatore U FollerItaly2024-05-16Truhlar And Truhlar Attys UNQUALIFIED11Ioni Bowcher
1024David U FerenczCanada2024-06-01Buckley Miller Wright PROPOSAL85Bernardo Dominic
1025Silvio G WhobreyItaly2024-06-06Chanay, Jeffrey A Esq NEW98Ivan Magalhaes
1026Ivar T OldroydAustralia2024-06-12Feiner Bros QUALIFIED64Asiya Javayant
1027Greenwood J InouyeGermany2024-05-19Rousseaux, Michael Esq NEW34Ivan Magalhaes
1028Isabel Y DilliardArgentina2024-05-17Printing Dimensions NEW75Onyama Limba
1029Johnson B RutaGermany2024-06-08Chemel, James L Cpa NEW64Asiya Javayant
1030Smith T FlosiCanada2024-06-01Buckley Miller Wright UNQUALIFIED6Asiya Javayant
1031David Z ShinkoRussia2024-06-10Commercial Press UNQUALIFIED86Amy Elsner
1032James I KuskoJapan2024-06-07Chanay, Jeffrey A Esq NEGOTIATION36Stephen Shaw
1033Ricardo Q VenereSpain2024-06-08Dorl, James J Esq RENEWAL62Stephen Shaw
1034Tony U MaletRussia2024-05-17Chemel, James L Cpa NEGOTIATION38Onyama Limba
1035Jennifer C BologniaArgentina2024-06-06Rousseaux, Michael Esq UNQUALIFIED43Anna Fali
1036Rodrigues D CampainUnited Kingdom2024-05-26Truhlar And Truhlar Attys UNQUALIFIED99Onyama Limba
1037Murillo T KolmetzUnited Kingdom2024-06-03Truhlar And Truhlar Attys NEW4Asiya Javayant
1038Wickens O FigeroaJapan2024-05-31Morlong Associates UNQUALIFIED65Anna Fali
1039Aika G DarakjyJapan2024-05-21Chemel, James L Cpa QUALIFIED33Bernardo Dominic
1040Emily X DoeSpain2024-06-12Chanay, Jeffrey A Esq PROPOSAL87Onyama Limba
1041Jeanfrancois H KolmetzCanada2024-05-19Morlong Associates NEGOTIATION55Xuxue Feng
1042Chavez U CampainJapan2024-05-20Benton, John B Jr QUALIFIED49Stephen Shaw
1043Salvatore R VenereJapan2024-06-07Commercial Press UNQUALIFIED42Elwin Sharvill
1044Murillo E PerinFrance2024-05-21Feltz Printing Service NEGOTIATION56Bernardo Dominic
1045Smith G SlusarskiArgentina2024-05-24Truhlar And Truhlar Attys NEW12Asiya Javayant
1046Francesco L DilliardGermany2024-05-28Chemel, James L Cpa RENEWAL4Ivan Magalhaes
1047Silvio A OstroskySpain2024-05-20Benton, John B Jr UNQUALIFIED95Ioni Bowcher
1048Ivar F ShinkoArgentina2024-05-19Truhlar And Truhlar Attys NEW9Anna Fali
1049Kaitlin N OldroydFrance2024-06-06Feiner Bros NEW80Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Morrow J GauchoItalyBernardo Dominic NEW
Wickens R StensethSpainOnyama Limba NEW
Adams N GauchoRussiaAnna Fali NEW
Faith J RulapaughRussiaAmy Elsner RENEWAL
Deepesh T FerenczCanadaIoni Bowcher QUALIFIED
Deepesh B MorascaUnited KingdomStephen Shaw NEGOTIATION
Octavia R VocelkaGermanyStephen Shaw PROPOSAL
Julie G WhobreyIndiaAmy Elsner UNQUALIFIED
Greenwood T PaprockiIndiaElwin Sharvill PROPOSAL
Costa P WhobreyCanadaAsiya Javayant RENEWAL
Nicolas Q FerenczIndiaXuxue Feng NEW
Octavia I RutaRussiaIoni Bowcher UNQUALIFIED
Ashley O PaprockiUnited KingdomAmy Elsner QUALIFIED
Juan Z RutaFranceBernardo Dominic NEGOTIATION
Maisha L PaprockiJapanOnyama Limba RENEWAL
Greenwood R StockhamCanadaIvan Magalhaes NEW
Octavia D AlbaresItalyIoni Bowcher PROPOSAL
Smith T ButtItalyIvan Magalhaes UNQUALIFIED
Isabel C MarrierJapanXuxue Feng NEGOTIATION
Mujtaba E AlbaresSpainXuxue Feng PROPOSAL
Ricardo Y OldroydCanadaAnna Fali NEGOTIATION
Maria Z RulapaughUnited KingdomAnna Fali PROPOSAL
Greenwood M PerinRussiaOnyama Limba PROPOSAL
Jones P GarufiArgentinaIoni Bowcher RENEWAL
Leon J PaprockiBrazilStephen Shaw PROPOSAL
Aditya N WhobreyCanadaStephen Shaw UNQUALIFIED
Jennifer N PaprockiUnited KingdomElwin Sharvill QUALIFIED
Ashley S MarrierAustraliaElwin Sharvill NEW
Alejandro T AlbaresCanadaBernardo Dominic PROPOSAL
Sinclair Z FollerJapanIvan Magalhaes RENEWAL
Izzy P PaprockiJapanAnna Fali NEGOTIATION
Mayumi Z SaylorsGermanyIoni Bowcher UNQUALIFIED
Aruna H DarakjyAustraliaAnna Fali RENEWAL
Mayumi U RulapaughJapanElwin Sharvill NEW
Kadeem W MorascaJapanBernardo Dominic UNQUALIFIED
Deepesh K MacleadCanadaXuxue Feng UNQUALIFIED
Sinclair I AlbaresArgentinaIoni Bowcher NEGOTIATION
Arvin A NickaFranceStephen Shaw NEGOTIATION
Julie G BriddickItalyAnna Fali RENEWAL
Ashley L FigeroaItalyOnyama Limba QUALIFIED
Tony Y SergiBrazilIoni Bowcher QUALIFIED
Salvatore Q StensethFranceAmy Elsner QUALIFIED
Rodrigues T NickaItalyIvan Magalhaes NEGOTIATION
Juan L SergiCanadaAsiya Javayant RENEWAL
Julie I GillianGermanyIoni Bowcher PROPOSAL
Jeanfrancois C BowleyIndiaBernardo Dominic NEGOTIATION
Arvin Z GauchoBrazilElwin Sharvill PROPOSAL
Ricardo V RutaBrazilIvan Magalhaes NEGOTIATION
Jeanfrancois V RoysterGermanyIoni Bowcher NEW
Costa P RoysterItalyElwin Sharvill NEGOTIATION
Frozen Columns
Name
Silvio I Butt
Aika L Venere
Isabel S Tollner
Misaki Q Morasca
Izzy M Waycott
Emily T Rim
Ricardo C Nestle
Aika W Tollner
Izzy J Waycott
Aruna D Gaucho
Jefferson V Gaucho
Izzy O Garufi
Tony Y Marrier
Arvin L Malet
Morrow M Gaucho
Sinclair S Saylors
Clifford G Ferencz
Aruna U Malet
Deepesh U Butt
Misaki T Caudy
Rodrigues Y Ostrosky
Nicolas B Campain
Juan T Bolognia
Silvio Q Sergi
Deepesh S Ruta
Jennifer G Morasca
Morrow R Rim
Misaki Q Maclead
Faith F Stenseth
James P Foller
Kadeem L Maclead
Antonio E Gaucho
Smith W Oldroyd
Clifford C Vocelka
Silvio L Briddick
Juan U Royster
Jefferson Q Maclead
Alejandro B Kolmetz
Julie P Nestle
Maisha H Caldarera
Maria F Rulapaugh
Juan F Flosi
Claire F Slusarski
David U Butt
Aika E Flosi
Sinclair Q Iturbide
Octavia N Poquette
Alejandro O Bolognia
Isabel D Paprocki
Jeanfrancois I Malet
IdCountryDate
1000Germany2024-05-18
1001Brazil2024-05-29
1002Russia2024-06-03
1003Argentina2024-06-07
1004Brazil2024-05-27
1005France2024-06-03
1006Italy2024-06-11
1007Italy2024-06-03
1008Argentina2024-05-28
1009United Kingdom2024-06-10
1010Japan2024-05-30
1011Canada2024-05-21
1012Spain2024-05-18
1013Russia2024-06-12
1014Brazil2024-06-08
1015Italy2024-05-26
1016Canada2024-06-03
1017Australia2024-05-18
1018Russia2024-06-11
1019Russia2024-06-02
1020Australia2024-06-04
1021Italy2024-06-03
1022United Kingdom2024-05-19
1023Spain2024-05-28
1024Spain2024-05-23
1025Russia2024-05-26
1026Canada2024-05-23
1027Japan2024-05-24
1028Germany2024-06-02
1029India2024-06-08
1030India2024-06-10
1031Spain2024-06-08
1032Italy2024-06-13
1033Canada2024-05-21
1034Germany2024-05-18
1035Germany2024-05-19
1036Italy2024-05-17
1037Russia2024-05-17
1038Argentina2024-05-17
1039United Kingdom2024-05-17
1040Spain2024-05-23
1041Argentina2024-06-08
1042Australia2024-05-23
1043United Kingdom2024-05-29
1044United Kingdom2024-05-18
1045Russia2024-05-24
1046Brazil2024-05-28
1047Russia2024-05-28
1048Japan2024-06-01
1049France2024-05-15

On-Demand Data

NameIdCountryDate
Ivar F Morasca1000Argentina2024-06-06
Julie G Perin1001Italy2024-05-23
Munro P Caldarera1002India2024-05-18
Murillo Q Butt1003United Kingdom2024-06-10
Greenwood Y Ruta1004Japan2024-06-09
Octavia K Butt1005Italy2024-05-23
Deepesh Z Tollner1006Italy2024-05-19
Maisha H Amigon1007Australia2024-05-23
Rodrigues Z Waycott1008Brazil2024-05-24
David A Garufi1009France2024-05-15
Nicolas C Royster1010Japan2024-06-12
Morrow Q Kusko1011Russia2024-05-19
Ricardo A Stenseth1012United Kingdom2024-06-02
Wickens R Gaucho1013United Kingdom2024-05-26
Silvio B Gaucho1014Australia2024-05-31
Smith S Whobrey1015Japan2024-06-07
Juan A Malet1016Australia2024-06-04
Adams L Oldroyd1017Canada2024-05-30
Aika P Slusarski1018United Kingdom2024-06-13
Jefferson N Garufi1019Argentina2024-06-10
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aika J VocelkaArgentinaIvan Magalhaes QUALIFIED
Clifford S SaylorsUnited KingdomOnyama Limba QUALIFIED
Maisha P FollerAustraliaXuxue Feng NEW
Adams F GauchoRussiaAsiya Javayant PROPOSAL
Morrow V FigeroaBrazilOnyama Limba QUALIFIED
Juan Y CaudyUnited KingdomIoni Bowcher PROPOSAL
Adams B MacleadSpainAmy Elsner UNQUALIFIED
Jones Q CaldareraCanadaBernardo Dominic QUALIFIED
Maisha L IturbideGermanyIvan Magalhaes NEW
Chavez F PerinFranceElwin Sharvill RENEWAL
David K KolmetzBrazilAsiya Javayant RENEWAL
Mayumi P PaprockiItalyAnna Fali QUALIFIED
Jones A FlosiFranceAsiya Javayant UNQUALIFIED
Julie W GlickAustraliaAmy Elsner QUALIFIED
Kaitlin Q WhobreySpainXuxue Feng NEW
Isabel D DarakjyJapanIvan Magalhaes NEGOTIATION
Ricardo M AmigonArgentinaIvan Magalhaes UNQUALIFIED
Wickens O StensethArgentinaIoni Bowcher UNQUALIFIED
Emily F CampainIndiaIvan Magalhaes NEGOTIATION
Izzy D OldroydSpainAsiya Javayant NEW
Aika U ShinkoSpainOnyama Limba RENEWAL
Morrow E VenereArgentinaAsiya Javayant PROPOSAL
Murillo K ButtFranceElwin Sharvill UNQUALIFIED
Leja H MorascaArgentinaAnna Fali UNQUALIFIED
Mayumi Q FlosiBrazilAnna Fali QUALIFIED
Octavia E OldroydArgentinaAsiya Javayant UNQUALIFIED
Costa U MaletItalyOnyama Limba NEW
Faith U AlbaresItalyStephen Shaw QUALIFIED
Greenwood W PerinSpainOnyama Limba RENEWAL
Johnson F OldroydUnited KingdomIoni Bowcher QUALIFIED
Murillo S CampainGermanyAnna Fali NEGOTIATION
Isabel R WieserSpainBernardo Dominic UNQUALIFIED
Jones M MacleadSpainBernardo Dominic UNQUALIFIED
Jennifer Y TollnerCanadaAsiya Javayant QUALIFIED
Jones W MacleadRussiaIoni Bowcher NEGOTIATION
Salvatore F KolmetzUnited KingdomIoni Bowcher QUALIFIED
Ricardo D NickaAustraliaIoni Bowcher PROPOSAL
Leon U FerenczCanadaIvan Magalhaes PROPOSAL
Izzy Q MaletFranceIvan Magalhaes UNQUALIFIED
Aruna A MaletSpainStephen Shaw 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>