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
Izzy V MacleadGermanyIvan Magalhaes PROPOSAL
Wickens S OstroskyItalyBernardo Dominic UNQUALIFIED
Stacey E FlosiCanadaIoni Bowcher PROPOSAL
Kadeem D RoysterAustraliaStephen Shaw PROPOSAL
Kaitlin T RutaRussiaBernardo Dominic NEW
Sinclair U DarakjyIndiaElwin Sharvill RENEWAL
Rodrigues Z RimCanadaAnna Fali UNQUALIFIED
Misaki U RulapaughItalyXuxue Feng NEGOTIATION
Murillo S FollerRussiaElwin Sharvill NEGOTIATION
Leja B MarrierJapanAsiya Javayant NEW
Ricardo Z AmigonFranceBernardo Dominic UNQUALIFIED
Salvatore D CaudyFranceStephen Shaw UNQUALIFIED
Rodrigues H TollnerFranceOnyama Limba NEW
Kaitlin K CampainIndiaElwin Sharvill QUALIFIED
Johnson K ShinkoItalyXuxue Feng QUALIFIED
Kadeem T DilliardArgentinaOnyama Limba PROPOSAL
Stacey R StensethUnited KingdomOnyama Limba RENEWAL
Octavia G AlbaresArgentinaAnna Fali RENEWAL
Francesco R RimArgentinaXuxue Feng PROPOSAL
Tony Q VocelkaJapanBernardo Dominic NEW
Faith X NestleFranceAsiya Javayant RENEWAL
Jefferson L RutaFranceElwin Sharvill NEW
Nicolas H DarakjyUnited KingdomBernardo Dominic UNQUALIFIED
Izzy V AlbaresAustraliaOnyama Limba QUALIFIED
Ricardo Q MaletBrazilStephen Shaw NEW
Darci L PerinGermanyAsiya Javayant PROPOSAL
Antonio M CaldareraGermanyAnna Fali PROPOSAL
Ashley T GauchoFranceAsiya Javayant UNQUALIFIED
Sinclair S RutaGermanyIvan Magalhaes PROPOSAL
Juan I TollnerIndiaIoni Bowcher RENEWAL
Jennifer T PerinArgentinaStephen Shaw RENEWAL
Octavia A OstroskyGermanyAnna Fali NEW
Rodrigues F ChuiArgentinaBernardo Dominic UNQUALIFIED
Aditya A DilliardCanadaElwin Sharvill NEGOTIATION
Ricardo S GillianAustraliaAnna Fali NEGOTIATION
Arvin J MaletUnited KingdomStephen Shaw UNQUALIFIED
Tony C DoeUnited KingdomBernardo Dominic RENEWAL
Cody O PerinAustraliaAsiya Javayant PROPOSAL
Chavez U PerinUnited KingdomStephen Shaw PROPOSAL
Greenwood A RutaCanadaIoni Bowcher QUALIFIED
Emily R SchemmerGermanyIoni Bowcher NEW
Aditya K PaprockiItalyIoni Bowcher NEW
Juan H CampainArgentinaElwin Sharvill QUALIFIED
Deepesh J SaylorsCanadaElwin Sharvill PROPOSAL
Ivar S GillianIndiaXuxue Feng NEW
Adams Q PerinSpainIoni Bowcher UNQUALIFIED
Jones J StensethUnited KingdomBernardo Dominic PROPOSAL
Jefferson K VocelkaSpainAnna Fali PROPOSAL
Aruna O PoquetteCanadaIvan Magalhaes PROPOSAL
Maria B RulapaughRussiaIoni Bowcher RENEWAL
Horizontal
NameCountryRepresentativeStatus
Kaitlin E InouyeRussiaIvan Magalhaes NEGOTIATION
Julie J WaycottFranceOnyama Limba QUALIFIED
Salvatore H CaudyBrazilAmy Elsner PROPOSAL
Isabel N MacleadBrazilAmy Elsner RENEWAL
Stacey V VocelkaIndiaXuxue Feng RENEWAL
Munro I OstroskyArgentinaOnyama Limba RENEWAL
David G TollnerGermanyIvan Magalhaes NEGOTIATION
Murillo Y NestleAustraliaOnyama Limba NEGOTIATION
Smith Q FigeroaJapanIvan Magalhaes RENEWAL
Murillo Z FollerArgentinaBernardo Dominic NEW
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Costa O StockhamAustralia2025-04-27Morlong Associates RENEWAL22Ivan Magalhaes
1001Costa Y RoysterAustralia2025-04-24Benton, John B Jr NEW86Ivan Magalhaes
1002Darci K SchemmerAustralia2025-04-11Rousseaux, Michael Esq PROPOSAL35Elwin Sharvill
1003Alejandro O MacleadUnited Kingdom2025-04-13Chanay, Jeffrey A Esq QUALIFIED13Amy Elsner
1004Sinclair K SergiFrance2025-04-03Chapman, Ross E Esq PROPOSAL56Ioni Bowcher
1005Jones U GillianCanada2025-04-17Dorl, James J Esq PROPOSAL58Anna Fali
1006Jeanfrancois I GarufiSpain2025-04-14Buckley Miller Wright RENEWAL14Xuxue Feng
1007Greenwood H GillianUnited Kingdom2025-04-11Feltz Printing Service NEW66Amy Elsner
1008Rodrigues O AmigonFrance2025-04-24Printing Dimensions RENEWAL17Ioni Bowcher
1009Jeanfrancois V GauchoFrance2025-04-08Printing Dimensions QUALIFIED86Elwin Sharvill
1010Morrow U DilliardCanada2025-04-02Truhlar And Truhlar Attys NEW49Amy Elsner
1011Sinclair A AlbaresGermany2025-04-06Feiner Bros PROPOSAL52Amy Elsner
1012Ivar D OstroskyRussia2025-04-22Commercial Press QUALIFIED55Ioni Bowcher
1013Johnson P PerinIndia2025-04-15King, Christopher A Esq QUALIFIED51Stephen Shaw
1014Ivar F OstroskyArgentina2025-04-19Feltz Printing Service NEGOTIATION39Stephen Shaw
1015Octavia H KuskoIndia2025-04-20Truhlar And Truhlar Attys PROPOSAL95Bernardo Dominic
1016Costa V BriddickBrazil2025-04-20Benton, John B Jr UNQUALIFIED31Anna Fali
1017Salvatore P AlbaresItaly2025-04-20Chanay, Jeffrey A Esq NEGOTIATION82Elwin Sharvill
1018Smith J NestleBrazil2025-04-22Morlong Associates NEW85Bernardo Dominic
1019Julie P DilliardAustralia2025-04-16Morlong Associates NEGOTIATION52Ioni Bowcher
1020Misaki K PerinArgentina2025-04-19Dorl, James J Esq UNQUALIFIED28Bernardo Dominic
1021Rodrigues X MarrierCanada2025-04-10Feiner Bros NEGOTIATION62Ioni Bowcher
1022Aruna Q RoysterUnited Kingdom2025-04-02Printing Dimensions UNQUALIFIED36Xuxue Feng
1023Jefferson I FigeroaArgentina2025-04-28Rangoni Of Florence NEGOTIATION2Bernardo Dominic
1024Kaitlin I SergiJapan2025-04-26Rousseaux, Michael Esq PROPOSAL80Bernardo Dominic
1025Jones Q BowleyIndia2025-04-30Chapman, Ross E Esq NEW40Anna Fali
1026Clifford U SchemmerIndia2025-04-29Dorl, James J Esq UNQUALIFIED16Anna Fali
1027Leja E WhobreyJapan2025-04-22Morlong Associates UNQUALIFIED74Amy Elsner
1028Murillo D AlbaresArgentina2025-04-13Feltz Printing Service UNQUALIFIED69Elwin Sharvill
1029Chavez H FigeroaJapan2025-04-05Chapman, Ross E Esq NEW61Stephen Shaw
1030Johnson T BologniaCanada2025-04-01Feltz Printing Service RENEWAL65Anna Fali
1031Cody F FigeroaItaly2025-04-22King, Christopher A Esq RENEWAL48Ioni Bowcher
1032Julie C PoquetteBrazil2025-04-22Feltz Printing Service NEW79Ivan Magalhaes
1033Jennifer Y GillianJapan2025-04-10Morlong Associates NEW65Stephen Shaw
1034Izzy G MorascaBrazil2025-04-13Commercial Press NEGOTIATION95Stephen Shaw
1035Kadeem J BologniaArgentina2025-04-03Rousseaux, Michael Esq UNQUALIFIED30Elwin Sharvill
1036Aika W FollerItaly2025-04-03Chanay, Jeffrey A Esq UNQUALIFIED28Elwin Sharvill
1037Maria E DilliardBrazil2025-04-24Dorl, James J Esq NEGOTIATION36Bernardo Dominic
1038Adams E IturbideFrance2025-04-16Morlong Associates RENEWAL68Ivan Magalhaes
1039Leon O WaycottBrazil2025-04-28Chapman, Ross E Esq PROPOSAL4Ivan Magalhaes
1040Stacey M CampainFrance2025-04-23Dorl, James J Esq QUALIFIED64Amy Elsner
1041Francesco I FerenczAustralia2025-04-24Feiner Bros QUALIFIED97Xuxue Feng
1042Mujtaba I CaudyAustralia2025-04-23Chapman, Ross E Esq NEGOTIATION33Onyama Limba
1043Salvatore M MarrierArgentina2025-04-28Truhlar And Truhlar Attys NEGOTIATION58Amy Elsner
1044Julie Z ShinkoRussia2025-04-10Printing Dimensions NEGOTIATION86Ioni Bowcher
1045Alejandro X MacleadFrance2025-04-24Truhlar And Truhlar Attys QUALIFIED44Anna Fali
1046Aditya K AlbaresGermany2025-04-09Benton, John B Jr NEW31Xuxue Feng
1047Jefferson F NestleUnited Kingdom2025-04-20Morlong Associates RENEWAL46Anna Fali
1048Chavez D WhobreyAustralia2025-04-27Benton, John B Jr NEW89Ioni Bowcher
1049Greenwood R DoeItaly2025-04-28Feltz Printing Service PROPOSAL2Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Maisha O SaylorsSpainAnna Fali UNQUALIFIED
Silvio H SlusarskiSpainOnyama Limba NEGOTIATION
Izzy C MarrierArgentinaBernardo Dominic QUALIFIED
Wickens W MaletGermanyOnyama Limba UNQUALIFIED
Mujtaba F MaletJapanAmy Elsner QUALIFIED
Silvio A SergiJapanIoni Bowcher QUALIFIED
Adams L GlickAustraliaStephen Shaw QUALIFIED
James P KuskoArgentinaStephen Shaw PROPOSAL
Wickens Q MarrierGermanyAmy Elsner RENEWAL
Wickens U PaprockiJapanOnyama Limba RENEWAL
Stacey I NestleAustraliaElwin Sharvill NEW
Sinclair M OldroydIndiaAnna Fali QUALIFIED
Munro O KuskoItalyElwin Sharvill QUALIFIED
Isabel B DoeFranceElwin Sharvill UNQUALIFIED
Aditya V FigeroaCanadaAmy Elsner NEGOTIATION
Clifford Y MacleadRussiaOnyama Limba RENEWAL
Deepesh J SaylorsBrazilOnyama Limba NEGOTIATION
Stacey M MaletIndiaElwin Sharvill NEGOTIATION
Leon E GauchoIndiaXuxue Feng UNQUALIFIED
Salvatore I StensethRussiaIoni Bowcher QUALIFIED
Rodrigues C BowleyCanadaStephen Shaw UNQUALIFIED
Jones M PerinItalyStephen Shaw PROPOSAL
Jeanfrancois L WieserFranceAmy Elsner PROPOSAL
Claire S KolmetzArgentinaElwin Sharvill NEW
Darci B WieserFranceIvan Magalhaes NEW
Faith X CampainSpainAnna Fali UNQUALIFIED
Claire K GlickGermanyOnyama Limba PROPOSAL
Maria B CampainItalyAmy Elsner RENEWAL
James W GillianJapanElwin Sharvill UNQUALIFIED
Salvatore D AlbaresCanadaElwin Sharvill QUALIFIED
Cody N KolmetzAustraliaAmy Elsner UNQUALIFIED
Darci V SaylorsArgentinaBernardo Dominic RENEWAL
Ivar W TollnerIndiaXuxue Feng NEGOTIATION
Tony L PerinSpainIoni Bowcher PROPOSAL
Faith L VenereFranceBernardo Dominic NEGOTIATION
Kadeem N PoquetteSpainAsiya Javayant QUALIFIED
Aika Z BologniaGermanyXuxue Feng NEW
Aruna V RimIndiaAmy Elsner NEGOTIATION
Claire O WieserUnited KingdomAsiya Javayant QUALIFIED
James K DilliardRussiaAnna Fali NEGOTIATION
Julie Y PoquetteFranceBernardo Dominic QUALIFIED
Jones Z MacleadIndiaAsiya Javayant NEGOTIATION
Johnson H IturbideCanadaAnna Fali NEGOTIATION
Cody Y CaudySpainAmy Elsner NEW
Maisha Z GlickBrazilStephen Shaw UNQUALIFIED
Deepesh Z WieserSpainElwin Sharvill PROPOSAL
Jones G VocelkaArgentinaAnna Fali NEGOTIATION
Smith M SchemmerAustraliaBernardo Dominic QUALIFIED
Tony D StockhamSpainStephen Shaw QUALIFIED
Ivar S GarufiRussiaAsiya Javayant RENEWAL
Frozen Columns
Name
Julie N Darakjy
Aditya U Waycott
Nicolas E Dilliard
Misaki R Kolmetz
David J Caudy
Jefferson B Slusarski
Leon H Stockham
Arvin H Bolognia
Misaki D Flosi
Ashley A Venere
James I Malet
Aruna W Butt
Maisha E Caudy
Salvatore B Ferencz
Stacey O Venere
Jeanfrancois S Rulapaugh
Octavia B Kolmetz
Murillo Y Rulapaugh
Mujtaba C Ruta
Faith I Inouye
Maria Y Caudy
Kaitlin T Schemmer
Kaitlin T Glick
Alejandro Z Butt
Adams F Morasca
Salvatore K Saylors
Murillo C Darakjy
Kaitlin R Paprocki
Maisha D Iturbide
Johnson X Dilliard
Faith W Rim
Murillo F Gillian
Rodrigues F Chui
Mayumi T Bowley
Aika T Ferencz
Silvio A Rulapaugh
Faith E Royster
Leon M Campain
Cody I Briddick
Kaitlin O Dilliard
Isabel P Malet
Johnson E Chui
Aika R Garufi
Johnson L Saylors
Jefferson C Glick
Francesco P Tollner
David U Sergi
Kadeem I Paprocki
Adams V Vocelka
Clifford F Marrier
IdCountryDate
1000Japan2025-04-07
1001Spain2025-04-11
1002Italy2025-04-18
1003France2025-04-14
1004France2025-04-22
1005India2025-04-01
1006Italy2025-04-07
1007Australia2025-04-06
1008Canada2025-04-26
1009Brazil2025-04-11
1010Australia2025-04-14
1011Germany2025-04-05
1012India2025-04-01
1013Brazil2025-04-13
1014Brazil2025-04-27
1015Australia2025-04-28
1016Australia2025-04-13
1017Japan2025-04-26
1018Italy2025-04-17
1019United Kingdom2025-04-06
1020Japan2025-04-04
1021Germany2025-04-09
1022Argentina2025-04-07
1023Japan2025-04-18
1024Spain2025-04-10
1025India2025-04-02
1026France2025-04-22
1027Japan2025-04-30
1028Brazil2025-04-23
1029Italy2025-04-18
1030Russia2025-04-28
1031France2025-04-23
1032Russia2025-04-02
1033Russia2025-04-02
1034Argentina2025-04-12
1035United Kingdom2025-04-02
1036Canada2025-04-18
1037Australia2025-04-09
1038United Kingdom2025-04-05
1039Japan2025-04-22
1040Germany2025-04-29
1041United Kingdom2025-04-03
1042Brazil2025-04-29
1043Russia2025-04-17
1044Argentina2025-04-05
1045France2025-04-19
1046Spain2025-04-26
1047Argentina2025-04-21
1048India2025-04-05
1049Spain2025-04-09

