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
Faith J WhobreyArgentinaElwin Sharvill PROPOSAL
Francesco O MaletIndiaAmy Elsner NEGOTIATION
Stacey H SaylorsArgentinaOnyama Limba PROPOSAL
Salvatore Z GlickUnited KingdomElwin Sharvill NEW
Salvatore I PerinJapanAmy Elsner NEW
Aika V WhobreyFranceIoni Bowcher QUALIFIED
Stacey Z BriddickUnited KingdomBernardo Dominic PROPOSAL
Clifford D StensethAustraliaElwin Sharvill NEGOTIATION
Tony Y OstroskyJapanAnna Fali RENEWAL
Salvatore H SchemmerFranceElwin Sharvill PROPOSAL
Izzy O SchemmerCanadaIoni Bowcher PROPOSAL
Tony Q StockhamArgentinaIvan Magalhaes UNQUALIFIED
Salvatore K CaudyFranceIoni Bowcher QUALIFIED
Julie T FerenczItalyIoni Bowcher RENEWAL
Alejandro T FollerJapanBernardo Dominic NEW
Mujtaba T BowleyBrazilStephen Shaw NEGOTIATION
Misaki Q MaletCanadaStephen Shaw RENEWAL
Mujtaba O SergiArgentinaIoni Bowcher NEW
Munro X WhobreyItalyIvan Magalhaes NEGOTIATION
Misaki K IturbideArgentinaAsiya Javayant NEW
Misaki S GillianItalyElwin Sharvill NEGOTIATION
Kadeem P FollerIndiaXuxue Feng RENEWAL
Munro W MorascaItalyStephen Shaw NEW
Kaitlin M DoeUnited KingdomStephen Shaw QUALIFIED
Isabel A VocelkaFranceBernardo Dominic NEGOTIATION
Alejandro V MaletUnited KingdomElwin Sharvill NEW
Aika Q SergiFranceAsiya Javayant QUALIFIED
Leja V DilliardFranceIoni Bowcher RENEWAL
Rodrigues J TollnerItalyIoni Bowcher QUALIFIED
Darci T CaudyJapanXuxue Feng NEGOTIATION
Ricardo B KuskoArgentinaAmy Elsner NEGOTIATION
Alejandro S CaudyFranceStephen Shaw NEW
Aika G KolmetzJapanElwin Sharvill NEW
Jefferson K SlusarskiItalyAsiya Javayant QUALIFIED
Ashley D InouyeCanadaAsiya Javayant NEGOTIATION
Tony Q ShinkoRussiaXuxue Feng NEW
Octavia J KuskoJapanIvan Magalhaes QUALIFIED
Leja V PaprockiBrazilXuxue Feng PROPOSAL
Maisha F DilliardJapanAnna Fali PROPOSAL
Mayumi E RutaIndiaOnyama Limba UNQUALIFIED
Rodrigues B WhobreyFranceIvan Magalhaes NEGOTIATION
Nicolas G FerenczUnited KingdomIoni Bowcher UNQUALIFIED
Johnson U OldroydGermanyXuxue Feng RENEWAL
Maisha B WaycottArgentinaOnyama Limba NEW
Costa G PerinGermanyXuxue Feng PROPOSAL
Izzy R AmigonRussiaBernardo Dominic NEGOTIATION
James Y StensethBrazilElwin Sharvill UNQUALIFIED
Kadeem K MaletUnited KingdomElwin Sharvill NEGOTIATION
Octavia W CaudyUnited KingdomIvan Magalhaes NEGOTIATION
Clifford M MacleadBrazilBernardo Dominic QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Kadeem J PerinBrazilAsiya Javayant QUALIFIED
Izzy Q MarrierJapanBernardo Dominic UNQUALIFIED
Maria B BologniaGermanyXuxue Feng UNQUALIFIED
Sinclair I KolmetzUnited KingdomIvan Magalhaes UNQUALIFIED
Clifford V ShinkoArgentinaBernardo Dominic UNQUALIFIED
Greenwood K CampainJapanElwin Sharvill RENEWAL
Ivar V AmigonSpainIvan Magalhaes NEGOTIATION
Stacey Z NestleItalyElwin Sharvill NEGOTIATION
Kaitlin Z BowleyIndiaBernardo Dominic NEW
Sinclair A RulapaughArgentinaElwin Sharvill QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Maria B BowleyJapan2025-06-10Printing Dimensions RENEWAL12Elwin Sharvill
1001Tony J BriddickItaly2025-06-03Chapman, Ross E Esq RENEWAL45Ioni Bowcher
1002Emily B FerenczRussia2025-06-10Dorl, James J Esq QUALIFIED68Asiya Javayant
1003Deepesh R FollerAustralia2025-06-12Commercial Press NEGOTIATION37Xuxue Feng
1004Maisha G SlusarskiBrazil2025-05-17Commercial Press QUALIFIED58Stephen Shaw
1005Ivar O VenereSpain2025-05-26Commercial Press PROPOSAL24Xuxue Feng
1006Rodrigues N GlickSpain2025-05-20Chemel, James L Cpa PROPOSAL92Xuxue Feng
1007Smith P RoysterCanada2025-06-13Morlong Associates QUALIFIED69Bernardo Dominic
1008Munro X FigeroaJapan2025-05-16Benton, John B Jr NEGOTIATION82Anna Fali
1009Aruna B BowleyAustralia2025-06-14Morlong Associates NEGOTIATION39Ioni Bowcher
1010Mayumi C WhobreyGermany2025-06-11Truhlar And Truhlar Attys NEGOTIATION40Ioni Bowcher
1011Greenwood E InouyeSpain2025-05-16Commercial Press PROPOSAL39Bernardo Dominic
1012Emily H GlickItaly2025-05-31Feiner Bros UNQUALIFIED84Ivan Magalhaes
1013Salvatore N RimFrance2025-06-10Morlong Associates PROPOSAL99Amy Elsner
1014Johnson X GarufiUnited Kingdom2025-05-22King, Christopher A Esq RENEWAL93Elwin Sharvill
1015Antonio T OldroydCanada2025-06-07Buckley Miller Wright QUALIFIED28Bernardo Dominic
1016Silvio T VenereIndia2025-06-05Commercial Press NEGOTIATION79Xuxue Feng
1017Kadeem R ChuiAustralia2025-06-01Morlong Associates UNQUALIFIED11Ivan Magalhaes
1018Emily V InouyeGermany2025-05-16Benton, John B Jr UNQUALIFIED59Amy Elsner
1019Leon P VocelkaAustralia2025-06-13King, Christopher A Esq RENEWAL56Bernardo Dominic
1020Mujtaba W BowleyUnited Kingdom2025-05-16King, Christopher A Esq NEGOTIATION15Elwin Sharvill
1021Salvatore S GillianCanada2025-06-14Truhlar And Truhlar Attys UNQUALIFIED46Anna Fali
1022Darci A SchemmerItaly2025-05-29Chanay, Jeffrey A Esq UNQUALIFIED91Xuxue Feng
1023Sinclair K WieserBrazil2025-05-22Commercial Press UNQUALIFIED80Asiya Javayant
1024Munro N FlosiItaly2025-06-04Morlong Associates PROPOSAL15Stephen Shaw
1025Ricardo R FlosiJapan2025-06-08Feltz Printing Service QUALIFIED14Ivan Magalhaes
1026David M FollerUnited Kingdom2025-05-22Morlong Associates NEW8Asiya Javayant
1027Salvatore V AlbaresArgentina2025-06-10Printing Dimensions NEW26Anna Fali
1028Julie K VenereRussia2025-05-24Feiner Bros UNQUALIFIED92Xuxue Feng
1029Silvio E FlosiJapan2025-06-10Chapman, Ross E Esq RENEWAL46Amy Elsner
1030Alejandro Y StensethAustralia2025-05-31Benton, John B Jr PROPOSAL43Ioni Bowcher
1031Francesco V BowleyItaly2025-06-12Chemel, James L Cpa QUALIFIED27Bernardo Dominic
1032Murillo D AlbaresCanada2025-06-02Chanay, Jeffrey A Esq NEGOTIATION80Ioni Bowcher
1033Wickens S StensethItaly2025-05-19Printing Dimensions RENEWAL69Ioni Bowcher
1034Morrow U RoysterJapan2025-06-01Dorl, James J Esq NEGOTIATION18Anna Fali
1035Alejandro H InouyeAustralia2025-06-01King, Christopher A Esq PROPOSAL60Elwin Sharvill
1036Aditya P RutaAustralia2025-06-11Dorl, James J Esq NEGOTIATION89Asiya Javayant
1037Costa H StockhamFrance2025-06-07Printing Dimensions NEGOTIATION69Ivan Magalhaes
1038Stacey T BowleyCanada2025-06-10Chanay, Jeffrey A Esq PROPOSAL63Asiya Javayant
1039Maria I DilliardIndia2025-06-01Chapman, Ross E Esq NEGOTIATION70Ivan Magalhaes
1040Octavia X ChuiCanada2025-05-29Dorl, James J Esq NEGOTIATION0Bernardo Dominic
1041Aditya L InouyeFrance2025-05-31Feltz Printing Service NEW48Bernardo Dominic
1042Munro T PerinGermany2025-05-17Commercial Press NEW62Stephen Shaw
1043Clifford B StensethFrance2025-05-18Truhlar And Truhlar Attys NEGOTIATION90Xuxue Feng
1044Mayumi L VenereSpain2025-06-06Chemel, James L Cpa PROPOSAL35Amy Elsner
1045Francesco G CaudyArgentina2025-05-27Feiner Bros NEW75Amy Elsner
1046Costa E StockhamBrazil2025-06-10Buckley Miller Wright UNQUALIFIED52Ioni Bowcher
1047Mayumi D FollerItaly2025-05-21Benton, John B Jr NEW55Xuxue Feng
1048Claire E MarrierUnited Kingdom2025-06-08Rangoni Of Florence QUALIFIED81Ivan Magalhaes
1049Antonio W ButtUnited Kingdom2025-05-25Rousseaux, Michael Esq NEGOTIATION39Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Arvin T MacleadGermanyElwin Sharvill PROPOSAL
Maria H WhobreyRussiaStephen Shaw UNQUALIFIED
Faith F NestleItalyXuxue Feng NEW
Alejandro G ChuiSpainOnyama Limba NEGOTIATION
Kadeem I WaycottArgentinaStephen Shaw QUALIFIED
Sinclair S CaudyRussiaElwin Sharvill NEGOTIATION
Rodrigues I WieserJapanXuxue Feng RENEWAL
Greenwood F MacleadBrazilBernardo Dominic NEGOTIATION
Costa S FerenczRussiaAnna Fali RENEWAL
Cody I ChuiGermanyStephen Shaw RENEWAL
Jeanfrancois S FollerIndiaIvan Magalhaes UNQUALIFIED
Arvin L PaprockiSpainAnna Fali QUALIFIED
Salvatore C NickaFranceIoni Bowcher QUALIFIED
Kadeem P DarakjyCanadaElwin Sharvill RENEWAL
Aditya D PaprockiSpainXuxue Feng NEGOTIATION
Stacey Y BriddickJapanBernardo Dominic RENEWAL
James N FigeroaBrazilAnna Fali NEW
Greenwood F GauchoBrazilIoni Bowcher NEW
Cody Y VenereRussiaAnna Fali QUALIFIED
Nicolas C InouyeRussiaBernardo Dominic PROPOSAL
Deepesh J SchemmerArgentinaXuxue Feng PROPOSAL
Rodrigues K CaudyArgentinaIoni Bowcher QUALIFIED
Julie P BologniaCanadaXuxue Feng NEGOTIATION
Arvin N AmigonItalyAnna Fali PROPOSAL
Misaki Y WaycottBrazilIoni Bowcher PROPOSAL
Jennifer L IturbideUnited KingdomAnna Fali QUALIFIED
Rodrigues R MaletItalyIvan Magalhaes QUALIFIED
Ricardo Q PaprockiCanadaIvan Magalhaes UNQUALIFIED
David W FlosiUnited KingdomAmy Elsner QUALIFIED
Antonio Y CaudyItalyIoni Bowcher UNQUALIFIED
Ricardo Z FollerBrazilXuxue Feng NEW
Tony T WaycottArgentinaBernardo Dominic RENEWAL
Mujtaba F MorascaIndiaBernardo Dominic NEGOTIATION
Ivar E CaldareraJapanAsiya Javayant PROPOSAL
Deepesh K InouyeSpainIvan Magalhaes QUALIFIED
Adams C ShinkoRussiaOnyama Limba UNQUALIFIED
Jeanfrancois C NestleItalyAsiya Javayant NEW
Stacey W DoeItalyOnyama Limba NEGOTIATION
Nicolas G AmigonAustraliaIvan Magalhaes PROPOSAL
Stacey J MaletItalyOnyama Limba RENEWAL
Leja T ShinkoArgentinaOnyama Limba NEGOTIATION
Ashley F GlickCanadaElwin Sharvill UNQUALIFIED
Adams V BologniaUnited KingdomIoni Bowcher PROPOSAL
Maria Q BriddickUnited KingdomIoni Bowcher PROPOSAL
Juan Q SlusarskiArgentinaIoni Bowcher RENEWAL
Isabel I GarufiIndiaElwin Sharvill UNQUALIFIED
Deepesh D OldroydJapanStephen Shaw UNQUALIFIED
Emily R BowleyBrazilBernardo Dominic UNQUALIFIED
Rodrigues D TollnerCanadaStephen Shaw RENEWAL
Wickens S KolmetzCanadaAnna Fali RENEWAL
Frozen Columns
Name
Silvio S Gillian
Aika O Darakjy
Clifford Z Morasca
Faith L Iturbide
Faith G Foller
Octavia A Rulapaugh
Morrow A Gillian
Jennifer R Oldroyd
Clifford N Figeroa
Kadeem Q Stockham
Stacey E Iturbide
Claire E Bowley
Costa R Garufi
Claire S Gillian
Greenwood K Nestle
Julie K Oldroyd
Jones Z Slusarski
Aika Q Bowley
Mayumi T Tollner
David A Waycott
Octavia I Kolmetz
Antonio R Sergi
Alejandro C Morasca
Antonio L Vocelka
Tony N Figeroa
Arvin X Stenseth
Arvin U Campain
Ivar M Chui
Octavia P Tollner
Adams F Paprocki
Tony C Gaucho
Leon N Butt
Clifford X Venere
Murillo Z Slusarski
Antonio Y Figeroa
Ivar Q Maclead
Rodrigues O Stockham
Aika H Vocelka
Deepesh C Ostrosky
Isabel G Poquette
Ricardo D Royster
Clifford I Shinko
Deepesh O Marrier
Costa S Sergi
Emily V Flosi
Ricardo H Figeroa
Aruna J Morasca
Maisha K Marrier
Cody T Venere
Salvatore V Flosi
IdCountryDate
1000Italy2025-06-02
1001India2025-05-23
1002India2025-06-14
1003Japan2025-06-09
1004France2025-06-03
1005Japan2025-05-27
1006Canada2025-05-28
1007Australia2025-06-05
1008Russia2025-05-20
1009Canada2025-05-25
1010Japan2025-05-27
1011Canada2025-05-28
1012Canada2025-06-05
1013India2025-06-09
1014Spain2025-06-03
1015India2025-05-21
1016Canada2025-05-31
1017Germany2025-06-14
1018Spain2025-06-09
1019Canada2025-05-23
1020Brazil2025-06-09
1021Canada2025-06-13
1022India2025-05-22
1023Canada2025-05-24
1024Italy2025-05-31
1025Canada2025-06-06
1026Canada2025-06-07
1027Argentina2025-05-16
1028Japan2025-06-10
1029France2025-06-06
1030Australia2025-06-13
1031Argentina2025-05-22
1032United Kingdom2025-05-20
1033United Kingdom2025-05-23
1034Brazil2025-05-17
1035Russia2025-05-16
1036Russia2025-05-22
1037Canada2025-05-26
1038Germany2025-06-04
1039Canada2025-06-08
1040India2025-05-22
1041France2025-05-22
1042India2025-06-01
1043United Kingdom2025-05-17
1044Japan2025-06-08
1045Japan2025-06-09
1046Argentina2025-05-16
1047France2025-06-12
1048Germany2025-05-22
1049Spain2025-05-27

