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
Morrow R KolmetzArgentinaBernardo Dominic RENEWAL
David U FerenczAustraliaOnyama Limba UNQUALIFIED
Jennifer B CaudyUnited KingdomBernardo Dominic UNQUALIFIED
Jones K GlickBrazilIvan Magalhaes RENEWAL
Kaitlin A WaycottFranceOnyama Limba NEGOTIATION
Aruna V CaudyItalyAnna Fali NEGOTIATION
Claire O PoquetteSpainIoni Bowcher QUALIFIED
Faith B RulapaughIndiaAsiya Javayant UNQUALIFIED
Maria I StensethSpainXuxue Feng PROPOSAL
Chavez I RoysterJapanXuxue Feng NEGOTIATION
Sinclair F AmigonGermanyBernardo Dominic UNQUALIFIED
Mayumi R NickaUnited KingdomIvan Magalhaes NEW
Johnson C BowleyFranceAmy Elsner PROPOSAL
Mayumi X AmigonAustraliaAsiya Javayant NEGOTIATION
Julie E CampainArgentinaOnyama Limba RENEWAL
Ashley B WieserGermanyIvan Magalhaes NEW
Mujtaba V StockhamArgentinaAmy Elsner UNQUALIFIED
Jefferson X TollnerUnited KingdomIoni Bowcher RENEWAL
James F WaycottIndiaAnna Fali NEW
Antonio U SlusarskiSpainBernardo Dominic UNQUALIFIED
Munro F RutaSpainIvan Magalhaes NEW
Mayumi N OldroydJapanStephen Shaw UNQUALIFIED
Arvin G DilliardUnited KingdomOnyama Limba UNQUALIFIED
Rodrigues Y TollnerArgentinaAnna Fali PROPOSAL
Leja O BologniaGermanyIvan Magalhaes UNQUALIFIED
Murillo K MarrierItalyIvan Magalhaes RENEWAL
Smith L WieserGermanyAnna Fali UNQUALIFIED
Jennifer J PerinAustraliaIvan Magalhaes NEGOTIATION
Maria Q MacleadIndiaOnyama Limba UNQUALIFIED
Ivar S NickaAustraliaOnyama Limba PROPOSAL
Kadeem N ShinkoIndiaIvan Magalhaes NEGOTIATION
Faith F RulapaughCanadaStephen Shaw PROPOSAL
Alejandro Q PoquetteIndiaIvan Magalhaes QUALIFIED
Silvio D TollnerJapanIvan Magalhaes PROPOSAL
Murillo E BowleySpainIoni Bowcher UNQUALIFIED
Kadeem P SlusarskiGermanyStephen Shaw NEW
Izzy J SaylorsFranceBernardo Dominic UNQUALIFIED
Rodrigues L AmigonUnited KingdomElwin Sharvill QUALIFIED
Claire I PoquetteJapanIvan Magalhaes NEW
Wickens X WaycottSpainAsiya Javayant PROPOSAL
Izzy O BowleyUnited KingdomIvan Magalhaes NEGOTIATION
Greenwood K OstroskySpainAmy Elsner NEGOTIATION
Jefferson B TollnerCanadaAnna Fali UNQUALIFIED
Greenwood N GillianAustraliaElwin Sharvill QUALIFIED
Aika W FlosiRussiaOnyama Limba UNQUALIFIED
Cody G FerenczFranceOnyama Limba PROPOSAL
Greenwood W TollnerBrazilIvan Magalhaes RENEWAL
Jeanfrancois Y InouyeBrazilAsiya Javayant UNQUALIFIED
Silvio H BologniaGermanyAsiya Javayant RENEWAL
James A RimCanadaAnna Fali QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Misaki P BriddickArgentinaStephen Shaw RENEWAL
Antonio Z BriddickFranceElwin Sharvill NEGOTIATION
Octavia N IturbideJapanAmy Elsner QUALIFIED
Sinclair I NestleJapanElwin Sharvill NEGOTIATION
Clifford T InouyeRussiaAsiya Javayant PROPOSAL
Silvio W ChuiUnited KingdomElwin Sharvill NEGOTIATION
Aika I InouyeAustraliaAsiya Javayant QUALIFIED
Isabel I VenereCanadaIoni Bowcher NEGOTIATION
Francesco V IturbideRussiaElwin Sharvill RENEWAL
Salvatore K TollnerRussiaOnyama Limba RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Munro W RulapaughIndia2024-06-18Printing Dimensions NEGOTIATION9Ioni Bowcher
1001Kaitlin C CampainItaly2024-05-28Morlong Associates NEGOTIATION79Asiya Javayant
1002Wickens X PaprockiUnited Kingdom2024-06-11Chanay, Jeffrey A Esq NEGOTIATION22Amy Elsner
1003Jones E StockhamAustralia2024-06-05Chemel, James L Cpa QUALIFIED97Xuxue Feng
1004Chavez N CampainGermany2024-05-31Rousseaux, Michael Esq PROPOSAL81Anna Fali
1005Smith F PaprockiItaly2024-06-10Feltz Printing Service QUALIFIED60Stephen Shaw
1006Kaitlin K WieserJapan2024-05-26Benton, John B Jr NEGOTIATION99Asiya Javayant
1007David N VocelkaCanada2024-05-26King, Christopher A Esq PROPOSAL93Amy Elsner
1008Stacey N IturbideUnited Kingdom2024-05-26Benton, John B Jr PROPOSAL93Onyama Limba
1009Leja A BologniaSpain2024-05-31Feiner Bros PROPOSAL43Ivan Magalhaes
1010Greenwood J RoysterFrance2024-06-15Dorl, James J Esq PROPOSAL28Ioni Bowcher
1011Murillo D NestleFrance2024-06-19Dorl, James J Esq UNQUALIFIED77Amy Elsner
1012Silvio P RulapaughJapan2024-06-07Buckley Miller Wright NEGOTIATION74Stephen Shaw
1013Faith L DarakjyItaly2024-06-22Buckley Miller Wright NEGOTIATION70Anna Fali
1014Stacey J FlosiArgentina2024-06-24Benton, John B Jr NEW33Bernardo Dominic
1015Francesco J RutaItaly2024-06-06Dorl, James J Esq PROPOSAL36Xuxue Feng
1016Leja E KolmetzIndia2024-06-11Printing Dimensions PROPOSAL29Elwin Sharvill
1017Jeanfrancois X PerinBrazil2024-06-10Chemel, James L Cpa NEGOTIATION88Onyama Limba
1018Jones R MaletIndia2024-05-27Printing Dimensions RENEWAL11Onyama Limba
1019Emily H PerinIndia2024-06-24Benton, John B Jr NEGOTIATION40Amy Elsner
1020Faith J MarrierRussia2024-06-01Printing Dimensions UNQUALIFIED83Ivan Magalhaes
1021Smith I BowleyAustralia2024-06-16Feiner Bros NEGOTIATION29Stephen Shaw
1022Sinclair V DarakjyJapan2024-06-06Dorl, James J Esq NEW79Amy Elsner
1023Munro J TollnerIndia2024-05-27Buckley Miller Wright UNQUALIFIED80Stephen Shaw
1024Leja H MarrierSpain2024-06-01Commercial Press PROPOSAL35Anna Fali
1025Mayumi Z DilliardGermany2024-06-24Chemel, James L Cpa NEW29Xuxue Feng
1026Octavia B WaycottArgentina2024-06-21King, Christopher A Esq QUALIFIED95Ivan Magalhaes
1027Kadeem F TollnerGermany2024-05-26Truhlar And Truhlar Attys UNQUALIFIED2Asiya Javayant
1028Munro B KolmetzBrazil2024-06-05Feltz Printing Service QUALIFIED27Amy Elsner
1029Misaki D RutaCanada2024-06-15Morlong Associates PROPOSAL43Bernardo Dominic
1030Faith A CampainJapan2024-05-31Buckley Miller Wright NEGOTIATION59Bernardo Dominic
1031Clifford Q StockhamAustralia2024-05-30Feltz Printing Service NEW96Amy Elsner
1032Cody V VenereUnited Kingdom2024-06-13Feltz Printing Service RENEWAL84Onyama Limba
1033Izzy Z FigeroaArgentina2024-06-02Benton, John B Jr RENEWAL14Anna Fali
1034Silvio Z GarufiGermany2024-06-12Commercial Press RENEWAL28Bernardo Dominic
1035David P InouyeAustralia2024-06-15Buckley Miller Wright NEGOTIATION35Onyama Limba
1036Claire D GarufiAustralia2024-06-04Chapman, Ross E Esq RENEWAL46Anna Fali
1037Arvin B NickaCanada2024-06-02Rousseaux, Michael Esq UNQUALIFIED51Onyama Limba
1038Munro F GillianFrance2024-05-27Chapman, Ross E Esq NEGOTIATION58Elwin Sharvill
1039Wickens X MaletGermany2024-06-08Truhlar And Truhlar Attys QUALIFIED37Bernardo Dominic
1040Stacey E StockhamArgentina2024-06-12Feiner Bros NEGOTIATION42Asiya Javayant
1041Jennifer P MaletRussia2024-05-28Truhlar And Truhlar Attys NEW73Ioni Bowcher
1042Aditya G SergiJapan2024-05-29Chemel, James L Cpa QUALIFIED40Ioni Bowcher
1043Greenwood Q DilliardSpain2024-06-10Truhlar And Truhlar Attys NEGOTIATION68Xuxue Feng
1044Kadeem L NestleArgentina2024-06-11Feltz Printing Service NEW12Anna Fali
1045Darci P ButtAustralia2024-06-21Commercial Press UNQUALIFIED64Asiya Javayant
1046Izzy M WaycottCanada2024-06-20Rangoni Of Florence RENEWAL36Xuxue Feng
1047Salvatore E PerinBrazil2024-06-16King, Christopher A Esq NEW41Bernardo Dominic
1048Nicolas S PoquetteJapan2024-06-22Printing Dimensions NEW85Bernardo Dominic
1049Kaitlin S MorascaBrazil2024-06-18Feiner Bros RENEWAL1Amy Elsner
Frozen Rows
NameCountryRepresentativeStatus
Chavez F DilliardItalyXuxue Feng UNQUALIFIED
Izzy P DoeFranceOnyama Limba QUALIFIED
Arvin M SlusarskiItalyIvan Magalhaes PROPOSAL
Leja Z VocelkaRussiaBernardo Dominic PROPOSAL
Johnson D RutaArgentinaXuxue Feng RENEWAL
Arvin P RulapaughGermanyIvan Magalhaes PROPOSAL
James E FlosiJapanStephen Shaw NEGOTIATION
Silvio H GillianAustraliaBernardo Dominic NEGOTIATION
Silvio U SergiItalyStephen Shaw NEW
Kadeem Y InouyeUnited KingdomIoni Bowcher NEW
Ashley Q ButtJapanIoni Bowcher PROPOSAL
Deepesh Z ChuiUnited KingdomAnna Fali NEGOTIATION
Aika O NickaArgentinaBernardo Dominic PROPOSAL
Silvio A RulapaughUnited KingdomElwin Sharvill QUALIFIED
Antonio T BowleyBrazilAmy Elsner QUALIFIED
Faith H FlosiSpainIvan Magalhaes NEGOTIATION
Ricardo Q ButtUnited KingdomBernardo Dominic PROPOSAL
Francesco Y KuskoRussiaIvan Magalhaes UNQUALIFIED
Mujtaba C RimArgentinaAnna Fali RENEWAL
Clifford P WhobreyArgentinaAmy Elsner QUALIFIED
Murillo S CaldareraIndiaXuxue Feng NEGOTIATION
Antonio Q BowleySpainIoni Bowcher NEW
Ashley G VocelkaCanadaStephen Shaw UNQUALIFIED
Morrow M ButtSpainIoni Bowcher QUALIFIED
Jefferson W StockhamAustraliaAmy Elsner PROPOSAL
Kaitlin P WaycottBrazilXuxue Feng QUALIFIED
Munro M BriddickGermanyAsiya Javayant NEW
Silvio P FlosiRussiaIvan Magalhaes RENEWAL
Stacey P VocelkaUnited KingdomAmy Elsner NEGOTIATION
Nicolas T IturbideRussiaIvan Magalhaes PROPOSAL
Aruna I GauchoIndiaBernardo Dominic UNQUALIFIED
Isabel N RutaFranceBernardo Dominic NEGOTIATION
Clifford R WhobreyArgentinaOnyama Limba NEW
Faith C WieserJapanBernardo Dominic PROPOSAL
Isabel U GarufiSpainAnna Fali NEGOTIATION
Emily X SergiAustraliaAmy Elsner PROPOSAL
Julie D ChuiCanadaIvan Magalhaes PROPOSAL
Jennifer H FollerArgentinaOnyama Limba QUALIFIED
Isabel D FlosiIndiaIvan Magalhaes QUALIFIED
Antonio M SergiGermanyAnna Fali NEW
Clifford A DilliardGermanyStephen Shaw NEGOTIATION
Wickens Z DilliardUnited KingdomAnna Fali NEW
Chavez W GauchoCanadaXuxue Feng NEGOTIATION
Ashley Y VenereGermanyAnna Fali NEGOTIATION
Kadeem B NestleItalyOnyama Limba UNQUALIFIED
Murillo Q PoquetteAustraliaAmy Elsner UNQUALIFIED
Sinclair U FerenczItalyElwin Sharvill NEW
Leon T KuskoJapanAmy Elsner QUALIFIED
Clifford F WieserIndiaIvan Magalhaes QUALIFIED
Jennifer U StockhamGermanyStephen Shaw QUALIFIED
Frozen Columns
Name
Isabel D Tollner
Salvatore E Bowley
Chavez M Poquette
Nicolas U Vocelka
Munro G Oldroyd
Ivar T Royster
Emily M Whobrey
Ricardo T Inouye
Wickens J Malet
Juan C Malet
Jennifer Y Darakjy
Jeanfrancois H Tollner
Alejandro M Butt
Chavez C Glick
Jeanfrancois K Maclead
Salvatore X Schemmer
Adams I Caudy
Antonio T Chui
Aditya Z Flosi
David K Amigon
Tony W Morasca
Cody P Morasca
Jennifer P Oldroyd
Smith Z Rim
Misaki N Chui
James H Bowley
Isabel H Briddick
Aruna K Stenseth
Nicolas C Schemmer
Cody F Iturbide
Ricardo Y Sergi
James G Schemmer
Ashley N Flosi
Isabel S Ferencz
Mayumi J Glick
Octavia N Waycott
Ivar U Shinko
Aika M Gillian
Juan Q Amigon
Jeanfrancois E Gillian
Julie C Amigon
Ivar O Shinko
Stacey T Shinko
Rodrigues Q Chui
David A Waycott
Izzy Z Amigon
Sinclair B Dilliard
Ricardo U Briddick
Jeanfrancois W Rulapaugh
Mayumi L Oldroyd
IdCountryDate
1000Italy2024-05-31
1001France2024-06-02
1002Australia2024-06-21
1003Russia2024-06-13
1004Russia2024-06-17
1005Spain2024-06-09
1006Argentina2024-06-13
1007Japan2024-05-28
1008Japan2024-06-05
1009Australia2024-06-12
1010Japan2024-06-06
1011Australia2024-06-02
1012Brazil2024-06-10
1013France2024-06-14
1014India2024-06-21
1015India2024-06-11
1016India2024-06-11
1017Russia2024-05-26
1018Italy2024-06-03
1019Brazil2024-06-07
1020Australia2024-06-09
1021Italy2024-06-04
1022Australia2024-05-27
1023Russia2024-06-09
1024Brazil2024-05-29
1025Russia2024-06-05
1026Canada2024-06-16
1027India2024-06-19
1028Canada2024-06-22
1029United Kingdom2024-06-08
1030Canada2024-06-20
1031Brazil2024-06-14
1032Germany2024-05-31
1033France2024-06-20
1034Italy2024-06-04
1035Germany2024-06-01
1036United Kingdom2024-06-14
1037Russia2024-06-17
1038Italy2024-06-09
1039India2024-06-22
1040Brazil2024-06-09
1041Spain2024-06-20
1042France2024-06-20
1043France2024-06-07
1044Canada2024-06-01
1045France2024-06-01
1046Japan2024-05-29
1047Italy2024-06-13
1048India2024-06-18
1049Japan2024-06-19

