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
Chavez P MacleadBrazilBernardo Dominic RENEWAL
Mayumi R GauchoCanadaIoni Bowcher UNQUALIFIED
Smith J WhobreyArgentinaElwin Sharvill UNQUALIFIED
Kaitlin O KuskoRussiaBernardo Dominic UNQUALIFIED
Deepesh S FlosiSpainStephen Shaw RENEWAL
Emily Z MaletJapanIoni Bowcher NEGOTIATION
Tony R PaprockiFranceOnyama Limba NEGOTIATION
Ricardo D OstroskyRussiaElwin Sharvill UNQUALIFIED
Maria I AmigonGermanyAmy Elsner NEW
David F StensethArgentinaAmy Elsner NEGOTIATION
Ricardo F PaprockiRussiaOnyama Limba RENEWAL
Munro F CaldareraGermanyAsiya Javayant QUALIFIED
Juan F CaldareraCanadaIvan Magalhaes NEGOTIATION
Juan L BologniaRussiaBernardo Dominic PROPOSAL
Izzy Q BowleyJapanOnyama Limba UNQUALIFIED
Leon L RimBrazilStephen Shaw NEGOTIATION
Octavia Q InouyeBrazilAmy Elsner QUALIFIED
Greenwood X AlbaresIndiaIoni Bowcher NEW
Octavia A NestleGermanyStephen Shaw NEGOTIATION
Darci P RutaAustraliaStephen Shaw UNQUALIFIED
Ricardo A OldroydCanadaAsiya Javayant QUALIFIED
Silvio R RoysterCanadaBernardo Dominic QUALIFIED
James Y WieserArgentinaIvan Magalhaes PROPOSAL
Stacey V PoquetteItalyBernardo Dominic PROPOSAL
Mujtaba A GarufiFranceBernardo Dominic NEGOTIATION
Johnson I FollerGermanyAmy Elsner UNQUALIFIED
Greenwood B RulapaughBrazilBernardo Dominic PROPOSAL
Ricardo R OstroskyCanadaStephen Shaw QUALIFIED
Chavez S ChuiItalyAsiya Javayant UNQUALIFIED
Izzy F OstroskyAustraliaAsiya Javayant QUALIFIED
Ashley S CampainBrazilBernardo Dominic NEW
Izzy L InouyeJapanXuxue Feng RENEWAL
Emily P DarakjySpainElwin Sharvill QUALIFIED
Stacey X MarrierArgentinaAsiya Javayant NEW
Claire K SergiArgentinaAmy Elsner UNQUALIFIED
Salvatore Q BowleyItalyStephen Shaw PROPOSAL
James Q FerenczAustraliaAsiya Javayant NEGOTIATION
Jones J MaletGermanyOnyama Limba PROPOSAL
Maisha E CampainArgentinaAsiya Javayant QUALIFIED
Wickens J WhobreyRussiaAmy Elsner NEW
Morrow Q KolmetzAustraliaIvan Magalhaes QUALIFIED
Mujtaba N MaletArgentinaElwin Sharvill RENEWAL
Rodrigues W StensethCanadaIoni Bowcher NEW
Maria A GillianArgentinaStephen Shaw NEW
Arvin P ChuiBrazilOnyama Limba QUALIFIED
Maria W FlosiItalyAsiya Javayant NEGOTIATION
Salvatore Q ChuiUnited KingdomAmy Elsner NEGOTIATION
Nicolas N BowleyItalyStephen Shaw QUALIFIED
Salvatore Z ChuiCanadaIoni Bowcher NEW
Mayumi F PerinRussiaAsiya Javayant NEW
Horizontal
NameCountryRepresentativeStatus
Isabel W SchemmerGermanyStephen Shaw NEGOTIATION
Murillo I MorascaJapanXuxue Feng QUALIFIED
Greenwood P MacleadRussiaAmy Elsner NEGOTIATION
Morrow B WhobreyJapanIvan Magalhaes UNQUALIFIED
Ricardo R InouyeSpainOnyama Limba NEW
Arvin H SaylorsAustraliaIoni Bowcher PROPOSAL
Munro A TollnerAustraliaOnyama Limba NEGOTIATION
Adams S PerinFranceStephen Shaw NEW
Aika A BowleyCanadaElwin Sharvill QUALIFIED
Munro F FerenczRussiaAsiya Javayant QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Silvio E FerenczSpain2024-05-09Morlong Associates UNQUALIFIED8Ioni Bowcher
1001Morrow M FigeroaUnited Kingdom2024-05-25Morlong Associates QUALIFIED10Xuxue Feng
1002Rodrigues D AlbaresFrance2024-05-06Benton, John B Jr RENEWAL97Xuxue Feng
1003Mayumi Z IturbideUnited Kingdom2024-05-31Commercial Press UNQUALIFIED67Xuxue Feng
1004Mujtaba Y KolmetzCanada2024-05-25Truhlar And Truhlar Attys PROPOSAL46Anna Fali
1005Stacey M CaldareraFrance2024-05-12Printing Dimensions NEGOTIATION68Elwin Sharvill
1006Jones U NestleFrance2024-05-27Rangoni Of Florence RENEWAL47Ioni Bowcher
1007Costa U SaylorsIndia2024-05-05Dorl, James J Esq NEGOTIATION66Elwin Sharvill
1008Tony P OstroskyFrance2024-05-05Chapman, Ross E Esq NEGOTIATION56Stephen Shaw
1009Rodrigues C NickaFrance2024-05-07Feiner Bros PROPOSAL10Asiya Javayant
1010Faith Q FollerIndia2024-05-21Rangoni Of Florence NEGOTIATION57Anna Fali
1011Smith P ShinkoSpain2024-05-27Chemel, James L Cpa QUALIFIED77Ivan Magalhaes
1012Jeanfrancois E AmigonItaly2024-05-29Morlong Associates NEW54Onyama Limba
1013Rodrigues K FollerCanada2024-05-29Benton, John B Jr NEW47Ioni Bowcher
1014Leja N GauchoAustralia2024-05-20Chemel, James L Cpa QUALIFIED22Onyama Limba
1015Leon K InouyeUnited Kingdom2024-05-24Rousseaux, Michael Esq QUALIFIED42Onyama Limba
1016Kadeem C InouyeUnited Kingdom2024-05-31Morlong Associates NEW87Ivan Magalhaes
1017Tony O StensethJapan2024-05-12Benton, John B Jr UNQUALIFIED75Asiya Javayant
1018Misaki E ShinkoFrance2024-05-17Chemel, James L Cpa NEGOTIATION32Elwin Sharvill
1019Ivar L IturbideGermany2024-05-10Dorl, James J Esq UNQUALIFIED85Anna Fali
1020Izzy V BowleyGermany2024-05-10King, Christopher A Esq QUALIFIED30Onyama Limba
1021Alejandro S DarakjyUnited Kingdom2024-05-16Feltz Printing Service PROPOSAL81Onyama Limba
1022Jennifer M BriddickFrance2024-05-21Rousseaux, Michael Esq UNQUALIFIED58Ivan Magalhaes
1023Isabel H RimItaly2024-05-28Rangoni Of Florence NEW42Ioni Bowcher
1024Deepesh F BowleyItaly2024-06-01Chanay, Jeffrey A Esq PROPOSAL4Xuxue Feng
1025Munro N MacleadGermany2024-05-26Feltz Printing Service UNQUALIFIED76Anna Fali
1026Isabel X NickaJapan2024-05-05Feiner Bros UNQUALIFIED83Bernardo Dominic
1027Emily K MacleadArgentina2024-05-17Rousseaux, Michael Esq UNQUALIFIED8Amy Elsner
1028Maria I MaletSpain2024-05-14Morlong Associates QUALIFIED64Amy Elsner
1029Jefferson M OstroskyArgentina2024-05-07Benton, John B Jr QUALIFIED89Ioni Bowcher
1030Aditya Z DoeIndia2024-05-30Buckley Miller Wright UNQUALIFIED83Ioni Bowcher
1031Mayumi M CampainArgentina2024-05-19Feltz Printing Service PROPOSAL89Ivan Magalhaes
1032Francesco E GlickCanada2024-05-11Rangoni Of Florence RENEWAL9Elwin Sharvill
1033Francesco V WhobreyFrance2024-05-29Morlong Associates QUALIFIED42Anna Fali
1034Deepesh B RulapaughUnited Kingdom2024-05-22Rangoni Of Florence QUALIFIED78Anna Fali
1035James E CaldareraArgentina2024-05-17Buckley Miller Wright UNQUALIFIED34Asiya Javayant
1036Faith P MaletSpain2024-05-13Buckley Miller Wright PROPOSAL27Asiya Javayant
1037James O IturbideUnited Kingdom2024-05-29King, Christopher A Esq NEW76Stephen Shaw
1038Stacey K BowleyItaly2024-05-19Truhlar And Truhlar Attys NEGOTIATION66Asiya Javayant
1039Aditya Z MaletAustralia2024-05-04Rousseaux, Michael Esq NEGOTIATION95Xuxue Feng
1040Salvatore R PaprockiSpain2024-05-11Printing Dimensions NEW65Ioni Bowcher
1041Mayumi S GillianSpain2024-05-08Chapman, Ross E Esq NEW11Anna Fali
1042Misaki S ChuiCanada2024-05-22Truhlar And Truhlar Attys NEGOTIATION35Bernardo Dominic
1043Aruna V InouyeJapan2024-05-05Printing Dimensions NEGOTIATION14Ioni Bowcher
1044Murillo M BowleyIndia2024-05-26Dorl, James J Esq RENEWAL12Stephen Shaw
1045Greenwood C VocelkaGermany2024-05-22Rousseaux, Michael Esq RENEWAL95Ioni Bowcher
1046Emily W RutaRussia2024-05-22Rangoni Of Florence UNQUALIFIED57Ivan Magalhaes
1047David A ShinkoIndia2024-05-19Benton, John B Jr PROPOSAL37Anna Fali
1048Silvio H FigeroaGermany2024-05-27Rousseaux, Michael Esq UNQUALIFIED44Bernardo Dominic
1049Mujtaba Z GlickSpain2024-05-28Chanay, Jeffrey A Esq PROPOSAL54Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Silvio Z KolmetzUnited KingdomXuxue Feng NEW
Ashley M CaldareraArgentinaAnna Fali NEGOTIATION
Ashley Z SaylorsGermanyXuxue Feng RENEWAL
Aditya C AlbaresBrazilAnna Fali RENEWAL
Murillo A GarufiArgentinaElwin Sharvill UNQUALIFIED
Tony I SlusarskiSpainIoni Bowcher NEGOTIATION
Ricardo Q RutaSpainIoni Bowcher RENEWAL
Cody X AmigonItalyElwin Sharvill RENEWAL
Rodrigues V OldroydFranceIvan Magalhaes NEGOTIATION
Mayumi H PaprockiBrazilIvan Magalhaes RENEWAL
Mujtaba R KolmetzCanadaStephen Shaw RENEWAL
Clifford V PerinUnited KingdomStephen Shaw UNQUALIFIED
Misaki B StockhamIndiaOnyama Limba PROPOSAL
David E OldroydRussiaXuxue Feng NEGOTIATION
Alejandro P RulapaughJapanIoni Bowcher RENEWAL
Silvio K MorascaItalyElwin Sharvill QUALIFIED
Arvin K RulapaughArgentinaAmy Elsner NEW
Tony J NickaUnited KingdomAmy Elsner UNQUALIFIED
Morrow D RimSpainElwin Sharvill PROPOSAL
Tony Q RutaBrazilXuxue Feng RENEWAL
Ricardo J SergiBrazilXuxue Feng UNQUALIFIED
Nicolas C TollnerIndiaOnyama Limba NEGOTIATION
Jennifer F IturbideAustraliaIoni Bowcher QUALIFIED
Darci R DoeItalyElwin Sharvill UNQUALIFIED
Kadeem O ChuiJapanBernardo Dominic PROPOSAL
Smith R KuskoSpainAnna Fali NEGOTIATION
Aika V BologniaGermanyElwin Sharvill NEGOTIATION
Adams F OstroskyBrazilAnna Fali RENEWAL
Aruna J StockhamItalyXuxue Feng RENEWAL
Antonio T BowleyIndiaAnna Fali PROPOSAL
Octavia S DoeItalyIoni Bowcher NEW
Tony D DoeItalyAsiya Javayant UNQUALIFIED
Izzy E ShinkoSpainAsiya Javayant QUALIFIED
Stacey S MarrierGermanyBernardo Dominic PROPOSAL
James W TollnerJapanIoni Bowcher NEW
Smith J IturbideItalyElwin Sharvill NEGOTIATION
Misaki L KolmetzItalyXuxue Feng NEGOTIATION
Chavez P VocelkaRussiaAsiya Javayant NEW
Jeanfrancois W FlosiBrazilElwin Sharvill NEGOTIATION
Jennifer T MorascaSpainIvan Magalhaes PROPOSAL
Silvio G VocelkaArgentinaElwin Sharvill NEGOTIATION
Rodrigues U WaycottBrazilAsiya Javayant PROPOSAL
Sinclair M BologniaFranceElwin Sharvill NEGOTIATION
Aruna C KuskoRussiaStephen Shaw QUALIFIED
Stacey K IturbideBrazilIoni Bowcher RENEWAL
Morrow U ShinkoArgentinaXuxue Feng NEGOTIATION
Ivar X AlbaresAustraliaStephen Shaw PROPOSAL
Nicolas F VenereIndiaAmy Elsner NEW
Kadeem B ShinkoAustraliaStephen Shaw NEW
Jones W KuskoSpainBernardo Dominic NEGOTIATION
Frozen Columns
Name
Maria V Waycott
Antonio I Slusarski
Ashley V Shinko
David C Tollner
Kadeem B Foller
Greenwood J Kusko
Antonio O Paprocki
Murillo X Slusarski
Alejandro G Malet
Maria R Stenseth
Alejandro B Ferencz
Adams B Butt
Silvio M Gaucho
Morrow H Rulapaugh
Salvatore B Schemmer
Darci C Perin
Jefferson W Marrier
Cody K Rim
Chavez R Rim
Mayumi G Maclead
Aruna K Oldroyd
Isabel N Inouye
Smith E Venere
Jeanfrancois A Paprocki
Cody K Gillian
Murillo E Caudy
Smith Q Doe
Morrow Y Ruta
Leon Q Campain
Octavia C Ostrosky
Leon Y Glick
Greenwood Q Perin
Leja G Rim
Misaki C Stenseth
Costa J Caudy
Ricardo M Saylors
Izzy M Venere
Ricardo K Butt
Jennifer H Saylors
Silvio W Ruta
Cody Y Briddick
Jeanfrancois K Ruta
Maria S Amigon
Francesco E Malet
Salvatore N Kusko
Salvatore L Shinko
Rodrigues G Caldarera
Maria Q Iturbide
Greenwood L Rulapaugh
Wickens T Royster
IdCountryDate
1000Russia2024-05-07
1001Russia2024-05-06
1002Russia2024-05-08
1003Italy2024-05-30
1004France2024-05-30
1005Japan2024-05-10
1006India2024-05-14
1007Australia2024-05-19
1008Brazil2024-05-30
1009Canada2024-05-18
1010Russia2024-05-18
1011Spain2024-05-05
1012Australia2024-05-08
1013Australia2024-05-21
1014Australia2024-05-10
1015Australia2024-05-31
1016India2024-05-09
1017United Kingdom2024-05-19
1018Japan2024-05-06
1019Japan2024-05-12
1020Germany2024-05-06
1021Brazil2024-05-14
1022Spain2024-05-07
1023Brazil2024-05-29
1024Spain2024-05-07
1025Germany2024-05-30
1026Italy2024-05-17
1027Germany2024-05-17
1028Japan2024-05-15
1029Spain2024-05-03
1030Japan2024-05-20
1031Brazil2024-05-17
1032United Kingdom2024-05-09
1033Italy2024-05-07
1034Italy2024-05-23
1035Japan2024-05-06
1036France2024-05-03
1037France2024-05-09
1038Argentina2024-05-06
1039United Kingdom2024-05-30
1040Russia2024-05-29
1041Germany2024-05-29
1042Argentina2024-05-20
1043Italy2024-06-01
1044France2024-05-23
1045Japan2024-05-27
1046Russia2024-05-16
1047Argentina2024-05-10
1048France2024-05-10
1049Russia2024-05-06

