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
Johnson I FigeroaRussiaElwin Sharvill NEGOTIATION
Nicolas G MaletSpainAnna Fali QUALIFIED
Emily S PoquetteIndiaBernardo Dominic NEW
David U MaletAustraliaIoni Bowcher NEW
Munro P AmigonCanadaIvan Magalhaes NEW
Alejandro U FlosiJapanXuxue Feng NEGOTIATION
Aruna X DilliardIndiaElwin Sharvill RENEWAL
Salvatore U ButtGermanyXuxue Feng NEGOTIATION
Chavez Q OldroydUnited KingdomOnyama Limba RENEWAL
Cody Z StockhamAustraliaElwin Sharvill RENEWAL
Leon O RutaSpainXuxue Feng UNQUALIFIED
Clifford D DilliardSpainStephen Shaw RENEWAL
Cody O TollnerCanadaOnyama Limba NEGOTIATION
Jennifer Y SlusarskiIndiaAnna Fali NEGOTIATION
James T SergiUnited KingdomElwin Sharvill UNQUALIFIED
Chavez Q RoysterJapanXuxue Feng NEW
Isabel W GarufiIndiaIoni Bowcher NEGOTIATION
Ashley F SlusarskiUnited KingdomAmy Elsner PROPOSAL
Juan X VocelkaCanadaAsiya Javayant QUALIFIED
Salvatore I IturbideRussiaIvan Magalhaes NEW
Salvatore D InouyeAustraliaAsiya Javayant NEW
Costa Y KolmetzJapanIvan Magalhaes RENEWAL
Kadeem F FollerRussiaAmy Elsner NEW
Juan H FlosiItalyXuxue Feng UNQUALIFIED
Aika E OldroydAustraliaAsiya Javayant UNQUALIFIED
Alejandro Y StensethGermanyIvan Magalhaes UNQUALIFIED
Jennifer M RulapaughUnited KingdomBernardo Dominic QUALIFIED
Rodrigues E RimCanadaAsiya Javayant PROPOSAL
James P KolmetzRussiaAnna Fali NEW
Aditya P VenereUnited KingdomOnyama Limba PROPOSAL
Morrow M BriddickBrazilStephen Shaw NEGOTIATION
Aruna C NestleGermanyAsiya Javayant RENEWAL
Sinclair N IturbideArgentinaIoni Bowcher PROPOSAL
Cody I ButtItalyIoni Bowcher PROPOSAL
David U FigeroaItalyXuxue Feng NEW
Tony V MarrierFranceBernardo Dominic PROPOSAL
Emily G PoquetteSpainElwin Sharvill NEW
Deepesh I SaylorsRussiaIoni Bowcher PROPOSAL
Antonio X StensethIndiaAnna Fali NEGOTIATION
Mujtaba L CaldareraArgentinaXuxue Feng NEGOTIATION
Sinclair E RulapaughGermanyAmy Elsner NEGOTIATION
Arvin W GillianIndiaBernardo Dominic NEGOTIATION
Maria F MarrierArgentinaIvan Magalhaes NEW
Rodrigues U NestleRussiaStephen Shaw NEGOTIATION
Cody O MorascaCanadaOnyama Limba NEGOTIATION
Maisha K MorascaJapanStephen Shaw PROPOSAL
Clifford H MaletArgentinaAsiya Javayant NEGOTIATION
Julie P FerenczFranceOnyama Limba NEGOTIATION
Ashley I SchemmerSpainOnyama Limba RENEWAL
Munro F OstroskyItalyAmy Elsner NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Antonio V WieserGermanyAsiya Javayant UNQUALIFIED
Jones N NickaUnited KingdomAsiya Javayant UNQUALIFIED
Johnson S DilliardBrazilAmy Elsner NEGOTIATION
Kaitlin J KolmetzFranceStephen Shaw PROPOSAL
Ivar G ShinkoArgentinaIoni Bowcher QUALIFIED
Jeanfrancois K KolmetzBrazilBernardo Dominic QUALIFIED
Ivar M GauchoJapanStephen Shaw UNQUALIFIED
Sinclair K GillianSpainElwin Sharvill NEGOTIATION
Francesco B KuskoCanadaBernardo Dominic RENEWAL
Misaki A WhobreyArgentinaXuxue Feng NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Stacey Z BriddickAustralia2025-05-31Chapman, Ross E Esq NEGOTIATION79Bernardo Dominic
1001Sinclair H CampainUnited Kingdom2025-05-11Rousseaux, Michael Esq QUALIFIED12Bernardo Dominic
1002Cody R RutaUnited Kingdom2025-05-30Commercial Press UNQUALIFIED20Xuxue Feng
1003Maisha O VocelkaAustralia2025-05-28Buckley Miller Wright NEGOTIATION9Ioni Bowcher
1004Smith G SergiUnited Kingdom2025-05-25Feltz Printing Service PROPOSAL57Bernardo Dominic
1005Wickens L DilliardIndia2025-05-08Chapman, Ross E Esq QUALIFIED57Ivan Magalhaes
1006Jeanfrancois Y WaycottFrance2025-05-16Printing Dimensions QUALIFIED4Xuxue Feng
1007Izzy F PoquetteArgentina2025-05-28Dorl, James J Esq RENEWAL87Xuxue Feng
1008Mayumi P FerenczAustralia2025-05-15Truhlar And Truhlar Attys QUALIFIED64Xuxue Feng
1009Nicolas J StensethGermany2025-05-06Chemel, James L Cpa NEW27Stephen Shaw
1010Isabel I WaycottIndia2025-06-02Benton, John B Jr NEGOTIATION45Bernardo Dominic
1011Leja X DilliardAustralia2025-05-06Benton, John B Jr NEGOTIATION32Xuxue Feng
1012Juan I PaprockiFrance2025-05-12Chapman, Ross E Esq UNQUALIFIED1Elwin Sharvill
1013Aditya T MorascaSpain2025-05-20Rangoni Of Florence NEW0Stephen Shaw
1014Maisha D WieserBrazil2025-05-24Dorl, James J Esq NEW5Asiya Javayant
1015Cody X WhobreyUnited Kingdom2025-05-09Chemel, James L Cpa UNQUALIFIED2Asiya Javayant
1016Arvin I CaldareraCanada2025-05-22Benton, John B Jr NEGOTIATION77Asiya Javayant
1017Kaitlin C NickaIndia2025-06-03Feiner Bros RENEWAL73Elwin Sharvill
1018Salvatore C BologniaAustralia2025-05-07Buckley Miller Wright UNQUALIFIED96Xuxue Feng
1019Adams J BowleyRussia2025-05-16Feiner Bros QUALIFIED50Asiya Javayant
1020Wickens G BriddickAustralia2025-05-18Buckley Miller Wright NEW65Xuxue Feng
1021Kaitlin X SchemmerFrance2025-05-12King, Christopher A Esq RENEWAL85Elwin Sharvill
1022Ricardo L ShinkoSpain2025-05-15Chanay, Jeffrey A Esq NEGOTIATION70Elwin Sharvill
1023Costa W DoeAustralia2025-06-02Buckley Miller Wright RENEWAL97Amy Elsner
1024Emily Q StockhamFrance2025-05-11Commercial Press PROPOSAL29Elwin Sharvill
1025Wickens V MacleadArgentina2025-05-26Feiner Bros RENEWAL28Anna Fali
1026Leon W MacleadRussia2025-06-01Feiner Bros RENEWAL94Stephen Shaw
1027Aruna E ShinkoArgentina2025-05-30Morlong Associates NEW59Amy Elsner
1028Julie R CaudyUnited Kingdom2025-05-07Feltz Printing Service RENEWAL92Amy Elsner
1029Julie X FollerIndia2025-05-26Chapman, Ross E Esq PROPOSAL0Elwin Sharvill
1030Aditya E CaldareraArgentina2025-05-31Printing Dimensions RENEWAL97Onyama Limba
1031Isabel O MaletIndia2025-05-23Printing Dimensions PROPOSAL7Ivan Magalhaes
1032Clifford Z StockhamItaly2025-05-07Morlong Associates RENEWAL51Stephen Shaw
1033Octavia T BriddickJapan2025-05-08Buckley Miller Wright QUALIFIED54Stephen Shaw
1034Emily O CampainArgentina2025-05-06Truhlar And Truhlar Attys QUALIFIED56Bernardo Dominic
1035Julie Z ShinkoFrance2025-06-03Feltz Printing Service QUALIFIED16Xuxue Feng
1036Murillo B InouyeBrazil2025-05-29Morlong Associates NEGOTIATION96Ioni Bowcher
1037Faith L RimSpain2025-05-20Chapman, Ross E Esq NEW95Stephen Shaw
1038Jennifer T DarakjyGermany2025-05-31Feltz Printing Service NEW24Xuxue Feng
1039Maisha W CaudyUnited Kingdom2025-05-30Benton, John B Jr PROPOSAL20Bernardo Dominic
1040Rodrigues Y VenereSpain2025-05-13Morlong Associates NEGOTIATION26Anna Fali
1041Julie S RutaItaly2025-05-09Morlong Associates NEW23Asiya Javayant
1042Aditya X MaletItaly2025-05-24Feiner Bros UNQUALIFIED71Onyama Limba
1043Silvio H CaldareraIndia2025-06-02Chapman, Ross E Esq NEGOTIATION44Stephen Shaw
1044Maisha M GauchoRussia2025-05-18Chapman, Ross E Esq NEW42Anna Fali
1045Ashley I CaldareraGermany2025-05-10Commercial Press RENEWAL2Anna Fali
1046David K MaletBrazil2025-05-16Feiner Bros QUALIFIED42Xuxue Feng
1047Juan H AlbaresUnited Kingdom2025-05-07Printing Dimensions RENEWAL76Onyama Limba
1048Maisha F MaletUnited Kingdom2025-05-26Chanay, Jeffrey A Esq NEW24Anna Fali
1049Ricardo F DilliardSpain2025-05-25Chapman, Ross E Esq PROPOSAL61Bernardo Dominic
Frozen Rows
NameCountryRepresentativeStatus
Ashley W FollerCanadaOnyama Limba NEW
Kadeem H OldroydBrazilBernardo Dominic RENEWAL
Misaki A RoysterSpainElwin Sharvill NEGOTIATION
Adams Z AmigonAustraliaOnyama Limba QUALIFIED
Deepesh E WieserJapanStephen Shaw RENEWAL
Misaki R GillianGermanyAsiya Javayant RENEWAL
Alejandro N IturbideBrazilOnyama Limba RENEWAL
Chavez W ShinkoCanadaAnna Fali PROPOSAL
Octavia G VocelkaRussiaIvan Magalhaes NEGOTIATION
Munro M CampainIndiaXuxue Feng UNQUALIFIED
Aditya C KolmetzUnited KingdomElwin Sharvill PROPOSAL
Mayumi C NickaCanadaIvan Magalhaes UNQUALIFIED
Francesco K GarufiJapanAnna Fali NEGOTIATION
Smith P GauchoIndiaOnyama Limba RENEWAL
Misaki W AmigonBrazilXuxue Feng RENEWAL
Costa K RutaUnited KingdomStephen Shaw NEW
Adams G KolmetzItalyAmy Elsner RENEWAL
Jefferson I WaycottSpainAsiya Javayant UNQUALIFIED
Leja C KolmetzRussiaAnna Fali NEGOTIATION
Smith V NestleIndiaElwin Sharvill NEGOTIATION
Faith Z InouyeRussiaStephen Shaw NEGOTIATION
Smith Q PaprockiUnited KingdomAnna Fali UNQUALIFIED
Johnson Y GauchoIndiaAsiya Javayant UNQUALIFIED
Izzy D SergiFranceAmy Elsner NEW
Emily L RimIndiaElwin Sharvill RENEWAL
Munro H RoysterBrazilElwin Sharvill NEGOTIATION
Leon L IturbideUnited KingdomBernardo Dominic NEGOTIATION
Sinclair G WaycottUnited KingdomIvan Magalhaes NEW
Greenwood L GauchoUnited KingdomAsiya Javayant NEW
Aika Y OldroydItalyOnyama Limba RENEWAL
James B TollnerSpainOnyama Limba NEW
Chavez D NestleIndiaIoni Bowcher QUALIFIED
Mayumi K GlickGermanyIvan Magalhaes PROPOSAL
Jennifer B KuskoArgentinaOnyama Limba QUALIFIED
Aditya U RimAustraliaStephen Shaw PROPOSAL
Chavez G InouyeJapanAsiya Javayant RENEWAL
Murillo Z SlusarskiFranceElwin Sharvill NEW
Morrow O MacleadFranceOnyama Limba QUALIFIED
Clifford V AlbaresItalyElwin Sharvill RENEWAL
Mayumi D DoeFranceOnyama Limba RENEWAL
Juan V FollerIndiaIoni Bowcher QUALIFIED
Jones M SaylorsBrazilAnna Fali PROPOSAL
Kaitlin K MacleadRussiaBernardo Dominic PROPOSAL
Aika D MacleadCanadaOnyama Limba NEGOTIATION
Adams C MacleadJapanBernardo Dominic RENEWAL
Wickens X RutaAustraliaBernardo Dominic RENEWAL
Rodrigues Y DarakjyIndiaStephen Shaw NEGOTIATION
Izzy O WieserBrazilAsiya Javayant NEGOTIATION
Salvatore Y CaldareraAustraliaOnyama Limba NEGOTIATION
Nicolas G RimFranceAnna Fali RENEWAL
Frozen Columns
Name
Morrow X Schemmer
Ashley W Slusarski
Leja J Rim
Ivar H Caudy
Tony E Royster
Ashley B Ostrosky
Murillo X Paprocki
Clifford L Iturbide
Aditya A Slusarski
Maria T Nicka
Jeanfrancois Z Caldarera
Cody T Iturbide
Maria D Figeroa
Francesco B Schemmer
Ivar K Kusko
Arvin O Darakjy
Jefferson H Stockham
Emily P Gillian
Deepesh O Rulapaugh
Murillo S Perin
Morrow B Saylors
Greenwood W Malet
Sinclair F Iturbide
Johnson O Oldroyd
Ashley S Saylors
Cody P Oldroyd
Ricardo S Oldroyd
Jeanfrancois O Malet
Wickens Z Wieser
Smith O Whobrey
Kadeem B Gillian
Maria E Paprocki
Clifford B Gaucho
Emily K Ferencz
Faith F Chui
Tony D Morasca
Mayumi V Perin
Cody M Caudy
Ashley E Saylors
Julie M Gillian
Rodrigues L Venere
Tony C Foller
Kaitlin S Kolmetz
Izzy X Albares
Darci E Iturbide
Jeanfrancois Q Albares
Munro J Wieser
Ricardo N Campain
Julie Z Rim
Misaki R Foller
IdCountryDate
1000Canada2025-05-20
1001Germany2025-05-15
1002Spain2025-05-30
1003Brazil2025-05-19
1004Russia2025-05-21
1005Japan2025-05-15
1006France2025-05-12
1007Australia2025-05-07
1008Brazil2025-05-23
1009Germany2025-06-02
1010Germany2025-05-18
1011United Kingdom2025-05-08
1012India2025-05-20
1013France2025-05-09
1014Japan2025-05-09
1015Canada2025-05-18
1016Spain2025-06-03
1017Spain2025-06-04
1018Argentina2025-05-18
1019Germany2025-05-30
1020Argentina2025-05-22
1021Canada2025-05-18
1022Brazil2025-05-29
1023Argentina2025-05-26
1024United Kingdom2025-06-03
1025Germany2025-05-15
1026Australia2025-05-13
1027Canada2025-05-14
1028France2025-05-06
1029Canada2025-06-01
1030Russia2025-06-03
1031Japan2025-05-23
1032Italy2025-05-30
1033Canada2025-06-04
1034United Kingdom2025-05-12
1035Argentina2025-05-08
1036Germany2025-05-11
1037Italy2025-05-09
1038Germany2025-05-12
1039Argentina2025-05-26
1040Argentina2025-05-06
1041France2025-05-21
1042France2025-05-31
1043Argentina2025-05-11
1044United Kingdom2025-05-08
1045Argentina2025-05-10
1046Australia2025-05-06
1047United Kingdom2025-05-24
1048Argentina2025-05-06
1049India2025-05-10

