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
Leon U PaprockiAustraliaOnyama Limba NEGOTIATION
Aika X BriddickCanadaStephen Shaw UNQUALIFIED
Aika A StockhamItalyXuxue Feng NEGOTIATION
Ashley Y RoysterRussiaAsiya Javayant UNQUALIFIED
Smith V GillianSpainAsiya Javayant NEGOTIATION
Isabel H StensethUnited KingdomBernardo Dominic RENEWAL
Izzy D SaylorsIndiaIvan Magalhaes UNQUALIFIED
Clifford U OstroskyRussiaXuxue Feng NEW
Deepesh N NestleCanadaXuxue Feng PROPOSAL
Juan A TollnerGermanyStephen Shaw QUALIFIED
Faith N MarrierItalyXuxue Feng QUALIFIED
Jeanfrancois O BowleyArgentinaAnna Fali NEW
Rodrigues Z DoeJapanOnyama Limba RENEWAL
Costa H KuskoAustraliaStephen Shaw NEGOTIATION
Francesco B SaylorsFranceAsiya Javayant NEGOTIATION
Ivar V OstroskySpainAmy Elsner NEGOTIATION
Claire N PerinRussiaAnna Fali RENEWAL
Ivar P CaldareraBrazilAmy Elsner NEW
Clifford Y MorascaItalyElwin Sharvill RENEWAL
Ivar H GillianCanadaIoni Bowcher NEW
Leon M NickaGermanyStephen Shaw PROPOSAL
Faith G FerenczJapanAnna Fali RENEWAL
Tony U RimIndiaBernardo Dominic RENEWAL
Juan S MaletAustraliaBernardo Dominic NEW
Tony K StensethIndiaOnyama Limba NEW
Morrow V DoeCanadaElwin Sharvill NEW
Kadeem V ShinkoFranceAnna Fali NEW
Octavia E PoquetteIndiaBernardo Dominic NEW
Jones W KolmetzGermanyAmy Elsner NEW
Ricardo I CaudyBrazilStephen Shaw NEW
Mayumi K SchemmerFranceAsiya Javayant UNQUALIFIED
Leja O FigeroaJapanAnna Fali NEGOTIATION
Juan B VocelkaFranceOnyama Limba NEW
Salvatore G SchemmerBrazilIvan Magalhaes NEGOTIATION
Octavia Q KolmetzJapanElwin Sharvill PROPOSAL
Jefferson T NickaRussiaAsiya Javayant RENEWAL
Isabel K SaylorsAustraliaAsiya Javayant QUALIFIED
Octavia R StensethCanadaIoni Bowcher UNQUALIFIED
Ashley M GillianItalyBernardo Dominic QUALIFIED
Mayumi I PaprockiBrazilOnyama Limba NEGOTIATION
Francesco E ShinkoRussiaIoni Bowcher NEW
Leon W IturbideCanadaBernardo Dominic UNQUALIFIED
Leja Y AlbaresFranceOnyama Limba NEGOTIATION
Arvin F FollerFranceElwin Sharvill PROPOSAL
Misaki N PerinFranceAnna Fali PROPOSAL
Jones J WieserBrazilIoni Bowcher NEGOTIATION
Leja N WieserCanadaOnyama Limba QUALIFIED
Deepesh E RulapaughBrazilOnyama Limba UNQUALIFIED
Julie P IturbideUnited KingdomAsiya Javayant RENEWAL
Alejandro W TollnerSpainAmy Elsner UNQUALIFIED
Horizontal
NameCountryRepresentativeStatus
Cody N FollerSpainOnyama Limba NEGOTIATION
Cody Q CaldareraArgentinaIoni Bowcher RENEWAL
Stacey T GarufiRussiaXuxue Feng RENEWAL
Aditya L GauchoGermanyAsiya Javayant NEW
Chavez X WhobreyGermanyBernardo Dominic RENEWAL
Jones W InouyeAustraliaElwin Sharvill NEGOTIATION
Jefferson K GillianJapanIvan Magalhaes NEW
Costa T AmigonJapanAsiya Javayant NEGOTIATION
Jefferson B CaldareraItalyAnna Fali PROPOSAL
David Z FerenczIndiaAsiya Javayant NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Nicolas T StensethFrance2024-06-11Rousseaux, Michael Esq NEGOTIATION54Asiya Javayant
1001Jefferson D KolmetzFrance2024-05-29Commercial Press NEW49Xuxue Feng
1002Arvin Q MacleadArgentina2024-06-10Dorl, James J Esq PROPOSAL78Ioni Bowcher
1003Faith A RoysterCanada2024-06-16Feiner Bros NEW13Asiya Javayant
1004Jones L FollerRussia2024-06-23Rangoni Of Florence NEGOTIATION27Onyama Limba
1005Jefferson I FollerUnited Kingdom2024-06-16Rangoni Of Florence NEGOTIATION25Ivan Magalhaes
1006Chavez E WhobreyFrance2024-06-18Printing Dimensions PROPOSAL65Amy Elsner
1007Kaitlin G RimSpain2024-05-30Chapman, Ross E Esq PROPOSAL7Onyama Limba
1008Julie R FigeroaBrazil2024-05-31Commercial Press NEGOTIATION86Ioni Bowcher
1009Kadeem O SlusarskiCanada2024-06-03Benton, John B Jr QUALIFIED51Amy Elsner
1010Francesco Z GlickCanada2024-06-12Buckley Miller Wright PROPOSAL15Xuxue Feng
1011Murillo W RulapaughAustralia2024-06-03Chemel, James L Cpa RENEWAL35Anna Fali
1012Silvio L MorascaJapan2024-05-31Printing Dimensions NEW0Asiya Javayant
1013Kadeem I RulapaughJapan2024-06-19Printing Dimensions RENEWAL21Amy Elsner
1014Izzy M RoysterJapan2024-06-07Rangoni Of Florence NEW81Stephen Shaw
1015Jeanfrancois U NestleArgentina2024-06-12Truhlar And Truhlar Attys NEGOTIATION60Onyama Limba
1016Misaki F DoeJapan2024-06-10Dorl, James J Esq PROPOSAL54Ioni Bowcher
1017Darci E OldroydCanada2024-06-01Buckley Miller Wright UNQUALIFIED3Amy Elsner
1018Morrow C StockhamFrance2024-05-27Printing Dimensions QUALIFIED63Ioni Bowcher
1019Ricardo M TollnerArgentina2024-06-11King, Christopher A Esq QUALIFIED83Ioni Bowcher
1020Maisha D DoeAustralia2024-06-24Truhlar And Truhlar Attys QUALIFIED23Ivan Magalhaes
1021Emily J KolmetzSpain2024-06-05Printing Dimensions NEGOTIATION51Stephen Shaw
1022Nicolas F VocelkaRussia2024-06-03Chanay, Jeffrey A Esq NEGOTIATION97Amy Elsner
1023Maria F TollnerCanada2024-05-28Feiner Bros PROPOSAL11Ivan Magalhaes
1024Aditya F PerinItaly2024-06-16Feiner Bros PROPOSAL82Xuxue Feng
1025Aika F GlickBrazil2024-06-10King, Christopher A Esq RENEWAL92Elwin Sharvill
1026Aruna K StensethJapan2024-05-27Dorl, James J Esq RENEWAL21Elwin Sharvill
1027Antonio H IturbideArgentina2024-06-19Benton, John B Jr RENEWAL91Ivan Magalhaes
1028Wickens H MacleadJapan2024-06-23King, Christopher A Esq NEGOTIATION92Asiya Javayant
1029Leon S FlosiAustralia2024-06-01Truhlar And Truhlar Attys NEGOTIATION25Onyama Limba
1030Emily Q NestleItaly2024-06-17Benton, John B Jr QUALIFIED12Ioni Bowcher
1031Claire A VocelkaCanada2024-05-28Printing Dimensions NEGOTIATION68Ivan Magalhaes
1032Munro W WieserCanada2024-06-08Morlong Associates RENEWAL1Anna Fali
1033Jennifer B GarufiJapan2024-06-13Morlong Associates NEGOTIATION21Bernardo Dominic
1034Smith R MaletBrazil2024-06-05Chemel, James L Cpa NEGOTIATION87Amy Elsner
1035Maria K GarufiRussia2024-06-07Morlong Associates NEGOTIATION53Anna Fali
1036Kaitlin B MaletJapan2024-06-08Dorl, James J Esq UNQUALIFIED15Asiya Javayant
1037Francesco A SaylorsBrazil2024-06-19Chemel, James L Cpa RENEWAL25Onyama Limba
1038David U SchemmerBrazil2024-06-05Feltz Printing Service PROPOSAL23Elwin Sharvill
1039Izzy A NickaRussia2024-06-19Chemel, James L Cpa QUALIFIED81Asiya Javayant
1040Kaitlin J MacleadFrance2024-06-02Rangoni Of Florence RENEWAL96Onyama Limba
1041Ashley O MaletGermany2024-06-16Chanay, Jeffrey A Esq NEW8Elwin Sharvill
1042Chavez S FlosiAustralia2024-06-09Benton, John B Jr PROPOSAL62Ioni Bowcher
1043Silvio V StockhamArgentina2024-06-11Chanay, Jeffrey A Esq QUALIFIED34Stephen Shaw
1044Jones L DarakjyItaly2024-06-09Truhlar And Truhlar Attys NEW41Onyama Limba
1045Sinclair L WhobreyUnited Kingdom2024-06-08Truhlar And Truhlar Attys UNQUALIFIED73Bernardo Dominic
1046Kadeem O OstroskyAustralia2024-06-04Rousseaux, Michael Esq UNQUALIFIED12Anna Fali
1047Aditya D CampainBrazil2024-06-10Printing Dimensions RENEWAL2Amy Elsner
1048Octavia H OldroydItaly2024-06-04Rangoni Of Florence QUALIFIED61Ivan Magalhaes
1049Wickens P MacleadUnited Kingdom2024-06-02Printing Dimensions NEGOTIATION52Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
Izzy J ShinkoBrazilIvan Magalhaes PROPOSAL
Arvin Z MaletCanadaAsiya Javayant NEGOTIATION
Kadeem E BologniaArgentinaStephen Shaw PROPOSAL
Alejandro O RutaArgentinaAsiya Javayant NEW
Jefferson V VocelkaUnited KingdomIvan Magalhaes NEGOTIATION
Jeanfrancois Y WaycottJapanOnyama Limba QUALIFIED
Stacey T IturbideUnited KingdomOnyama Limba UNQUALIFIED
Deepesh M FlosiCanadaAsiya Javayant UNQUALIFIED
Mujtaba K KuskoFranceElwin Sharvill NEGOTIATION
Claire V NestleIndiaElwin Sharvill NEGOTIATION
Juan F RulapaughFranceIoni Bowcher NEGOTIATION
Darci B WhobreyItalyIvan Magalhaes QUALIFIED
Aditya A FlosiGermanyIoni Bowcher PROPOSAL
Maria I ChuiGermanyXuxue Feng NEGOTIATION
Deepesh Y AmigonArgentinaElwin Sharvill QUALIFIED
Rodrigues S SergiSpainAsiya Javayant UNQUALIFIED
Julie I FlosiBrazilIvan Magalhaes PROPOSAL
Arvin U GarufiUnited KingdomXuxue Feng NEW
Leon D BologniaIndiaIvan Magalhaes RENEWAL
Claire Q WieserAustraliaAnna Fali NEW
Greenwood Q FollerBrazilIoni Bowcher QUALIFIED
Ivar H DarakjyRussiaXuxue Feng NEW
Jones X IturbideSpainAnna Fali UNQUALIFIED
Murillo Y CampainSpainAmy Elsner PROPOSAL
Wickens W AlbaresBrazilIvan Magalhaes UNQUALIFIED
Tony V BologniaRussiaIvan Magalhaes PROPOSAL
Juan P MaletIndiaIoni Bowcher NEW
Izzy V MacleadArgentinaIvan Magalhaes UNQUALIFIED
Kadeem D MorascaArgentinaIvan Magalhaes NEW
Morrow X PerinIndiaStephen Shaw QUALIFIED
Aruna H AmigonGermanyOnyama Limba PROPOSAL
Tony Q GillianBrazilBernardo Dominic NEW
Kaitlin D StensethItalyOnyama Limba UNQUALIFIED
Mujtaba U GauchoSpainOnyama Limba PROPOSAL
Smith J BriddickArgentinaXuxue Feng PROPOSAL
Darci W WieserAustraliaBernardo Dominic NEGOTIATION
Leja O SlusarskiRussiaIoni Bowcher QUALIFIED
Kadeem D FigeroaGermanyIvan Magalhaes PROPOSAL
Arvin P FerenczIndiaAsiya Javayant NEW
Munro H CampainItalyXuxue Feng NEGOTIATION
James X MacleadRussiaAmy Elsner QUALIFIED
Sinclair T PaprockiArgentinaOnyama Limba UNQUALIFIED
Rodrigues X TollnerUnited KingdomElwin Sharvill NEGOTIATION
Octavia Y ShinkoGermanyIvan Magalhaes NEW
Alejandro D PaprockiAustraliaElwin Sharvill NEGOTIATION
Leja S FlosiCanadaXuxue Feng NEGOTIATION
Costa V NestleUnited KingdomOnyama Limba NEGOTIATION
Johnson M RimGermanyAnna Fali RENEWAL
Misaki K GarufiBrazilAmy Elsner QUALIFIED
Isabel B ButtCanadaElwin Sharvill QUALIFIED
Frozen Columns
Name
David P Dilliard
Isabel G Flosi
Leon K Caudy
Ricardo I Iturbide
James F Albares
Maria V Nicka
Smith B Poquette
Nicolas L Bowley
Ivar O Saylors
Smith J Foller
Ashley C Kolmetz
Alejandro X Morasca
Kadeem O Chui
Alejandro B Bolognia
Costa G Vocelka
Greenwood V Shinko
Juan W Stockham
Clifford V Briddick
Juan U Whobrey
Jones C Dilliard
Izzy V Poquette
Nicolas B Saylors
Costa W Figeroa
Wickens D Inouye
Emily O Nestle
Deepesh Z Malet
David Q Malet
Greenwood F Campain
Costa Y Butt
Ricardo T Marrier
Johnson G Kusko
Jefferson S Butt
Deepesh J Wieser
Jefferson M Paprocki
Francesco F Iturbide
Misaki Y Inouye
Alejandro G Stenseth
Deepesh J Saylors
Leja U Maclead
Leon N Marrier
Smith Q Marrier
Mayumi L Gaucho
Misaki F Foller
Deepesh V Foller
Salvatore O Albares
Izzy B Paprocki
Darci C Saylors
Johnson M Gaucho
Aditya R Malet
Faith Q Poquette
IdCountryDate
1000Canada2024-06-13
1001Japan2024-06-19
1002Argentina2024-06-23
1003Germany2024-06-07
1004Spain2024-06-13
1005Canada2024-06-17
1006Japan2024-06-23
1007Brazil2024-06-02
1008Japan2024-06-10
1009Brazil2024-05-26
1010India2024-05-31
1011Brazil2024-06-17
1012Argentina2024-06-24
1013United Kingdom2024-06-04
1014Brazil2024-06-19
1015Russia2024-06-01
1016Russia2024-06-05
1017Argentina2024-06-18
1018Germany2024-06-07
1019Japan2024-05-26
1020France2024-06-15
1021United Kingdom2024-05-27
1022France2024-06-12
1023Germany2024-06-08
1024Italy2024-06-17
1025Canada2024-05-29
1026Italy2024-06-11
1027Argentina2024-06-08
1028India2024-06-17
1029Canada2024-06-16
1030India2024-06-23
1031Italy2024-05-28
1032Argentina2024-06-18
1033India2024-06-17
1034Argentina2024-06-08
1035Spain2024-06-04
1036India2024-06-03
1037Australia2024-06-17
1038Italy2024-06-18
1039France2024-06-15
1040United Kingdom2024-05-28
1041United Kingdom2024-06-09
1042Argentina2024-06-11
1043Germany2024-06-16
1044Australia2024-06-24
1045Germany2024-06-17
1046Russia2024-06-13
1047United Kingdom2024-05-28
1048France2024-06-06
1049United Kingdom2024-06-24

