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
Jeanfrancois T OstroskyFranceAnna Fali NEGOTIATION
Juan G BowleyBrazilAsiya Javayant UNQUALIFIED
Salvatore I FerenczSpainIvan Magalhaes NEW
James H FerenczIndiaIoni Bowcher NEW
Juan A VocelkaRussiaAmy Elsner QUALIFIED
Jones W KolmetzSpainIoni Bowcher NEGOTIATION
Tony N BologniaGermanyXuxue Feng UNQUALIFIED
Francesco K GlickItalyElwin Sharvill NEW
Chavez D FigeroaUnited KingdomAsiya Javayant RENEWAL
Smith S StensethGermanyAsiya Javayant QUALIFIED
Morrow T FigeroaArgentinaOnyama Limba QUALIFIED
Jeanfrancois X InouyeJapanElwin Sharvill PROPOSAL
Kaitlin D GillianCanadaIoni Bowcher QUALIFIED
Leja G DilliardUnited KingdomAnna Fali NEGOTIATION
Mujtaba A VocelkaAustraliaIvan Magalhaes NEGOTIATION
Clifford A GarufiFranceAnna Fali NEGOTIATION
Jones H GlickSpainAsiya Javayant QUALIFIED
Antonio V MarrierItalyIvan Magalhaes NEGOTIATION
Ivar D VocelkaAustraliaIvan Magalhaes UNQUALIFIED
Jeanfrancois B StockhamJapanStephen Shaw UNQUALIFIED
Rodrigues A GillianUnited KingdomOnyama Limba PROPOSAL
Octavia E CaldareraItalyAnna Fali NEGOTIATION
Aruna C StockhamArgentinaIvan Magalhaes PROPOSAL
Munro W GauchoSpainOnyama Limba NEGOTIATION
Aditya L WhobreyJapanAsiya Javayant PROPOSAL
Mujtaba V WaycottIndiaXuxue Feng RENEWAL
Misaki G TollnerCanadaIoni Bowcher NEGOTIATION
Kaitlin U AlbaresUnited KingdomIoni Bowcher UNQUALIFIED
Misaki G RimRussiaXuxue Feng NEW
Misaki D StockhamBrazilXuxue Feng QUALIFIED
Costa Y FerenczItalyAsiya Javayant PROPOSAL
Alejandro K SaylorsItalyAsiya Javayant QUALIFIED
Sinclair N RimJapanXuxue Feng NEW
Tony C CaudyCanadaStephen Shaw QUALIFIED
Mujtaba E StockhamFranceOnyama Limba RENEWAL
Aruna H MaletRussiaAsiya Javayant PROPOSAL
Leon P BriddickFranceOnyama Limba QUALIFIED
Maisha R KuskoIndiaBernardo Dominic QUALIFIED
Costa G AlbaresGermanyBernardo Dominic PROPOSAL
Alejandro W SchemmerGermanyBernardo Dominic NEW
Costa T DoeUnited KingdomBernardo Dominic PROPOSAL
Aruna U GarufiAustraliaOnyama Limba PROPOSAL
Ivar P AmigonBrazilAsiya Javayant NEGOTIATION
Leja E WieserItalyIvan Magalhaes QUALIFIED
Jefferson A ChuiIndiaAsiya Javayant PROPOSAL
Chavez H IturbideAustraliaOnyama Limba RENEWAL
Deepesh A NestleRussiaElwin Sharvill UNQUALIFIED
James F InouyeFranceElwin Sharvill UNQUALIFIED
Francesco M FigeroaArgentinaOnyama Limba QUALIFIED
Nicolas N SaylorsIndiaAsiya Javayant QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Clifford K BowleyCanadaOnyama Limba PROPOSAL
Jeanfrancois F FollerArgentinaXuxue Feng QUALIFIED
Jefferson X BowleyAustraliaAmy Elsner UNQUALIFIED
Mayumi T SchemmerJapanIvan Magalhaes NEGOTIATION
Kaitlin C CaldareraSpainXuxue Feng UNQUALIFIED
Faith Y MaletBrazilOnyama Limba PROPOSAL
Aditya G OstroskyGermanyIvan Magalhaes NEGOTIATION
Leja T VenereBrazilStephen Shaw NEGOTIATION
Tony U WaycottUnited KingdomXuxue Feng PROPOSAL
Sinclair L StockhamBrazilElwin Sharvill NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Darci O VenereSpain2024-05-31Feltz Printing Service PROPOSAL47Ivan Magalhaes
1001Ashley C OldroydSpain2024-06-10Feiner Bros RENEWAL97Anna Fali
1002Rodrigues J FigeroaSpain2024-06-02Truhlar And Truhlar Attys NEW42Xuxue Feng
1003Deepesh S KolmetzUnited Kingdom2024-05-27Printing Dimensions NEW11Anna Fali
1004Johnson N FerenczCanada2024-05-24Chapman, Ross E Esq PROPOSAL3Ioni Bowcher
1005Rodrigues A GillianCanada2024-06-17Buckley Miller Wright RENEWAL98Xuxue Feng
1006Johnson R PoquetteAustralia2024-06-12Truhlar And Truhlar Attys PROPOSAL63Anna Fali
1007Cody B IturbideIndia2024-05-24King, Christopher A Esq UNQUALIFIED67Stephen Shaw
1008Darci P FerenczItaly2024-05-28Chapman, Ross E Esq PROPOSAL99Asiya Javayant
1009Ivar Z FerenczFrance2024-06-08Commercial Press NEGOTIATION80Asiya Javayant
1010Aditya O WieserArgentina2024-06-16Buckley Miller Wright UNQUALIFIED22Bernardo Dominic
1011Aditya C BriddickAustralia2024-06-02Morlong Associates PROPOSAL5Elwin Sharvill
1012Salvatore F MaletAustralia2024-06-11Chapman, Ross E Esq UNQUALIFIED47Ioni Bowcher
1013Octavia Y WhobreyArgentina2024-06-07Rangoni Of Florence NEW36Amy Elsner
1014Sinclair X KolmetzAustralia2024-06-05Truhlar And Truhlar Attys PROPOSAL84Onyama Limba
1015Rodrigues E ShinkoRussia2024-06-21Buckley Miller Wright UNQUALIFIED94Amy Elsner
1016Ashley H SchemmerItaly2024-06-14Chapman, Ross E Esq UNQUALIFIED62Ivan Magalhaes
1017Octavia O FollerItaly2024-06-16Rangoni Of Florence NEGOTIATION73Bernardo Dominic
1018Misaki Q NickaAustralia2024-06-02Rangoni Of Florence RENEWAL67Ivan Magalhaes
1019Darci Q MaletAustralia2024-06-11Buckley Miller Wright UNQUALIFIED3Asiya Javayant
1020Mayumi C FerenczCanada2024-06-21Chemel, James L Cpa RENEWAL23Bernardo Dominic
1021Johnson F MaletRussia2024-06-21Chapman, Ross E Esq NEGOTIATION10Xuxue Feng
1022Smith Y MaletGermany2024-06-18Chapman, Ross E Esq UNQUALIFIED84Stephen Shaw
1023Tony F VocelkaBrazil2024-06-03Chapman, Ross E Esq RENEWAL83Ivan Magalhaes
1024Maisha R FigeroaUnited Kingdom2024-06-09Chemel, James L Cpa NEGOTIATION65Amy Elsner
1025Ivar R WhobreyArgentina2024-06-10Morlong Associates PROPOSAL30Bernardo Dominic
1026Leja E KolmetzItaly2024-05-25Dorl, James J Esq RENEWAL79Stephen Shaw
1027Antonio Q GlickArgentina2024-06-22King, Christopher A Esq NEW44Elwin Sharvill
1028Maria X VenereRussia2024-06-20Dorl, James J Esq RENEWAL80Anna Fali
1029Johnson A MarrierSpain2024-06-10Chemel, James L Cpa RENEWAL6Asiya Javayant
1030Leon Q AlbaresJapan2024-06-04Printing Dimensions PROPOSAL29Bernardo Dominic
1031Salvatore I BriddickIndia2024-05-27Feiner Bros UNQUALIFIED56Ivan Magalhaes
1032Chavez T VenereFrance2024-06-06Dorl, James J Esq UNQUALIFIED12Elwin Sharvill
1033Silvio P RutaCanada2024-05-25Chapman, Ross E Esq PROPOSAL20Stephen Shaw
1034Darci R FigeroaIndia2024-06-13Printing Dimensions RENEWAL34Elwin Sharvill
1035Morrow I WaycottJapan2024-06-12Feltz Printing Service NEW18Asiya Javayant
1036Kadeem B AlbaresIndia2024-06-09Rangoni Of Florence NEGOTIATION38Bernardo Dominic
1037Antonio Y RulapaughJapan2024-06-15Truhlar And Truhlar Attys PROPOSAL69Anna Fali
1038Alejandro Q FlosiBrazil2024-06-20Rousseaux, Michael Esq NEW99Bernardo Dominic
1039Salvatore L GlickUnited Kingdom2024-05-24Feltz Printing Service NEGOTIATION41Anna Fali
1040Clifford P FollerRussia2024-05-24Buckley Miller Wright RENEWAL73Stephen Shaw
1041Aruna Q SlusarskiRussia2024-06-04Commercial Press NEW22Stephen Shaw
1042Juan D GillianAustralia2024-05-25Feiner Bros QUALIFIED58Xuxue Feng
1043Johnson E BologniaUnited Kingdom2024-06-05Benton, John B Jr NEGOTIATION78Asiya Javayant
1044Alejandro C MaletJapan2024-06-16Chemel, James L Cpa RENEWAL75Onyama Limba
1045Octavia V BriddickBrazil2024-05-30Printing Dimensions NEW15Bernardo Dominic
1046Julie U GillianSpain2024-06-21Rangoni Of Florence QUALIFIED26Bernardo Dominic
1047Kaitlin H WieserCanada2024-05-24Feltz Printing Service NEGOTIATION15Stephen Shaw
1048Jennifer K SlusarskiSpain2024-05-25King, Christopher A Esq NEW6Ioni Bowcher
1049Jeanfrancois B WieserArgentina2024-05-28Rousseaux, Michael Esq UNQUALIFIED29Elwin Sharvill
Frozen Rows
NameCountryRepresentativeStatus
Mujtaba N GillianBrazilAmy Elsner QUALIFIED
Ivar T KuskoRussiaAmy Elsner QUALIFIED
Maisha L FigeroaRussiaStephen Shaw NEW
Silvio Q VocelkaIndiaIvan Magalhaes QUALIFIED
Kadeem W SaylorsBrazilBernardo Dominic QUALIFIED
Morrow V SaylorsIndiaAmy Elsner PROPOSAL
Smith L CampainAustraliaIvan Magalhaes RENEWAL
Aika F PaprockiCanadaAsiya Javayant NEGOTIATION
Arvin D MorascaBrazilBernardo Dominic NEW
Greenwood H GlickBrazilIoni Bowcher NEGOTIATION
Murillo L MarrierItalyAnna Fali UNQUALIFIED
Jones Y StensethJapanAmy Elsner QUALIFIED
Emily F DoeSpainAmy Elsner PROPOSAL
Mujtaba P OldroydIndiaIoni Bowcher RENEWAL
Mujtaba X RoysterIndiaAnna Fali PROPOSAL
Ricardo M MorascaGermanyIvan Magalhaes NEW
Maria Y PerinSpainIvan Magalhaes QUALIFIED
Rodrigues E FerenczSpainStephen Shaw PROPOSAL
Morrow L WaycottAustraliaXuxue Feng NEGOTIATION
Chavez I FlosiSpainIoni Bowcher NEGOTIATION
Jefferson G SlusarskiItalyAnna Fali QUALIFIED
Faith Q FollerAustraliaIoni Bowcher NEW
Arvin G ButtRussiaStephen Shaw UNQUALIFIED
Jefferson D RimIndiaIoni Bowcher NEW
Smith O CampainBrazilOnyama Limba RENEWAL
Faith K StockhamCanadaOnyama Limba UNQUALIFIED
James H GauchoIndiaIvan Magalhaes UNQUALIFIED
Mayumi G FollerFranceIvan Magalhaes NEGOTIATION
Wickens J KuskoFranceAsiya Javayant UNQUALIFIED
Jefferson L OstroskyIndiaBernardo Dominic UNQUALIFIED
Francesco Y RulapaughCanadaAnna Fali UNQUALIFIED
Tony E GarufiArgentinaAsiya Javayant PROPOSAL
Jefferson C BowleyIndiaOnyama Limba RENEWAL
Silvio B FlosiItalyAsiya Javayant NEGOTIATION
Ashley R GlickIndiaXuxue Feng NEW
Leja P GillianAustraliaBernardo Dominic QUALIFIED
Jones V AlbaresBrazilXuxue Feng NEGOTIATION
Antonio K DarakjyJapanIvan Magalhaes UNQUALIFIED
Francesco B OstroskyRussiaAsiya Javayant QUALIFIED
Greenwood C NickaFranceBernardo Dominic NEGOTIATION
Darci D DilliardGermanyOnyama Limba QUALIFIED
Silvio G VocelkaAustraliaAsiya Javayant UNQUALIFIED
Mujtaba Y RimFranceAsiya Javayant NEW
Mayumi D RulapaughSpainAmy Elsner RENEWAL
Antonio W TollnerAustraliaAmy Elsner PROPOSAL
Maisha J RoysterUnited KingdomAsiya Javayant NEW
Salvatore F SaylorsJapanAmy Elsner QUALIFIED
Ivar H DilliardAustraliaAnna Fali NEGOTIATION
Costa R PoquetteIndiaIoni Bowcher QUALIFIED
Maria Q KuskoGermanyIoni Bowcher NEGOTIATION
Frozen Columns
Name
Kaitlin U Malet
Chavez V Venere
Cody U Dilliard
Stacey E Whobrey
Mujtaba Z Whobrey
Izzy O Slusarski
Silvio N Nicka
Ivar S Ferencz
Leon A Paprocki
Kaitlin X Dilliard
Adams X Foller
Kaitlin K Slusarski
Aruna N Schemmer
Izzy K Campain
Aika J Gillian
Greenwood P Oldroyd
Ricardo K Amigon
Aika R Gillian
Silvio D Saylors
Maria S Doe
Wickens M Doe
Ashley S Caudy
Kadeem A Chui
Stacey U Nicka
Alejandro D Garufi
Ricardo F Darakjy
Jennifer Y Oldroyd
Costa A Ostrosky
Maisha F Waycott
Greenwood A Stenseth
Clifford I Campain
Smith D Garufi
Cody K Schemmer
Maisha W Oldroyd
Faith V Stenseth
Morrow Y Paprocki
Leon D Shinko
Darci D Garufi
Adams M Kusko
Maisha P Schemmer
Smith V Venere
James I Waycott
Mujtaba M Flosi
Jones I Kusko
Mayumi L Glick
Wickens I Royster
David Q Paprocki
James Q Garufi
Wickens E Sergi
Aika A Glick
IdCountryDate
1000United Kingdom2024-06-11
1001Brazil2024-06-02
1002Spain2024-06-09
1003India2024-06-21
1004Canada2024-06-04
1005Japan2024-06-02
1006Spain2024-05-27
1007Australia2024-06-03
1008Italy2024-06-13
1009Brazil2024-06-10
1010Germany2024-05-27
1011Russia2024-06-18
1012Argentina2024-05-24
1013France2024-06-01
1014India2024-06-13
1015United Kingdom2024-05-27
1016Russia2024-05-27
1017Japan2024-06-04
1018Japan2024-06-14
1019Brazil2024-06-13
1020Russia2024-06-19
1021Spain2024-06-09
1022Canada2024-06-12
1023Brazil2024-06-09
1024Brazil2024-06-04
1025Brazil2024-06-03
1026France2024-06-17
1027United Kingdom2024-05-29
1028Japan2024-06-21
1029Canada2024-06-06
1030Germany2024-06-04
1031United Kingdom2024-06-11
1032France2024-06-06
1033Russia2024-06-06
1034Italy2024-06-16
1035Germany2024-06-21
1036Russia2024-06-01
1037United Kingdom2024-06-02
1038Argentina2024-06-02
1039Italy2024-06-05
1040Australia2024-05-31
1041Germany2024-06-02
1042France2024-05-25
1043Germany2024-06-20
1044Australia2024-06-08
1045Spain2024-06-01
1046Germany2024-06-04
1047United Kingdom2024-06-09
1048Spain2024-05-30
1049France2024-05-26

