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
Ashley B CaudyBrazilIoni Bowcher NEW
Munro M KuskoGermanyAnna Fali NEW
Deepesh F MaletArgentinaStephen Shaw RENEWAL
Ashley Z DarakjyArgentinaElwin Sharvill QUALIFIED
Jefferson E StensethSpainIoni Bowcher NEGOTIATION
Ricardo M ShinkoRussiaXuxue Feng NEW
Emily N GauchoGermanyAnna Fali PROPOSAL
Mayumi T VocelkaJapanElwin Sharvill NEGOTIATION
Leja A SchemmerUnited KingdomXuxue Feng PROPOSAL
Jeanfrancois U SergiBrazilXuxue Feng UNQUALIFIED
Ricardo K ButtCanadaIvan Magalhaes PROPOSAL
Jefferson T AmigonArgentinaIoni Bowcher RENEWAL
Mujtaba Q MacleadAustraliaAnna Fali QUALIFIED
Smith E SaylorsJapanAmy Elsner RENEWAL
Ricardo J ButtItalyBernardo Dominic QUALIFIED
Johnson E ChuiItalyAsiya Javayant RENEWAL
Adams H FlosiBrazilStephen Shaw PROPOSAL
Jeanfrancois G KuskoCanadaIoni Bowcher QUALIFIED
Rodrigues M FigeroaBrazilXuxue Feng PROPOSAL
Aika G VenereSpainElwin Sharvill NEGOTIATION
Clifford C SchemmerItalyBernardo Dominic UNQUALIFIED
Isabel R PaprockiJapanIoni Bowcher NEGOTIATION
Alejandro X GauchoAustraliaBernardo Dominic PROPOSAL
Kadeem I GillianAustraliaStephen Shaw NEW
Johnson G FollerRussiaAnna Fali QUALIFIED
Alejandro A AlbaresSpainIoni Bowcher QUALIFIED
Emily X CampainBrazilOnyama Limba RENEWAL
Aika W CampainRussiaIvan Magalhaes QUALIFIED
Alejandro N ButtCanadaAmy Elsner QUALIFIED
Maria O MacleadGermanyStephen Shaw UNQUALIFIED
Kadeem F NickaItalyOnyama Limba RENEWAL
Octavia Z MorascaCanadaXuxue Feng UNQUALIFIED
Chavez K KolmetzCanadaXuxue Feng RENEWAL
Silvio E RulapaughCanadaAnna Fali RENEWAL
Mayumi H RulapaughItalyIvan Magalhaes NEGOTIATION
Mayumi Q DarakjyJapanAsiya Javayant RENEWAL
Ivar B OstroskyFranceOnyama Limba UNQUALIFIED
Deepesh X SaylorsArgentinaIvan Magalhaes NEW
Ivar J DarakjyGermanyIvan Magalhaes QUALIFIED
Leon L PerinSpainIoni Bowcher NEGOTIATION
Aika N VenereArgentinaElwin Sharvill NEGOTIATION
Rodrigues N ShinkoCanadaAmy Elsner QUALIFIED
Leon K BologniaSpainAnna Fali UNQUALIFIED
David Y WaycottItalyStephen Shaw UNQUALIFIED
Maisha I FerenczItalyBernardo Dominic NEGOTIATION
Mujtaba G CampainBrazilAmy Elsner QUALIFIED
Kadeem R ShinkoSpainElwin Sharvill UNQUALIFIED
Ivar W GauchoBrazilAmy Elsner RENEWAL
Clifford B PerinFranceBernardo Dominic NEGOTIATION
Johnson G WaycottRussiaAmy Elsner NEGOTIATION
Horizontal
NameCountryRepresentativeStatus
Stacey L SaylorsIndiaStephen Shaw PROPOSAL
Mayumi M GarufiGermanyAsiya Javayant QUALIFIED
Juan Q WaycottFranceAsiya Javayant RENEWAL
Jennifer T BowleyGermanyStephen Shaw QUALIFIED
Nicolas I RutaGermanyIoni Bowcher RENEWAL
Emily P OldroydSpainAsiya Javayant NEGOTIATION
Aditya S GillianUnited KingdomAsiya Javayant NEW
Murillo J KuskoSpainOnyama Limba PROPOSAL
Mayumi X NickaRussiaXuxue Feng PROPOSAL
Aditya F NestleJapanAsiya Javayant RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Maisha P DoeRussia2024-05-28Chanay, Jeffrey A Esq RENEWAL81Stephen Shaw
1001Mujtaba A BologniaIndia2024-06-22Feiner Bros RENEWAL55Amy Elsner
1002David I DoeArgentina2024-05-31Buckley Miller Wright NEGOTIATION91Ivan Magalhaes
1003Aruna M CaudyCanada2024-06-16Dorl, James J Esq PROPOSAL29Anna Fali
1004Munro R FlosiGermany2024-05-26Buckley Miller Wright PROPOSAL57Anna Fali
1005Darci Q SaylorsAustralia2024-06-05Rousseaux, Michael Esq RENEWAL7Anna Fali
1006Aruna G RutaItaly2024-05-27Printing Dimensions QUALIFIED97Ivan Magalhaes
1007Rodrigues E FerenczFrance2024-06-05Printing Dimensions NEW14Stephen Shaw
1008Jeanfrancois M MorascaRussia2024-05-30Morlong Associates UNQUALIFIED74Ioni Bowcher
1009Maisha E NickaCanada2024-05-31Chapman, Ross E Esq UNQUALIFIED69Anna Fali
1010Faith H VocelkaItaly2024-06-15Rangoni Of Florence NEGOTIATION93Ioni Bowcher
1011Smith E NickaArgentina2024-06-03Chemel, James L Cpa RENEWAL63Ioni Bowcher
1012Juan R MacleadFrance2024-06-06King, Christopher A Esq QUALIFIED54Onyama Limba
1013Ricardo G MorascaRussia2024-06-14Rousseaux, Michael Esq NEW93Asiya Javayant
1014Mujtaba D PaprockiJapan2024-06-05Morlong Associates RENEWAL82Bernardo Dominic
1015Jefferson J ShinkoJapan2024-06-02Buckley Miller Wright RENEWAL33Ivan Magalhaes
1016Mayumi A GarufiCanada2024-06-05Commercial Press NEGOTIATION72Anna Fali
1017Costa K ShinkoFrance2024-06-21Benton, John B Jr NEGOTIATION62Bernardo Dominic
1018Silvio X RoysterGermany2024-06-15Truhlar And Truhlar Attys UNQUALIFIED64Bernardo Dominic
1019Johnson A InouyeSpain2024-06-14Printing Dimensions PROPOSAL43Elwin Sharvill
1020Chavez I BowleyRussia2024-06-11Morlong Associates NEGOTIATION95Xuxue Feng
1021Kadeem M GauchoSpain2024-06-10King, Christopher A Esq QUALIFIED96Amy Elsner
1022Izzy L DarakjyItaly2024-06-06Dorl, James J Esq NEW86Stephen Shaw
1023Octavia C OldroydBrazil2024-06-23Dorl, James J Esq NEW91Onyama Limba
1024Stacey S SchemmerRussia2024-06-19Dorl, James J Esq NEGOTIATION77Amy Elsner
1025Mayumi H TollnerSpain2024-06-17Chemel, James L Cpa QUALIFIED46Stephen Shaw
1026James X AmigonJapan2024-06-08Rousseaux, Michael Esq NEGOTIATION51Onyama Limba
1027Claire Y FlosiGermany2024-05-30Buckley Miller Wright PROPOSAL19Onyama Limba
1028Antonio B OstroskyJapan2024-05-30Chemel, James L Cpa NEW77Elwin Sharvill
1029Murillo V MorascaRussia2024-05-30Morlong Associates NEGOTIATION22Ivan Magalhaes
1030Ashley R GarufiCanada2024-05-26Dorl, James J Esq NEW52Bernardo Dominic
1031Isabel F VocelkaBrazil2024-06-07Truhlar And Truhlar Attys NEGOTIATION49Ivan Magalhaes
1032Munro E FlosiCanada2024-06-08Chanay, Jeffrey A Esq QUALIFIED36Bernardo Dominic
1033Leon E SlusarskiRussia2024-06-13Chemel, James L Cpa NEW67Anna Fali
1034Jeanfrancois R SlusarskiArgentina2024-06-04Truhlar And Truhlar Attys RENEWAL36Stephen Shaw
1035Jefferson R OstroskyCanada2024-06-24Buckley Miller Wright QUALIFIED68Asiya Javayant
1036James D MaletFrance2024-05-30Rangoni Of Florence PROPOSAL88Asiya Javayant
1037Cody O IturbideArgentina2024-06-16Benton, John B Jr RENEWAL42Onyama Limba
1038Cody J SergiFrance2024-06-06Chemel, James L Cpa RENEWAL34Elwin Sharvill
1039Nicolas D WieserArgentina2024-06-03Chapman, Ross E Esq NEGOTIATION39Ivan Magalhaes
1040Wickens V NestleBrazil2024-06-10Morlong Associates RENEWAL12Ivan Magalhaes
1041Chavez Q ButtRussia2024-06-09King, Christopher A Esq QUALIFIED21Bernardo Dominic
1042James B WaycottFrance2024-06-05Chemel, James L Cpa PROPOSAL14Xuxue Feng
1043Alejandro Q StensethBrazil2024-06-23Benton, John B Jr QUALIFIED62Ioni Bowcher
1044Maisha Y ButtFrance2024-06-05Chapman, Ross E Esq QUALIFIED85Bernardo Dominic
1045Cody J AlbaresAustralia2024-06-05Buckley Miller Wright PROPOSAL86Elwin Sharvill
1046Isabel Z RimBrazil2024-05-31Buckley Miller Wright NEW55Xuxue Feng
1047Alejandro G SergiJapan2024-06-01Chapman, Ross E Esq UNQUALIFIED40Amy Elsner
1048Aruna G AmigonUnited Kingdom2024-05-31Chanay, Jeffrey A Esq NEW33Onyama Limba
1049Darci F InouyeFrance2024-06-22Commercial Press PROPOSAL31Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Izzy J AlbaresFranceBernardo Dominic UNQUALIFIED
Smith U FigeroaItalyIoni Bowcher NEGOTIATION
James D MarrierAustraliaOnyama Limba NEGOTIATION
Deepesh O TollnerUnited KingdomBernardo Dominic UNQUALIFIED
Izzy R RoysterIndiaBernardo Dominic RENEWAL
Silvio S GarufiRussiaAmy Elsner QUALIFIED
Adams Z SchemmerUnited KingdomIoni Bowcher UNQUALIFIED
Clifford X CaudyFranceXuxue Feng UNQUALIFIED
Ricardo R BowleyBrazilIoni Bowcher UNQUALIFIED
Misaki X DilliardBrazilAsiya Javayant PROPOSAL
Adams E ChuiItalyOnyama Limba QUALIFIED
Ashley H FigeroaUnited KingdomIoni Bowcher RENEWAL
Jefferson Q PerinGermanyAnna Fali PROPOSAL
Aditya C WaycottCanadaAnna Fali QUALIFIED
James S ChuiCanadaAnna Fali UNQUALIFIED
Kadeem F WaycottJapanIoni Bowcher RENEWAL
Stacey R AmigonGermanyAmy Elsner QUALIFIED
Stacey B MacleadAustraliaOnyama Limba PROPOSAL
Kadeem O SergiGermanyAsiya Javayant NEW
Morrow W BologniaFranceAmy Elsner NEGOTIATION
Aditya D ChuiCanadaElwin Sharvill UNQUALIFIED
Darci N DilliardArgentinaAmy Elsner QUALIFIED
Jefferson P MacleadJapanIoni Bowcher NEW
James Q MaletAustraliaIoni Bowcher NEGOTIATION
Mujtaba W GauchoBrazilAnna Fali RENEWAL
Isabel Z OstroskyJapanAnna Fali QUALIFIED
Rodrigues W MorascaUnited KingdomStephen Shaw PROPOSAL
Johnson P KolmetzGermanyBernardo Dominic NEGOTIATION
Ivar R InouyeArgentinaElwin Sharvill PROPOSAL
Izzy D InouyeCanadaIoni Bowcher UNQUALIFIED
Morrow D PaprockiCanadaAsiya Javayant NEGOTIATION
Leon W FlosiUnited KingdomBernardo Dominic NEW
Aika N DilliardBrazilXuxue Feng QUALIFIED
Izzy B PoquetteUnited KingdomOnyama Limba NEGOTIATION
Adams I CampainBrazilOnyama Limba PROPOSAL
Kadeem P DilliardBrazilAnna Fali NEGOTIATION
Aika P RulapaughSpainIvan Magalhaes QUALIFIED
Cody N VenereFranceAnna Fali QUALIFIED
Sinclair V RutaGermanyBernardo Dominic RENEWAL
Kaitlin Q SaylorsSpainAsiya Javayant QUALIFIED
Mujtaba F WaycottIndiaXuxue Feng NEGOTIATION
Morrow R MorascaArgentinaAnna Fali UNQUALIFIED
Salvatore W MacleadCanadaAsiya Javayant NEW
Sinclair R CampainSpainAsiya Javayant PROPOSAL
Izzy T BowleyIndiaAmy Elsner UNQUALIFIED
Jefferson S InouyeArgentinaIoni Bowcher QUALIFIED
Aika Q OldroydCanadaAsiya Javayant RENEWAL
Julie L TollnerRussiaAmy Elsner PROPOSAL
Jeanfrancois T OldroydAustraliaXuxue Feng RENEWAL
Munro Q MarrierFranceElwin Sharvill RENEWAL
Frozen Columns
Name
Francesco S Paprocki
Alejandro J Doe
Maisha G Gaucho
Sinclair G Oldroyd
Leon P Caudy
Rodrigues J Inouye
Murillo O Inouye
Tony G Rulapaugh
Morrow O Sergi
Jefferson X Maclead
Ashley J Gillian
Aika V Perin
Adams D Caudy
David G Malet
Clifford O Oldroyd
Jones C Glick
Ricardo N Garufi
Clifford H Darakjy
Salvatore U Tollner
Maisha X Figeroa
Clifford D Kolmetz
Stacey D Chui
Julie B Campain
Stacey Z Gaucho
Cody L Paprocki
Leja C Campain
Greenwood Z Stenseth
Maisha F Iturbide
Aruna F Royster
Juan I Malet
Johnson L Foller
Tony F Stenseth
Maria Q Shinko
Jeanfrancois X Foller
Darci D Oldroyd
Rodrigues P Campain
Ashley F Royster
Aika H Nestle
Aditya Z Paprocki
Sinclair I Doe
Julie K Caudy
Maria G Glick
Tony G Tollner
Kaitlin O Kusko
Sinclair P Butt
James M Figeroa
Chavez S Campain
Maisha B Bowley
Julie M Shinko
Adams Q Caldarera
IdCountryDate
1000Russia2024-06-21
1001Russia2024-06-15
1002Argentina2024-06-19
1003India2024-06-17
1004Japan2024-06-20
1005United Kingdom2024-06-19
1006India2024-06-13
1007Brazil2024-06-23
1008Spain2024-06-02
1009Argentina2024-06-01
1010Argentina2024-06-22
1011Spain2024-06-22
1012Russia2024-06-13
1013India2024-06-11
1014Canada2024-06-10
1015India2024-06-19
1016Australia2024-05-27
1017Germany2024-06-22
1018Canada2024-06-17
1019Germany2024-06-20
1020United Kingdom2024-06-01
1021Russia2024-06-07
1022Italy2024-05-30
1023United Kingdom2024-05-31
1024Australia2024-05-26
1025India2024-06-16
1026Japan2024-06-23
1027Japan2024-06-19
1028Canada2024-06-20
1029Russia2024-06-14
1030India2024-06-02
1031India2024-06-11
1032France2024-06-16
1033Brazil2024-06-20
1034Spain2024-06-12
1035France2024-06-12
1036Japan2024-06-23
1037Brazil2024-06-15
1038Germany2024-06-07
1039Italy2024-06-18
1040Australia2024-06-03
1041Germany2024-06-01
1042United Kingdom2024-06-21
1043Russia2024-06-11
1044Australia2024-06-20
1045India2024-06-04
1046United Kingdom2024-06-17
1047Russia2024-06-24
1048India2024-06-17
1049France2024-06-12

