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
Rodrigues T AlbaresItalyIoni Bowcher RENEWAL
Izzy Q StensethUnited KingdomBernardo Dominic RENEWAL
Chavez Q CaudyUnited KingdomXuxue Feng RENEWAL
Mujtaba M WaycottIndiaBernardo Dominic NEW
Ashley F CaldareraCanadaElwin Sharvill RENEWAL
Mayumi W SergiSpainIvan Magalhaes PROPOSAL
Rodrigues V WaycottJapanAmy Elsner NEW
Aditya P GarufiJapanOnyama Limba QUALIFIED
Smith K MaletFranceAmy Elsner UNQUALIFIED
Leon K CaldareraBrazilBernardo Dominic QUALIFIED
Antonio K ChuiSpainIvan Magalhaes UNQUALIFIED
Julie Z BologniaArgentinaBernardo Dominic RENEWAL
Munro A SergiCanadaIvan Magalhaes NEW
Leja J AmigonGermanyIvan Magalhaes PROPOSAL
Emily C ChuiAustraliaIvan Magalhaes QUALIFIED
Kaitlin V MaletArgentinaStephen Shaw PROPOSAL
Aruna U PerinBrazilAsiya Javayant UNQUALIFIED
Costa H GlickFranceStephen Shaw RENEWAL
Rodrigues V KolmetzCanadaElwin Sharvill RENEWAL
Nicolas Z MarrierSpainIvan Magalhaes RENEWAL
Darci Z WhobreyGermanyIvan Magalhaes QUALIFIED
Octavia V NestleBrazilAmy Elsner QUALIFIED
Rodrigues Z SergiFranceAnna Fali UNQUALIFIED
Stacey K SchemmerUnited KingdomStephen Shaw NEW
Ivar N WieserSpainAnna Fali RENEWAL
Arvin C RutaCanadaBernardo Dominic NEW
Murillo F SlusarskiItalyIoni Bowcher NEW
Murillo A MaletJapanAsiya Javayant QUALIFIED
Francesco Q WaycottUnited KingdomElwin Sharvill PROPOSAL
Leon N StensethFranceXuxue Feng QUALIFIED
Darci D FlosiBrazilXuxue Feng QUALIFIED
Francesco N AmigonAustraliaIoni Bowcher NEGOTIATION
Jefferson F MacleadGermanyIvan Magalhaes UNQUALIFIED
Mujtaba S FigeroaArgentinaBernardo Dominic NEW
Johnson P StockhamCanadaStephen Shaw UNQUALIFIED
Octavia E KolmetzJapanAmy Elsner RENEWAL
Tony H ShinkoGermanyIvan Magalhaes UNQUALIFIED
Jennifer Z BologniaIndiaIvan Magalhaes NEGOTIATION
Clifford D SaylorsGermanyOnyama Limba NEGOTIATION
Izzy D WaycottGermanyStephen Shaw PROPOSAL
Julie L IturbideBrazilAnna Fali NEGOTIATION
Aditya N RutaUnited KingdomElwin Sharvill QUALIFIED
Maisha C FlosiItalyAsiya Javayant UNQUALIFIED
Sinclair Z CaldareraItalyIvan Magalhaes UNQUALIFIED
Costa L SaylorsUnited KingdomAmy Elsner QUALIFIED
Johnson C OldroydJapanAnna Fali RENEWAL
Mayumi G WaycottArgentinaIvan Magalhaes RENEWAL
Salvatore P StensethRussiaStephen Shaw RENEWAL
Stacey L BologniaIndiaElwin Sharvill RENEWAL
Tony C GlickIndiaOnyama Limba PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Izzy A DilliardCanadaIoni Bowcher UNQUALIFIED
Morrow D OldroydItalyIoni Bowcher RENEWAL
Francesco I SergiAustraliaIoni Bowcher NEGOTIATION
Greenwood F BriddickRussiaXuxue Feng RENEWAL
Morrow Q FerenczRussiaIoni Bowcher NEW
Leon Y FigeroaItalyAsiya Javayant QUALIFIED
Ashley I TollnerGermanyStephen Shaw NEGOTIATION
Greenwood O VocelkaGermanyIvan Magalhaes NEGOTIATION
Aruna O GauchoRussiaBernardo Dominic NEW
Johnson H KuskoAustraliaStephen Shaw UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Claire E IturbideBrazil2025-06-03Morlong Associates PROPOSAL23Stephen Shaw
1001Jones D IturbideArgentina2025-06-12Printing Dimensions RENEWAL72Stephen Shaw
1002Ricardo U ButtBrazil2025-05-22Chemel, James L Cpa RENEWAL4Amy Elsner
1003Cody P BologniaArgentina2025-05-25Benton, John B Jr UNQUALIFIED0Ioni Bowcher
1004Smith D SaylorsJapan2025-05-19Chanay, Jeffrey A Esq NEGOTIATION88Bernardo Dominic
1005Antonio I MarrierIndia2025-05-17Commercial Press UNQUALIFIED4Bernardo Dominic
1006Aditya A SlusarskiJapan2025-05-23Commercial Press UNQUALIFIED51Elwin Sharvill
1007Maria P SchemmerArgentina2025-06-01Commercial Press UNQUALIFIED63Bernardo Dominic
1008Emily F MacleadAustralia2025-06-04Dorl, James J Esq RENEWAL73Asiya Javayant
1009Aruna Z GlickBrazil2025-06-11Dorl, James J Esq UNQUALIFIED14Xuxue Feng
1010Mayumi K RoysterIndia2025-06-05Rousseaux, Michael Esq PROPOSAL57Bernardo Dominic
1011Juan H TollnerFrance2025-06-14Chemel, James L Cpa RENEWAL9Bernardo Dominic
1012Francesco B PoquetteIndia2025-06-04Morlong Associates RENEWAL74Xuxue Feng
1013Juan H FlosiRussia2025-05-23Dorl, James J Esq NEGOTIATION37Ioni Bowcher
1014Smith E BriddickRussia2025-05-26Chanay, Jeffrey A Esq NEW3Elwin Sharvill
1015Leja N BriddickRussia2025-05-28Printing Dimensions NEGOTIATION77Xuxue Feng
1016Ashley Q RimAustralia2025-05-21King, Christopher A Esq UNQUALIFIED29Elwin Sharvill
1017Maisha U OldroydJapan2025-05-23Dorl, James J Esq RENEWAL61Bernardo Dominic
1018Jefferson U ShinkoAustralia2025-06-01Rousseaux, Michael Esq UNQUALIFIED79Stephen Shaw
1019Leon U KuskoSpain2025-05-23Printing Dimensions NEGOTIATION18Ivan Magalhaes
1020Clifford W KolmetzArgentina2025-05-30Truhlar And Truhlar Attys PROPOSAL97Elwin Sharvill
1021Leon J FerenczJapan2025-06-09Chemel, James L Cpa RENEWAL92Bernardo Dominic
1022Alejandro V KolmetzItaly2025-06-12Chemel, James L Cpa RENEWAL12Amy Elsner
1023Juan U AlbaresFrance2025-06-15Chemel, James L Cpa PROPOSAL82Anna Fali
1024Mayumi J SlusarskiIndia2025-05-24Commercial Press RENEWAL87Ioni Bowcher
1025Misaki M PaprockiBrazil2025-06-12Buckley Miller Wright UNQUALIFIED5Anna Fali
1026Munro Q FigeroaSpain2025-05-27King, Christopher A Esq NEW5Asiya Javayant
1027Alejandro H VocelkaUnited Kingdom2025-05-20Buckley Miller Wright PROPOSAL23Onyama Limba
1028Munro O SchemmerRussia2025-06-07Feltz Printing Service NEW96Ivan Magalhaes
1029Faith S IturbideAustralia2025-06-09Rousseaux, Michael Esq NEW79Asiya Javayant
1030Darci U MorascaItaly2025-05-22Buckley Miller Wright NEGOTIATION26Onyama Limba
1031Morrow R OstroskyUnited Kingdom2025-05-30Morlong Associates PROPOSAL85Onyama Limba
1032Izzy H InouyeAustralia2025-05-27Feiner Bros QUALIFIED54Onyama Limba
1033Aditya D BriddickCanada2025-05-18King, Christopher A Esq RENEWAL87Amy Elsner
1034Aruna P DilliardArgentina2025-06-09Chapman, Ross E Esq PROPOSAL23Xuxue Feng
1035Clifford X RulapaughItaly2025-06-06Rangoni Of Florence QUALIFIED22Anna Fali
1036Juan K PaprockiAustralia2025-05-26Chanay, Jeffrey A Esq RENEWAL82Ivan Magalhaes
1037Rodrigues E GarufiUnited Kingdom2025-06-05Rousseaux, Michael Esq UNQUALIFIED68Ivan Magalhaes
1038Wickens W FerenczRussia2025-06-15Buckley Miller Wright QUALIFIED34Ivan Magalhaes
1039David V ChuiAustralia2025-05-19Printing Dimensions PROPOSAL8Elwin Sharvill
1040Munro A GillianFrance2025-06-07Dorl, James J Esq NEW32Ivan Magalhaes
1041Leja K DilliardGermany2025-05-28Rousseaux, Michael Esq QUALIFIED44Ivan Magalhaes
1042Aditya X DilliardSpain2025-05-27Buckley Miller Wright UNQUALIFIED35Anna Fali
1043Jeanfrancois E StockhamGermany2025-06-10Chemel, James L Cpa QUALIFIED42Xuxue Feng
1044Maisha D DarakjyItaly2025-05-30Chemel, James L Cpa NEW75Elwin Sharvill
1045Munro H RoysterIndia2025-05-25Chemel, James L Cpa QUALIFIED76Xuxue Feng
1046Clifford Q IturbideUnited Kingdom2025-05-18Chanay, Jeffrey A Esq PROPOSAL3Elwin Sharvill
1047Leja A OldroydUnited Kingdom2025-06-06King, Christopher A Esq UNQUALIFIED20Ivan Magalhaes
1048Octavia A BologniaBrazil2025-06-01Rousseaux, Michael Esq NEGOTIATION28Amy Elsner
1049Jones M GlickSpain2025-06-10Dorl, James J Esq QUALIFIED49Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Misaki A StensethUnited KingdomBernardo Dominic NEW
Salvatore U FollerItalyElwin Sharvill RENEWAL
Emily Y RimArgentinaOnyama Limba RENEWAL
Sinclair M RoysterUnited KingdomAmy Elsner PROPOSAL
Rodrigues N NestleJapanIoni Bowcher QUALIFIED
Smith U PerinFranceIoni Bowcher RENEWAL
Alejandro C StockhamIndiaElwin Sharvill PROPOSAL
Leja L BowleyRussiaOnyama Limba NEW
Misaki Z ButtBrazilElwin Sharvill RENEWAL
Jefferson X FigeroaJapanStephen Shaw PROPOSAL
Aditya T KolmetzSpainIoni Bowcher NEW
Rodrigues I CampainArgentinaElwin Sharvill NEW
Costa G FerenczUnited KingdomBernardo Dominic NEW
Stacey I RoysterCanadaElwin Sharvill NEGOTIATION
Alejandro L CaldareraBrazilOnyama Limba PROPOSAL
Murillo U FollerAustraliaIvan Magalhaes UNQUALIFIED
Alejandro P KolmetzRussiaElwin Sharvill QUALIFIED
Julie D CampainCanadaAmy Elsner QUALIFIED
James R WaycottSpainStephen Shaw RENEWAL
Leon C PoquetteBrazilAsiya Javayant QUALIFIED
Tony H FerenczIndiaIvan Magalhaes NEW
Jones J BriddickJapanOnyama Limba NEGOTIATION
Mayumi W WieserCanadaIoni Bowcher QUALIFIED
David V BriddickAustraliaIoni Bowcher NEW
Claire L BologniaItalyXuxue Feng PROPOSAL
Johnson H IturbideIndiaAmy Elsner PROPOSAL
Izzy U AmigonUnited KingdomStephen Shaw QUALIFIED
Greenwood E WhobreyItalyBernardo Dominic QUALIFIED
Ashley T TollnerRussiaXuxue Feng RENEWAL
Alejandro I MaletBrazilStephen Shaw PROPOSAL
Jones Q IturbideArgentinaXuxue Feng UNQUALIFIED
Juan N KolmetzIndiaAnna Fali NEW
Aika V RulapaughFranceIvan Magalhaes NEGOTIATION
Julie D BriddickUnited KingdomAmy Elsner UNQUALIFIED
Costa I MorascaFranceBernardo Dominic RENEWAL
Isabel U CaudyCanadaBernardo Dominic UNQUALIFIED
Leon L ChuiJapanAnna Fali NEGOTIATION
Smith I DarakjyFranceIoni Bowcher NEGOTIATION
Maria R WieserBrazilAsiya Javayant NEW
Mujtaba B PoquetteUnited KingdomAnna Fali QUALIFIED
Johnson B MaletBrazilIvan Magalhaes RENEWAL
Arvin Q GillianRussiaIoni Bowcher NEW
Nicolas Z CampainCanadaOnyama Limba NEW
Isabel L SergiFranceAnna Fali UNQUALIFIED
Isabel B VocelkaRussiaXuxue Feng RENEWAL
Izzy F CampainSpainOnyama Limba NEGOTIATION
Wickens G FlosiGermanyAnna Fali QUALIFIED
Misaki E MarrierBrazilBernardo Dominic UNQUALIFIED
Ivar O MorascaArgentinaIoni Bowcher RENEWAL
Ricardo Q WhobreyRussiaOnyama Limba PROPOSAL
Frozen Columns
Name
Deepesh A Gaucho
Mayumi K Venere
Adams L Briddick
Antonio X Glick
Aruna J Poquette
James Y Nicka
Aika N Flosi
Faith B Campain
Kadeem V Maclead
James F Rulapaugh
Leon C Albares
Smith P Paprocki
James S Inouye
Darci L Butt
Aditya O Nestle
Johnson Q Maclead
Aika M Chui
Juan R Inouye
Mujtaba D Stockham
Ivar Q Kusko
Clifford S Oldroyd
Sinclair L Butt
Faith M Vocelka
Misaki C Morasca
Leon K Caldarera
Aditya S Nestle
Faith M Foller
Johnson A Caudy
Juan Y Malet
Francesco M Gaucho
Aditya W Briddick
Stacey L Shinko
Octavia R Gaucho
Salvatore P Garufi
Adams I Waycott
Isabel A Caudy
Salvatore V Sergi
Jeanfrancois M Bowley
Greenwood J Inouye
Costa B Ferencz
Maria T Butt
Kaitlin S Rulapaugh
Salvatore U Malet
James U Whobrey
Emily Y Gaucho
James S Royster
Juan B Venere
Kadeem E Doe
Ricardo I Campain
Mujtaba N Stenseth
IdCountryDate
1000France2025-06-01
1001Australia2025-06-12
1002Russia2025-05-19
1003Argentina2025-06-13
1004Canada2025-05-27
1005Germany2025-05-19
1006Italy2025-05-23
1007Italy2025-05-26
1008United Kingdom2025-05-27
1009Italy2025-06-14
1010Japan2025-05-31
1011Canada2025-05-20
1012Argentina2025-05-19
1013Spain2025-06-06
1014Canada2025-06-06
1015Italy2025-05-31
1016Italy2025-05-30
1017Italy2025-06-07
1018United Kingdom2025-05-23
1019Brazil2025-06-15
1020Germany2025-05-21
1021Brazil2025-05-19
1022Australia2025-05-22
1023Canada2025-06-06
1024Brazil2025-05-26
1025Brazil2025-05-17
1026Australia2025-05-19
1027Spain2025-06-04
1028Canada2025-06-01
1029Australia2025-05-19
1030France2025-05-30
1031Japan2025-06-08
1032Russia2025-06-11
1033Russia2025-05-24
1034Australia2025-06-02
1035Japan2025-05-26
1036Russia2025-05-25
1037United Kingdom2025-06-11
1038Australia2025-06-03
1039United Kingdom2025-06-11
1040Australia2025-06-13
1041Spain2025-05-28
1042Russia2025-06-09
1043Russia2025-05-21
1044Argentina2025-06-09
1045Japan2025-05-23
1046Argentina2025-05-30
1047Canada2025-05-17
1048Japan2025-05-17
1049Spain2025-06-06