On-Demand Data

NameIdCountryDate
Julie H Schemmer1000France2025-04-18
Antonio A Marrier1001Australia2025-04-14
Mujtaba V Slusarski1002United Kingdom2025-04-22
Aditya B Butt1003Russia2025-04-12
Rodrigues V Kolmetz1004Brazil2025-04-20
Faith L Stockham1005India2025-04-29
Kaitlin N Waycott1006India2025-04-02
Maisha I Poquette1007Spain2025-04-19
Morrow E Glick1008United Kingdom2025-04-08
Chavez I Kolmetz1009Brazil2025-04-27
Tony O Caudy1010Russia2025-04-02
Morrow V Perin1011United Kingdom2025-04-12
Alejandro F Sergi1012United Kingdom2025-04-14
Greenwood W Malet1013Japan2025-04-27
Antonio J Bowley1014Russia2025-04-04
Octavia V Doe1015India2025-04-12
Morrow P Morasca1016Argentina2025-04-10
Munro A Maclead1017Germany2025-04-11
Isabel P Butt1018Japan2025-04-28
Munro B Gillian1019Argentina2025-04-09
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Darci M FlosiFranceOnyama Limba QUALIFIED
Aditya O KolmetzFranceIoni Bowcher QUALIFIED
Octavia N GarufiBrazilStephen Shaw NEW
Ashley H PoquetteJapanAsiya Javayant PROPOSAL
Morrow I PoquetteGermanyAnna Fali QUALIFIED
Maria T MarrierBrazilXuxue Feng NEW
Arvin M PaprockiSpainAnna Fali PROPOSAL
Leon M CampainCanadaAmy Elsner NEW
Stacey I ButtItalyBernardo Dominic RENEWAL
Silvio T OstroskyFranceOnyama Limba RENEWAL
Kaitlin O TollnerCanadaElwin Sharvill NEW
Leon T GauchoCanadaAsiya Javayant RENEWAL
Misaki O CampainJapanElwin Sharvill NEGOTIATION
Faith J PaprockiCanadaXuxue Feng QUALIFIED
Kaitlin L SergiAustraliaIoni Bowcher PROPOSAL
Ashley U BologniaArgentinaOnyama Limba NEW
Kaitlin A MorascaJapanAmy Elsner RENEWAL
Darci Q MorascaBrazilAnna Fali PROPOSAL
Maisha X OldroydArgentinaAmy Elsner RENEWAL
Kadeem C CampainCanadaIvan Magalhaes NEW
Francesco L MacleadArgentinaOnyama Limba QUALIFIED
Mujtaba Z OldroydJapanAnna Fali UNQUALIFIED
Clifford J SaylorsFranceAsiya Javayant PROPOSAL
Julie T RulapaughJapanBernardo Dominic NEGOTIATION
Greenwood A MorascaBrazilIoni Bowcher NEGOTIATION
Claire Q PoquetteJapanXuxue Feng NEGOTIATION
Jennifer K VenereJapanOnyama Limba NEGOTIATION
Kaitlin C GarufiBrazilXuxue Feng NEGOTIATION
Ivar R NestleSpainIvan Magalhaes NEGOTIATION
Maria J BologniaSpainAsiya Javayant QUALIFIED
Adams Q RoysterItalyElwin Sharvill NEW
Juan Z IturbideBrazilBernardo Dominic NEGOTIATION
Leja G CaldareraGermanyAsiya Javayant NEGOTIATION
Nicolas A StensethCanadaOnyama Limba RENEWAL
Cody H MacleadUnited KingdomIvan Magalhaes UNQUALIFIED
Darci Q PoquetteSpainStephen Shaw QUALIFIED
Ashley H RoysterAustraliaAsiya Javayant UNQUALIFIED
Sinclair O OstroskyCanadaBernardo Dominic NEW
Alejandro U StensethCanadaStephen Shaw RENEWAL
Johnson G ShinkoIndiaAsiya Javayant NEGOTIATION

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