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
Costa H FollerFranceElwin Sharvill RENEWAL
Clifford M ChuiRussiaAsiya Javayant RENEWAL
Smith D PaprockiItalyAnna Fali RENEWAL
Murillo C AlbaresSpainIvan Magalhaes RENEWAL
Salvatore Q DilliardAustraliaIvan Magalhaes NEGOTIATION
Clifford H RulapaughCanadaAnna Fali PROPOSAL
Jennifer M PerinSpainXuxue Feng RENEWAL
Adams Q BriddickIndiaBernardo Dominic QUALIFIED
Rodrigues I RutaRussiaIoni Bowcher UNQUALIFIED
Alejandro T WieserItalyIoni Bowcher PROPOSAL
Jefferson T CaldareraCanadaAsiya Javayant UNQUALIFIED
Greenwood Q RutaRussiaIvan Magalhaes NEW
Misaki L FerenczJapanBernardo Dominic QUALIFIED
Maria D InouyeCanadaStephen Shaw NEGOTIATION
Alejandro Y WieserFranceIvan Magalhaes NEGOTIATION
Misaki E OstroskyBrazilIoni Bowcher RENEWAL
Kadeem W GauchoIndiaIoni Bowcher NEW
Mayumi H RoysterRussiaElwin Sharvill NEGOTIATION
James U RutaCanadaBernardo Dominic QUALIFIED
Mujtaba P OstroskyRussiaAmy Elsner PROPOSAL
Leon O BowleyCanadaBernardo Dominic NEW
James O VocelkaItalyElwin Sharvill QUALIFIED
Nicolas S NestleAustraliaAnna Fali NEGOTIATION
Chavez B FerenczGermanyIvan Magalhaes QUALIFIED
Jefferson Y FigeroaArgentinaAnna Fali QUALIFIED
Mujtaba E VocelkaUnited KingdomStephen Shaw NEGOTIATION
Emily Y MarrierItalyAsiya Javayant PROPOSAL
Wickens B StockhamIndiaIvan Magalhaes PROPOSAL
Wickens R NickaCanadaAnna Fali NEGOTIATION
Ivar C PerinJapanAmy Elsner NEW
Francesco U MacleadUnited KingdomAmy Elsner UNQUALIFIED
Ricardo G IturbideIndiaStephen Shaw RENEWAL
Aika S SlusarskiCanadaXuxue Feng UNQUALIFIED
Smith D WhobreyCanadaAmy Elsner NEW
Greenwood U FollerArgentinaAmy Elsner NEW
Kaitlin F VocelkaIndiaOnyama Limba RENEWAL
Kaitlin E MacleadUnited KingdomAsiya Javayant QUALIFIED
Leja G VenereJapanStephen Shaw QUALIFIED
Mujtaba C CaldareraJapanOnyama Limba NEGOTIATION
Chavez W FigeroaJapanBernardo Dominic QUALIFIED
Francesco S InouyeArgentinaIoni Bowcher QUALIFIED
Darci J KolmetzUnited KingdomOnyama Limba RENEWAL
Morrow L PaprockiAustraliaAmy Elsner NEW
Emily M GillianItalyAsiya Javayant RENEWAL
Kadeem X InouyeItalyAnna Fali NEW
Tony V VenereCanadaIoni Bowcher NEGOTIATION
Juan I MaletGermanyElwin Sharvill NEGOTIATION
Misaki F GlickItalyAnna Fali NEGOTIATION
Stacey C NestleBrazilIoni Bowcher PROPOSAL
Smith N InouyeUnited KingdomAnna Fali NEW
Horizontal
NameCountryRepresentativeStatus
Francesco H DarakjyIndiaAnna Fali QUALIFIED
Silvio A FerenczIndiaOnyama Limba PROPOSAL
Arvin P KolmetzSpainElwin Sharvill UNQUALIFIED
James L SlusarskiGermanyAmy Elsner NEW
Greenwood R MaletIndiaAnna Fali UNQUALIFIED
Jennifer C IturbideFranceElwin Sharvill RENEWAL
Murillo X VocelkaFranceAsiya Javayant RENEWAL
Julie Q MacleadArgentinaAmy Elsner NEGOTIATION
Jefferson E GarufiAustraliaXuxue Feng PROPOSAL
Cody G FollerSpainOnyama Limba RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Chavez S MaletArgentina2025-04-14Chemel, James L Cpa QUALIFIED46Ivan Magalhaes
1001Jennifer D DilliardRussia2025-04-06Truhlar And Truhlar Attys UNQUALIFIED3Onyama Limba
1002Leon U PoquetteAustralia2025-04-13Rangoni Of Florence QUALIFIED86Anna Fali
1003Kaitlin M NestleGermany2025-04-13Rangoni Of Florence PROPOSAL81Ioni Bowcher
1004Silvio T NestleJapan2025-04-02Chemel, James L Cpa RENEWAL72Xuxue Feng
1005Aruna W RutaFrance2025-04-11Truhlar And Truhlar Attys RENEWAL77Onyama Limba
1006Misaki J FerenczCanada2025-04-17Feiner Bros NEW31Bernardo Dominic
1007Emily K KuskoSpain2025-04-06Truhlar And Truhlar Attys RENEWAL12Elwin Sharvill
1008Johnson D OstroskyGermany2025-04-15Commercial Press UNQUALIFIED72Stephen Shaw
1009Ashley U MarrierGermany2025-04-22Chapman, Ross E Esq NEW24Onyama Limba
1010Leja U PaprockiItaly2025-04-24Printing Dimensions NEW34Asiya Javayant
1011Jones C RulapaughItaly2025-04-26Commercial Press NEW47Amy Elsner
1012Rodrigues X SlusarskiRussia2025-04-30Chapman, Ross E Esq RENEWAL85Onyama Limba
1013Leon R BriddickAustralia2025-04-22Chemel, James L Cpa PROPOSAL51Stephen Shaw
1014Salvatore X SaylorsArgentina2025-04-05King, Christopher A Esq NEW60Elwin Sharvill
1015Antonio F MaletIndia2025-04-24Buckley Miller Wright NEW8Stephen Shaw
1016Aika G NickaArgentina2025-04-27Benton, John B Jr UNQUALIFIED72Bernardo Dominic
1017Munro C OldroydRussia2025-04-15Benton, John B Jr QUALIFIED76Ivan Magalhaes
1018Julie M GarufiUnited Kingdom2025-04-16Truhlar And Truhlar Attys RENEWAL52Bernardo Dominic
1019Faith R WaycottRussia2025-04-20Dorl, James J Esq QUALIFIED74Asiya Javayant
1020Izzy O GillianJapan2025-04-10Feiner Bros RENEWAL90Anna Fali
1021Mayumi L PoquetteIndia2025-04-12Rousseaux, Michael Esq NEW67Amy Elsner
1022Smith A OstroskyGermany2025-04-19Benton, John B Jr NEW16Anna Fali
1023Kaitlin B ShinkoIndia2025-04-12Chanay, Jeffrey A Esq RENEWAL66Amy Elsner
1024Faith B SaylorsSpain2025-04-07Printing Dimensions UNQUALIFIED76Asiya Javayant
1025Mujtaba Z NickaRussia2025-04-03Chapman, Ross E Esq UNQUALIFIED97Onyama Limba
1026Morrow G RulapaughCanada2025-04-28Printing Dimensions PROPOSAL62Bernardo Dominic
1027Aruna K DoeRussia2025-04-15Feltz Printing Service RENEWAL69Anna Fali
1028Izzy I RoysterRussia2025-04-26Chemel, James L Cpa PROPOSAL87Stephen Shaw
1029Julie N TollnerItaly2025-04-24Truhlar And Truhlar Attys UNQUALIFIED80Ioni Bowcher
1030Faith T MorascaJapan2025-04-03Commercial Press NEGOTIATION15Onyama Limba
1031Francesco A ShinkoArgentina2025-04-01Rangoni Of Florence PROPOSAL70Bernardo Dominic
1032Salvatore W OstroskyIndia2025-04-13Chanay, Jeffrey A Esq RENEWAL7Stephen Shaw
1033Maisha F TollnerBrazil2025-04-16Commercial Press PROPOSAL30Asiya Javayant
1034Faith K ButtUnited Kingdom2025-04-24Benton, John B Jr RENEWAL91Asiya Javayant
1035Deepesh D StensethRussia2025-04-28King, Christopher A Esq NEGOTIATION73Stephen Shaw
1036Ricardo Y WieserSpain2025-04-27Benton, John B Jr NEW0Elwin Sharvill
1037Francesco K RimFrance2025-04-15Benton, John B Jr UNQUALIFIED90Asiya Javayant
1038Salvatore N SlusarskiCanada2025-04-18Chemel, James L Cpa QUALIFIED36Onyama Limba
1039Mujtaba D PaprockiBrazil2025-04-21Chanay, Jeffrey A Esq NEW87Anna Fali
1040David O TollnerUnited Kingdom2025-04-22Rangoni Of Florence NEGOTIATION2Xuxue Feng
1041Maisha A CaudyItaly2025-04-11Truhlar And Truhlar Attys UNQUALIFIED46Ivan Magalhaes
1042Nicolas W BriddickAustralia2025-04-16Commercial Press NEGOTIATION19Asiya Javayant
1043Kaitlin S StockhamAustralia2025-04-09Rangoni Of Florence NEGOTIATION9Bernardo Dominic
1044Nicolas T ButtItaly2025-04-24Buckley Miller Wright UNQUALIFIED35Xuxue Feng
1045Deepesh O CampainIndia2025-04-26Feiner Bros NEW35Bernardo Dominic
1046Jefferson C AlbaresAustralia2025-04-15Printing Dimensions UNQUALIFIED67Asiya Javayant
1047Munro U WieserGermany2025-04-09King, Christopher A Esq PROPOSAL87Asiya Javayant
1048Greenwood Z GarufiBrazil2025-04-29Feiner Bros NEGOTIATION11Ivan Magalhaes
1049Murillo A MorascaJapan2025-04-19Truhlar And Truhlar Attys NEGOTIATION14Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Adams G ShinkoSpainStephen Shaw UNQUALIFIED
Darci Z RutaAustraliaBernardo Dominic RENEWAL
Deepesh B WieserArgentinaIvan Magalhaes QUALIFIED
Aruna J PoquetteSpainAmy Elsner UNQUALIFIED
David J GarufiArgentinaElwin Sharvill RENEWAL
Juan H SaylorsUnited KingdomStephen Shaw RENEWAL
David H PaprockiItalyStephen Shaw UNQUALIFIED
Salvatore L MorascaItalyIvan Magalhaes UNQUALIFIED
Maisha J MaletIndiaAsiya Javayant QUALIFIED
Ivar F AmigonFranceAsiya Javayant NEW
Chavez R CaldareraRussiaAmy Elsner NEGOTIATION
Kaitlin Y FlosiRussiaBernardo Dominic QUALIFIED
Jones N MarrierCanadaOnyama Limba QUALIFIED
Murillo O WaycottRussiaAnna Fali QUALIFIED
James V NestleIndiaAmy Elsner RENEWAL
Jones E KolmetzItalyAsiya Javayant UNQUALIFIED
Isabel H FigeroaRussiaAnna Fali QUALIFIED
Darci R WaycottFranceElwin Sharvill UNQUALIFIED
Aditya T WaycottFranceXuxue Feng UNQUALIFIED
Deepesh V FlosiSpainBernardo Dominic NEW
Leon O CaldareraIndiaIvan Magalhaes RENEWAL
Mayumi P FollerGermanyElwin Sharvill UNQUALIFIED
Tony V BriddickBrazilStephen Shaw UNQUALIFIED
Emily S ChuiUnited KingdomIoni Bowcher PROPOSAL
Arvin M SlusarskiCanadaIoni Bowcher NEGOTIATION
Tony D ButtUnited KingdomElwin Sharvill NEW
Faith H NestleIndiaElwin Sharvill RENEWAL
Tony V CampainIndiaIoni Bowcher NEGOTIATION
Aika Z TollnerCanadaOnyama Limba NEGOTIATION
Misaki M CampainBrazilXuxue Feng NEW
Greenwood Q CampainGermanyBernardo Dominic UNQUALIFIED
Misaki K InouyeJapanStephen Shaw NEW
Kadeem A RimRussiaAsiya Javayant NEW
Tony V NickaJapanBernardo Dominic NEGOTIATION
Smith U GlickAustraliaAsiya Javayant RENEWAL
Jeanfrancois E GarufiUnited KingdomBernardo Dominic QUALIFIED
Adams B SergiJapanIvan Magalhaes PROPOSAL
Deepesh T PerinFranceAsiya Javayant PROPOSAL
Jefferson N RulapaughJapanIoni Bowcher PROPOSAL
Greenwood Y SaylorsRussiaXuxue Feng QUALIFIED
Darci P DarakjyRussiaOnyama Limba NEGOTIATION
Jeanfrancois D NickaBrazilIoni Bowcher QUALIFIED
Murillo V MaletArgentinaAsiya Javayant RENEWAL
Juan K SaylorsUnited KingdomIoni Bowcher QUALIFIED
Julie X PaprockiBrazilElwin Sharvill NEGOTIATION
Clifford T ChuiFranceAnna Fali NEW
Murillo A TollnerUnited KingdomIvan Magalhaes NEW
Maisha D AlbaresGermanyElwin Sharvill RENEWAL
Isabel I InouyeArgentinaElwin Sharvill QUALIFIED
Alejandro I StockhamArgentinaIvan Magalhaes UNQUALIFIED
Frozen Columns
Name
Isabel A Stenseth
Mayumi L Rulapaugh
Alejandro Y Caudy
Mujtaba D Malet
Jennifer B Iturbide
Aditya P Figeroa
Antonio A Kusko
Smith M Ferencz
Isabel X Stenseth
Rodrigues T Morasca
Claire X Glick
Arvin N Garufi
Jeanfrancois X Inouye
Emily B Gaucho
Leja U Ferencz
Misaki M Royster
Jefferson J Inouye
Claire H Inouye
Nicolas N Glick
Julie Y Perin
Clifford E Shinko
Morrow M Ostrosky
Aruna G Flosi
Maria F Amigon
Johnson J Maclead
Arvin C Inouye
Mayumi S Glick
James P Sergi
Stacey D Briddick
Jefferson E Albares
Mayumi S Albares
Antonio V Glick
Smith R Schemmer
Maria L Iturbide
Francesco P Marrier
Clifford Y Ruta
Jefferson K Nicka
Tony H Gaucho
James U Royster
Ivar O Dilliard
Octavia J Foller
Jones C Venere
Jennifer G Sergi
Kadeem I Gaucho
Deepesh M Ostrosky
Adams C Oldroyd
Kadeem B Briddick
Cody U Nestle
Kaitlin G Slusarski
Izzy K Malet
IdCountryDate
1000Spain2025-04-07
1001Spain2025-04-03
1002Germany2025-04-21
1003Italy2025-04-15
1004Russia2025-04-17
1005United Kingdom2025-04-30
1006Canada2025-04-03
1007Canada2025-04-10
1008India2025-04-03
1009Argentina2025-04-21
1010Brazil2025-04-29
1011Brazil2025-04-20
1012India2025-04-28
1013Italy2025-04-04
1014France2025-04-13
1015Russia2025-04-17
1016Australia2025-04-27
1017France2025-04-21
1018Brazil2025-04-17
1019Australia2025-04-07
1020Brazil2025-04-24
1021Spain2025-04-14
1022Spain2025-04-02
1023Russia2025-04-18
1024India2025-04-24
1025Canada2025-04-17
1026Spain2025-04-01
1027Russia2025-04-26
1028France2025-04-30
1029Russia2025-04-18
1030United Kingdom2025-04-29
1031United Kingdom2025-04-29
1032Brazil2025-04-18
1033France2025-04-07
1034Argentina2025-04-01
1035Japan2025-04-05
1036Spain2025-04-03
1037France2025-04-21
1038Canada2025-04-30
1039Brazil2025-04-14
1040Argentina2025-04-27
1041United Kingdom2025-04-07
1042Japan2025-04-27
1043Japan2025-04-13
1044Brazil2025-04-16
1045United Kingdom2025-04-03
1046France2025-04-07
1047Italy2025-04-10
1048Australia2025-04-18
1049Canada2025-04-03