On-Demand Data

NameIdCountryDate
Emily W Figeroa1000Russia2025-06-03
Wickens G Whobrey1001Canada2025-06-01
Juan Y Saylors1002Russia2025-06-10
Stacey D Shinko1003Germany2025-06-13
Faith F Saylors1004Germany2025-06-12
Johnson R Waycott1005Australia2025-05-31
Nicolas O Nicka1006Australia2025-05-29
Jennifer K Venere1007France2025-05-29
Rodrigues R Shinko1008France2025-05-24
David S Nicka1009France2025-06-02
Maisha Z Tollner1010Japan2025-06-02
Izzy K Malet1011Canada2025-05-24
Alejandro U Figeroa1012Russia2025-05-28
Salvatore O Caldarera1013Argentina2025-06-03
Munro J Inouye1014Japan2025-06-14
Maisha K Poquette1015Japan2025-06-04
Misaki T Shinko1016Argentina2025-05-22
Arvin C Bowley1017Russia2025-06-01
Chavez D Doe1018Canada2025-05-19
James N Glick1019Brazil2025-06-02
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Johnson E SchemmerAustraliaIoni Bowcher NEW
Kaitlin D OstroskyBrazilIoni Bowcher NEW
Jennifer M MorascaFranceIoni Bowcher PROPOSAL
Darci O KuskoArgentinaAsiya Javayant UNQUALIFIED
Juan J AmigonBrazilXuxue Feng NEW
Greenwood J KuskoFranceIoni Bowcher RENEWAL
Greenwood K StensethGermanyOnyama Limba NEGOTIATION
Johnson M ButtAustraliaBernardo Dominic QUALIFIED
Silvio N MaletSpainAsiya Javayant NEGOTIATION
Arvin K SchemmerSpainBernardo Dominic NEW
Adams E RulapaughSpainOnyama Limba UNQUALIFIED
Cody O DilliardFranceOnyama Limba PROPOSAL
Wickens D WieserCanadaXuxue Feng NEGOTIATION
Ivar S SaylorsItalyElwin Sharvill PROPOSAL
Alejandro W StensethSpainOnyama Limba PROPOSAL
Aruna R NestleBrazilIvan Magalhaes QUALIFIED
Cody G StensethFranceAnna Fali RENEWAL
Maisha R InouyeRussiaAnna Fali NEGOTIATION
Morrow V FlosiItalyAnna Fali RENEWAL
Kadeem R SchemmerIndiaIvan Magalhaes PROPOSAL
Julie A KuskoGermanyOnyama Limba NEGOTIATION
Jeanfrancois O RulapaughSpainAnna Fali QUALIFIED
Murillo T MorascaRussiaAmy Elsner NEGOTIATION
Isabel R NestleAustraliaBernardo Dominic QUALIFIED
Morrow C OstroskyArgentinaIvan Magalhaes PROPOSAL
Salvatore P SchemmerIndiaOnyama Limba RENEWAL
Jeanfrancois F BowleyUnited KingdomXuxue Feng PROPOSAL
James K BriddickCanadaIoni Bowcher QUALIFIED
Aditya P MaletGermanyAsiya Javayant RENEWAL
Costa J MaletSpainOnyama Limba RENEWAL
Sinclair B AlbaresBrazilAmy Elsner PROPOSAL
Jefferson U WaycottIndiaStephen Shaw PROPOSAL
Faith K DilliardRussiaIvan Magalhaes NEGOTIATION
Maisha E WhobreyGermanyOnyama Limba QUALIFIED
Leja H DarakjyItalyBernardo Dominic NEGOTIATION
Claire R StensethBrazilAmy Elsner NEW
Silvio A RutaUnited KingdomStephen Shaw QUALIFIED
Costa C WhobreyCanadaAsiya Javayant QUALIFIED
Costa Z GauchoIndiaStephen Shaw NEW
Morrow I OstroskySpainAsiya Javayant NEW

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