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
Ricardo V KolmetzUnited KingdomXuxue Feng NEGOTIATION
Arvin Y NickaGermanyAmy Elsner NEGOTIATION
Munro Y SlusarskiItalyBernardo Dominic QUALIFIED
Julie Z SergiSpainBernardo Dominic UNQUALIFIED
Antonio E StensethGermanyXuxue Feng RENEWAL
David M MarrierItalyAmy Elsner PROPOSAL
Antonio Z GlickSpainBernardo Dominic NEW
Izzy B MarrierItalyOnyama Limba NEGOTIATION
Francesco F BriddickGermanyIoni Bowcher PROPOSAL
Clifford X BologniaAustraliaStephen Shaw RENEWAL
Mujtaba G MaletItalyAsiya Javayant NEW
Wickens V VenereIndiaAmy Elsner PROPOSAL
Cody A FlosiRussiaXuxue Feng QUALIFIED
Jeanfrancois C PerinCanadaElwin Sharvill QUALIFIED
Murillo E WaycottUnited KingdomIvan Magalhaes PROPOSAL
Ricardo N KolmetzAustraliaAsiya Javayant RENEWAL
Ricardo J RimItalyAmy Elsner PROPOSAL
Aika T NickaJapanIvan Magalhaes UNQUALIFIED
Stacey C AlbaresBrazilIvan Magalhaes RENEWAL
Emily N CaudyBrazilAsiya Javayant QUALIFIED
Rodrigues W ChuiBrazilIoni Bowcher NEW
Jennifer F CampainCanadaAsiya Javayant NEW
Leja D WieserBrazilBernardo Dominic PROPOSAL
Nicolas V OstroskyRussiaBernardo Dominic RENEWAL
Wickens M SlusarskiBrazilBernardo Dominic NEGOTIATION
Nicolas B VenereJapanXuxue Feng PROPOSAL
Leon N ButtIndiaElwin Sharvill PROPOSAL
Arvin V WhobreyIndiaAnna Fali NEW
Izzy I BowleyCanadaStephen Shaw NEGOTIATION
Leja S MaletItalyXuxue Feng RENEWAL
Izzy Z MacleadRussiaAnna Fali QUALIFIED
Jones W RimBrazilAmy Elsner NEW
Aika R AmigonJapanIoni Bowcher NEW
Izzy X ChuiFranceIvan Magalhaes NEGOTIATION
Maisha T FigeroaArgentinaIvan Magalhaes UNQUALIFIED
Aika J ButtJapanAmy Elsner UNQUALIFIED
Emily T StensethRussiaIvan Magalhaes PROPOSAL
Ivar Q GauchoAustraliaStephen Shaw NEW
Mayumi F ShinkoAustraliaAsiya Javayant RENEWAL
Salvatore L GlickUnited KingdomOnyama Limba QUALIFIED
Johnson Z OstroskyBrazilElwin Sharvill PROPOSAL
Maria C AlbaresIndiaIvan Magalhaes RENEWAL
Silvio R NickaBrazilAsiya Javayant NEGOTIATION
Chavez O ButtItalyXuxue Feng QUALIFIED
Francesco U OstroskyIndiaBernardo Dominic RENEWAL
Misaki V GarufiSpainAsiya Javayant NEGOTIATION
Cody G WhobreyFranceAmy Elsner UNQUALIFIED
Aditya S MorascaAustraliaElwin Sharvill NEGOTIATION
Sinclair N AlbaresAustraliaStephen Shaw NEW
Maria E FlosiArgentinaAsiya Javayant NEW
Horizontal
NameCountryRepresentativeStatus
Munro L MacleadJapanStephen Shaw PROPOSAL
Octavia Z CaldareraBrazilAsiya Javayant PROPOSAL
Isabel T BologniaAustraliaAsiya Javayant RENEWAL
Mujtaba V SergiIndiaAsiya Javayant NEGOTIATION
Cody G MorascaRussiaAnna Fali NEW
Izzy X StockhamCanadaIvan Magalhaes UNQUALIFIED
Octavia W GauchoBrazilBernardo Dominic NEW
Julie E ChuiJapanXuxue Feng RENEWAL
Nicolas E BowleyRussiaXuxue Feng PROPOSAL
Greenwood R DoeGermanyAnna Fali RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Aditya C VenereBrazil2025-04-29Rangoni Of Florence NEW42Xuxue Feng
1001Francesco M TollnerFrance2025-04-19Rangoni Of Florence NEGOTIATION57Onyama Limba
1002Octavia J StockhamJapan2025-04-22Printing Dimensions UNQUALIFIED26Anna Fali
1003Deepesh Z StensethUnited Kingdom2025-04-10Rangoni Of Florence PROPOSAL6Anna Fali
1004Munro E InouyeItaly2025-04-20King, Christopher A Esq NEW2Ivan Magalhaes
1005Kadeem V BriddickRussia2025-04-15Morlong Associates UNQUALIFIED48Stephen Shaw
1006Costa E AmigonJapan2025-04-22Commercial Press PROPOSAL24Asiya Javayant
1007Faith R BowleySpain2025-04-06Rousseaux, Michael Esq PROPOSAL79Asiya Javayant
1008Izzy M BologniaIndia2025-04-12King, Christopher A Esq UNQUALIFIED97Asiya Javayant
1009Leja H DarakjyJapan2025-04-02Truhlar And Truhlar Attys QUALIFIED86Asiya Javayant
1010Octavia C ChuiIndia2025-04-16Rousseaux, Michael Esq PROPOSAL86Elwin Sharvill
1011Costa F PerinItaly2025-04-24Chemel, James L Cpa NEGOTIATION98Ioni Bowcher
1012Aruna N RulapaughArgentina2025-04-14Morlong Associates QUALIFIED21Bernardo Dominic
1013Misaki H FlosiIndia2025-04-15Printing Dimensions PROPOSAL31Xuxue Feng
1014Adams K PoquetteSpain2025-04-21Morlong Associates NEGOTIATION91Ioni Bowcher
1015Kaitlin C SchemmerAustralia2025-04-12Commercial Press NEW61Elwin Sharvill
1016Nicolas J GarufiUnited Kingdom2025-04-09Benton, John B Jr NEGOTIATION90Xuxue Feng
1017Aika M FigeroaAustralia2025-04-04Benton, John B Jr NEW34Asiya Javayant
1018Stacey C ShinkoFrance2025-04-30Feltz Printing Service QUALIFIED23Asiya Javayant
1019Cody O CaudyFrance2025-04-11Feltz Printing Service NEW83Anna Fali
1020Alejandro G PoquetteUnited Kingdom2025-04-18Dorl, James J Esq RENEWAL80Elwin Sharvill
1021Octavia J RimRussia2025-04-28Chanay, Jeffrey A Esq PROPOSAL57Ioni Bowcher
1022Murillo O StockhamAustralia2025-04-11Chapman, Ross E Esq QUALIFIED52Amy Elsner
1023Stacey Z RimJapan2025-04-23Feltz Printing Service UNQUALIFIED66Ioni Bowcher
1024Isabel X InouyeArgentina2025-04-05Feltz Printing Service QUALIFIED84Xuxue Feng
1025Adams W ShinkoUnited Kingdom2025-04-23Morlong Associates NEW42Stephen Shaw
1026Alejandro N GlickGermany2025-04-09Rousseaux, Michael Esq PROPOSAL13Anna Fali
1027Mayumi H KuskoAustralia2025-04-01Dorl, James J Esq NEW78Onyama Limba
1028Cody G WieserSpain2025-04-10Chemel, James L Cpa RENEWAL78Asiya Javayant
1029Ashley A WieserUnited Kingdom2025-04-04Buckley Miller Wright NEGOTIATION52Xuxue Feng
1030Francesco T VocelkaCanada2025-04-30Printing Dimensions UNQUALIFIED65Stephen Shaw
1031Octavia O BowleyUnited Kingdom2025-04-27Morlong Associates NEGOTIATION61Elwin Sharvill
1032Leon T WieserGermany2025-04-10Printing Dimensions NEW36Onyama Limba
1033Clifford R DilliardArgentina2025-04-04Chanay, Jeffrey A Esq NEGOTIATION41Elwin Sharvill
1034Antonio I BriddickUnited Kingdom2025-04-23Rangoni Of Florence NEW53Asiya Javayant
1035Murillo K RoysterRussia2025-04-19Feiner Bros UNQUALIFIED41Bernardo Dominic
1036Aruna C DilliardArgentina2025-04-07Chemel, James L Cpa NEGOTIATION66Ivan Magalhaes
1037Sinclair K FollerIndia2025-04-09Rousseaux, Michael Esq NEW2Ivan Magalhaes
1038Maisha I ButtJapan2025-04-05Buckley Miller Wright NEW83Onyama Limba
1039Arvin P ChuiGermany2025-04-24Commercial Press QUALIFIED56Amy Elsner
1040Jones S ButtGermany2025-04-20Printing Dimensions NEW62Anna Fali
1041Nicolas G NestleGermany2025-04-09Benton, John B Jr PROPOSAL79Anna Fali
1042James D PerinItaly2025-04-10Benton, John B Jr PROPOSAL67Amy Elsner
1043David A FigeroaAustralia2025-04-29Chanay, Jeffrey A Esq QUALIFIED8Elwin Sharvill
1044Silvio O CaldareraCanada2025-04-18Chanay, Jeffrey A Esq PROPOSAL92Bernardo Dominic
1045David T MaletGermany2025-04-18Morlong Associates UNQUALIFIED83Amy Elsner
1046Octavia B PoquetteUnited Kingdom2025-04-21Printing Dimensions RENEWAL12Ivan Magalhaes
1047Murillo T MarrierRussia2025-04-16Truhlar And Truhlar Attys RENEWAL48Elwin Sharvill
1048Jones M BowleyCanada2025-04-08Benton, John B Jr UNQUALIFIED22Ivan Magalhaes
1049Darci Y ShinkoBrazil2025-04-11King, Christopher A Esq UNQUALIFIED9Ivan Magalhaes
Frozen Rows
NameCountryRepresentativeStatus
Deepesh H BriddickAustraliaOnyama Limba NEGOTIATION
Stacey X FollerCanadaIvan Magalhaes RENEWAL
Alejandro A MarrierArgentinaOnyama Limba PROPOSAL
Wickens W KolmetzCanadaXuxue Feng RENEWAL
Chavez I AmigonBrazilIoni Bowcher NEGOTIATION
Aika B ChuiGermanyIoni Bowcher NEGOTIATION
Jefferson C PerinUnited KingdomAsiya Javayant UNQUALIFIED
Adams L MorascaItalyIoni Bowcher NEW
Tony S GlickBrazilIvan Magalhaes QUALIFIED
Tony M RimSpainBernardo Dominic NEW
Salvatore F VocelkaIndiaAnna Fali QUALIFIED
David R SergiCanadaXuxue Feng NEGOTIATION
Misaki T GarufiItalyAsiya Javayant QUALIFIED
David W NestleGermanyAsiya Javayant NEGOTIATION
Antonio H GillianRussiaAmy Elsner NEGOTIATION
James N RoysterBrazilAmy Elsner NEW
Clifford O AmigonSpainAsiya Javayant QUALIFIED
Chavez Y DarakjyRussiaAsiya Javayant QUALIFIED
Adams S NestleGermanyXuxue Feng NEW
Johnson V BologniaItalyBernardo Dominic UNQUALIFIED
Morrow U MorascaGermanyAnna Fali PROPOSAL
Stacey F CaudySpainBernardo Dominic PROPOSAL
Cody L IturbideJapanAmy Elsner PROPOSAL
Juan R MaletArgentinaStephen Shaw UNQUALIFIED
Munro M NickaAustraliaStephen Shaw NEGOTIATION
Munro X DoeSpainStephen Shaw RENEWAL
Greenwood X DoeFranceOnyama Limba NEGOTIATION
Cody O ChuiItalyAmy Elsner QUALIFIED
Ivar P SlusarskiGermanyIvan Magalhaes UNQUALIFIED
Leon I InouyeRussiaIvan Magalhaes QUALIFIED
Jennifer V MarrierFranceAnna Fali NEW
Johnson Z KolmetzBrazilElwin Sharvill UNQUALIFIED
Sinclair K GlickFranceXuxue Feng QUALIFIED
Jeanfrancois P AmigonRussiaAnna Fali PROPOSAL
Julie P FerenczBrazilIvan Magalhaes QUALIFIED
Morrow B CaldareraArgentinaBernardo Dominic UNQUALIFIED
Jeanfrancois J SlusarskiSpainAmy Elsner QUALIFIED
Juan B DoeIndiaIoni Bowcher NEGOTIATION
Smith R MaletUnited KingdomAsiya Javayant PROPOSAL
Stacey J RimFranceIoni Bowcher QUALIFIED
Emily T BologniaUnited KingdomAnna Fali RENEWAL
Maisha C FerenczSpainElwin Sharvill NEW
Tony R RutaGermanyXuxue Feng NEGOTIATION
Emily X GauchoSpainIoni Bowcher QUALIFIED
Wickens O CaldareraSpainAmy Elsner QUALIFIED
Jeanfrancois T SergiSpainXuxue Feng NEW
Emily I GauchoItalyBernardo Dominic QUALIFIED
Jeanfrancois B MacleadBrazilAmy Elsner RENEWAL
Leon B WaycottSpainIvan Magalhaes RENEWAL
Clifford C ShinkoItalyStephen Shaw UNQUALIFIED
Frozen Columns
Name
Kadeem B Glick
Costa X Amigon
Juan C Poquette
Johnson K Nicka
Izzy Y Malet
Darci T Garufi
Isabel K Slusarski
Julie Q Morasca
Aruna J Foller
Murillo E Figeroa
Nicolas O Kusko
Deepesh D Marrier
Johnson O Figeroa
Maria E Rulapaugh
Costa D Wieser
Ivar K Gillian
Leon U Ferencz
Jeanfrancois Y Maclead
Misaki W Kolmetz
Stacey U Maclead
Murillo G Rim
Munro N Schemmer
Maria D Rim
Mujtaba H Maclead
Aruna P Doe
Sinclair S Glick
Stacey O Butt
Jefferson J Inouye
Jefferson T Glick
Faith G Butt
Claire K Briddick
Arvin H Waycott
Greenwood Z Dilliard
Ivar B Oldroyd
Julie G Poquette
Leon M Figeroa
Nicolas O Rim
Kaitlin E Schemmer
Ashley Z Kolmetz
Ricardo G Waycott
Deepesh T Wieser
Isabel V Figeroa
Maisha O Chui
Jeanfrancois F Ruta
Greenwood X Flosi
Ashley Q Campain
Aditya M Morasca
Claire N Venere
Maria E Gillian
Francesco X Garufi
IdCountryDate
1000Argentina2025-04-23
1001Japan2025-04-19
1002Brazil2025-04-27
1003Germany2025-04-05
1004Germany2025-04-23
1005France2025-04-02
1006Brazil2025-04-29
1007Australia2025-04-25
1008Germany2025-04-12
1009Canada2025-04-26
1010Canada2025-04-16
1011France2025-04-23
1012Italy2025-04-29
1013Italy2025-04-18
1014Russia2025-04-05
1015Spain2025-04-24
1016Australia2025-04-10
1017Japan2025-04-07
1018India2025-04-14
1019Argentina2025-04-10
1020Australia2025-04-12
1021France2025-04-14
1022Canada2025-04-22
1023Australia2025-04-17
1024Canada2025-04-18
1025United Kingdom2025-04-03
1026Brazil2025-04-03
1027Australia2025-04-14
1028Spain2025-04-24
1029Italy2025-04-18
1030Russia2025-04-14
1031Brazil2025-04-12
1032Brazil2025-04-09
1033United Kingdom2025-04-14
1034Argentina2025-04-12
1035Russia2025-04-24
1036Spain2025-04-24
1037Canada2025-04-30
1038Japan2025-04-20
1039Argentina2025-04-28
1040Canada2025-04-18
1041Brazil2025-04-20
1042Russia2025-04-16
1043Italy2025-04-02
1044Argentina2025-04-21
1045India2025-04-19
1046Australia2025-04-12
1047India2025-04-12
1048Australia2025-04-07
1049Spain2025-04-01

