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
Nicolas D PerinUnited KingdomStephen Shaw PROPOSAL
Maria Q BowleyUnited KingdomAsiya Javayant RENEWAL
Arvin K MarrierCanadaAmy Elsner UNQUALIFIED
Greenwood K DilliardRussiaAsiya Javayant PROPOSAL
Greenwood W SlusarskiAustraliaOnyama Limba RENEWAL
Emily W SaylorsCanadaIvan Magalhaes PROPOSAL
Costa V NestleJapanAsiya Javayant NEGOTIATION
Aika K DilliardFranceBernardo Dominic NEW
Ivar J VenereUnited KingdomStephen Shaw UNQUALIFIED
Emily X AmigonIndiaOnyama Limba PROPOSAL
Costa M PerinGermanyOnyama Limba RENEWAL
Mayumi C StockhamJapanStephen Shaw PROPOSAL
Antonio V PaprockiGermanyAmy Elsner PROPOSAL
Ashley U VocelkaAustraliaIvan Magalhaes PROPOSAL
Misaki N DilliardItalyAnna Fali RENEWAL
Antonio N SchemmerGermanyOnyama Limba UNQUALIFIED
Alejandro N WhobreyCanadaBernardo Dominic UNQUALIFIED
David T KolmetzItalyXuxue Feng NEW
Murillo T BologniaItalyIoni Bowcher RENEWAL
Misaki B MorascaAustraliaIvan Magalhaes RENEWAL
Faith Q FigeroaArgentinaElwin Sharvill UNQUALIFIED
Francesco Q BowleySpainStephen Shaw QUALIFIED
Arvin A CaudyItalyBernardo Dominic QUALIFIED
Kadeem E SaylorsRussiaElwin Sharvill QUALIFIED
Costa D GauchoArgentinaXuxue Feng PROPOSAL
David B SchemmerGermanyStephen Shaw PROPOSAL
Jeanfrancois T PerinCanadaAnna Fali NEW
Kadeem Z ButtArgentinaIvan Magalhaes NEW
Aditya D AlbaresUnited KingdomAnna Fali QUALIFIED
Mayumi F PerinGermanyBernardo Dominic RENEWAL
Leja B BologniaArgentinaIoni Bowcher NEGOTIATION
Mujtaba W NestleSpainAnna Fali NEW
Silvio E VocelkaArgentinaBernardo Dominic NEGOTIATION
Emily I ChuiGermanyAmy Elsner NEW
Greenwood K RoysterCanadaIoni Bowcher RENEWAL
Emily U WhobreySpainAnna Fali RENEWAL
Kaitlin Y SergiAustraliaElwin Sharvill UNQUALIFIED
Leon K KuskoIndiaOnyama Limba UNQUALIFIED
Ricardo F RulapaughAustraliaAsiya Javayant UNQUALIFIED
Kadeem D FlosiRussiaElwin Sharvill RENEWAL
Jones S ChuiSpainXuxue Feng RENEWAL
Chavez Y SchemmerBrazilStephen Shaw UNQUALIFIED
Antonio U SchemmerUnited KingdomAmy Elsner PROPOSAL
Juan Y IturbideGermanyXuxue Feng QUALIFIED
Aditya Q MarrierBrazilElwin Sharvill NEW
David U SlusarskiCanadaAsiya Javayant RENEWAL
Deepesh H MaletUnited KingdomAsiya Javayant QUALIFIED
Arvin X RutaSpainAmy Elsner UNQUALIFIED
James F FlosiIndiaAsiya Javayant NEGOTIATION
Arvin H FollerCanadaIvan Magalhaes PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Claire O IturbideRussiaBernardo Dominic NEGOTIATION
Smith E MaletAustraliaAmy Elsner NEGOTIATION
Leja B OstroskyBrazilOnyama Limba PROPOSAL
Tony Y SergiItalyAnna Fali NEGOTIATION
Munro B SlusarskiGermanyAmy Elsner RENEWAL
Leon G MaletGermanyAnna Fali NEGOTIATION
Misaki L RimArgentinaStephen Shaw PROPOSAL
David V NickaRussiaXuxue Feng UNQUALIFIED
Ashley G InouyeBrazilAmy Elsner RENEWAL
Antonio P InouyeJapanIvan Magalhaes PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Sinclair Q WhobreyCanada2024-05-01Rangoni Of Florence NEW56Bernardo Dominic
1001Faith W InouyeFrance2024-05-23Chemel, James L Cpa UNQUALIFIED11Elwin Sharvill
1002Leja I WieserArgentina2024-05-11Buckley Miller Wright RENEWAL16Anna Fali
1003Isabel H BologniaJapan2024-04-29Buckley Miller Wright RENEWAL22Ioni Bowcher
1004Arvin B ButtSpain2024-04-29Feiner Bros RENEWAL31Anna Fali
1005Antonio F ChuiBrazil2024-05-20Chemel, James L Cpa RENEWAL26Ioni Bowcher
1006Ashley S WhobreyRussia2024-05-10Dorl, James J Esq QUALIFIED35Ioni Bowcher
1007Rodrigues P FerenczUnited Kingdom2024-05-15Rousseaux, Michael Esq PROPOSAL87Amy Elsner
1008Aditya Z ButtBrazil2024-05-03Commercial Press NEW26Onyama Limba
1009Silvio N PerinItaly2024-05-10Commercial Press PROPOSAL40Ivan Magalhaes
1010Jennifer X GauchoIndia2024-05-11King, Christopher A Esq PROPOSAL45Anna Fali
1011Misaki I SergiCanada2024-05-22Chapman, Ross E Esq PROPOSAL65Anna Fali
1012Ashley P NickaIndia2024-04-29Chapman, Ross E Esq PROPOSAL41Asiya Javayant
1013Mayumi Z RimRussia2024-05-02Printing Dimensions PROPOSAL98Anna Fali
1014Aika T DarakjyJapan2024-05-04Chapman, Ross E Esq UNQUALIFIED27Ivan Magalhaes
1015Darci L BriddickAustralia2024-05-24Feiner Bros NEW57Stephen Shaw
1016Aditya F MarrierRussia2024-05-11Dorl, James J Esq RENEWAL13Bernardo Dominic
1017Aruna R MacleadCanada2024-05-10Commercial Press UNQUALIFIED11Ioni Bowcher
1018Darci T SchemmerItaly2024-05-20Commercial Press UNQUALIFIED47Stephen Shaw
1019Salvatore V FerenczCanada2024-05-05Chemel, James L Cpa NEW70Ivan Magalhaes
1020Sinclair W GillianGermany2024-05-26Buckley Miller Wright NEW47Ivan Magalhaes
1021Faith A SaylorsFrance2024-05-03Commercial Press QUALIFIED39Onyama Limba
1022Sinclair W PerinSpain2024-05-12Chemel, James L Cpa NEW40Stephen Shaw
1023Leja H RimUnited Kingdom2024-05-06Chapman, Ross E Esq RENEWAL22Amy Elsner
1024Munro H PoquetteIndia2024-05-06Chapman, Ross E Esq QUALIFIED45Amy Elsner
1025Clifford H MacleadFrance2024-05-07Buckley Miller Wright QUALIFIED63Anna Fali
1026Silvio X AlbaresRussia2024-05-22Morlong Associates NEW30Anna Fali
1027Munro B WieserJapan2024-05-02Commercial Press UNQUALIFIED88Ioni Bowcher
1028Leon H RutaFrance2024-05-15Feiner Bros PROPOSAL71Bernardo Dominic
1029Francesco M FerenczGermany2024-05-24Benton, John B Jr QUALIFIED48Onyama Limba
1030Antonio T DilliardIndia2024-05-01King, Christopher A Esq NEGOTIATION92Amy Elsner
1031Antonio J RutaCanada2024-05-16Feiner Bros NEW48Asiya Javayant
1032Jones Z VocelkaJapan2024-05-27Dorl, James J Esq RENEWAL68Xuxue Feng
1033Silvio X AlbaresFrance2024-05-09Buckley Miller Wright UNQUALIFIED73Ivan Magalhaes
1034Aika V CaldareraItaly2024-04-29King, Christopher A Esq NEW74Onyama Limba
1035Claire D ButtJapan2024-05-12Buckley Miller Wright NEGOTIATION86Anna Fali
1036Deepesh L DoeRussia2024-04-30Rangoni Of Florence NEGOTIATION3Stephen Shaw
1037James Z BologniaFrance2024-05-08King, Christopher A Esq NEGOTIATION64Xuxue Feng
1038Stacey F OstroskyIndia2024-05-11Rangoni Of Florence UNQUALIFIED51Stephen Shaw
1039Octavia W OstroskyCanada2024-05-21Dorl, James J Esq RENEWAL8Stephen Shaw
1040Isabel U DarakjyUnited Kingdom2024-05-14Chanay, Jeffrey A Esq UNQUALIFIED99Ivan Magalhaes
1041Julie P GarufiUnited Kingdom2024-05-03Benton, John B Jr QUALIFIED87Onyama Limba
1042Sinclair Y RoysterRussia2024-05-15Commercial Press PROPOSAL22Xuxue Feng
1043Stacey U TollnerJapan2024-05-25Benton, John B Jr NEW26Onyama Limba
1044Chavez I NestleCanada2024-05-10Dorl, James J Esq UNQUALIFIED49Ioni Bowcher
1045Kadeem H VenereAustralia2024-05-06Feltz Printing Service PROPOSAL31Bernardo Dominic
1046Wickens Z TollnerSpain2024-05-03Rangoni Of Florence PROPOSAL16Onyama Limba
1047Rodrigues C TollnerBrazil2024-05-07Feltz Printing Service PROPOSAL15Ivan Magalhaes
1048Morrow K CampainArgentina2024-05-09Chanay, Jeffrey A Esq NEW29Onyama Limba
1049Ivar T WieserGermany2024-05-10Rousseaux, Michael Esq NEW11Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Izzy P CampainCanadaOnyama Limba NEW
Emily S CampainArgentinaBernardo Dominic RENEWAL
Chavez P RoysterAustraliaAmy Elsner NEW
Rodrigues X RimRussiaOnyama Limba UNQUALIFIED
Salvatore I KolmetzFranceAnna Fali RENEWAL
Leon N RoysterAustraliaAsiya Javayant QUALIFIED
Jeanfrancois S SaylorsUnited KingdomIoni Bowcher QUALIFIED
Munro L VenereItalyIoni Bowcher RENEWAL
Smith K RulapaughGermanyElwin Sharvill QUALIFIED
Wickens Q WhobreyIndiaAsiya Javayant PROPOSAL
Jones J NickaIndiaElwin Sharvill RENEWAL
Kaitlin E ShinkoRussiaBernardo Dominic NEW
Murillo N FigeroaArgentinaOnyama Limba RENEWAL
Adams C NickaJapanAmy Elsner RENEWAL
Aika K DilliardAustraliaAmy Elsner PROPOSAL
Deepesh B FigeroaJapanAmy Elsner NEGOTIATION
Isabel Z FerenczJapanOnyama Limba NEGOTIATION
Chavez Q RimRussiaAmy Elsner NEGOTIATION
Alejandro M GlickCanadaStephen Shaw RENEWAL
Maisha B GillianRussiaStephen Shaw PROPOSAL
Wickens G AmigonRussiaAnna Fali UNQUALIFIED
Kaitlin Y CaudyJapanIvan Magalhaes NEGOTIATION
Munro G CampainFranceOnyama Limba NEGOTIATION
Murillo P GillianRussiaIoni Bowcher UNQUALIFIED
Jennifer D WaycottBrazilStephen Shaw QUALIFIED
Nicolas R ButtIndiaAnna Fali NEW
Mayumi P AlbaresFranceAsiya Javayant RENEWAL
Jeanfrancois I AlbaresAustraliaElwin Sharvill PROPOSAL
Claire V BowleyBrazilIoni Bowcher UNQUALIFIED
Kadeem D NestleGermanyElwin Sharvill NEGOTIATION
Ashley F MorascaArgentinaElwin Sharvill PROPOSAL
Misaki T DilliardArgentinaOnyama Limba RENEWAL
Ivar F RulapaughItalyIvan Magalhaes QUALIFIED
Tony O IturbideFranceBernardo Dominic NEGOTIATION
Isabel D KuskoFranceAsiya Javayant NEGOTIATION
Rodrigues C KuskoItalyBernardo Dominic RENEWAL
Alejandro O MaletFranceBernardo Dominic PROPOSAL
Leon N BowleyAustraliaXuxue Feng QUALIFIED
Octavia O KuskoUnited KingdomIoni Bowcher NEGOTIATION
Aditya X DarakjyUnited KingdomAsiya Javayant UNQUALIFIED
Mayumi U ButtArgentinaStephen Shaw UNQUALIFIED
Morrow V DoeArgentinaAnna Fali UNQUALIFIED
Costa M WhobreyFranceOnyama Limba NEW
Murillo E StockhamJapanBernardo Dominic NEW
Mujtaba T BowleyGermanyAnna Fali NEGOTIATION
Arvin P DarakjySpainIvan Magalhaes NEGOTIATION
Julie S MorascaAustraliaXuxue Feng NEW
Juan N SergiUnited KingdomBernardo Dominic NEGOTIATION
Darci A BowleyCanadaElwin Sharvill PROPOSAL
Salvatore J NestleAustraliaStephen Shaw PROPOSAL
Frozen Columns
Name
Clifford A Bowley
Johnson G Schemmer
Maria F Doe
Johnson Q Glick
David R Ferencz
Emily S Malet
Jennifer P Malet
Ashley P Albares
Tony T Bowley
Kadeem T Paprocki
Salvatore T Kolmetz
Mayumi A Waycott
Leon R Butt
Deepesh U Gillian
Maisha L Sergi
Stacey B Bolognia
Nicolas J Kolmetz
Faith H Bowley
Stacey Y Bolognia
Deepesh G Briddick
David T Albares
Johnson L Campain
Mujtaba U Waycott
Sinclair N Figeroa
Silvio O Wieser
Misaki S Iturbide
David A Nicka
Octavia N Ruta
Silvio E Ruta
Ricardo R Gaucho
James F Shinko
Munro I Campain
Ashley T Kolmetz
Ricardo E Darakjy
Greenwood D Shinko
Maisha I Marrier
Leon Q Shinko
Murillo N Rulapaugh
Ricardo B Tollner
Chavez C Kolmetz
Ivar V Garufi
Claire C Flosi
Izzy K Nicka
Claire D Albares
Johnson J Darakjy
Salvatore K Bowley
Juan G Nestle
Clifford L Albares
Jones J Sergi
Clifford H Garufi
IdCountryDate
1000Italy2024-05-19
1001Spain2024-05-06
1002Brazil2024-05-11
1003Argentina2024-05-16
1004India2024-05-01
1005Russia2024-05-18
1006India2024-05-16
1007United Kingdom2024-05-02
1008Argentina2024-04-29
1009Australia2024-05-22
1010Brazil2024-05-20
1011Germany2024-05-04
1012Japan2024-05-06
1013Australia2024-04-29
1014Brazil2024-04-29
1015Italy2024-05-08
1016Canada2024-05-15
1017Russia2024-05-10
1018Russia2024-05-06
1019Australia2024-05-06
1020Japan2024-05-23
1021Germany2024-05-13
1022Russia2024-05-14
1023France2024-05-02
1024Italy2024-05-06
1025Argentina2024-05-13
1026Brazil2024-05-14
1027Italy2024-05-15
1028Russia2024-05-09
1029Italy2024-05-17
1030Germany2024-05-01
1031Spain2024-05-13
1032Russia2024-05-27
1033Germany2024-05-22
1034Spain2024-05-01
1035United Kingdom2024-05-18
1036Brazil2024-05-01
1037Japan2024-05-01
1038United Kingdom2024-05-21
1039Argentina2024-05-09
1040India2024-04-30
1041Brazil2024-05-24
1042Australia2024-05-21
1043Canada2024-05-12
1044Russia2024-05-08
1045France2024-05-11
1046Italy2024-05-23
1047Spain2024-05-20
1048Brazil2024-05-18
1049Germany2024-05-22

