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
Nicolas F MarrierJapanAsiya Javayant PROPOSAL
Deepesh Q RoysterCanadaStephen Shaw QUALIFIED
Jeanfrancois Z RoysterGermanyElwin Sharvill UNQUALIFIED
Ricardo N FollerRussiaIoni Bowcher NEGOTIATION
Silvio V KolmetzArgentinaIoni Bowcher NEGOTIATION
Deepesh Q OstroskyRussiaIoni Bowcher NEW
Silvio V RulapaughIndiaElwin Sharvill NEGOTIATION
Jeanfrancois A RulapaughAustraliaElwin Sharvill NEGOTIATION
Faith H KolmetzRussiaIoni Bowcher UNQUALIFIED
Deepesh R SlusarskiGermanyXuxue Feng UNQUALIFIED
Francesco X TollnerCanadaBernardo Dominic NEGOTIATION
Salvatore R TollnerItalyIvan Magalhaes NEGOTIATION
Faith P RulapaughGermanyIvan Magalhaes RENEWAL
Antonio P DilliardGermanyIoni Bowcher NEW
Silvio E ChuiFranceAsiya Javayant NEGOTIATION
Julie T CaudyAustraliaAnna Fali RENEWAL
Sinclair D InouyeRussiaAmy Elsner RENEWAL
Stacey O DarakjyBrazilStephen Shaw QUALIFIED
Johnson G WhobreyFranceOnyama Limba QUALIFIED
Clifford Q PaprockiRussiaOnyama Limba UNQUALIFIED
Ashley F CampainFranceOnyama Limba QUALIFIED
Sinclair U MorascaJapanStephen Shaw NEW
Johnson R RulapaughUnited KingdomIvan Magalhaes PROPOSAL
Kaitlin Z InouyeFranceElwin Sharvill PROPOSAL
Greenwood C PerinAustraliaOnyama Limba NEGOTIATION
Antonio J PoquetteCanadaAnna Fali NEGOTIATION
Darci T IturbideFranceAnna Fali UNQUALIFIED
Leon B FlosiItalyIvan Magalhaes NEW
Juan K IturbideItalyElwin Sharvill PROPOSAL
Leja X DarakjyItalyAmy Elsner UNQUALIFIED
Costa H CaudyRussiaAsiya Javayant RENEWAL
Ricardo A FerenczUnited KingdomAsiya Javayant QUALIFIED
Nicolas K StockhamSpainIvan Magalhaes NEW
Murillo G VenereFranceIoni Bowcher PROPOSAL
Isabel C DoeGermanyStephen Shaw UNQUALIFIED
Costa S CaldareraUnited KingdomBernardo Dominic QUALIFIED
Salvatore V StockhamIndiaStephen Shaw QUALIFIED
Clifford D WieserBrazilAmy Elsner UNQUALIFIED
Francesco N MorascaJapanAmy Elsner NEW
Murillo E OldroydAustraliaAmy Elsner UNQUALIFIED
Costa M DoeFranceIvan Magalhaes NEGOTIATION
Arvin I GarufiUnited KingdomAsiya Javayant RENEWAL
Claire Y RutaFranceOnyama Limba QUALIFIED
James N BowleyUnited KingdomElwin Sharvill RENEWAL
Antonio W WhobreyCanadaOnyama Limba QUALIFIED
Costa D WaycottItalyStephen Shaw NEW
Silvio W MaletGermanyIvan Magalhaes QUALIFIED
Ivar C DilliardGermanyAmy Elsner RENEWAL
Emily A PerinCanadaAsiya Javayant PROPOSAL
Jefferson J BriddickUnited KingdomElwin Sharvill PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Stacey G NickaAustraliaStephen Shaw NEW
Isabel Z DarakjyGermanyIoni Bowcher PROPOSAL
Isabel I AmigonGermanyAmy Elsner RENEWAL
Kadeem A RoysterCanadaIoni Bowcher RENEWAL
David K StockhamUnited KingdomElwin Sharvill PROPOSAL
Darci F FerenczAustraliaAsiya Javayant NEGOTIATION
Isabel M GlickIndiaBernardo Dominic NEW
Mujtaba P SlusarskiSpainOnyama Limba PROPOSAL
Izzy V BriddickGermanyElwin Sharvill NEW
Costa H VenereIndiaStephen Shaw QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Cody Z RoysterBrazil2024-06-05Feltz Printing Service PROPOSAL60Ioni Bowcher
1001Mujtaba L SchemmerBrazil2024-06-03Chapman, Ross E Esq UNQUALIFIED30Ivan Magalhaes
1002Arvin K MorascaSpain2024-06-01Morlong Associates RENEWAL27Bernardo Dominic
1003Mujtaba P VenereUnited Kingdom2024-05-30King, Christopher A Esq QUALIFIED24Elwin Sharvill
1004Jones C RutaCanada2024-06-10Feiner Bros PROPOSAL16Ioni Bowcher
1005Munro B FigeroaCanada2024-06-18Truhlar And Truhlar Attys RENEWAL17Asiya Javayant
1006Mujtaba U IturbideSpain2024-06-16Rangoni Of Florence RENEWAL50Stephen Shaw
1007Kadeem F BologniaIndia2024-06-12Benton, John B Jr RENEWAL30Ioni Bowcher
1008Faith C FollerAustralia2024-06-20Feltz Printing Service NEW85Ivan Magalhaes
1009Antonio Z KuskoFrance2024-06-01Chapman, Ross E Esq UNQUALIFIED80Bernardo Dominic
1010Munro B SchemmerArgentina2024-06-18Benton, John B Jr UNQUALIFIED92Asiya Javayant
1011Misaki C NickaAustralia2024-06-14King, Christopher A Esq PROPOSAL0Asiya Javayant
1012Ricardo G RulapaughArgentina2024-06-21Rangoni Of Florence RENEWAL89Ioni Bowcher
1013Salvatore F NestleCanada2024-06-12Buckley Miller Wright NEGOTIATION68Ioni Bowcher
1014Julie R StockhamUnited Kingdom2024-05-30Morlong Associates QUALIFIED89Anna Fali
1015Aruna M AmigonIndia2024-05-23Rangoni Of Florence QUALIFIED16Amy Elsner
1016Greenwood M NickaItaly2024-06-21Chapman, Ross E Esq NEGOTIATION5Xuxue Feng
1017Wickens Y StensethGermany2024-06-01Benton, John B Jr NEW25Elwin Sharvill
1018Rodrigues Z DoeJapan2024-06-14Benton, John B Jr NEGOTIATION81Amy Elsner
1019Jefferson S RimJapan2024-05-27King, Christopher A Esq UNQUALIFIED18Ivan Magalhaes
1020Johnson R SaylorsRussia2024-05-24Feiner Bros NEGOTIATION29Onyama Limba
1021Octavia F BriddickJapan2024-06-11King, Christopher A Esq PROPOSAL57Ioni Bowcher
1022Aruna W BologniaSpain2024-06-11Chanay, Jeffrey A Esq UNQUALIFIED18Ioni Bowcher
1023Maria N IturbideItaly2024-05-24Printing Dimensions NEW76Onyama Limba
1024Kaitlin Z FollerFrance2024-06-04Rangoni Of Florence RENEWAL71Bernardo Dominic
1025David F CaudyItaly2024-06-10Buckley Miller Wright PROPOSAL60Elwin Sharvill
1026Jefferson S BowleyGermany2024-05-27Chapman, Ross E Esq PROPOSAL71Asiya Javayant
1027Izzy V GarufiCanada2024-06-02Commercial Press NEGOTIATION5Anna Fali
1028Kaitlin E GlickGermany2024-06-14Rangoni Of Florence PROPOSAL38Asiya Javayant
1029Salvatore C GillianUnited Kingdom2024-06-01Printing Dimensions NEGOTIATION23Anna Fali
1030Aruna J GauchoGermany2024-06-13Buckley Miller Wright NEGOTIATION98Xuxue Feng
1031Munro I RimArgentina2024-06-10Buckley Miller Wright RENEWAL3Ioni Bowcher
1032Kadeem W NestleItaly2024-06-06Feltz Printing Service UNQUALIFIED77Onyama Limba
1033Ricardo K PoquetteFrance2024-06-06Morlong Associates NEW15Onyama Limba
1034Greenwood N SergiFrance2024-06-08Chemel, James L Cpa UNQUALIFIED23Amy Elsner
1035Deepesh N NickaGermany2024-06-18Feiner Bros NEW15Stephen Shaw
1036James X PaprockiJapan2024-05-31Chanay, Jeffrey A Esq UNQUALIFIED8Stephen Shaw
1037Emily C WieserRussia2024-06-18Chapman, Ross E Esq QUALIFIED94Asiya Javayant
1038Adams I KuskoAustralia2024-06-16Feltz Printing Service NEGOTIATION56Stephen Shaw
1039Ivar P InouyeGermany2024-05-31Rousseaux, Michael Esq NEW39Elwin Sharvill
1040David I FollerArgentina2024-06-10Chanay, Jeffrey A Esq QUALIFIED62Asiya Javayant
1041Jefferson W KuskoArgentina2024-06-21Truhlar And Truhlar Attys NEGOTIATION79Amy Elsner
1042Arvin R DilliardIndia2024-06-06Printing Dimensions NEGOTIATION63Asiya Javayant
1043Antonio F MarrierCanada2024-06-10Morlong Associates UNQUALIFIED66Onyama Limba
1044Munro S IturbideFrance2024-05-30King, Christopher A Esq QUALIFIED55Stephen Shaw
1045Deepesh H KolmetzGermany2024-05-26Rousseaux, Michael Esq RENEWAL92Bernardo Dominic
1046Ivar M IturbideRussia2024-05-31Feiner Bros NEW56Amy Elsner
1047Nicolas G InouyeFrance2024-06-08Rousseaux, Michael Esq NEW41Asiya Javayant
1048Aika V VocelkaGermany2024-06-04Printing Dimensions NEGOTIATION90Stephen Shaw
1049Greenwood Y RoysterRussia2024-06-21Rangoni Of Florence NEW77Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Emily J FerenczCanadaStephen Shaw UNQUALIFIED
Kadeem E RutaUnited KingdomBernardo Dominic RENEWAL
Mujtaba M RulapaughSpainAmy Elsner QUALIFIED
Maria P GillianSpainIvan Magalhaes UNQUALIFIED
Aruna I PoquetteCanadaIvan Magalhaes RENEWAL
Silvio B FerenczFranceBernardo Dominic RENEWAL
Clifford Y PaprockiRussiaAmy Elsner PROPOSAL
Jefferson V DarakjyJapanIvan Magalhaes RENEWAL
David C ChuiCanadaOnyama Limba RENEWAL
Aika U RoysterGermanyAnna Fali NEW
Smith N PaprockiAustraliaBernardo Dominic RENEWAL
Octavia Q ButtBrazilIoni Bowcher NEGOTIATION
Tony X GlickSpainXuxue Feng PROPOSAL
Jefferson P SaylorsItalyBernardo Dominic NEGOTIATION
Claire S DoeUnited KingdomAmy Elsner UNQUALIFIED
Ashley U RoysterJapanAnna Fali QUALIFIED
Faith Q InouyeBrazilOnyama Limba UNQUALIFIED
Greenwood Y SchemmerGermanyIoni Bowcher NEW
Stacey T SchemmerSpainIvan Magalhaes UNQUALIFIED
Jefferson T OstroskyGermanyAmy Elsner QUALIFIED
Mayumi V FlosiAustraliaAmy Elsner UNQUALIFIED
James B DilliardSpainXuxue Feng UNQUALIFIED
Alejandro F AmigonArgentinaAnna Fali NEW
Leja R ShinkoJapanIoni Bowcher RENEWAL
Murillo T AmigonArgentinaIoni Bowcher RENEWAL
Costa E ShinkoGermanyXuxue Feng PROPOSAL
Mujtaba S PaprockiGermanyAsiya Javayant UNQUALIFIED
James S FlosiJapanElwin Sharvill NEGOTIATION
Tony F GauchoArgentinaBernardo Dominic NEW
Aditya O RoysterIndiaIvan Magalhaes NEGOTIATION
Jones W MorascaCanadaStephen Shaw NEGOTIATION
Jeanfrancois P RimCanadaAsiya Javayant RENEWAL
Kadeem W FollerFranceAnna Fali QUALIFIED
Jones P ShinkoUnited KingdomIvan Magalhaes UNQUALIFIED
Aruna I BowleySpainIvan Magalhaes NEW
David G StensethSpainIoni Bowcher QUALIFIED
Wickens Y NickaJapanStephen Shaw RENEWAL
Antonio P SergiJapanElwin Sharvill NEW
Aditya I WhobreyAustraliaIvan Magalhaes QUALIFIED
Johnson B TollnerGermanyStephen Shaw UNQUALIFIED
Alejandro Z WieserArgentinaElwin Sharvill QUALIFIED
Ricardo M SchemmerArgentinaIoni Bowcher RENEWAL
Mujtaba B StensethItalyElwin Sharvill UNQUALIFIED
Johnson I FollerRussiaOnyama Limba QUALIFIED
Jeanfrancois U TollnerGermanyIvan Magalhaes PROPOSAL
Ashley Q ButtSpainAnna Fali NEGOTIATION
Claire I WaycottCanadaAmy Elsner RENEWAL
Emily K StockhamUnited KingdomBernardo Dominic PROPOSAL
Greenwood Y VenereIndiaAmy Elsner NEGOTIATION
Murillo B StockhamJapanAsiya Javayant QUALIFIED
Frozen Columns
Name
Smith P Gillian
Aditya G Foller
Salvatore D Malet
Ivar F Inouye
Kadeem M Whobrey
Alejandro S Dilliard
Nicolas E Ostrosky
Maisha R Malet
Misaki D Sergi
Juan J Darakjy
James J Dilliard
Kadeem B Chui
Darci P Rulapaugh
Jones S Foller
Smith P Nestle
Stacey N Slusarski
Ivar K Malet
Leja U Tollner
James Q Waycott
Jennifer L Poquette
Aika J Doe
Salvatore K Marrier
Ivar Y Figeroa
Aika R Slusarski
Johnson V Ruta
Alejandro I Malet
Darci Z Paprocki
Izzy N Sergi
Emily V Chui
Cody K Sergi
Arvin G Doe
Smith L Foller
Arvin N Ferencz
Mayumi Z Tollner
Murillo B Nicka
Sinclair N Wieser
Izzy Y Foller
Octavia Y Amigon
Claire J Ferencz
Kaitlin W Nicka
Octavia N Waycott
Smith B Oldroyd
Wickens L Stenseth
Adams N Briddick
David X Kolmetz
Mayumi Q Ruta
Arvin X Butt
Izzy E Vocelka
Greenwood J Tollner
Jones T Saylors
IdCountryDate
1000Spain2024-06-20
1001Russia2024-06-17
1002Italy2024-06-17
1003United Kingdom2024-05-31
1004France2024-06-12
1005India2024-06-14
1006Canada2024-06-06
1007Brazil2024-06-09
1008United Kingdom2024-05-24
1009Japan2024-06-06
1010France2024-06-18
1011Italy2024-06-17
1012United Kingdom2024-06-16
1013United Kingdom2024-06-07
1014Brazil2024-06-21
1015Russia2024-05-24
1016United Kingdom2024-05-31
1017Argentina2024-06-04
1018Japan2024-06-13
1019India2024-06-16
1020Italy2024-05-30
1021Canada2024-06-04
1022Australia2024-05-25
1023Argentina2024-06-11
1024Italy2024-06-12
1025Japan2024-05-31
1026Argentina2024-06-20
1027France2024-05-27
1028Brazil2024-06-11
1029Spain2024-06-04
1030Canada2024-05-31
1031Canada2024-06-03
1032Brazil2024-06-21
1033Japan2024-06-11
1034United Kingdom2024-05-28
1035Italy2024-06-04
1036Russia2024-06-08
1037Canada2024-06-20
1038Germany2024-06-17
1039Germany2024-06-17
1040Brazil2024-06-03
1041Argentina2024-05-27
1042Japan2024-06-17
1043Australia2024-06-20
1044Japan2024-06-18
1045Germany2024-05-27
1046United Kingdom2024-06-06
1047Australia2024-06-05
1048Canada2024-06-19
1049Germany2024-05-31

