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
Mujtaba E KolmetzAustraliaStephen Shaw NEW
Izzy N BologniaBrazilOnyama Limba NEGOTIATION
Aditya Q TollnerGermanyAmy Elsner NEGOTIATION
Deepesh L DoeJapanAsiya Javayant RENEWAL
Smith W OstroskyRussiaAmy Elsner PROPOSAL
Darci B CaldareraGermanyBernardo Dominic NEGOTIATION
Chavez P DarakjyGermanyIvan Magalhaes QUALIFIED
Misaki C PerinGermanyStephen Shaw PROPOSAL
Darci I SergiUnited KingdomElwin Sharvill RENEWAL
Maisha M ChuiCanadaOnyama Limba NEGOTIATION
Silvio K PaprockiArgentinaIvan Magalhaes NEW
Isabel R WieserArgentinaOnyama Limba RENEWAL
Antonio C WaycottAustraliaAmy Elsner UNQUALIFIED
Maisha Q GlickRussiaIoni Bowcher PROPOSAL
Adams A RulapaughBrazilAmy Elsner UNQUALIFIED
Cody Z DoeGermanyIvan Magalhaes UNQUALIFIED
Morrow A TollnerGermanyBernardo Dominic QUALIFIED
Adams Z NickaItalyOnyama Limba QUALIFIED
Rodrigues T BologniaGermanyIoni Bowcher NEGOTIATION
Juan G NickaItalyIoni Bowcher QUALIFIED
Wickens Z NestleGermanyIoni Bowcher QUALIFIED
Costa J GarufiUnited KingdomStephen Shaw NEGOTIATION
Francesco R InouyeUnited KingdomOnyama Limba NEW
Darci C SlusarskiItalyAnna Fali QUALIFIED
Arvin Q KuskoRussiaOnyama Limba RENEWAL
Kadeem G MacleadIndiaOnyama Limba RENEWAL
Aruna A MacleadBrazilOnyama Limba UNQUALIFIED
Aditya Y MorascaCanadaAmy Elsner NEW
Sinclair S KuskoBrazilAmy Elsner UNQUALIFIED
Adams J ChuiJapanAsiya Javayant UNQUALIFIED
Nicolas I DoeRussiaOnyama Limba RENEWAL
Silvio F SaylorsUnited KingdomIoni Bowcher NEW
Nicolas T AlbaresBrazilIoni Bowcher NEGOTIATION
Munro L MaletBrazilIvan Magalhaes PROPOSAL
Kadeem M RulapaughUnited KingdomElwin Sharvill UNQUALIFIED
Costa G CampainIndiaAsiya Javayant QUALIFIED
James A GillianItalyOnyama Limba NEGOTIATION
Aruna D RulapaughJapanXuxue Feng NEW
Mayumi V NickaJapanIoni Bowcher NEW
Munro M PerinBrazilOnyama Limba PROPOSAL
Costa C GarufiSpainIoni Bowcher UNQUALIFIED
Jennifer Q RulapaughSpainAmy Elsner PROPOSAL
Sinclair Q ChuiUnited KingdomAsiya Javayant QUALIFIED
David X SaylorsBrazilAsiya Javayant NEW
Kadeem Y RutaUnited KingdomIoni Bowcher QUALIFIED
Arvin L TollnerFranceIvan Magalhaes PROPOSAL
Chavez E WaycottSpainXuxue Feng NEW
Jefferson T GlickAustraliaOnyama Limba UNQUALIFIED
Izzy G RoysterItalyAmy Elsner NEW
Kaitlin W GauchoAustraliaAsiya Javayant RENEWAL
Horizontal
NameCountryRepresentativeStatus
Morrow T SlusarskiAustraliaOnyama Limba NEGOTIATION
Salvatore B BologniaGermanyAsiya Javayant UNQUALIFIED
Nicolas J OldroydBrazilAnna Fali PROPOSAL
Ashley L PerinItalyStephen Shaw NEGOTIATION
Octavia J ShinkoIndiaStephen Shaw UNQUALIFIED
Silvio M StockhamSpainAmy Elsner RENEWAL
Octavia Z MaletIndiaStephen Shaw NEGOTIATION
Stacey J BowleyIndiaBernardo Dominic NEW
Mujtaba J MarrierFranceAnna Fali NEW
Costa A NickaBrazilIvan Magalhaes QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Greenwood B MorascaArgentina2024-06-07Chemel, James L Cpa RENEWAL55Asiya Javayant
1001Ashley O SchemmerFrance2024-06-01King, Christopher A Esq NEGOTIATION51Onyama Limba
1002Alejandro P GauchoItaly2024-06-16King, Christopher A Esq UNQUALIFIED23Onyama Limba
1003Isabel K WieserUnited Kingdom2024-06-13Printing Dimensions NEW56Ivan Magalhaes
1004Julie V PoquetteItaly2024-06-09Chapman, Ross E Esq NEW72Elwin Sharvill
1005Maria E GauchoAustralia2024-06-05Printing Dimensions RENEWAL77Asiya Javayant
1006Francesco O IturbideFrance2024-06-01Feltz Printing Service PROPOSAL37Xuxue Feng
1007Alejandro Q SchemmerGermany2024-06-13Feiner Bros UNQUALIFIED92Elwin Sharvill
1008Clifford N MarrierCanada2024-06-18Chanay, Jeffrey A Esq RENEWAL0Ivan Magalhaes
1009Claire Z IturbideItaly2024-06-19King, Christopher A Esq PROPOSAL71Elwin Sharvill
1010Juan F AlbaresUnited Kingdom2024-05-29Printing Dimensions NEW37Xuxue Feng
1011Leon B WaycottRussia2024-06-03Feltz Printing Service RENEWAL6Anna Fali
1012Jennifer D GlickArgentina2024-06-21Morlong Associates QUALIFIED70Ioni Bowcher
1013Ivar O StensethSpain2024-06-10Chapman, Ross E Esq QUALIFIED60Stephen Shaw
1014Deepesh Y InouyeCanada2024-05-31Buckley Miller Wright NEW27Elwin Sharvill
1015Misaki N WhobreyItaly2024-05-30Chemel, James L Cpa NEW20Onyama Limba
1016Kadeem I RoysterBrazil2024-06-04King, Christopher A Esq NEGOTIATION9Onyama Limba
1017Deepesh Z IturbideSpain2024-05-27Chemel, James L Cpa RENEWAL30Onyama Limba
1018Chavez D GlickGermany2024-06-13Rangoni Of Florence PROPOSAL85Amy Elsner
1019Sinclair M VocelkaItaly2024-06-03Buckley Miller Wright NEGOTIATION27Asiya Javayant
1020Maria S MaletCanada2024-06-16Rangoni Of Florence QUALIFIED21Anna Fali
1021Cody P DarakjyCanada2024-06-22Morlong Associates RENEWAL14Stephen Shaw
1022Mayumi M OstroskyRussia2024-06-24Truhlar And Truhlar Attys NEW68Stephen Shaw
1023Leja W VenereAustralia2024-06-03Feiner Bros NEW89Elwin Sharvill
1024Johnson B GauchoIndia2024-06-23King, Christopher A Esq QUALIFIED16Onyama Limba
1025Smith C NestleArgentina2024-05-29Chanay, Jeffrey A Esq PROPOSAL15Elwin Sharvill
1026Sinclair I AmigonRussia2024-06-05Buckley Miller Wright NEGOTIATION81Xuxue Feng
1027Jeanfrancois F NickaArgentina2024-06-21Chanay, Jeffrey A Esq QUALIFIED99Ioni Bowcher
1028Emily M NestleUnited Kingdom2024-06-16Feltz Printing Service NEW72Ivan Magalhaes
1029Julie Z GauchoAustralia2024-06-22Printing Dimensions UNQUALIFIED85Anna Fali
1030Greenwood E GarufiBrazil2024-06-17Rousseaux, Michael Esq QUALIFIED53Xuxue Feng
1031Emily N AmigonUnited Kingdom2024-06-04Rousseaux, Michael Esq QUALIFIED31Onyama Limba
1032Kaitlin A MaletGermany2024-06-04Rousseaux, Michael Esq NEW65Ivan Magalhaes
1033Wickens G FigeroaRussia2024-06-18Dorl, James J Esq NEW64Xuxue Feng
1034Silvio Y BologniaGermany2024-06-22Feiner Bros RENEWAL90Ivan Magalhaes
1035Smith L KolmetzBrazil2024-06-06Feiner Bros NEW13Amy Elsner
1036Izzy X NickaSpain2024-06-23Truhlar And Truhlar Attys RENEWAL22Ioni Bowcher
1037Johnson K RimIndia2024-06-22Feiner Bros UNQUALIFIED36Asiya Javayant
1038Sinclair G VocelkaFrance2024-06-14Morlong Associates RENEWAL51Amy Elsner
1039Jennifer T ButtUnited Kingdom2024-06-07Dorl, James J Esq NEW73Ivan Magalhaes
1040Maria W SaylorsAustralia2024-06-08Rousseaux, Michael Esq PROPOSAL65Elwin Sharvill
1041Silvio A NestleBrazil2024-06-13Chemel, James L Cpa QUALIFIED24Amy Elsner
1042Octavia V KuskoJapan2024-06-16Truhlar And Truhlar Attys RENEWAL48Onyama Limba
1043Isabel X WhobreyAustralia2024-06-20Benton, John B Jr QUALIFIED26Stephen Shaw
1044David Z MaletUnited Kingdom2024-05-29Feiner Bros UNQUALIFIED16Stephen Shaw
1045Adams D RimIndia2024-06-15Rousseaux, Michael Esq UNQUALIFIED56Asiya Javayant
1046Alejandro I SlusarskiFrance2024-06-04Truhlar And Truhlar Attys PROPOSAL61Amy Elsner
1047James P PoquetteFrance2024-05-30Chemel, James L Cpa UNQUALIFIED79Elwin Sharvill
1048Ashley N OstroskyItaly2024-06-03Dorl, James J Esq PROPOSAL76Stephen Shaw
1049Smith Q KolmetzAustralia2024-06-20Morlong Associates UNQUALIFIED4Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Leja F BologniaSpainAsiya Javayant PROPOSAL
Kadeem E WhobreyRussiaBernardo Dominic NEW
Murillo O DoeArgentinaAnna Fali PROPOSAL
Clifford V MaletBrazilBernardo Dominic QUALIFIED
Arvin L WaycottUnited KingdomStephen Shaw UNQUALIFIED
Greenwood B FollerCanadaXuxue Feng NEW
Alejandro J PerinBrazilXuxue Feng UNQUALIFIED
Adams X GlickGermanyXuxue Feng UNQUALIFIED
Juan V WhobreyUnited KingdomIoni Bowcher UNQUALIFIED
Emily U DilliardFranceBernardo Dominic QUALIFIED
Kaitlin O StensethCanadaIoni Bowcher QUALIFIED
Jefferson H AlbaresRussiaXuxue Feng RENEWAL
Claire A BriddickItalyBernardo Dominic QUALIFIED
David I DarakjyRussiaXuxue Feng PROPOSAL
Stacey O DoeItalyAmy Elsner RENEWAL
Johnson Q PoquetteSpainAnna Fali RENEWAL
Johnson J SaylorsJapanIvan Magalhaes UNQUALIFIED
James K PerinRussiaAnna Fali QUALIFIED
Jeanfrancois B RulapaughUnited KingdomOnyama Limba PROPOSAL
Ivar W WhobreyCanadaIoni Bowcher NEW
Maria V DarakjyGermanyAmy Elsner NEW
Morrow D SaylorsGermanyElwin Sharvill RENEWAL
Mujtaba H PoquetteFranceIoni Bowcher RENEWAL
James W MaletUnited KingdomBernardo Dominic RENEWAL
Murillo G SlusarskiSpainOnyama Limba QUALIFIED
Isabel A IturbideArgentinaXuxue Feng NEGOTIATION
Salvatore O FerenczItalyIoni Bowcher NEGOTIATION
Misaki J WieserSpainAnna Fali QUALIFIED
Jefferson Z BowleyFranceBernardo Dominic NEW
David G FlosiFranceBernardo Dominic NEGOTIATION
Costa L MaletGermanyIoni Bowcher NEW
Arvin G ShinkoFranceIvan Magalhaes PROPOSAL
Jefferson B SergiJapanStephen Shaw NEGOTIATION
Antonio T VocelkaRussiaElwin Sharvill PROPOSAL
Emily P SchemmerGermanyXuxue Feng QUALIFIED
Faith Y TollnerRussiaIvan Magalhaes NEGOTIATION
Munro U InouyeJapanIvan Magalhaes NEW
Isabel F NickaUnited KingdomIoni Bowcher NEGOTIATION
Aruna O FollerRussiaBernardo Dominic RENEWAL
Julie Z MaletUnited KingdomStephen Shaw RENEWAL
Ricardo U CaldareraGermanyBernardo Dominic NEGOTIATION
Faith M CaudyGermanyBernardo Dominic RENEWAL
Ivar M IturbideItalyAsiya Javayant NEW
James T CaudyIndiaIoni Bowcher RENEWAL
Chavez D OstroskySpainElwin Sharvill PROPOSAL
Kadeem M PoquetteJapanElwin Sharvill QUALIFIED
James M RimAustraliaElwin Sharvill UNQUALIFIED
Julie T AmigonArgentinaAnna Fali RENEWAL
Misaki A IturbideRussiaIoni Bowcher RENEWAL
Jones E WhobreyJapanOnyama Limba RENEWAL
Frozen Columns
Name
Ricardo R Tollner
James V Garufi
Chavez A Sergi
Kaitlin V Flosi
Cody W Rulapaugh
Emily T Caudy
Jones E Chui
Silvio X Whobrey
Ricardo W Nicka
Kadeem V Oldroyd
Salvatore U Ostrosky
Greenwood K Sergi
Izzy X Glick
Salvatore T Slusarski
David A Briddick
Faith B Darakjy
Munro C Malet
Jennifer C Kolmetz
Darci Z Slusarski
Jones U Bowley
Salvatore B Maclead
Chavez W Caldarera
Arvin Z Inouye
Morrow M Malet
Izzy P Kusko
Claire J Inouye
Kaitlin W Kolmetz
Salvatore X Kusko
Darci K Caldarera
Antonio S Campain
Leon P Foller
Leon B Royster
Claire B Nestle
Emily M Garufi
Munro P Gaucho
Maisha S Gillian
Ricardo H Nestle
Emily I Chui
Stacey X Bolognia
Munro J Bowley
Jeanfrancois G Butt
Faith X Oldroyd
Ricardo H Amigon
Costa O Waycott
Antonio P Nicka
Isabel M Rulapaugh
Morrow E Inouye
Costa L Ruta
Emily J Saylors
Maisha O Amigon
IdCountryDate
1000Argentina2024-06-04
1001Argentina2024-06-02
1002Spain2024-06-05
1003Japan2024-06-16
1004United Kingdom2024-06-15
1005Germany2024-06-15
1006Italy2024-06-02
1007Brazil2024-06-12
1008France2024-06-17
1009Canada2024-06-06
1010Germany2024-06-07
1011Argentina2024-06-15
1012Spain2024-06-12
1013India2024-06-21
1014India2024-06-19
1015Germany2024-06-13
1016Argentina2024-06-05
1017Germany2024-06-07
1018Italy2024-06-05
1019Argentina2024-06-07
1020Brazil2024-06-14
1021Spain2024-06-15
1022Spain2024-06-23
1023Russia2024-05-30
1024India2024-05-31
1025Argentina2024-06-17
1026United Kingdom2024-05-29
1027Japan2024-06-21
1028Brazil2024-06-13
1029Argentina2024-06-09
1030Italy2024-06-23
1031Canada2024-06-06
1032Argentina2024-06-05
1033Russia2024-06-20
1034France2024-06-06
1035India2024-06-19
1036Russia2024-06-11
1037Italy2024-06-10
1038Japan2024-06-08
1039Spain2024-06-18
1040Germany2024-06-07
1041Germany2024-06-18
1042Germany2024-06-23
1043Japan2024-06-24
1044United Kingdom2024-06-13
1045Russia2024-06-11
1046France2024-06-24
1047United Kingdom2024-06-09
1048Italy2024-06-21
1049Argentina2024-06-12