On-Demand Data

NameIdCountryDate
Kadeem F Morasca1000Canada2024-06-22
David Z Oldroyd1001Italy2024-06-13
Aruna A Stenseth1002Canada2024-06-10
Ricardo L Bolognia1003Japan2024-06-16
Munro U Nicka1004Japan2024-06-09
Jeanfrancois C Nestle1005Italy2024-06-07
Clifford W Garufi1006Italy2024-06-21
Aruna O Dilliard1007Brazil2024-06-07
Murillo A Poquette1008France2024-06-16
Juan Z Inouye1009France2024-06-18
Rodrigues N Tollner1010Russia2024-06-15
Mujtaba A Dilliard1011Brazil2024-06-02
Leon V Butt1012Spain2024-06-23
Kadeem W Maclead1013Spain2024-06-19
Murillo B Glick1014Canada2024-06-24
David R Bowley1015India2024-06-06
Isabel U Morasca1016India2024-05-27
Jones X Whobrey1017United Kingdom2024-06-17
Misaki O Sergi1018Australia2024-05-29
Mujtaba S Ostrosky1019Japan2024-06-01
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Alejandro A NestleFranceStephen Shaw NEGOTIATION
Mujtaba H KolmetzRussiaAsiya Javayant PROPOSAL
Arvin W WieserSpainAnna Fali UNQUALIFIED
Costa H ChuiAustraliaAmy Elsner NEW
Chavez V OstroskyItalyBernardo Dominic NEW
Arvin S MarrierItalyXuxue Feng PROPOSAL
Ashley B MacleadAustraliaElwin Sharvill RENEWAL
Morrow B CaldareraJapanAmy Elsner UNQUALIFIED
Ivar T MacleadRussiaIoni Bowcher NEGOTIATION
Munro O SchemmerJapanIvan Magalhaes NEGOTIATION
Alejandro W IturbideFranceXuxue Feng PROPOSAL
Maria A CaldareraItalyBernardo Dominic PROPOSAL
Jones J GlickSpainOnyama Limba RENEWAL
Claire O GarufiBrazilXuxue Feng UNQUALIFIED
Arvin Q KolmetzGermanyIvan Magalhaes NEGOTIATION
Mayumi T MorascaItalyAmy Elsner NEGOTIATION
Claire D GarufiIndiaElwin Sharvill NEW
Jeanfrancois N MarrierBrazilAsiya Javayant QUALIFIED
Deepesh H WhobreyRussiaBernardo Dominic UNQUALIFIED
Costa Y CampainItalyAnna Fali NEW
Faith W DarakjyAustraliaBernardo Dominic NEGOTIATION
Nicolas X ChuiFranceElwin Sharvill NEW
Maria I GillianCanadaBernardo Dominic PROPOSAL
Wickens R SaylorsCanadaBernardo Dominic QUALIFIED
Izzy H StockhamUnited KingdomAmy Elsner PROPOSAL
Chavez S CaldareraSpainOnyama Limba UNQUALIFIED
Wickens F SergiAustraliaElwin Sharvill QUALIFIED
Darci V SergiJapanAnna Fali NEW
Claire E RimCanadaIvan Magalhaes UNQUALIFIED
Octavia K GarufiIndiaAnna Fali QUALIFIED
Alejandro I IturbideJapanBernardo Dominic NEGOTIATION
Aruna H TollnerGermanyAnna Fali PROPOSAL
James K WaycottArgentinaOnyama Limba NEGOTIATION
Salvatore G DoeGermanyBernardo Dominic RENEWAL
Sinclair I SchemmerArgentinaXuxue Feng QUALIFIED
Faith L BriddickBrazilAnna Fali UNQUALIFIED
Salvatore R NickaCanadaBernardo Dominic UNQUALIFIED
Adams R OldroydCanadaIvan Magalhaes PROPOSAL
Silvio A SaylorsAustraliaElwin Sharvill RENEWAL
Murillo E ShinkoJapanAmy 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>