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
Kaitlin M SlusarskiArgentinaElwin Sharvill QUALIFIED
Emily N RoysterBrazilStephen Shaw NEGOTIATION
Maisha Q IturbideAustraliaAnna Fali QUALIFIED
Leon J PerinUnited KingdomBernardo Dominic NEW
James S OldroydFranceAnna Fali RENEWAL
Arvin H NestleBrazilIoni Bowcher PROPOSAL
Kaitlin N BriddickCanadaElwin Sharvill RENEWAL
Cody J DarakjyItalyElwin Sharvill NEGOTIATION
Misaki D FollerItalyBernardo Dominic UNQUALIFIED
Leja I WaycottArgentinaIvan Magalhaes PROPOSAL
Ivar G AlbaresFranceIvan Magalhaes RENEWAL
Ivar D PerinCanadaIvan Magalhaes QUALIFIED
Antonio I ButtAustraliaAsiya Javayant QUALIFIED
Jones H SchemmerCanadaElwin Sharvill PROPOSAL
Aruna Y FigeroaUnited KingdomAnna Fali QUALIFIED
Aditya J SaylorsRussiaAnna Fali RENEWAL
Alejandro Q SergiAustraliaIvan Magalhaes NEGOTIATION
Emily W SergiAustraliaBernardo Dominic NEGOTIATION
Emily I KuskoRussiaIvan Magalhaes RENEWAL
Juan P WieserArgentinaIvan Magalhaes NEW
Johnson U MacleadIndiaAmy Elsner PROPOSAL
Juan Q MaletGermanyIvan Magalhaes RENEWAL
Maria B KuskoIndiaXuxue Feng UNQUALIFIED
David X GarufiAustraliaAsiya Javayant PROPOSAL
Darci L InouyeArgentinaAnna Fali UNQUALIFIED
Jefferson G MaletGermanyAnna Fali NEGOTIATION
James G CaldareraRussiaAsiya Javayant NEGOTIATION
Julie F IturbideJapanIoni Bowcher QUALIFIED
Aika M OstroskyArgentinaAsiya Javayant QUALIFIED
Morrow H FerenczFranceElwin Sharvill NEW
Claire Y RulapaughAustraliaIvan Magalhaes QUALIFIED
Mayumi Y MacleadGermanyXuxue Feng NEGOTIATION
Jones C MarrierUnited KingdomIoni Bowcher UNQUALIFIED
Mujtaba G VocelkaCanadaElwin Sharvill QUALIFIED
Julie C KuskoArgentinaBernardo Dominic UNQUALIFIED
Mayumi F SaylorsRussiaBernardo Dominic RENEWAL
Silvio L CaldareraRussiaAsiya Javayant NEGOTIATION
Emily L RimSpainXuxue Feng NEGOTIATION
Aika J BriddickGermanyAsiya Javayant NEW
Cody N PerinJapanXuxue Feng NEGOTIATION
Wickens G RimRussiaAsiya Javayant NEGOTIATION
Octavia E RutaCanadaIvan Magalhaes NEW
Deepesh O PaprockiBrazilBernardo Dominic UNQUALIFIED
Cody D NestleAustraliaElwin Sharvill UNQUALIFIED
Jeanfrancois H PaprockiItalyAmy Elsner UNQUALIFIED
Smith E BologniaRussiaXuxue Feng QUALIFIED
Isabel H MorascaFranceStephen Shaw UNQUALIFIED
Johnson X FerenczItalyAnna Fali QUALIFIED
Maria I WaycottFranceStephen Shaw NEW
Cody O NestleUnited KingdomBernardo Dominic RENEWAL
Horizontal
NameCountryRepresentativeStatus
Chavez U PerinCanadaBernardo Dominic NEGOTIATION
Arvin V RulapaughBrazilIoni Bowcher RENEWAL
Jeanfrancois O NestleJapanIvan Magalhaes NEGOTIATION
Adams T FollerRussiaXuxue Feng NEW
Jones L WaycottIndiaAnna Fali NEW
Octavia L PaprockiFranceXuxue Feng RENEWAL
Salvatore Y MorascaGermanyAmy Elsner PROPOSAL
Salvatore B ShinkoSpainStephen Shaw RENEWAL
Mayumi D TollnerRussiaAnna Fali UNQUALIFIED
Nicolas P OldroydJapanAnna Fali QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jennifer A GlickUnited Kingdom2024-05-26Feiner Bros UNQUALIFIED56Stephen Shaw
1001Munro M GauchoAustralia2024-06-15Chanay, Jeffrey A Esq UNQUALIFIED48Ivan Magalhaes
1002Claire X WieserAustralia2024-05-25Chanay, Jeffrey A Esq RENEWAL4Ivan Magalhaes
1003Izzy W FerenczJapan2024-06-03King, Christopher A Esq NEGOTIATION35Stephen Shaw
1004James A DoeUnited Kingdom2024-05-28Printing Dimensions RENEWAL46Ivan Magalhaes
1005Octavia T GlickRussia2024-06-16Truhlar And Truhlar Attys NEW29Asiya Javayant
1006Maisha D MarrierFrance2024-05-26Chanay, Jeffrey A Esq NEGOTIATION41Ioni Bowcher
1007Mujtaba V ShinkoRussia2024-06-16Benton, John B Jr RENEWAL53Ivan Magalhaes
1008Octavia M GauchoGermany2024-06-09Rousseaux, Michael Esq PROPOSAL49Ivan Magalhaes
1009Misaki S DarakjyGermany2024-06-17Feltz Printing Service RENEWAL40Amy Elsner
1010Ivar A NickaIndia2024-06-04Feltz Printing Service NEW17Onyama Limba
1011Sinclair F WaycottItaly2024-06-17Chemel, James L Cpa PROPOSAL71Ioni Bowcher
1012Emily Y MacleadArgentina2024-06-07King, Christopher A Esq RENEWAL62Xuxue Feng
1013Ricardo N StensethBrazil2024-06-11Feiner Bros NEGOTIATION7Xuxue Feng
1014Salvatore E RulapaughFrance2024-06-01Dorl, James J Esq NEGOTIATION52Amy Elsner
1015Deepesh Y KuskoSpain2024-06-10Morlong Associates UNQUALIFIED33Bernardo Dominic
1016Misaki P SlusarskiItaly2024-06-02Truhlar And Truhlar Attys NEW40Elwin Sharvill
1017Misaki T NickaUnited Kingdom2024-05-19King, Christopher A Esq RENEWAL75Asiya Javayant
1018Silvio P DarakjyFrance2024-05-26Chemel, James L Cpa QUALIFIED57Ivan Magalhaes
1019James H VocelkaFrance2024-06-15Commercial Press PROPOSAL93Elwin Sharvill
1020Deepesh T SchemmerRussia2024-05-29Truhlar And Truhlar Attys RENEWAL99Xuxue Feng
1021Jones Q MacleadItaly2024-05-29Rangoni Of Florence UNQUALIFIED69Bernardo Dominic
1022Aditya L DilliardJapan2024-05-22Rangoni Of Florence PROPOSAL26Asiya Javayant
1023Darci K GlickJapan2024-06-02Chanay, Jeffrey A Esq NEGOTIATION36Onyama Limba
1024Maisha M PaprockiArgentina2024-06-02Chanay, Jeffrey A Esq UNQUALIFIED67Ivan Magalhaes
1025Alejandro H IturbideIndia2024-05-20Printing Dimensions PROPOSAL82Ioni Bowcher
1026Izzy B AmigonCanada2024-06-13Truhlar And Truhlar Attys PROPOSAL24Ioni Bowcher
1027Jefferson A RutaJapan2024-06-16Commercial Press NEGOTIATION19Ivan Magalhaes
1028Nicolas T SaylorsIndia2024-05-28Truhlar And Truhlar Attys RENEWAL10Asiya Javayant
1029Ashley B NestleBrazil2024-05-20Printing Dimensions PROPOSAL46Ioni Bowcher
1030David N RoysterFrance2024-05-25Printing Dimensions NEW76Amy Elsner
1031Kaitlin B ChuiIndia2024-05-27Chanay, Jeffrey A Esq UNQUALIFIED66Bernardo Dominic
1032Kadeem G InouyeItaly2024-05-20King, Christopher A Esq NEGOTIATION39Stephen Shaw
1033Chavez X StensethBrazil2024-06-07Dorl, James J Esq NEW28Bernardo Dominic
1034Ashley N RoysterRussia2024-06-04Dorl, James J Esq UNQUALIFIED93Bernardo Dominic
1035Kaitlin Z RoysterUnited Kingdom2024-06-15Printing Dimensions RENEWAL29Stephen Shaw
1036Mayumi G VenereItaly2024-05-25Chanay, Jeffrey A Esq UNQUALIFIED21Anna Fali
1037Kadeem Y MarrierAustralia2024-05-30Feltz Printing Service RENEWAL52Xuxue Feng
1038Maisha Z MaletIndia2024-05-31Morlong Associates PROPOSAL57Onyama Limba
1039Aditya F MaletAustralia2024-05-27King, Christopher A Esq NEGOTIATION80Stephen Shaw
1040Tony S RoysterAustralia2024-06-04Feiner Bros NEGOTIATION61Stephen Shaw
1041Salvatore A StockhamCanada2024-06-13Commercial Press UNQUALIFIED58Ioni Bowcher
1042Silvio L MarrierArgentina2024-06-05Dorl, James J Esq PROPOSAL72Onyama Limba
1043Faith O AlbaresBrazil2024-05-23Feltz Printing Service QUALIFIED33Xuxue Feng
1044Johnson C DoeArgentina2024-06-02Printing Dimensions QUALIFIED0Asiya Javayant
1045Ricardo R BologniaArgentina2024-05-19Chemel, James L Cpa RENEWAL10Xuxue Feng
1046Cody G GillianAustralia2024-06-16Chemel, James L Cpa RENEWAL8Onyama Limba
1047Sinclair Y FollerArgentina2024-06-15Truhlar And Truhlar Attys NEGOTIATION25Stephen Shaw
1048Jeanfrancois O KolmetzUnited Kingdom2024-05-27Dorl, James J Esq NEGOTIATION55Asiya Javayant
1049Mayumi I MorascaBrazil2024-05-26Feltz Printing Service NEW76Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Maisha M RimIndiaStephen Shaw PROPOSAL
Misaki J RutaRussiaIoni Bowcher PROPOSAL
Darci T AmigonBrazilXuxue Feng PROPOSAL
Deepesh N SchemmerFranceIoni Bowcher NEGOTIATION
Jones V InouyeSpainStephen Shaw NEGOTIATION
Jeanfrancois P AlbaresIndiaXuxue Feng QUALIFIED
Kaitlin W GillianCanadaStephen Shaw RENEWAL
Johnson W DilliardJapanIvan Magalhaes PROPOSAL
Clifford E GillianBrazilAsiya Javayant PROPOSAL
Aika G WieserJapanBernardo Dominic UNQUALIFIED
Izzy C StockhamBrazilElwin Sharvill RENEWAL
Ivar K VenereIndiaBernardo Dominic PROPOSAL
Wickens S VocelkaIndiaIvan Magalhaes RENEWAL
Juan A PoquetteFranceAnna Fali UNQUALIFIED
Ricardo J GauchoFranceAsiya Javayant PROPOSAL
Jones F RoysterAustraliaAnna Fali QUALIFIED
Chavez S MaletSpainAmy Elsner NEGOTIATION
Leja Q InouyeFranceStephen Shaw RENEWAL
Francesco Y DoeAustraliaAsiya Javayant QUALIFIED
Smith W GillianBrazilAnna Fali UNQUALIFIED
Octavia W FlosiBrazilIoni Bowcher QUALIFIED
Isabel S CampainRussiaIoni Bowcher QUALIFIED
Jefferson P SlusarskiUnited KingdomIvan Magalhaes QUALIFIED
Greenwood G WieserBrazilAnna Fali UNQUALIFIED
Nicolas C AmigonIndiaStephen Shaw RENEWAL
Mayumi N MaletUnited KingdomAnna Fali QUALIFIED
Aditya D KuskoJapanElwin Sharvill NEGOTIATION
Mujtaba J DilliardBrazilIvan Magalhaes NEW
Nicolas B TollnerItalyAsiya Javayant NEW
Alejandro T KolmetzFranceIoni Bowcher NEW
Deepesh T StensethFranceIoni Bowcher PROPOSAL
Stacey T GauchoAustraliaIvan Magalhaes PROPOSAL
Silvio A AmigonGermanyIvan Magalhaes NEGOTIATION
Jones M VocelkaCanadaOnyama Limba NEGOTIATION
Munro C StensethJapanOnyama Limba UNQUALIFIED
Chavez V FlosiItalyOnyama Limba UNQUALIFIED
Izzy G MaletGermanyAmy Elsner NEW
Ivar N RulapaughFranceAnna Fali UNQUALIFIED
Emily R CaldareraJapanIvan Magalhaes NEGOTIATION
Murillo F PaprockiUnited KingdomIoni Bowcher NEGOTIATION
Deepesh G MorascaSpainAnna Fali NEW
Mayumi Y StensethIndiaAsiya Javayant RENEWAL
Jeanfrancois B DoeCanadaAmy Elsner PROPOSAL
Stacey O BowleyGermanyIvan Magalhaes NEW
Mayumi S ShinkoFranceAmy Elsner UNQUALIFIED
Mayumi H KolmetzItalyIoni Bowcher RENEWAL
Francesco U StockhamRussiaBernardo Dominic NEW
Alejandro M OldroydItalyAnna Fali NEGOTIATION
Emily Y AlbaresJapanAsiya Javayant NEGOTIATION
Octavia A KolmetzCanadaBernardo Dominic NEGOTIATION
Frozen Columns
Name
Aditya Q Briddick
Greenwood Z Morasca
Deepesh E Venere
Morrow G Bowley
Kaitlin R Gaucho
Ashley O Caldarera
Jennifer J Paprocki
Ashley L Morasca
Claire U Tollner
Ivar S Stockham
Octavia Y Perin
Jones A Garufi
Salvatore Y Glick
Francesco L Gillian
Salvatore M Briddick
Deepesh M Gillian
Adams E Schemmer
Jefferson J Nestle
Antonio B Butt
Aika L Kusko
Costa W Nicka
Johnson Z Malet
Kadeem H Campain
Alejandro E Ruta
Murillo J Ferencz
Murillo R Bowley
Adams A Albares
Kadeem U Darakjy
Murillo Z Campain
Arvin W Rulapaugh
Johnson F Royster
Ivar M Vocelka
Aruna V Foller
Emily Z Schemmer
Kadeem A Maclead
Jones Q Foller
Isabel J Shinko
Claire U Caudy
Clifford R Slusarski
Ricardo Q Kusko
Smith H Stenseth
Octavia F Caldarera
Stacey G Figeroa
Arvin N Bowley
Sinclair F Perin
Emily L Perin
Greenwood M Paprocki
Emily Z Bowley
Silvio D Shinko
Smith R Oldroyd
IdCountryDate
1000United Kingdom2024-05-23
1001Germany2024-06-04
1002Japan2024-05-24
1003France2024-06-02
1004Argentina2024-06-17
1005Japan2024-05-26
1006United Kingdom2024-05-21
1007Italy2024-05-21
1008Russia2024-05-29
1009Spain2024-05-24
1010Germany2024-06-06
1011India2024-06-14
1012Australia2024-05-29
1013Australia2024-05-19
1014Spain2024-05-25
1015Australia2024-05-23
1016Australia2024-05-25
1017Italy2024-06-17
1018France2024-06-11
1019Spain2024-05-26
1020Japan2024-06-11
1021India2024-05-20
1022Spain2024-06-17
1023Russia2024-06-10
1024Russia2024-06-07
1025Japan2024-06-07
1026Argentina2024-05-22
1027Argentina2024-06-10
1028Canada2024-06-07
1029Australia2024-05-26
1030Japan2024-06-09
1031United Kingdom2024-05-20
1032Brazil2024-06-10
1033Canada2024-05-23
1034Argentina2024-05-22
1035Russia2024-06-07
1036India2024-06-11
1037Brazil2024-06-11
1038Japan2024-05-25
1039France2024-05-21
1040Canada2024-05-27
1041Spain2024-05-20
1042Russia2024-05-27
1043Germany2024-05-26
1044India2024-06-13
1045Spain2024-05-30
1046United Kingdom2024-06-03
1047Australia2024-06-08
1048Russia2024-05-31
1049Canada2024-05-19