On-Demand Data

NameIdCountryDate
Jefferson Q Stockham1000Argentina2024-06-21
Murillo J Royster1001United Kingdom2024-06-17
Rodrigues U Perin1002Brazil2024-05-27
Sinclair W Flosi1003Australia2024-05-29
Juan Z Darakjy1004Brazil2024-06-13
Rodrigues I Waycott1005Argentina2024-05-28
Smith N Foller1006Brazil2024-05-31
Izzy A Perin1007Brazil2024-06-24
Leja W Glick1008Canada2024-06-11
Leon H Butt1009Canada2024-06-24
Murillo H Bolognia1010Argentina2024-05-30
Maria H Iturbide1011India2024-06-09
David K Saylors1012Argentina2024-05-31
Misaki L Saylors1013India2024-06-23
Jennifer L Malet1014Russia2024-06-03
Maria B Nicka1015United Kingdom2024-06-08
Isabel Z Doe1016Germany2024-06-23
Ricardo X Nicka1017India2024-06-21
Leon M Saylors1018Russia2024-06-15
Jennifer B Saylors1019Italy2024-05-29
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Julie A InouyeSpainElwin Sharvill UNQUALIFIED
Clifford R PaprockiIndiaOnyama Limba PROPOSAL
Nicolas W TollnerFranceAmy Elsner NEGOTIATION
Costa V StensethArgentinaIoni Bowcher PROPOSAL
Johnson N StensethIndiaAsiya Javayant NEGOTIATION
Costa J GauchoItalyStephen Shaw NEGOTIATION
Jeanfrancois A SaylorsFranceIvan Magalhaes NEGOTIATION
Darci S BriddickItalyXuxue Feng QUALIFIED
Aika N WaycottRussiaBernardo Dominic NEGOTIATION
Francesco I MarrierBrazilOnyama Limba NEGOTIATION
Alejandro X StensethArgentinaXuxue Feng RENEWAL
Murillo Q SchemmerCanadaElwin Sharvill NEW
James K WhobreyJapanStephen Shaw PROPOSAL
Tony F DilliardIndiaStephen Shaw UNQUALIFIED
Kadeem Q PerinGermanyAnna Fali NEGOTIATION
Darci Z WaycottArgentinaAsiya Javayant QUALIFIED
Sinclair Q PoquetteRussiaAmy Elsner NEW
Cody P KuskoUnited KingdomIoni Bowcher NEGOTIATION
Tony C VenereUnited KingdomIoni Bowcher QUALIFIED
David V NestleRussiaStephen Shaw NEGOTIATION
Cody B StockhamRussiaAnna Fali UNQUALIFIED
Tony D DilliardJapanAnna Fali RENEWAL
David R SlusarskiAustraliaOnyama Limba PROPOSAL
Silvio P SaylorsAustraliaOnyama Limba NEGOTIATION
Ivar P SaylorsItalyOnyama Limba PROPOSAL
Octavia F KuskoAustraliaAmy Elsner NEGOTIATION
Ricardo N DarakjyBrazilIvan Magalhaes UNQUALIFIED
James T TollnerIndiaAnna Fali RENEWAL
Isabel A SchemmerIndiaIoni Bowcher NEW
Mujtaba D WhobreyIndiaAmy Elsner NEGOTIATION
Arvin S GauchoFranceIvan Magalhaes RENEWAL
Alejandro O BologniaIndiaElwin Sharvill NEGOTIATION
Claire Q GillianJapanIvan Magalhaes NEW
Leja R RutaAustraliaAmy Elsner PROPOSAL
Claire Y WieserArgentinaElwin Sharvill UNQUALIFIED
Clifford J WaycottSpainIvan Magalhaes QUALIFIED
Salvatore G OstroskyUnited KingdomIvan Magalhaes RENEWAL
Ashley B BowleyUnited KingdomIvan Magalhaes RENEWAL
Nicolas W BriddickAustraliaAmy Elsner PROPOSAL
Jones C TollnerCanadaOnyama Limba UNQUALIFIED

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