On-Demand Data

NameIdCountryDate
Wickens T Morasca1000Australia2024-06-17
Kaitlin A Waycott1001Spain2024-06-08
Aruna O Amigon1002Brazil2024-05-30
Izzy V Caldarera1003India2024-06-05
Kadeem V Slusarski1004Australia2024-06-11
Ivar X Foller1005India2024-06-08
Rodrigues R Briddick1006France2024-06-22
Salvatore A Stockham1007Canada2024-06-01
Morrow V Amigon1008Canada2024-06-03
Johnson R Amigon1009India2024-06-04
Alejandro Z Shinko1010Canada2024-06-19
Claire H Briddick1011Italy2024-06-06
Aruna B Albares1012Italy2024-06-12
Munro B Kolmetz1013Japan2024-06-15
Murillo D Ferencz1014Australia2024-06-10
Chavez M Iturbide1015Canada2024-06-13
Tony W Paprocki1016Australia2024-06-04
Ivar Q Shinko1017Brazil2024-06-03
Juan F Glick1018Italy2024-06-11
Morrow K Caudy1019Japan2024-06-06
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Aika Y KuskoUnited KingdomOnyama Limba NEW
Sinclair J AmigonCanadaStephen Shaw UNQUALIFIED
Isabel K GlickUnited KingdomIvan Magalhaes UNQUALIFIED
Faith U SchemmerBrazilAnna Fali PROPOSAL
Aika N MacleadAustraliaAnna Fali RENEWAL
Jones Y SergiFranceAsiya Javayant NEGOTIATION
Morrow O CaudyAustraliaAsiya Javayant NEGOTIATION
Maisha U CaudyItalyStephen Shaw RENEWAL
Leja X BriddickJapanXuxue Feng NEGOTIATION
Jones C RoysterJapanAmy Elsner NEW
Darci O PerinArgentinaBernardo Dominic PROPOSAL
Francesco H TollnerRussiaIvan Magalhaes QUALIFIED
Deepesh E WhobreyFranceBernardo Dominic PROPOSAL
Silvio Q KolmetzGermanyElwin Sharvill NEGOTIATION
Wickens U WieserIndiaAmy Elsner UNQUALIFIED
Claire D StockhamAustraliaElwin Sharvill UNQUALIFIED
Silvio R PoquetteBrazilBernardo Dominic RENEWAL
Alejandro J RimGermanyAsiya Javayant NEW
Morrow L SchemmerJapanElwin Sharvill RENEWAL
Faith J NickaItalyElwin Sharvill PROPOSAL
Sinclair D DilliardGermanyAnna Fali RENEWAL
Cody R MacleadItalyOnyama Limba UNQUALIFIED
Julie W DarakjyRussiaIvan Magalhaes NEW
Isabel O FerenczBrazilElwin Sharvill NEGOTIATION
Nicolas K CampainUnited KingdomAnna Fali NEW
Juan K SchemmerUnited KingdomIoni Bowcher RENEWAL
Aruna A WieserUnited KingdomIoni Bowcher NEGOTIATION
Kadeem V ButtRussiaAsiya Javayant PROPOSAL
Jones K VenereBrazilIvan Magalhaes NEW
Silvio Z StockhamArgentinaOnyama Limba NEW
Maisha Y ButtUnited KingdomAmy Elsner PROPOSAL
Silvio Y MaletGermanyAsiya Javayant NEW
Ashley Z GlickFranceAnna Fali RENEWAL
Deepesh N PaprockiGermanyOnyama Limba PROPOSAL
Chavez D VenereCanadaStephen Shaw QUALIFIED
Kadeem V BriddickArgentinaAnna Fali UNQUALIFIED
Mayumi A KolmetzFranceIvan Magalhaes QUALIFIED
Tony A ShinkoSpainElwin Sharvill PROPOSAL
Ashley P AlbaresUnited KingdomStephen Shaw UNQUALIFIED
Leon A StockhamCanadaIvan Magalhaes PROPOSAL

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