On-Demand Data

NameIdCountryDate
Costa M Rulapaugh1000Canada2024-05-15
Ashley N Stockham1001Italy2024-05-16
Misaki F Ruta1002Australia2024-05-04
Leon K Marrier1003Brazil2024-05-13
James T Kusko1004Spain2024-05-29
Claire K Slusarski1005France2024-05-14
Misaki E Bolognia1006India2024-05-19
Jeanfrancois V Kolmetz1007Argentina2024-05-19
Ashley R Malet1008France2024-05-18
Salvatore B Nestle1009India2024-05-10
Sinclair M Gillian1010Canada2024-05-18
Juan M Ruta1011Canada2024-05-16
Ivar Q Garufi1012Japan2024-05-14
Jefferson S Marrier1013Argentina2024-05-28
Stacey N Amigon1014France2024-05-16
Kaitlin N Maclead1015Argentina2024-06-01
Kadeem B Dilliard1016Japan2024-05-12
Antonio L Butt1017Russia2024-06-01
Ashley V Malet1018Japan2024-05-17
Munro Y Figeroa1019Argentina2024-05-05
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Antonio C RulapaughRussiaBernardo Dominic RENEWAL
Mayumi C FigeroaJapanOnyama Limba QUALIFIED
Alejandro E SlusarskiItalyAmy Elsner NEGOTIATION
Silvio H CaudyFranceIvan Magalhaes UNQUALIFIED
Sinclair Z VenereIndiaBernardo Dominic PROPOSAL
Aditya Z PerinJapanStephen Shaw QUALIFIED
Chavez V MaletUnited KingdomIvan Magalhaes NEGOTIATION
Emily X SergiArgentinaOnyama Limba NEGOTIATION
Jefferson R SaylorsItalyAsiya Javayant PROPOSAL
Maisha D RoysterRussiaOnyama Limba NEW
Clifford L ButtArgentinaXuxue Feng PROPOSAL
Tony N KolmetzBrazilIoni Bowcher RENEWAL
Aruna O BowleyJapanIoni Bowcher NEGOTIATION
Tony J MaletBrazilOnyama Limba PROPOSAL
Wickens W FigeroaGermanyIvan Magalhaes UNQUALIFIED
Clifford V OstroskyGermanyAsiya Javayant UNQUALIFIED
Francesco D BologniaFranceIoni Bowcher QUALIFIED
Adams W SaylorsGermanyOnyama Limba QUALIFIED
Isabel L SaylorsJapanBernardo Dominic QUALIFIED
Misaki Z WhobreyCanadaAnna Fali RENEWAL
Jeanfrancois L NestleArgentinaIvan Magalhaes NEGOTIATION
Jones X FigeroaFranceAmy Elsner NEW
Stacey Z WhobreyJapanStephen Shaw NEW
Claire Z FollerGermanyIvan Magalhaes PROPOSAL
Cody I DoeUnited KingdomElwin Sharvill NEGOTIATION
Wickens Z ButtFranceIoni Bowcher PROPOSAL
Mujtaba Z SaylorsAustraliaAnna Fali QUALIFIED
Juan E ChuiArgentinaAsiya Javayant PROPOSAL
Ricardo Z RutaGermanyIvan Magalhaes UNQUALIFIED
Kadeem V StensethAustraliaAsiya Javayant NEGOTIATION
Chavez Z VocelkaArgentinaAnna Fali RENEWAL
Clifford O NestleFranceOnyama Limba PROPOSAL
Greenwood P WhobreyArgentinaBernardo Dominic UNQUALIFIED
Mujtaba K KuskoJapanIvan Magalhaes UNQUALIFIED
Aika J ChuiCanadaElwin Sharvill NEW
Izzy R DilliardFranceElwin Sharvill QUALIFIED
Smith N DarakjyAustraliaAmy Elsner UNQUALIFIED
Greenwood Y DarakjyArgentinaXuxue Feng PROPOSAL
Jeanfrancois L SlusarskiBrazilBernardo Dominic UNQUALIFIED
Jones T BriddickBrazilBernardo Dominic 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>