On-Demand Data

NameIdCountryDate
Costa K Chui1000Brazil2025-04-09
Darci F Caudy1001Russia2025-04-05
Ivar B Campain1002India2025-04-04
Leja N Slusarski1003Spain2025-04-26
Ivar Y Morasca1004Australia2025-04-28
David A Malet1005Japan2025-04-25
Rodrigues U Iturbide1006United Kingdom2025-04-04
Aika G Bowley1007Canada2025-04-10
Stacey J Garufi1008United Kingdom2025-04-16
David B Poquette1009India2025-04-18
Aruna G Wieser1010Brazil2025-04-08
Kadeem U Shinko1011United Kingdom2025-04-15
David K Morasca1012Canada2025-04-23
Kadeem Z Garufi1013Italy2025-04-04
Johnson A Malet1014France2025-04-30
Mayumi S Royster1015Germany2025-04-09
Jeanfrancois T Wieser1016France2025-04-09
Jefferson U Flosi1017Germany2025-04-14
Octavia E Malet1018India2025-04-11
Kaitlin S Stenseth1019India2025-04-20
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Leon S FerenczCanadaOnyama Limba UNQUALIFIED
Mayumi D WieserFranceXuxue Feng NEGOTIATION
Francesco P FlosiGermanyIoni Bowcher QUALIFIED
Arvin L VocelkaItalyIoni Bowcher RENEWAL
Cody G AlbaresItalyXuxue Feng QUALIFIED
Arvin D FigeroaRussiaIvan Magalhaes QUALIFIED
Octavia E WieserFranceIvan Magalhaes RENEWAL
Antonio Q MaletUnited KingdomAsiya Javayant UNQUALIFIED
Clifford E InouyeArgentinaAsiya Javayant QUALIFIED
Isabel J MarrierSpainAmy Elsner UNQUALIFIED
Ricardo B DoeItalyIoni Bowcher PROPOSAL
Julie J ChuiCanadaIvan Magalhaes NEGOTIATION
Costa X AlbaresAustraliaElwin Sharvill PROPOSAL
Isabel Y AlbaresIndiaAsiya Javayant QUALIFIED
James N KuskoItalyOnyama Limba UNQUALIFIED
Francesco C FlosiJapanOnyama Limba NEW
David O MorascaItalyOnyama Limba RENEWAL
Antonio W KolmetzFranceAnna Fali QUALIFIED
Stacey R SaylorsArgentinaAmy Elsner PROPOSAL
Misaki A FerenczAustraliaAmy Elsner PROPOSAL
Faith W RimIndiaAmy Elsner PROPOSAL
Claire Y GlickFranceElwin Sharvill NEW
Stacey D CaudyFranceIvan Magalhaes UNQUALIFIED
Faith R IturbideAustraliaStephen Shaw UNQUALIFIED
Aruna I DilliardRussiaStephen Shaw QUALIFIED
Julie K BowleyGermanyIvan Magalhaes RENEWAL
Murillo U MaletSpainAnna Fali UNQUALIFIED
Maisha A OstroskySpainOnyama Limba RENEWAL
Smith H DarakjyJapanOnyama Limba PROPOSAL
Aditya Z MaletItalyStephen Shaw UNQUALIFIED
Leon T InouyeItalyOnyama Limba PROPOSAL
Jones D PerinRussiaOnyama Limba UNQUALIFIED
Kadeem S KuskoBrazilAsiya Javayant UNQUALIFIED
Mayumi O GillianUnited KingdomOnyama Limba NEGOTIATION
Kaitlin O InouyeJapanXuxue Feng QUALIFIED
Sinclair E MaletUnited KingdomElwin Sharvill NEW
Greenwood V FerenczJapanAsiya Javayant QUALIFIED
Leon R WhobreyBrazilBernardo Dominic NEW
Deepesh V GarufiFranceStephen Shaw QUALIFIED
Aruna L VenereJapanElwin Sharvill 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>