On-Demand Data

NameIdCountryDate
Nicolas N Whobrey1000Germany2024-05-30
Antonio K Gaucho1001Canada2024-06-18
Isabel Y Royster1002India2024-05-30
Tony L Amigon1003France2024-06-04
Jeanfrancois Z Gillian1004Brazil2024-06-11
Misaki E Poquette1005Canada2024-05-25
Alejandro A Perin1006Brazil2024-05-28
Izzy H Nestle1007India2024-06-09
Jones N Royster1008Brazil2024-06-02
Tony B Inouye1009India2024-05-27
Ricardo D Flosi1010Argentina2024-05-25
Jefferson E Oldroyd1011Argentina2024-05-28
Mujtaba X Maclead1012Japan2024-05-30
Mayumi O Nicka1013Argentina2024-05-26
Salvatore F Slusarski1014Germany2024-05-30
Mujtaba F Poquette1015Germany2024-05-30
Nicolas A Slusarski1016Russia2024-06-05
Jennifer M Perin1017Argentina2024-06-02
Misaki H Glick1018Argentina2024-06-07
Jefferson W Stenseth1019Russia2024-06-03
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Arvin C GillianFranceBernardo Dominic NEW
Kaitlin E MaletJapanXuxue Feng UNQUALIFIED
Octavia M OstroskyItalyIvan Magalhaes PROPOSAL
Julie W StockhamFranceAnna Fali NEGOTIATION
Kadeem W SaylorsJapanElwin Sharvill NEW
Arvin A OstroskyArgentinaStephen Shaw RENEWAL
Morrow G PerinAustraliaElwin Sharvill QUALIFIED
Kaitlin K WaycottSpainAnna Fali NEW
Ricardo J RimIndiaAnna Fali NEGOTIATION
Clifford P WieserItalyElwin Sharvill NEGOTIATION
Ricardo Z VenereRussiaStephen Shaw NEGOTIATION
Murillo S SergiItalyElwin Sharvill NEGOTIATION
Juan D NestleRussiaIoni Bowcher RENEWAL
Mujtaba Q NestleUnited KingdomOnyama Limba PROPOSAL
Juan W AmigonSpainOnyama Limba UNQUALIFIED
Cody Q SlusarskiRussiaIvan Magalhaes UNQUALIFIED
Leon E IturbideBrazilAmy Elsner NEGOTIATION
Claire A RoysterGermanyAmy Elsner QUALIFIED
James E WieserRussiaBernardo Dominic RENEWAL
Francesco Y InouyeFranceStephen Shaw NEGOTIATION
Chavez Q VenereItalyBernardo Dominic UNQUALIFIED
Adams C InouyeCanadaAnna Fali UNQUALIFIED
Leja C DarakjyItalyAnna Fali UNQUALIFIED
Faith W CaldareraJapanIoni Bowcher PROPOSAL
Deepesh K WhobreyRussiaIoni Bowcher PROPOSAL
Juan Q ShinkoFranceElwin Sharvill QUALIFIED
Maisha B CaudyCanadaBernardo Dominic QUALIFIED
Arvin V RulapaughGermanyBernardo Dominic NEW
Greenwood Y ChuiFranceAnna Fali QUALIFIED
Misaki V SchemmerItalyAsiya Javayant UNQUALIFIED
Maisha C VocelkaFranceAsiya Javayant NEGOTIATION
Isabel V PerinItalyElwin Sharvill NEGOTIATION
Aika G AlbaresUnited KingdomAsiya Javayant PROPOSAL
Julie D BologniaGermanyBernardo Dominic NEW
Izzy X StensethCanadaIoni Bowcher QUALIFIED
Maisha O FollerRussiaOnyama Limba PROPOSAL
Claire B DarakjyJapanAmy Elsner NEW
Wickens J MaletCanadaAsiya Javayant QUALIFIED
Isabel N BologniaAustraliaAmy Elsner PROPOSAL
Kadeem C RutaItalyOnyama Limba PROPOSAL

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