On-Demand Data

NameIdCountryDate
Jones B Inouye1000Italy2025-04-05
Munro Q Flosi1001Japan2025-04-14
Julie M Flosi1002United Kingdom2025-04-02
Johnson C Perin1003France2025-04-05
Jones J Vocelka1004Germany2025-04-24
Izzy H Stockham1005Australia2025-04-22
Adams R Bowley1006Italy2025-04-16
Francesco O Dilliard1007Germany2025-04-11
Darci C Malet1008France2025-04-02
Johnson H Kusko1009United Kingdom2025-04-19
Maria N Tollner1010Argentina2025-04-18
Greenwood F Royster1011Germany2025-04-20
Jones T Paprocki1012Spain2025-04-06
Jefferson R Schemmer1013Japan2025-04-21
Nicolas L Albares1014Japan2025-04-26
Silvio I Briddick1015France2025-04-13
Ashley Q Darakjy1016Spain2025-04-30
James B Sergi1017India2025-04-19
Sinclair X Iturbide1018Japan2025-04-03
Mujtaba X Stockham1019India2025-04-11
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Claire S BologniaFranceIvan Magalhaes UNQUALIFIED
Leon Y OldroydJapanAsiya Javayant RENEWAL
Jennifer A BowleyArgentinaAnna Fali UNQUALIFIED
Antonio C OldroydIndiaStephen Shaw RENEWAL
Jefferson I VenereUnited KingdomIoni Bowcher RENEWAL
Octavia P PaprockiFranceAnna Fali NEGOTIATION
Ivar Q RimJapanBernardo Dominic UNQUALIFIED
Murillo U IturbideUnited KingdomAnna Fali NEGOTIATION
Jennifer C BriddickArgentinaXuxue Feng NEGOTIATION
Kadeem E RoysterArgentinaOnyama Limba NEW
Mujtaba Z FollerFranceElwin Sharvill NEW
Isabel X MaletJapanIvan Magalhaes RENEWAL
Wickens Z RimAustraliaBernardo Dominic QUALIFIED
Sinclair M WieserSpainIvan Magalhaes QUALIFIED
Aditya A IturbideCanadaAnna Fali RENEWAL
Ashley Y PaprockiRussiaElwin Sharvill RENEWAL
Leon D AmigonSpainIvan Magalhaes QUALIFIED
Munro M CampainUnited KingdomAsiya Javayant NEW
David C OldroydItalyAnna Fali NEW
Kadeem C CampainBrazilIoni Bowcher UNQUALIFIED
Sinclair P FigeroaSpainAmy Elsner QUALIFIED
Kadeem K NestleIndiaIoni Bowcher NEGOTIATION
Juan L MacleadSpainOnyama Limba UNQUALIFIED
Salvatore A ButtBrazilIoni Bowcher QUALIFIED
Murillo W WhobreyFranceIvan Magalhaes QUALIFIED
Antonio Y OldroydCanadaIvan Magalhaes NEW
Munro X RoysterGermanyOnyama Limba PROPOSAL
James V AlbaresSpainElwin Sharvill NEGOTIATION
Juan S NickaSpainAmy Elsner NEW
Mayumi C PerinJapanOnyama Limba NEGOTIATION
Smith B SlusarskiItalyIvan Magalhaes RENEWAL
Murillo T WaycottGermanyAmy Elsner NEW
Emily W VocelkaAustraliaBernardo Dominic RENEWAL
Ashley M ShinkoIndiaAmy Elsner RENEWAL
Jennifer Q VocelkaFranceElwin Sharvill NEW
Maisha Z FlosiArgentinaStephen Shaw RENEWAL
Johnson K TollnerJapanStephen Shaw RENEWAL
Johnson M MacleadBrazilBernardo Dominic PROPOSAL
Murillo M GlickSpainStephen Shaw NEGOTIATION
Julie B PerinRussiaStephen Shaw UNQUALIFIED

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