On-Demand Data

NameIdCountryDate
Ashley F Sergi1000Germany2025-05-28
Tony E Royster1001Germany2025-05-12
Greenwood X Gillian1002Australia2025-06-02
Darci K Stenseth1003Japan2025-05-26
Mayumi M Maclead1004Brazil2025-05-24
Kadeem K Ruta1005France2025-05-27
Costa B Iturbide1006Italy2025-05-18
Ashley D Bowley1007Argentina2025-05-30
Arvin Z Dilliard1008France2025-05-06
Deepesh D Paprocki1009France2025-05-09
Ashley J Schemmer1010Germany2025-06-04
Emily A Doe1011India2025-05-30
Maisha H Slusarski1012United Kingdom2025-05-29
Ricardo P Saylors1013India2025-05-13
Silvio U Poquette1014Russia2025-05-19
Ricardo T Campain1015Russia2025-05-12
Tony W Tollner1016Spain2025-05-16
Jennifer V Stockham1017Canada2025-05-11
Morrow W Venere1018Italy2025-05-10
Kaitlin H Maclead1019Brazil2025-05-17
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Salvatore W RimAustraliaAmy Elsner UNQUALIFIED
Misaki B ShinkoItalyElwin Sharvill PROPOSAL
Morrow S StensethUnited KingdomStephen Shaw QUALIFIED
Arvin W FlosiSpainOnyama Limba UNQUALIFIED
Darci Y NickaBrazilOnyama Limba RENEWAL
Kaitlin Y BowleyItalyXuxue Feng NEW
Leja N MaletIndiaOnyama Limba PROPOSAL
Johnson I RimIndiaXuxue Feng PROPOSAL
Julie E BologniaRussiaStephen Shaw PROPOSAL
Ivar Z DarakjyFranceIvan Magalhaes NEW
Smith Y ButtBrazilElwin Sharvill UNQUALIFIED
Clifford X DilliardRussiaOnyama Limba QUALIFIED
Jennifer M GlickGermanyXuxue Feng NEGOTIATION
Tony R GlickSpainIvan Magalhaes UNQUALIFIED
Jones Z OstroskyCanadaXuxue Feng NEW
Emily M BowleyFranceIvan Magalhaes RENEWAL
Nicolas M CaudyRussiaIoni Bowcher NEGOTIATION
Costa E OstroskyAustraliaIvan Magalhaes UNQUALIFIED
Alejandro S PaprockiSpainAnna Fali PROPOSAL
Leon Q MaletBrazilElwin Sharvill NEGOTIATION
Ivar G DarakjyGermanyIvan Magalhaes NEW
Ashley L MorascaArgentinaAmy Elsner RENEWAL
Izzy H SergiBrazilAmy Elsner RENEWAL
Jefferson N AmigonIndiaAmy Elsner PROPOSAL
Juan B SchemmerGermanyIvan Magalhaes NEGOTIATION
Arvin K BowleyCanadaIvan Magalhaes QUALIFIED
Emily A WieserGermanyBernardo Dominic RENEWAL
Rodrigues H TollnerSpainIvan Magalhaes NEGOTIATION
Isabel S RoysterSpainIvan Magalhaes NEW
Leon Y CaldareraJapanElwin Sharvill QUALIFIED
Jefferson J RutaGermanyIvan Magalhaes NEGOTIATION
Chavez H KuskoSpainAmy Elsner RENEWAL
Rodrigues X GlickFranceXuxue Feng NEW
Arvin R StensethUnited KingdomAmy Elsner NEW
Darci W KolmetzRussiaXuxue Feng RENEWAL
Wickens P StockhamCanadaOnyama Limba NEGOTIATION
Tony Z DarakjyIndiaIvan Magalhaes PROPOSAL
Isabel C WieserBrazilXuxue Feng NEGOTIATION
Juan S SlusarskiAustraliaXuxue Feng UNQUALIFIED
Ricardo R GarufiRussiaAnna Fali QUALIFIED

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