On-Demand Data

NameIdCountryDate
Leja P Flosi1000Brazil2024-05-22
Nicolas N Morasca1001Japan2024-06-16
Cody Q Malet1002Canada2024-06-12
Salvatore S Schemmer1003Canada2024-05-28
Smith F Venere1004Brazil2024-05-23
Munro I Nicka1005Spain2024-06-06
Maria W Rim1006Argentina2024-06-05
Clifford S Stockham1007Russia2024-06-14
James X Foller1008Argentina2024-06-07
Rodrigues I Bolognia1009Spain2024-05-31
Aruna E Chui1010Spain2024-05-26
Francesco E Tollner1011Italy2024-05-31
Darci C Ostrosky1012Australia2024-06-15
Salvatore G Butt1013Spain2024-05-19
Silvio O Butt1014Germany2024-06-16
Jefferson D Glick1015Brazil2024-05-25
Nicolas M Vocelka1016Australia2024-06-04
Silvio W Foller1017Australia2024-05-23
Leon B Kusko1018Australia2024-06-15
Silvio H Darakjy1019Canada2024-05-25
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Claire Y NestleAustraliaBernardo Dominic QUALIFIED
Claire Z FlosiCanadaBernardo Dominic QUALIFIED
Maisha U TollnerCanadaOnyama Limba RENEWAL
Costa T VocelkaCanadaXuxue Feng RENEWAL
Nicolas U FerenczIndiaIvan Magalhaes PROPOSAL
Munro H MorascaUnited KingdomIoni Bowcher NEW
James L WaycottJapanStephen Shaw RENEWAL
Nicolas P IturbideItalyElwin Sharvill RENEWAL
Jennifer K StockhamAustraliaAsiya Javayant NEW
Isabel P NickaJapanElwin Sharvill UNQUALIFIED
Clifford G MacleadItalyOnyama Limba QUALIFIED
Rodrigues M ShinkoAustraliaElwin Sharvill QUALIFIED
Leja Z SaylorsBrazilIvan Magalhaes RENEWAL
Julie R KolmetzGermanyAmy Elsner NEGOTIATION
Stacey C MacleadItalyBernardo Dominic UNQUALIFIED
Greenwood E MaletFranceOnyama Limba QUALIFIED
Adams U FigeroaFranceOnyama Limba RENEWAL
Tony Y DoeGermanyIoni Bowcher UNQUALIFIED
Kadeem N CaudyFranceIoni Bowcher PROPOSAL
Deepesh U MaletBrazilIoni Bowcher NEGOTIATION
Octavia G SchemmerCanadaAmy Elsner PROPOSAL
Misaki T GarufiJapanStephen Shaw QUALIFIED
Ricardo Z ButtRussiaAsiya Javayant PROPOSAL
Silvio G FollerAustraliaXuxue Feng NEGOTIATION
Costa T RoysterIndiaStephen Shaw QUALIFIED
Leon D ChuiRussiaElwin Sharvill UNQUALIFIED
Chavez T MaletCanadaBernardo Dominic UNQUALIFIED
Adams E MorascaAustraliaAmy Elsner NEW
Ivar E RutaGermanyOnyama Limba NEGOTIATION
Julie Z DilliardSpainStephen Shaw NEW
Ricardo K MaletRussiaAmy Elsner QUALIFIED
Tony P SlusarskiCanadaElwin Sharvill UNQUALIFIED
Mujtaba F ShinkoIndiaElwin Sharvill QUALIFIED
Antonio M GillianCanadaIoni Bowcher RENEWAL
Sinclair Y RutaIndiaElwin Sharvill RENEWAL
Faith X MorascaFranceOnyama Limba NEGOTIATION
Ivar V MaletItalyIvan Magalhaes UNQUALIFIED
Maria D SlusarskiRussiaOnyama Limba NEGOTIATION
Misaki F KuskoUnited KingdomIvan Magalhaes NEW
Adams M CaldareraCanadaOnyama 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>