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
Jennifer H BriddickSpainOnyama Limba PROPOSAL
Deepesh R GlickGermanyAmy Elsner UNQUALIFIED
Misaki O OldroydUnited KingdomAmy Elsner RENEWAL
Salvatore G InouyeIndiaIoni Bowcher UNQUALIFIED
Jeanfrancois F FlosiIndiaAnna Fali QUALIFIED
Tony R SergiItalyAnna Fali QUALIFIED
Julie I PerinRussiaAmy Elsner PROPOSAL
Silvio R CaudyItalyElwin Sharvill PROPOSAL
Nicolas T ChuiGermanyAnna Fali UNQUALIFIED
Morrow W RutaCanadaAsiya Javayant RENEWAL
Chavez A CaldareraBrazilAnna Fali RENEWAL
Munro P VocelkaAustraliaBernardo Dominic UNQUALIFIED
Izzy S MacleadJapanXuxue Feng UNQUALIFIED
Stacey J FlosiFranceElwin Sharvill NEGOTIATION
Kadeem Y SchemmerRussiaAnna Fali NEW
Tony V FigeroaSpainBernardo Dominic NEW
Aruna B MarrierItalyAmy Elsner QUALIFIED
Salvatore G PoquetteArgentinaXuxue Feng PROPOSAL
Ivar A SaylorsFranceElwin Sharvill PROPOSAL
Juan Q StensethFranceIvan Magalhaes UNQUALIFIED
Mayumi A DoeGermanyBernardo Dominic UNQUALIFIED
Jones F FlosiSpainAnna Fali RENEWAL
Ricardo B VocelkaRussiaXuxue Feng QUALIFIED
Nicolas R NestleArgentinaIoni Bowcher NEW
Nicolas N MorascaFranceAmy Elsner RENEWAL
Ashley G MaletJapanAnna Fali NEW
Jones A MarrierIndiaElwin Sharvill NEW
Adams D RimCanadaIoni Bowcher PROPOSAL
Jones V PaprockiCanadaAmy Elsner UNQUALIFIED
Smith T AmigonRussiaAsiya Javayant UNQUALIFIED
Izzy D VocelkaGermanyOnyama Limba RENEWAL
Stacey W DarakjyAustraliaStephen Shaw UNQUALIFIED
Salvatore T CaudyBrazilIvan Magalhaes UNQUALIFIED
Wickens O FerenczRussiaElwin Sharvill RENEWAL
Mayumi C SergiRussiaAnna Fali NEGOTIATION
Alejandro O ButtArgentinaBernardo Dominic QUALIFIED
Cody X BriddickIndiaXuxue Feng QUALIFIED
Alejandro J RutaBrazilStephen Shaw PROPOSAL
Antonio P CampainBrazilXuxue Feng RENEWAL
Francesco C GauchoGermanyBernardo Dominic NEW
Chavez J WieserArgentinaBernardo Dominic UNQUALIFIED
Darci U FlosiGermanyAsiya Javayant PROPOSAL
Chavez I BriddickSpainAmy Elsner PROPOSAL
Ricardo M RulapaughArgentinaOnyama Limba RENEWAL
Aruna A IturbideItalyOnyama Limba QUALIFIED
Mujtaba O NestleJapanStephen Shaw NEW
Kaitlin O WaycottJapanAnna Fali NEGOTIATION
Arvin S ButtItalyAmy Elsner RENEWAL
Silvio A BologniaAustraliaIoni Bowcher NEW
Stacey X GillianRussiaIoni Bowcher PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Arvin X SlusarskiItalyIoni Bowcher UNQUALIFIED
Johnson N AlbaresAustraliaElwin Sharvill QUALIFIED
Sinclair Y GillianSpainAnna Fali NEGOTIATION
Stacey C TollnerCanadaBernardo Dominic QUALIFIED
Murillo M GauchoBrazilIvan Magalhaes UNQUALIFIED
Arvin B OldroydUnited KingdomStephen Shaw QUALIFIED
Leon H IturbideItalyOnyama Limba NEGOTIATION
Misaki V AmigonAustraliaAmy Elsner PROPOSAL
Juan Z WaycottRussiaStephen Shaw QUALIFIED
Stacey F DoeSpainIoni Bowcher PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Stacey J PerinGermany2024-05-21Truhlar And Truhlar Attys UNQUALIFIED8Ioni Bowcher
1001Stacey E MacleadGermany2024-05-11Printing Dimensions QUALIFIED98Bernardo Dominic
1002Antonio G RoysterAustralia2024-05-21King, Christopher A Esq NEGOTIATION82Ioni Bowcher
1003Rodrigues L OstroskyBrazil2024-05-02King, Christopher A Esq NEGOTIATION28Ioni Bowcher
1004Octavia V OldroydGermany2024-05-12Chanay, Jeffrey A Esq PROPOSAL34Asiya Javayant
1005Juan F KolmetzIndia2024-05-01Dorl, James J Esq NEGOTIATION43Ivan Magalhaes
1006Morrow J FlosiJapan2024-05-25Truhlar And Truhlar Attys NEW86Xuxue Feng
1007Mayumi R BriddickFrance2024-05-06Printing Dimensions QUALIFIED48Anna Fali
1008Arvin R NickaItaly2024-05-22Morlong Associates NEGOTIATION61Onyama Limba
1009Salvatore M NickaUnited Kingdom2024-05-15Commercial Press QUALIFIED19Anna Fali
1010Emily G FigeroaJapan2024-05-06King, Christopher A Esq PROPOSAL73Xuxue Feng
1011Nicolas P CaudyUnited Kingdom2024-05-24Chanay, Jeffrey A Esq RENEWAL44Bernardo Dominic
1012Jeanfrancois O ShinkoUnited Kingdom2024-05-20Benton, John B Jr QUALIFIED8Amy Elsner
1013Jeanfrancois W GillianCanada2024-04-29Truhlar And Truhlar Attys PROPOSAL53Ioni Bowcher
1014Stacey K SaylorsRussia2024-04-29Morlong Associates QUALIFIED8Bernardo Dominic
1015Smith G MaletArgentina2024-04-29King, Christopher A Esq UNQUALIFIED63Elwin Sharvill
1016David J GauchoRussia2024-05-13Rangoni Of Florence NEGOTIATION2Elwin Sharvill
1017Murillo L MaletGermany2024-05-21Rousseaux, Michael Esq UNQUALIFIED71Xuxue Feng
1018Kadeem M CampainCanada2024-05-25Printing Dimensions NEW99Ioni Bowcher
1019Antonio P OstroskySpain2024-05-12Rangoni Of Florence QUALIFIED46Onyama Limba
1020Morrow N OstroskyJapan2024-05-09Benton, John B Jr PROPOSAL80Onyama Limba
1021Ricardo I StensethIndia2024-05-26Chemel, James L Cpa NEGOTIATION44Elwin Sharvill
1022David M MaletCanada2024-05-25Chemel, James L Cpa RENEWAL15Amy Elsner
1023Smith K StensethAustralia2024-05-15Chanay, Jeffrey A Esq NEGOTIATION19Stephen Shaw
1024Silvio C RutaBrazil2024-05-07Feiner Bros RENEWAL79Amy Elsner
1025Maisha Y CaudyJapan2024-05-19Chapman, Ross E Esq NEW49Stephen Shaw
1026Maisha F VocelkaSpain2024-05-17Morlong Associates UNQUALIFIED65Ioni Bowcher
1027Juan R BriddickBrazil2024-05-02Chemel, James L Cpa NEGOTIATION34Ivan Magalhaes
1028Faith Z KuskoRussia2024-05-19Chemel, James L Cpa PROPOSAL63Xuxue Feng
1029Kaitlin X FigeroaSpain2024-05-06Dorl, James J Esq RENEWAL76Amy Elsner
1030Claire F AmigonGermany2024-05-21Printing Dimensions RENEWAL76Anna Fali
1031Isabel M OstroskyJapan2024-05-03Feltz Printing Service RENEWAL49Ivan Magalhaes
1032Alejandro S SchemmerIndia2024-05-27Benton, John B Jr UNQUALIFIED47Asiya Javayant
1033Jefferson V NickaIndia2024-05-26King, Christopher A Esq NEGOTIATION18Ivan Magalhaes
1034Munro Y GauchoGermany2024-04-30Morlong Associates NEGOTIATION73Bernardo Dominic
1035Maisha N RutaAustralia2024-05-08Morlong Associates NEW92Bernardo Dominic
1036Mayumi I PaprockiUnited Kingdom2024-05-08Rousseaux, Michael Esq UNQUALIFIED78Asiya Javayant
1037Cody R DilliardArgentina2024-05-23Chemel, James L Cpa QUALIFIED89Xuxue Feng
1038Wickens Z VenereJapan2024-05-23Commercial Press QUALIFIED41Asiya Javayant
1039Jennifer S WieserJapan2024-05-07Chemel, James L Cpa NEGOTIATION17Amy Elsner
1040Octavia W BologniaFrance2024-05-24Chapman, Ross E Esq RENEWAL0Xuxue Feng
1041David L GlickIndia2024-05-23Feiner Bros QUALIFIED89Asiya Javayant
1042Alejandro P GlickUnited Kingdom2024-05-02Rousseaux, Michael Esq QUALIFIED33Xuxue Feng
1043Ashley P MacleadArgentina2024-05-17Chapman, Ross E Esq PROPOSAL52Ioni Bowcher
1044Deepesh M StockhamArgentina2024-05-18Printing Dimensions QUALIFIED67Elwin Sharvill
1045Johnson D StockhamUnited Kingdom2024-05-15Chapman, Ross E Esq UNQUALIFIED73Anna Fali
1046Kaitlin Z PaprockiFrance2024-05-24Dorl, James J Esq NEGOTIATION82Asiya Javayant
1047Cody M PoquetteRussia2024-05-14Chapman, Ross E Esq PROPOSAL22Ivan Magalhaes
1048Kaitlin T FollerFrance2024-05-22Feltz Printing Service NEW8Asiya Javayant
1049Octavia M FigeroaRussia2024-05-06Truhlar And Truhlar Attys QUALIFIED85Elwin Sharvill
Frozen Rows
NameCountryRepresentativeStatus
Morrow B GarufiFranceIoni Bowcher NEW
Darci J KolmetzIndiaIvan Magalhaes NEGOTIATION
Arvin T CampainFranceAsiya Javayant RENEWAL
David R FollerBrazilIoni Bowcher PROPOSAL
Maria J RutaGermanyXuxue Feng RENEWAL
Darci Q FerenczBrazilAnna Fali NEGOTIATION
Kadeem T GarufiArgentinaStephen Shaw NEW
Salvatore Q VocelkaIndiaAnna Fali NEGOTIATION
Emily C DilliardUnited KingdomAsiya Javayant NEGOTIATION
Julie L GauchoUnited KingdomElwin Sharvill UNQUALIFIED
Jefferson L DarakjyAustraliaIoni Bowcher NEW
Kadeem Y PoquetteCanadaXuxue Feng NEW
Aika X AmigonItalyIoni Bowcher PROPOSAL
Leon A StensethItalyElwin Sharvill QUALIFIED
Chavez N FigeroaBrazilAsiya Javayant QUALIFIED
Kadeem M FerenczFranceStephen Shaw QUALIFIED
Stacey S DilliardItalyAnna Fali PROPOSAL
David F WieserArgentinaAsiya Javayant NEW
Rodrigues S MorascaGermanyElwin Sharvill QUALIFIED
Kaitlin Z MarrierJapanIoni Bowcher RENEWAL
Emily Y SaylorsGermanyOnyama Limba UNQUALIFIED
Greenwood U SchemmerUnited KingdomXuxue Feng UNQUALIFIED
James J ButtBrazilIoni Bowcher NEW
Ivar G CampainRussiaElwin Sharvill RENEWAL
Wickens M BowleyFranceAnna Fali QUALIFIED
Stacey T CampainAustraliaXuxue Feng NEGOTIATION
David M SaylorsAustraliaStephen Shaw PROPOSAL
Aditya D SchemmerSpainAnna Fali UNQUALIFIED
Emily J CampainUnited KingdomIoni Bowcher NEGOTIATION
Jennifer S MorascaArgentinaBernardo Dominic UNQUALIFIED
Leon V KolmetzUnited KingdomOnyama Limba NEGOTIATION
Juan Q OldroydAustraliaAsiya Javayant NEGOTIATION
Jeanfrancois C DarakjyGermanyAnna Fali UNQUALIFIED
Tony I SergiGermanyIvan Magalhaes PROPOSAL
Tony O KuskoItalyXuxue Feng PROPOSAL
Leja Z FerenczFranceStephen Shaw NEGOTIATION
Leon R StensethBrazilAnna Fali RENEWAL
Ashley U RimItalyAsiya Javayant NEW
Greenwood J WhobreyAustraliaAmy Elsner UNQUALIFIED
Rodrigues E BologniaBrazilXuxue Feng NEGOTIATION
Ashley F WhobreyCanadaIvan Magalhaes QUALIFIED
Antonio H GarufiBrazilBernardo Dominic RENEWAL
Maria K SlusarskiJapanIvan Magalhaes PROPOSAL
Arvin N OldroydGermanyOnyama Limba UNQUALIFIED
Maisha Z FlosiJapanAnna Fali QUALIFIED
Morrow T SlusarskiItalyAsiya Javayant UNQUALIFIED
Emily O NickaCanadaBernardo Dominic NEGOTIATION
Aditya D RutaGermanyIvan Magalhaes NEW
Mujtaba D ShinkoUnited KingdomAsiya Javayant NEGOTIATION
Nicolas X NestleBrazilAmy Elsner PROPOSAL
Frozen Columns
Name
Arvin L Oldroyd
Arvin F Butt
Jefferson H Ruta
Antonio W Slusarski
Maria M Stockham
Greenwood D Nestle
Kadeem M Inouye
Wickens T Vocelka
Izzy W Waycott
Chavez N Flosi
Izzy K Royster
Izzy Z Nestle
Wickens C Kusko
Sinclair R Bolognia
Murillo R Kolmetz
Deepesh B Vocelka
Adams I Butt
Leon H Flosi
Aditya Q Sergi
Clifford F Amigon
Antonio F Chui
Maisha H Morasca
Leja A Malet
Claire E Rim
Jeanfrancois B Bolognia
Jennifer N Foller
Morrow F Rulapaugh
Deepesh W Stockham
Ashley Q Paprocki
Tony W Nicka
James L Sergi
Munro M Waycott
Aika Y Slusarski
Greenwood W Venere
David Q Waycott
Chavez U Flosi
Sinclair P Malet
Adams W Glick
Juan O Nestle
Maisha I Ferencz
Emily B Caudy
Adams T Schemmer
Chavez D Nestle
Arvin R Shinko
Jeanfrancois Y Slusarski
Julie I Whobrey
Emily B Tollner
Aika I Sergi
Maisha I Slusarski
Clifford W Marrier
IdCountryDate
1000Brazil2024-05-05
1001Canada2024-05-03
1002India2024-05-27
1003Brazil2024-05-05
1004Spain2024-05-08
1005Australia2024-05-03
1006Brazil2024-05-16
1007India2024-05-19
1008Italy2024-05-03
1009Australia2024-05-17
1010Argentina2024-05-24
1011India2024-05-09
1012Argentina2024-05-10
1013Germany2024-05-02
1014Japan2024-05-27
1015Australia2024-05-21
1016Australia2024-05-18
1017Spain2024-05-23
1018Japan2024-05-01
1019Argentina2024-05-21
1020Italy2024-05-18
1021Canada2024-05-01
1022Spain2024-05-08
1023Italy2024-05-15
1024Canada2024-05-21
1025Japan2024-04-28
1026Italy2024-05-02
1027India2024-05-12
1028Germany2024-05-07
1029Brazil2024-04-29
1030Canada2024-05-05
1031Argentina2024-05-14
1032Canada2024-05-08
1033France2024-04-30
1034Japan2024-05-10
1035Australia2024-05-21
1036Spain2024-05-07
1037Australia2024-05-17
1038Canada2024-05-23
1039Canada2024-05-08
1040Canada2024-05-03
1041France2024-05-04
1042Brazil2024-05-03
1043France2024-05-12
1044Japan2024-04-29
1045Russia2024-05-06
1046Italy2024-05-14
1047Argentina2024-05-02
1048Russia2024-05-20
1049Japan2024-05-02