On-Demand Data

NameIdCountryDate
Aditya D Tollner1000Russia2025-06-11
Silvio Y Royster1001Brazil2025-06-12
Francesco W Iturbide1002Japan2025-05-16
Ashley F Caldarera1003Japan2025-06-02
Jennifer Z Darakjy1004Spain2025-05-30
Aditya S Butt1005Italy2025-05-24
David C Perin1006India2025-05-28
Arvin X Briddick1007United Kingdom2025-06-11
Jones C Slusarski1008France2025-05-18
Ricardo V Darakjy1009Argentina2025-06-13
Stacey T Poquette1010Australia2025-06-13
Munro K Butt1011Argentina2025-05-26
Kadeem A Briddick1012India2025-06-03
Emily L Albares1013Brazil2025-06-12
Julie B Rulapaugh1014Germany2025-06-05
Juan P Wieser1015Australia2025-05-19
Jeanfrancois O Rim1016Brazil2025-05-19
Juan T Gillian1017Australia2025-05-16
Maisha O Ostrosky1018Japan2025-06-09
Costa K Ostrosky1019Australia2025-06-11
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aruna S WieserUnited KingdomAsiya Javayant UNQUALIFIED
Sinclair U WhobreyRussiaAnna Fali RENEWAL
Kadeem G SaylorsSpainIoni Bowcher NEGOTIATION
Sinclair C CaldareraGermanyBernardo Dominic NEGOTIATION
Aruna C MarrierSpainStephen Shaw NEGOTIATION
Costa U GlickIndiaIoni Bowcher NEGOTIATION
Rodrigues P DoeGermanyBernardo Dominic NEW
Faith A RimRussiaIvan Magalhaes PROPOSAL
Ivar V NickaJapanAsiya Javayant UNQUALIFIED
Rodrigues Q WieserUnited KingdomIvan Magalhaes NEGOTIATION
Munro I OstroskyAustraliaAsiya Javayant QUALIFIED
Costa B CaudyBrazilAnna Fali UNQUALIFIED
David S PerinUnited KingdomXuxue Feng NEGOTIATION
Mayumi E IturbideItalyBernardo Dominic RENEWAL
Jennifer Y TollnerUnited KingdomIoni Bowcher NEGOTIATION
Clifford Q KuskoCanadaElwin Sharvill NEW
Nicolas W VenereRussiaAnna Fali PROPOSAL
Ivar B RimGermanyOnyama Limba NEW
Leon J DilliardUnited KingdomXuxue Feng RENEWAL
Leja U DoeArgentinaXuxue Feng PROPOSAL
Francesco B StockhamFranceElwin Sharvill RENEWAL
Jennifer X IturbideBrazilAnna Fali UNQUALIFIED
Ashley M SergiJapanIvan Magalhaes PROPOSAL
Leon F BriddickItalyXuxue Feng QUALIFIED
Isabel W DoeBrazilIoni Bowcher NEW
Faith B GarufiItalyAsiya Javayant UNQUALIFIED
Stacey J VenereBrazilAsiya Javayant UNQUALIFIED
Aruna X DoeGermanyStephen Shaw NEW
Faith A BologniaCanadaStephen Shaw UNQUALIFIED
Aika U PaprockiBrazilStephen Shaw UNQUALIFIED
Mayumi T NestleSpainAnna Fali PROPOSAL
Arvin X ButtGermanyIvan Magalhaes QUALIFIED
Ivar W RimJapanAmy Elsner UNQUALIFIED
Maria H AlbaresItalyAmy Elsner QUALIFIED
Costa E OstroskyItalyAsiya Javayant QUALIFIED
Costa Z SaylorsIndiaStephen Shaw NEGOTIATION
Leon W RutaArgentinaXuxue Feng PROPOSAL
Izzy V WaycottUnited KingdomXuxue Feng NEW
Mujtaba F MaletIndiaAsiya Javayant QUALIFIED
Munro G RoysterItalyXuxue Feng 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>