On-Demand Data

NameIdCountryDate
Alejandro F Sergi1000Australia2024-05-28
Greenwood S Perin1001Canada2024-06-07
Jeanfrancois G Campain1002Canada2024-06-05
Munro C Rulapaugh1003Argentina2024-05-30
Maria E Oldroyd1004Japan2024-06-20
Silvio Y Bowley1005Russia2024-06-19
Alejandro U Bowley1006Brazil2024-06-03
Jennifer Q Wieser1007Germany2024-06-15
Aditya Q Flosi1008Japan2024-05-30
Juan F Campain1009Australia2024-06-20
Aditya Z Malet1010France2024-05-26
Ricardo N Foller1011Australia2024-06-09
Mayumi O Caldarera1012Canada2024-06-03
Smith A Caudy1013Germany2024-06-17
Misaki P Schemmer1014Australia2024-05-26
Julie I Paprocki1015India2024-06-17
Sinclair A Chui1016India2024-06-07
Maisha V Shinko1017France2024-06-19
Jeanfrancois W Bolognia1018Spain2024-05-23
Costa M Sergi1019Spain2024-06-17
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Juan Q RutaFranceAnna Fali PROPOSAL
Rodrigues M DoeItalyAsiya Javayant UNQUALIFIED
Aika H ButtBrazilStephen Shaw RENEWAL
Greenwood L MarrierFranceAsiya Javayant RENEWAL
Arvin W ShinkoJapanAmy Elsner PROPOSAL
Greenwood W PaprockiFranceAnna Fali NEGOTIATION
Deepesh X ButtJapanAmy Elsner RENEWAL
Greenwood T RimAustraliaOnyama Limba RENEWAL
Johnson O StockhamAustraliaOnyama Limba UNQUALIFIED
Sinclair F MaletSpainXuxue Feng QUALIFIED
Ricardo I PaprockiAustraliaOnyama Limba UNQUALIFIED
Smith S PerinAustraliaAsiya Javayant NEW
Silvio E SergiAustraliaXuxue Feng RENEWAL
Aika G WieserItalyBernardo Dominic QUALIFIED
Morrow H NickaIndiaOnyama Limba PROPOSAL
Izzy F MorascaFranceIvan Magalhaes NEGOTIATION
Wickens T SergiItalyIoni Bowcher NEW
Arvin T NestleRussiaIoni Bowcher NEGOTIATION
Darci I WaycottGermanyXuxue Feng NEGOTIATION
Clifford S WhobreyJapanXuxue Feng QUALIFIED
Darci H GarufiCanadaOnyama Limba QUALIFIED
Stacey X WhobreyIndiaXuxue Feng NEW
Antonio C RimAustraliaOnyama Limba UNQUALIFIED
Claire K GarufiSpainAnna Fali RENEWAL
Cody D VenereArgentinaXuxue Feng UNQUALIFIED
Nicolas Q KuskoAustraliaIvan Magalhaes PROPOSAL
Arvin W VocelkaUnited KingdomOnyama Limba UNQUALIFIED
Jefferson C BologniaArgentinaAmy Elsner NEGOTIATION
Salvatore H PaprockiRussiaAmy Elsner NEGOTIATION
Antonio A FlosiArgentinaAsiya Javayant PROPOSAL
Leja E CampainIndiaAsiya Javayant NEGOTIATION
Munro G MarrierSpainIvan Magalhaes QUALIFIED
Mayumi P ButtIndiaAnna Fali RENEWAL
Cody W SergiUnited KingdomAsiya Javayant NEW
Misaki D KolmetzItalyXuxue Feng PROPOSAL
Jeanfrancois P FlosiIndiaAnna Fali NEGOTIATION
Mayumi E RimIndiaIoni Bowcher NEW
Stacey K MacleadRussiaAnna Fali QUALIFIED
Aditya Z ChuiUnited KingdomAsiya Javayant QUALIFIED
Chavez I SchemmerJapanAsiya Javayant 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>