On-Demand Data

NameIdCountryDate
Nicolas Q Caudy1000France2024-05-24
Mujtaba R Schemmer1001Spain2024-05-07
Costa H Saylors1002United Kingdom2024-05-13
Ivar R Slusarski1003Spain2024-04-30
Clifford P Iturbide1004Canada2024-05-13
Kadeem V Waycott1005United Kingdom2024-05-24
Salvatore U Vocelka1006Germany2024-05-09
Arvin M Albares1007Russia2024-05-18
Misaki N Sergi1008Australia2024-05-10
Leon S Schemmer1009France2024-05-01
Chavez M Stockham1010Italy2024-05-12
Juan E Stenseth1011Canada2024-05-08
Octavia E Gillian1012Germany2024-05-16
Adams D Bolognia1013Italy2024-05-05
Mayumi Z Ferencz1014India2024-05-01
Costa Y Gaucho1015Canada2024-05-18
Jones Q Darakjy1016Spain2024-05-18
Francesco W Dilliard1017Spain2024-05-07
Aditya A Caudy1018Germany2024-05-14
Aruna K Dilliard1019Canada2024-05-08
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Leja T PaprockiIndiaXuxue Feng QUALIFIED
Nicolas Y RulapaughCanadaAnna Fali NEGOTIATION
Ivar C BriddickFranceBernardo Dominic QUALIFIED
Darci C InouyeBrazilAnna Fali QUALIFIED
Kadeem F TollnerFranceIoni Bowcher QUALIFIED
Tony Q VenereGermanyAsiya Javayant PROPOSAL
Jones G OstroskyCanadaXuxue Feng QUALIFIED
Octavia O PerinRussiaStephen Shaw QUALIFIED
Julie R MacleadUnited KingdomBernardo Dominic RENEWAL
Tony B GauchoGermanyOnyama Limba NEW
Cody P CaldareraJapanXuxue Feng NEW
Misaki H SchemmerRussiaIoni Bowcher NEW
Aditya W PaprockiSpainXuxue Feng NEW
Juan E BologniaIndiaAmy Elsner NEW
Johnson I WieserCanadaAnna Fali PROPOSAL
Misaki A GillianJapanAnna Fali NEGOTIATION
Juan C GlickCanadaBernardo Dominic QUALIFIED
Salvatore C ButtUnited KingdomIvan Magalhaes PROPOSAL
Tony U SlusarskiSpainAsiya Javayant UNQUALIFIED
Aditya Q CampainAustraliaBernardo Dominic UNQUALIFIED
Mayumi Z TollnerAustraliaAnna Fali UNQUALIFIED
Leon L SaylorsJapanElwin Sharvill NEW
Munro O DarakjyUnited KingdomAnna Fali QUALIFIED
Silvio C ChuiRussiaAnna Fali RENEWAL
Jennifer V BriddickAustraliaAmy Elsner NEW
Ricardo R GlickBrazilAmy Elsner UNQUALIFIED
Claire N SlusarskiFranceBernardo Dominic NEW
Adams D ButtCanadaAnna Fali NEGOTIATION
Isabel T BologniaJapanBernardo Dominic UNQUALIFIED
Faith U RimAustraliaBernardo Dominic NEGOTIATION
Claire U ShinkoSpainOnyama Limba UNQUALIFIED
Wickens A MorascaBrazilAsiya Javayant QUALIFIED
Kaitlin O ButtAustraliaOnyama Limba QUALIFIED
Cody H ShinkoGermanyIoni Bowcher QUALIFIED
Maisha G ButtJapanAmy Elsner RENEWAL
Aika T MacleadIndiaIoni Bowcher UNQUALIFIED
Cody Q CampainFranceIvan Magalhaes NEW
Octavia U DoeFranceIvan Magalhaes QUALIFIED
Kaitlin N FlosiJapanXuxue Feng RENEWAL
Leja I OldroydIndiaXuxue Feng 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>