On-Demand Data

NameIdCountryDate
Nicolas Q Poquette1000France2024-06-22
Kaitlin O Waycott1001Argentina2024-05-26
Jones G Albares1002Brazil2024-06-19
Silvio W Ferencz1003United Kingdom2024-06-19
Tony B Paprocki1004Argentina2024-06-12
Izzy D Marrier1005Japan2024-06-04
Ricardo Q Doe1006Spain2024-05-31
Alejandro T Gillian1007Canada2024-06-08
Tony Q Royster1008Russia2024-06-11
Aruna E Nestle1009Russia2024-06-22
Salvatore K Royster1010Argentina2024-06-22
Faith M Albares1011Brazil2024-06-11
Aruna D Kolmetz1012Germany2024-06-12
Rodrigues E Shinko1013Spain2024-06-17
Ricardo Y Ostrosky1014India2024-06-13
Murillo C Bowley1015Italy2024-06-22
Morrow Y Venere1016India2024-06-17
Aika L Albares1017Germany2024-05-28
Francesco Z Ostrosky1018Canada2024-06-14
Ricardo S Figeroa1019Canada2024-06-15
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Nicolas W DarakjyGermanyOnyama Limba PROPOSAL
Ivar M FerenczIndiaOnyama Limba PROPOSAL
Antonio E PaprockiRussiaAmy Elsner PROPOSAL
Izzy K DarakjyItalyBernardo Dominic QUALIFIED
Izzy S OldroydSpainAsiya Javayant QUALIFIED
Leja Q MaletIndiaXuxue Feng NEGOTIATION
James D InouyeBrazilAsiya Javayant QUALIFIED
Leja N OstroskyIndiaXuxue Feng NEGOTIATION
Jennifer B WieserUnited KingdomStephen Shaw RENEWAL
Nicolas R BowleyIndiaAnna Fali RENEWAL
Kaitlin L FigeroaAustraliaIoni Bowcher PROPOSAL
James D RutaArgentinaElwin Sharvill PROPOSAL
Munro V MacleadSpainAnna Fali QUALIFIED
Adams T FigeroaCanadaOnyama Limba NEGOTIATION
Jones Z SaylorsItalyElwin Sharvill RENEWAL
Mayumi D SchemmerBrazilAnna Fali NEW
Adams P MorascaSpainStephen Shaw UNQUALIFIED
Stacey W OstroskyFranceIoni Bowcher PROPOSAL
Octavia W AlbaresArgentinaAsiya Javayant PROPOSAL
Antonio Y InouyeItalyIoni Bowcher RENEWAL
Clifford Y OstroskyIndiaIvan Magalhaes PROPOSAL
Costa L CaldareraCanadaAmy Elsner PROPOSAL
Greenwood S GarufiRussiaXuxue Feng NEGOTIATION
Deepesh H WhobreyItalyXuxue Feng UNQUALIFIED
Nicolas A InouyeArgentinaXuxue Feng NEW
Costa J BriddickFranceIoni Bowcher NEGOTIATION
Ricardo K DarakjyRussiaAnna Fali RENEWAL
Leon U PoquetteGermanyIoni Bowcher PROPOSAL
Emily C WaycottRussiaIvan Magalhaes NEW
Aika R FollerItalyElwin Sharvill QUALIFIED
James I WhobreyRussiaOnyama Limba NEGOTIATION
Kadeem H RoysterBrazilAsiya Javayant NEW
Maria C BowleyItalyStephen Shaw PROPOSAL
Ricardo Q ChuiAustraliaXuxue Feng UNQUALIFIED
Jefferson J MaletGermanyAsiya Javayant PROPOSAL
Cody I DoeIndiaStephen Shaw RENEWAL
Kaitlin B SchemmerIndiaAmy Elsner NEW
Faith U NestleIndiaElwin Sharvill QUALIFIED
Costa C KolmetzRussiaAsiya Javayant NEW
Johnson M VenereIndiaIoni Bowcher RENEWAL

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