On-Demand Data

NameIdCountryDate
Alejandro K Albares1000Argentina2024-05-09
Silvio V Wieser1001Germany2024-05-05
Silvio Y Vocelka1002France2024-05-20
Claire V Gaucho1003Spain2024-05-04
Mayumi I Ferencz1004India2024-05-22
Misaki X Stenseth1005Australia2024-05-13
Aditya B Wieser1006Russia2024-05-25
Murillo Q Foller1007Spain2024-05-17
Costa Z Albares1008United Kingdom2024-05-04
Darci D Gaucho1009Australia2024-05-24
Costa P Gillian1010Spain2024-05-16
Izzy Q Caldarera1011Germany2024-05-01
Emily S Kolmetz1012Brazil2024-05-28
Chavez Y Marrier1013Brazil2024-05-12
Jennifer H Slusarski1014France2024-05-25
David V Doe1015Argentina2024-04-30
Munro C Caudy1016Russia2024-05-12
Stacey Y Vocelka1017Argentina2024-05-19
Silvio F Gillian1018Germany2024-05-02
Isabel X Bolognia1019Canada2024-05-16
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Smith O DilliardBrazilStephen Shaw RENEWAL
Rodrigues L DarakjyRussiaIoni Bowcher RENEWAL
Salvatore K KolmetzCanadaElwin Sharvill QUALIFIED
Costa J ShinkoAustraliaElwin Sharvill QUALIFIED
Kaitlin U KuskoCanadaXuxue Feng UNQUALIFIED
Octavia B VocelkaFranceAmy Elsner NEW
Aditya S BologniaGermanyAsiya Javayant RENEWAL
Julie E DarakjyJapanAsiya Javayant UNQUALIFIED
Claire C MorascaRussiaXuxue Feng PROPOSAL
Aruna E ButtArgentinaIvan Magalhaes NEGOTIATION
Darci J NestleGermanyOnyama Limba QUALIFIED
Emily A GlickItalyAsiya Javayant NEW
Arvin W AlbaresRussiaAsiya Javayant RENEWAL
Maisha J BologniaAustraliaOnyama Limba NEW
Juan W NestleGermanyBernardo Dominic NEW
Cody I VenereAustraliaBernardo Dominic PROPOSAL
Clifford F RulapaughFranceAmy Elsner NEW
Silvio C FerenczFranceIoni Bowcher NEGOTIATION
Wickens S WaycottIndiaOnyama Limba UNQUALIFIED
Claire J FigeroaSpainElwin Sharvill PROPOSAL
Isabel O FerenczGermanyAmy Elsner UNQUALIFIED
Rodrigues I GlickGermanyIvan Magalhaes NEGOTIATION
Isabel Z StensethSpainElwin Sharvill PROPOSAL
Faith U BologniaGermanyXuxue Feng NEW
Juan E GauchoUnited KingdomAnna Fali QUALIFIED
Chavez K DarakjyJapanElwin Sharvill UNQUALIFIED
Jeanfrancois R CaudyCanadaAnna Fali UNQUALIFIED
Jeanfrancois K MaletAustraliaAsiya Javayant RENEWAL
Julie R TollnerIndiaBernardo Dominic PROPOSAL
Nicolas S GlickUnited KingdomElwin Sharvill NEW
Cody Q SlusarskiSpainElwin Sharvill PROPOSAL
Smith D WieserRussiaIvan Magalhaes QUALIFIED
Jennifer X VenereIndiaElwin Sharvill UNQUALIFIED
Rodrigues A StockhamAustraliaBernardo Dominic NEW
Maisha G TollnerJapanIvan Magalhaes NEW
Faith Z MaletAustraliaStephen Shaw NEW
Alejandro O DilliardArgentinaAsiya Javayant NEW
Izzy P PoquetteCanadaXuxue Feng NEW
Mayumi T MorascaGermanyElwin Sharvill RENEWAL
Chavez F AmigonFranceXuxue Feng 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>