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
Mayumi G DilliardRussiaAmy Elsner QUALIFIED
Emily D BologniaBrazilAsiya Javayant NEGOTIATION
Jeanfrancois E FlosiSpainElwin Sharvill UNQUALIFIED
Jennifer X FerenczArgentinaOnyama Limba RENEWAL
Kadeem X GauchoGermanyStephen Shaw NEW
Mayumi P ChuiArgentinaBernardo Dominic UNQUALIFIED
Murillo T RimGermanyStephen Shaw QUALIFIED
Jeanfrancois M CaudyAustraliaAnna Fali NEW
Faith Q RimAustraliaIoni Bowcher RENEWAL
Costa E MorascaGermanyBernardo Dominic PROPOSAL
Nicolas T VenereGermanyIoni Bowcher QUALIFIED
Sinclair P CampainArgentinaStephen Shaw RENEWAL
Wickens Y DilliardRussiaXuxue Feng UNQUALIFIED
Leja X MaletArgentinaAsiya Javayant NEW
Clifford A FollerAustraliaElwin Sharvill NEGOTIATION
Ashley J TollnerCanadaOnyama Limba PROPOSAL
Ivar B VocelkaBrazilAsiya Javayant QUALIFIED
Izzy A StockhamJapanAsiya Javayant NEGOTIATION
Kadeem E DilliardCanadaAnna Fali NEGOTIATION
Cody J ChuiIndiaElwin Sharvill PROPOSAL
Isabel W AmigonCanadaIvan Magalhaes QUALIFIED
Francesco H WieserIndiaIvan Magalhaes UNQUALIFIED
Faith T KuskoAustraliaOnyama Limba RENEWAL
Sinclair U NickaUnited KingdomXuxue Feng NEGOTIATION
Maisha A DilliardJapanAmy Elsner NEGOTIATION
Rodrigues E WhobreyGermanyOnyama Limba RENEWAL
Kadeem I FlosiBrazilAmy Elsner QUALIFIED
Ivar Q RutaItalyAmy Elsner NEGOTIATION
Kadeem N AlbaresUnited KingdomAsiya Javayant RENEWAL
Chavez T OstroskyItalyAsiya Javayant RENEWAL
Faith L BriddickUnited KingdomXuxue Feng QUALIFIED
Sinclair G PaprockiIndiaIvan Magalhaes QUALIFIED
Julie W NestleFranceOnyama Limba NEW
Claire L ButtFranceElwin Sharvill QUALIFIED
James J StockhamBrazilAmy Elsner QUALIFIED
Emily S VocelkaRussiaBernardo Dominic RENEWAL
Greenwood K NickaBrazilOnyama Limba UNQUALIFIED
Arvin T BriddickSpainElwin Sharvill UNQUALIFIED
Izzy G DoeCanadaAsiya Javayant NEGOTIATION
David C InouyeItalyAmy Elsner QUALIFIED
Maisha T FerenczUnited KingdomBernardo Dominic NEGOTIATION
Mujtaba Z OstroskyFranceAsiya Javayant PROPOSAL
Costa V StockhamIndiaBernardo Dominic NEGOTIATION
Izzy I MaletSpainElwin Sharvill QUALIFIED
Cody X GarufiCanadaElwin Sharvill NEGOTIATION
Arvin V WieserArgentinaXuxue Feng QUALIFIED
Aditya K CampainRussiaAsiya Javayant QUALIFIED
Octavia Q BologniaSpainIoni Bowcher QUALIFIED
Clifford L NickaJapanOnyama Limba QUALIFIED
Jeanfrancois Y StensethAustraliaStephen Shaw RENEWAL
Horizontal
NameCountryRepresentativeStatus
Francesco A GarufiGermanyAnna Fali NEGOTIATION
Ashley K StensethUnited KingdomAmy Elsner NEGOTIATION
Antonio M BologniaItalyElwin Sharvill PROPOSAL
Sinclair Y IturbideJapanAmy Elsner RENEWAL
Isabel H WaycottSpainOnyama Limba RENEWAL
Cody A SchemmerFranceBernardo Dominic QUALIFIED
Murillo B MaletAustraliaBernardo Dominic RENEWAL
Salvatore M RutaArgentinaXuxue Feng RENEWAL
Munro L PaprockiRussiaElwin Sharvill QUALIFIED
Murillo E GauchoUnited KingdomAnna Fali UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Kaitlin S StockhamIndia2024-06-06Feltz Printing Service NEW71Stephen Shaw
1001Mayumi F OstroskyCanada2024-05-21Rangoni Of Florence PROPOSAL18Bernardo Dominic
1002Aruna J SchemmerSpain2024-06-07Truhlar And Truhlar Attys UNQUALIFIED12Ivan Magalhaes
1003Nicolas H WaycottAustralia2024-06-16Morlong Associates RENEWAL86Stephen Shaw
1004Johnson Q MaletAustralia2024-06-09Rangoni Of Florence RENEWAL83Bernardo Dominic
1005Alejandro N OldroydBrazil2024-06-05Feiner Bros UNQUALIFIED93Ivan Magalhaes
1006Kaitlin J DoeFrance2024-06-16Chapman, Ross E Esq RENEWAL55Onyama Limba
1007Misaki X KolmetzIndia2024-06-15Commercial Press RENEWAL98Xuxue Feng
1008David V FollerBrazil2024-05-22Truhlar And Truhlar Attys QUALIFIED53Elwin Sharvill
1009Leon Z MarrierBrazil2024-06-03Benton, John B Jr NEW78Elwin Sharvill
1010Salvatore Y GlickUnited Kingdom2024-06-06Chanay, Jeffrey A Esq NEGOTIATION23Ioni Bowcher
1011Maria A PaprockiCanada2024-05-29Chemel, James L Cpa NEGOTIATION37Amy Elsner
1012Chavez T AlbaresItaly2024-06-06Morlong Associates PROPOSAL88Onyama Limba
1013Sinclair D RimBrazil2024-06-07King, Christopher A Esq PROPOSAL41Asiya Javayant
1014Nicolas T StockhamSpain2024-06-17King, Christopher A Esq NEGOTIATION50Anna Fali
1015Deepesh P MaletRussia2024-06-11King, Christopher A Esq QUALIFIED95Anna Fali
1016Adams S CampainItaly2024-06-11Printing Dimensions PROPOSAL60Asiya Javayant
1017Morrow B RulapaughCanada2024-05-29Commercial Press RENEWAL77Ivan Magalhaes
1018Aika C IturbideIndia2024-05-20King, Christopher A Esq RENEWAL10Ivan Magalhaes
1019Jennifer P FerenczUnited Kingdom2024-06-03Printing Dimensions RENEWAL91Ivan Magalhaes
1020Izzy P WaycottSpain2024-05-20Chemel, James L Cpa PROPOSAL25Ivan Magalhaes
1021Silvio B InouyeCanada2024-06-08Chemel, James L Cpa RENEWAL9Stephen Shaw
1022Mayumi F DarakjyGermany2024-05-23Chemel, James L Cpa NEGOTIATION55Xuxue Feng
1023Greenwood Y GarufiItaly2024-05-23Rangoni Of Florence NEGOTIATION22Elwin Sharvill
1024Rodrigues L KuskoIndia2024-05-26Truhlar And Truhlar Attys NEGOTIATION95Bernardo Dominic
1025Jennifer W NickaRussia2024-06-12Chemel, James L Cpa RENEWAL95Onyama Limba
1026James E MorascaCanada2024-05-25Benton, John B Jr NEW52Asiya Javayant
1027Adams S GarufiItaly2024-05-21Buckley Miller Wright RENEWAL38Stephen Shaw
1028Maisha W StensethSpain2024-06-18Truhlar And Truhlar Attys QUALIFIED41Amy Elsner
1029Emily M BowleyIndia2024-06-08Buckley Miller Wright NEGOTIATION61Elwin Sharvill
1030Arvin F KolmetzItaly2024-06-01Chapman, Ross E Esq RENEWAL51Amy Elsner
1031Faith F BriddickBrazil2024-06-13Rangoni Of Florence PROPOSAL49Anna Fali
1032Mayumi Z FollerBrazil2024-06-14Feiner Bros QUALIFIED55Stephen Shaw
1033Alejandro I ShinkoUnited Kingdom2024-06-05Rangoni Of Florence UNQUALIFIED89Elwin Sharvill
1034Costa B RutaRussia2024-06-02Commercial Press UNQUALIFIED75Bernardo Dominic
1035Ricardo L VenereFrance2024-06-15Chapman, Ross E Esq RENEWAL0Elwin Sharvill
1036Smith L CaudyGermany2024-06-11Commercial Press NEGOTIATION52Bernardo Dominic
1037Kaitlin X FlosiGermany2024-05-31Chemel, James L Cpa UNQUALIFIED34Stephen Shaw
1038Jefferson I PoquetteRussia2024-05-21Printing Dimensions NEGOTIATION81Amy Elsner
1039Stacey D RulapaughAustralia2024-05-25Rangoni Of Florence NEGOTIATION5Asiya Javayant
1040Kaitlin T MacleadCanada2024-06-01Rousseaux, Michael Esq UNQUALIFIED20Ioni Bowcher
1041Adams U SergiSpain2024-06-16Truhlar And Truhlar Attys NEGOTIATION42Asiya Javayant
1042Claire K ShinkoItaly2024-06-09Feltz Printing Service PROPOSAL12Amy Elsner
1043Maria I BologniaAustralia2024-05-24Morlong Associates QUALIFIED21Ivan Magalhaes
1044Aditya R WhobreyFrance2024-05-20Benton, John B Jr NEGOTIATION76Bernardo Dominic
1045Alejandro W VocelkaBrazil2024-05-24King, Christopher A Esq RENEWAL13Xuxue Feng
1046Emily V CaldareraSpain2024-06-08Chemel, James L Cpa QUALIFIED16Bernardo Dominic
1047Darci L ShinkoRussia2024-06-02Chemel, James L Cpa QUALIFIED47Asiya Javayant
1048Jones F PerinFrance2024-05-24Feiner Bros RENEWAL51Bernardo Dominic
1049Greenwood C ChuiBrazil2024-05-27Dorl, James J Esq QUALIFIED4Anna Fali
Frozen Rows
NameCountryRepresentativeStatus
Leon V FlosiItalyIoni Bowcher UNQUALIFIED
Mujtaba L NestleBrazilAsiya Javayant RENEWAL
Ashley B WhobreyJapanStephen Shaw NEGOTIATION
Deepesh M TollnerJapanElwin Sharvill RENEWAL
Tony F NestleUnited KingdomAnna Fali NEW
Costa T OldroydItalyIoni Bowcher RENEWAL
Jefferson O IturbideRussiaAsiya Javayant PROPOSAL
Ashley F PerinItalyStephen Shaw UNQUALIFIED
Claire D WhobreyJapanStephen Shaw QUALIFIED
Ricardo Y PoquetteArgentinaXuxue Feng RENEWAL
Deepesh L AmigonItalyOnyama Limba UNQUALIFIED
Misaki K OldroydItalyIoni Bowcher RENEWAL
Juan M ButtUnited KingdomOnyama Limba UNQUALIFIED
Emily I FigeroaItalyOnyama Limba NEW
Arvin J OstroskyAustraliaIoni Bowcher RENEWAL
Kaitlin W WieserArgentinaXuxue Feng RENEWAL
Munro X KolmetzArgentinaOnyama Limba UNQUALIFIED
Silvio K RutaAustraliaBernardo Dominic UNQUALIFIED
Chavez R DilliardSpainOnyama Limba QUALIFIED
Alejandro D FollerAustraliaBernardo Dominic NEW
Juan B ButtArgentinaXuxue Feng NEW
Adams G StockhamIndiaAmy Elsner QUALIFIED
Faith Q OldroydSpainOnyama Limba UNQUALIFIED
Tony W SchemmerFranceIvan Magalhaes NEW
Jennifer B WieserJapanElwin Sharvill RENEWAL
Ashley S TollnerGermanyStephen Shaw NEGOTIATION
Jones R MaletCanadaStephen Shaw QUALIFIED
Tony I ShinkoIndiaStephen Shaw QUALIFIED
James Q WaycottSpainStephen Shaw NEW
Octavia Q KuskoRussiaStephen Shaw UNQUALIFIED
Cody H StensethCanadaIvan Magalhaes NEW
Silvio Z PaprockiSpainXuxue Feng QUALIFIED
Rodrigues C GarufiArgentinaIoni Bowcher QUALIFIED
Greenwood H ButtRussiaAnna Fali QUALIFIED
Maria Y SchemmerItalyStephen Shaw QUALIFIED
Sinclair Y VenereFranceBernardo Dominic NEGOTIATION
Juan R GillianUnited KingdomBernardo Dominic QUALIFIED
Jefferson Z KuskoArgentinaAmy Elsner RENEWAL
Izzy T BologniaFranceIvan Magalhaes PROPOSAL
Clifford A DoeIndiaOnyama Limba QUALIFIED
Darci U DoeBrazilAnna Fali RENEWAL
Ricardo R BologniaJapanXuxue Feng UNQUALIFIED
Kaitlin U MaletArgentinaIvan Magalhaes NEGOTIATION
Greenwood Z SchemmerFranceBernardo Dominic QUALIFIED
Johnson S PaprockiAustraliaIvan Magalhaes NEW
David P AlbaresArgentinaIvan Magalhaes NEW
Mayumi P VocelkaSpainOnyama Limba QUALIFIED
Maisha E NickaRussiaIvan Magalhaes NEW
Aditya B GarufiItalyBernardo Dominic NEW
Claire K InouyeCanadaAsiya Javayant NEGOTIATION
Frozen Columns
Name
Morrow R Malet
Leja Y Rim
Wickens K Venere
Aika F Schemmer
Greenwood L Garufi
Jefferson F Butt
Nicolas S Garufi
Alejandro Y Tollner
Clifford F Figeroa
Nicolas H Rulapaugh
Mayumi O Gillian
Murillo Z Ruta
Costa Q Ostrosky
Juan L Chui
Cody K Shinko
Wickens Q Garufi
Clifford S Chui
Sinclair Y Bowley
Tony J Garufi
Jennifer Z Nestle
Alejandro N Wieser
Octavia E Inouye
Smith C Kolmetz
Claire V Schemmer
Tony N Foller
Misaki Q Caldarera
Chavez V Malet
Munro Y Figeroa
Jeanfrancois S Butt
Maisha W Malet
Claire B Caldarera
Misaki H Ferencz
Adams O Campain
James G Flosi
Alejandro G Bolognia
Chavez R Paprocki
Izzy P Flosi
Silvio D Nicka
Maria U Royster
Tony F Briddick
Ivar I Albares
Adams V Oldroyd
Salvatore V Morasca
Ashley M Vocelka
Alejandro H Glick
Izzy F Amigon
Wickens B Stenseth
Munro F Oldroyd
Cody X Oldroyd
Maisha Z Waycott
IdCountryDate
1000India2024-06-03
1001United Kingdom2024-05-26
1002Spain2024-06-02
1003Spain2024-06-14
1004Germany2024-05-27
1005Brazil2024-05-30
1006Russia2024-06-02
1007Brazil2024-06-12
1008Brazil2024-06-18
1009Japan2024-06-12
1010Argentina2024-06-05
1011Russia2024-06-12
1012Russia2024-06-12
1013France2024-06-03
1014Italy2024-06-02
1015India2024-05-27
1016Italy2024-06-13
1017Russia2024-06-16
1018India2024-06-01
1019Italy2024-06-18
1020Australia2024-05-22
1021Brazil2024-05-25
1022Australia2024-06-17
1023Argentina2024-05-28
1024India2024-05-24
1025India2024-06-01
1026United Kingdom2024-05-25
1027Germany2024-06-18
1028Japan2024-06-07
1029Argentina2024-06-12
1030Russia2024-06-09
1031Russia2024-05-30
1032Canada2024-06-10
1033Germany2024-05-22
1034Spain2024-05-27
1035Italy2024-06-09
1036Spain2024-05-23
1037Argentina2024-06-08
1038India2024-05-30
1039Argentina2024-06-05
1040Spain2024-05-25
1041Australia2024-05-21
1042Spain2024-06-14
1043Australia2024-05-22
1044Argentina2024-06-18
1045India2024-06-06
1046Canada2024-05-21
1047United Kingdom2024-06-14
1048Germany2024-06-03
1049Germany2024-06-04

On-Demand Data

NameIdCountryDate
Emily Y Albares1000United Kingdom2024-06-18
Ricardo C Perin1001Japan2024-06-12
Nicolas X Amigon1002Spain2024-06-05
Emily U Iturbide1003Argentina2024-05-25
Julie T Gaucho1004United Kingdom2024-06-03
Darci X Ferencz1005Italy2024-06-01
Aditya W Caldarera1006Russia2024-05-27
Morrow D Caudy1007United Kingdom2024-06-16
Sinclair Q Butt1008Australia2024-05-27
Adams K Ruta1009United Kingdom2024-06-13
Sinclair M Caudy1010Germany2024-06-09
Claire D Royster1011Brazil2024-05-23
Tony R Rim1012India2024-06-18
Rodrigues I Kusko1013United Kingdom2024-06-07
Kaitlin E Maclead1014Argentina2024-05-27
David Z Iturbide1015Australia2024-05-25
Maisha W Perin1016Germany2024-06-03
Deepesh N Malet1017Russia2024-06-07
Izzy V Bolognia1018India2024-05-25
Kadeem U Paprocki1019Russia2024-06-10
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
David J CaudyUnited KingdomOnyama Limba NEW
Isabel H RutaAustraliaElwin Sharvill UNQUALIFIED
Claire H RimArgentinaAmy Elsner PROPOSAL
Maria A GillianJapanElwin Sharvill RENEWAL
Antonio M OldroydRussiaBernardo Dominic QUALIFIED
Ashley M SlusarskiAustraliaAsiya Javayant PROPOSAL
Sinclair Q SchemmerItalyBernardo Dominic QUALIFIED
Aruna B FlosiCanadaAmy Elsner NEW
Greenwood T RimIndiaIoni Bowcher PROPOSAL
Silvio F CaldareraCanadaIoni Bowcher RENEWAL
Jones O MaletFranceAsiya Javayant UNQUALIFIED
Costa B NickaGermanyAmy Elsner QUALIFIED
Misaki B NickaUnited KingdomBernardo Dominic NEW
Julie M BriddickJapanOnyama Limba PROPOSAL
Aika R VocelkaGermanyAsiya Javayant RENEWAL
Smith H BowleyAustraliaIvan Magalhaes QUALIFIED
Jefferson N MorascaUnited KingdomElwin Sharvill QUALIFIED
Jeanfrancois Q FlosiGermanyAnna Fali RENEWAL
Ricardo V MaletRussiaElwin Sharvill UNQUALIFIED
Chavez M SergiFranceOnyama Limba RENEWAL
Octavia H FerenczRussiaIoni Bowcher NEGOTIATION
Arvin U MacleadItalyAmy Elsner PROPOSAL
Misaki M NickaGermanyBernardo Dominic QUALIFIED
Murillo K GauchoFranceAsiya Javayant NEGOTIATION
Rodrigues T NestleUnited KingdomIoni Bowcher NEGOTIATION
Francesco Q RoysterCanadaAnna Fali NEW
Greenwood Q FlosiArgentinaBernardo Dominic RENEWAL
Kaitlin Y OstroskyRussiaBernardo Dominic QUALIFIED
Aditya G PaprockiBrazilIoni Bowcher RENEWAL
Ivar N KuskoBrazilIvan Magalhaes NEW
Antonio Y RoysterUnited KingdomIvan Magalhaes QUALIFIED
Jeanfrancois K RimBrazilIoni Bowcher UNQUALIFIED
Octavia Z CaudyBrazilAmy Elsner NEGOTIATION
Isabel U CaldareraIndiaBernardo Dominic QUALIFIED
Aika X KolmetzBrazilStephen Shaw PROPOSAL
Maisha Y IturbideSpainIvan Magalhaes PROPOSAL
Kaitlin T StockhamJapanBernardo Dominic RENEWAL
Misaki Q RutaItalyXuxue Feng NEGOTIATION
Rodrigues U GlickArgentinaAsiya Javayant UNQUALIFIED
Jeanfrancois Q AmigonSpainAmy Elsner 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>