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
Faith W MaletGermanyAsiya Javayant RENEWAL
Cody K CampainFranceIoni Bowcher RENEWAL
Munro R BriddickRussiaStephen Shaw RENEWAL
Costa M BologniaRussiaAnna Fali UNQUALIFIED
Jennifer Z PaprockiUnited KingdomAnna Fali NEGOTIATION
Mujtaba J IturbideJapanOnyama Limba NEW
Deepesh J BologniaRussiaStephen Shaw NEW
Jefferson B KolmetzCanadaBernardo Dominic RENEWAL
Darci H OldroydGermanyAmy Elsner RENEWAL
Rodrigues Z OstroskySpainXuxue Feng RENEWAL
Cody G WhobreyBrazilAsiya Javayant PROPOSAL
Silvio K FollerIndiaXuxue Feng RENEWAL
Juan Q NestleAustraliaAmy Elsner PROPOSAL
Jefferson Q TollnerCanadaBernardo Dominic UNQUALIFIED
Juan E SlusarskiArgentinaAmy Elsner RENEWAL
Claire Q WhobreyIndiaAmy Elsner NEW
Deepesh Q GillianCanadaAsiya Javayant NEW
Johnson D RimUnited KingdomIoni Bowcher UNQUALIFIED
Maisha V RoysterItalyBernardo Dominic RENEWAL
Kaitlin C AlbaresFranceElwin Sharvill RENEWAL
Murillo V RutaSpainBernardo Dominic QUALIFIED
Ivar U ButtUnited KingdomOnyama Limba UNQUALIFIED
Murillo O SchemmerAustraliaXuxue Feng RENEWAL
Cody I DoeCanadaAsiya Javayant PROPOSAL
Jeanfrancois A InouyeItalyElwin Sharvill NEGOTIATION
Ricardo N CaldareraSpainStephen Shaw UNQUALIFIED
Ivar C MacleadJapanXuxue Feng QUALIFIED
Jefferson I GillianUnited KingdomIvan Magalhaes PROPOSAL
Ricardo Q ChuiItalyStephen Shaw NEW
Stacey L IturbideRussiaStephen Shaw PROPOSAL
Adams Z DarakjySpainElwin Sharvill QUALIFIED
Aika Z BologniaBrazilElwin Sharvill UNQUALIFIED
Mujtaba K RoysterJapanStephen Shaw RENEWAL
Emily Y SergiFranceBernardo Dominic UNQUALIFIED
Jefferson H ButtFranceAmy Elsner PROPOSAL
Aika I MaletUnited KingdomAsiya Javayant NEW
Faith L SaylorsRussiaAsiya Javayant QUALIFIED
Antonio G InouyeItalyBernardo Dominic NEW
Smith G VocelkaGermanyStephen Shaw RENEWAL
Emily S VocelkaGermanyOnyama Limba NEW
Alejandro X FollerBrazilAnna Fali NEGOTIATION
Mayumi F ChuiJapanAmy Elsner NEW
James C FigeroaGermanyStephen Shaw QUALIFIED
Maisha X NickaItalyAsiya Javayant PROPOSAL
Cody P MaletRussiaAsiya Javayant QUALIFIED
Deepesh G OstroskyUnited KingdomIoni Bowcher PROPOSAL
Arvin C FerenczJapanAmy Elsner NEW
Stacey A MaletItalyStephen Shaw PROPOSAL
Octavia T BowleyCanadaAsiya Javayant NEGOTIATION
Leja B CaudyItalyIoni Bowcher NEW
Horizontal
NameCountryRepresentativeStatus
Murillo E WaycottAustraliaStephen Shaw UNQUALIFIED
Kaitlin D NickaGermanyAnna Fali NEGOTIATION
Faith Y RoysterFranceOnyama Limba NEGOTIATION
Stacey K NickaFranceOnyama Limba PROPOSAL
Cody M VocelkaItalyAnna Fali NEGOTIATION
Clifford J NestleUnited KingdomIvan Magalhaes NEGOTIATION
Julie R GillianSpainIvan Magalhaes PROPOSAL
Arvin M FerenczBrazilBernardo Dominic NEGOTIATION
Johnson G CampainArgentinaAsiya Javayant UNQUALIFIED
Costa W WhobreyGermanyIoni Bowcher QUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Morrow J SaylorsSpain2024-05-29Chanay, Jeffrey A Esq UNQUALIFIED11Stephen Shaw
1001Claire Z CampainBrazil2024-06-18Printing Dimensions PROPOSAL50Bernardo Dominic
1002Julie R DoeIndia2024-05-26Benton, John B Jr NEW35Ioni Bowcher
1003Jeanfrancois V BologniaFrance2024-06-08Truhlar And Truhlar Attys QUALIFIED18Ivan Magalhaes
1004Mayumi W SaylorsCanada2024-06-13Benton, John B Jr RENEWAL5Ivan Magalhaes
1005Salvatore E MaletRussia2024-06-14King, Christopher A Esq QUALIFIED57Ioni Bowcher
1006David W CampainGermany2024-05-26Truhlar And Truhlar Attys PROPOSAL57Asiya Javayant
1007Isabel O SlusarskiCanada2024-06-16Rangoni Of Florence UNQUALIFIED76Asiya Javayant
1008Salvatore U OstroskyJapan2024-05-29Buckley Miller Wright RENEWAL39Onyama Limba
1009Alejandro O WieserArgentina2024-06-16Dorl, James J Esq NEGOTIATION36Ioni Bowcher
1010James W FollerCanada2024-06-10Feltz Printing Service PROPOSAL62Xuxue Feng
1011Juan S RimArgentina2024-06-22Chemel, James L Cpa NEW2Stephen Shaw
1012Jennifer M StensethUnited Kingdom2024-06-03Printing Dimensions NEGOTIATION73Stephen Shaw
1013Faith N SchemmerBrazil2024-06-21Truhlar And Truhlar Attys PROPOSAL76Elwin Sharvill
1014Darci K WieserBrazil2024-05-26Printing Dimensions NEGOTIATION12Onyama Limba
1015Ivar V WhobreyRussia2024-06-13Rousseaux, Michael Esq UNQUALIFIED69Elwin Sharvill
1016Claire Q BologniaJapan2024-06-02Chemel, James L Cpa RENEWAL60Ivan Magalhaes
1017Maria Y FigeroaRussia2024-06-11Buckley Miller Wright PROPOSAL97Bernardo Dominic
1018Kadeem A WieserBrazil2024-06-17Truhlar And Truhlar Attys NEW70Asiya Javayant
1019James G DilliardGermany2024-05-26Buckley Miller Wright QUALIFIED35Amy Elsner
1020Kaitlin T InouyeFrance2024-06-02Rousseaux, Michael Esq RENEWAL62Amy Elsner
1021Kaitlin T TollnerCanada2024-06-23Dorl, James J Esq QUALIFIED20Ioni Bowcher
1022Leon Q WaycottIndia2024-05-31Printing Dimensions RENEWAL74Bernardo Dominic
1023Isabel H ButtBrazil2024-05-30Printing Dimensions QUALIFIED0Onyama Limba
1024Juan U GillianBrazil2024-06-04Printing Dimensions QUALIFIED72Elwin Sharvill
1025Johnson N DarakjyAustralia2024-06-17Truhlar And Truhlar Attys NEGOTIATION82Amy Elsner
1026Darci U OstroskyUnited Kingdom2024-06-22Morlong Associates UNQUALIFIED79Ivan Magalhaes
1027Mayumi A GarufiJapan2024-06-22Truhlar And Truhlar Attys NEW88Xuxue Feng
1028Faith T VenereGermany2024-06-05Chapman, Ross E Esq NEGOTIATION16Ioni Bowcher
1029Morrow V WieserUnited Kingdom2024-05-26Benton, John B Jr UNQUALIFIED40Asiya Javayant
1030Salvatore S MaletBrazil2024-06-24Rousseaux, Michael Esq QUALIFIED15Elwin Sharvill
1031Wickens W MarrierAustralia2024-06-11Feltz Printing Service UNQUALIFIED18Ioni Bowcher
1032Mayumi L RutaSpain2024-06-13Dorl, James J Esq NEGOTIATION57Bernardo Dominic
1033Octavia K WieserUnited Kingdom2024-06-22Chanay, Jeffrey A Esq RENEWAL13Xuxue Feng
1034Stacey Y NestleArgentina2024-06-04Rousseaux, Michael Esq QUALIFIED16Anna Fali
1035Ricardo L PerinItaly2024-06-22Truhlar And Truhlar Attys QUALIFIED33Ivan Magalhaes
1036Mayumi J OldroydItaly2024-06-01Rangoni Of Florence PROPOSAL23Asiya Javayant
1037Adams J InouyeCanada2024-05-28Dorl, James J Esq NEW98Stephen Shaw
1038Johnson R BriddickFrance2024-06-18Dorl, James J Esq NEGOTIATION60Xuxue Feng
1039Aditya I OldroydUnited Kingdom2024-06-16Benton, John B Jr NEGOTIATION89Ivan Magalhaes
1040Cody E SlusarskiSpain2024-06-01Truhlar And Truhlar Attys NEGOTIATION14Elwin Sharvill
1041Kaitlin Z CaldareraBrazil2024-06-13Chanay, Jeffrey A Esq RENEWAL39Onyama Limba
1042Deepesh B MorascaAustralia2024-06-05Rangoni Of Florence NEGOTIATION57Anna Fali
1043Clifford U WieserIndia2024-06-10Truhlar And Truhlar Attys NEGOTIATION38Amy Elsner
1044Octavia V FerenczItaly2024-06-19Feltz Printing Service RENEWAL64Asiya Javayant
1045Claire Z BriddickSpain2024-06-06Morlong Associates RENEWAL0Ivan Magalhaes
1046Stacey B ChuiUnited Kingdom2024-06-24Rangoni Of Florence QUALIFIED64Elwin Sharvill
1047Leja R KolmetzAustralia2024-06-12King, Christopher A Esq UNQUALIFIED4Ioni Bowcher
1048Ricardo D BowleyArgentina2024-05-26Printing Dimensions NEW77Stephen Shaw
1049Darci X GarufiUnited Kingdom2024-05-29King, Christopher A Esq UNQUALIFIED96Stephen Shaw
Frozen Rows
NameCountryRepresentativeStatus
Chavez H WieserRussiaAnna Fali UNQUALIFIED
Antonio J DoeAustraliaElwin Sharvill NEW
Francesco H GlickFranceIoni Bowcher QUALIFIED
Leon G GarufiAustraliaOnyama Limba RENEWAL
Johnson C WieserItalyAmy Elsner PROPOSAL
Murillo U KuskoJapanAsiya Javayant NEW
James A WhobreyAustraliaElwin Sharvill QUALIFIED
Rodrigues L StockhamCanadaXuxue Feng NEGOTIATION
Sinclair K ChuiArgentinaBernardo Dominic UNQUALIFIED
Deepesh O CampainItalyIoni Bowcher PROPOSAL
Arvin D PoquetteAustraliaAmy Elsner NEGOTIATION
Ivar T WieserArgentinaElwin Sharvill QUALIFIED
Aditya K MaletJapanAmy Elsner UNQUALIFIED
Misaki S WaycottBrazilIvan Magalhaes PROPOSAL
Leja N CaudyArgentinaIvan Magalhaes UNQUALIFIED
Claire T CampainGermanyAmy Elsner RENEWAL
Antonio M WhobreyRussiaAmy Elsner QUALIFIED
Cody S TollnerRussiaBernardo Dominic NEW
Mayumi E BologniaItalyBernardo Dominic NEGOTIATION
Mujtaba E DilliardFranceOnyama Limba NEW
Izzy D NickaArgentinaIvan Magalhaes RENEWAL
Adams A AmigonCanadaIvan Magalhaes QUALIFIED
Kadeem E MarrierRussiaXuxue Feng NEW
Johnson F WhobreyBrazilAmy Elsner PROPOSAL
Isabel L PerinRussiaAmy Elsner NEGOTIATION
Alejandro B DarakjyAustraliaAsiya Javayant UNQUALIFIED
Deepesh G StensethGermanyOnyama Limba UNQUALIFIED
Johnson M StensethSpainAmy Elsner QUALIFIED
Ivar H RutaCanadaIoni Bowcher QUALIFIED
Ashley D VenereFranceAsiya Javayant PROPOSAL
Stacey I OldroydCanadaAnna Fali UNQUALIFIED
Jefferson N DoeAustraliaIvan Magalhaes RENEWAL
Chavez Q IturbideUnited KingdomStephen Shaw NEGOTIATION
Jones Y MarrierFranceAmy Elsner NEGOTIATION
Leon A PaprockiGermanyStephen Shaw PROPOSAL
Emily H AlbaresItalyIoni Bowcher UNQUALIFIED
Sinclair D StensethRussiaBernardo Dominic QUALIFIED
Aditya V VocelkaSpainAsiya Javayant NEGOTIATION
David P KuskoItalyAmy Elsner QUALIFIED
Julie H StockhamSpainStephen Shaw QUALIFIED
Sinclair Q OldroydSpainIvan Magalhaes NEW
Maria Y ButtArgentinaIoni Bowcher UNQUALIFIED
Maisha G NestleItalyBernardo Dominic QUALIFIED
Misaki O FlosiArgentinaBernardo Dominic NEGOTIATION
Costa E PerinUnited KingdomOnyama Limba NEGOTIATION
Adams O BologniaCanadaIvan Magalhaes RENEWAL
Greenwood L FollerBrazilIoni Bowcher NEGOTIATION
Munro E WieserGermanyIoni Bowcher RENEWAL
Juan M VocelkaGermanyOnyama Limba UNQUALIFIED
Arvin C GarufiUnited KingdomOnyama Limba PROPOSAL
Frozen Columns
Name
Francesco L Gaucho
Ashley W Perin
Deepesh J Whobrey
Francesco R Paprocki
Stacey S Bowley
Silvio D Stenseth
Clifford D Poquette
Johnson Y Bowley
Ricardo I Darakjy
Isabel R Sergi
Julie J Oldroyd
Aditya G Venere
Jones B Dilliard
Ricardo L Saylors
Morrow Y Garufi
Mayumi F Albares
Adams H Briddick
Smith G Poquette
Sinclair L Garufi
Leja B Malet
Cody Y Albares
Izzy L Iturbide
Munro T Morasca
Morrow Y Bowley
Maisha M Bolognia
Leon M Campain
Octavia S Sergi
Cody Z Briddick
Morrow M Inouye
Leon G Stockham
Mayumi S Malet
Aditya M Amigon
Johnson V Stockham
Sinclair K Butt
Darci Z Rulapaugh
Jones L Venere
Aditya D Perin
Kadeem W Albares
Maria X Iturbide
Salvatore T Waycott
Leja X Paprocki
Aditya R Poquette
Mujtaba E Morasca
Kadeem W Perin
Smith J Chui
Ivar L Chui
James R Iturbide
Mujtaba I Stenseth
Leja T Caudy
Darci K Ruta
IdCountryDate
1000Brazil2024-05-27
1001Brazil2024-06-20
1002Italy2024-06-16
1003Italy2024-06-07
1004United Kingdom2024-06-09
1005Italy2024-06-18
1006Brazil2024-06-09
1007Russia2024-06-02
1008India2024-06-08
1009Brazil2024-06-23
1010Russia2024-06-20
1011France2024-05-27
1012Canada2024-06-10
1013France2024-06-05
1014Australia2024-06-21
1015Germany2024-05-29
1016Italy2024-06-13
1017Italy2024-06-02
1018Japan2024-06-12
1019Germany2024-06-04
1020Japan2024-06-18
1021India2024-06-09
1022Spain2024-06-14
1023Japan2024-06-13
1024Australia2024-06-22
1025Argentina2024-05-26
1026Japan2024-06-14
1027Italy2024-06-01
1028Argentina2024-06-08
1029France2024-06-21
1030Italy2024-06-23
1031United Kingdom2024-05-27
1032Russia2024-06-03
1033India2024-06-08
1034Argentina2024-05-29
1035Spain2024-06-12
1036Italy2024-06-09
1037Argentina2024-06-13
1038India2024-06-02
1039France2024-06-03
1040Argentina2024-06-18
1041Brazil2024-06-03
1042Brazil2024-05-29
1043Brazil2024-05-31
1044Argentina2024-06-22
1045Germany2024-06-03
1046United Kingdom2024-06-14
1047Russia2024-06-01
1048Japan2024-06-11
1049Argentina2024-06-15

On-Demand Data

NameIdCountryDate
Darci N Foller1000Germany2024-06-07
Maisha J Briddick1001Australia2024-06-21
Kadeem S Nestle1002Italy2024-05-31
Ashley U Figeroa1003Germany2024-06-20
Jones V Saylors1004Argentina2024-05-26
Leja R Sergi1005India2024-06-16
Jones I Iturbide1006Japan2024-06-10
Kaitlin W Figeroa1007Italy2024-06-05
Emily Z Rim1008Italy2024-06-18
Claire I Slusarski1009Japan2024-06-24
Tony L Malet1010Australia2024-06-12
Cody A Gaucho1011Italy2024-06-19
Chavez X Sergi1012Germany2024-06-15
Deepesh Z Figeroa1013Germany2024-06-08
Smith P Amigon1014Brazil2024-06-24
Claire L Slusarski1015France2024-06-20
Leon U Venere1016Brazil2024-05-31
Aika E Amigon1017Brazil2024-06-24
Wickens F Glick1018Italy2024-06-13
Tony S Caudy1019Argentina2024-06-06
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Izzy J BriddickJapanOnyama Limba PROPOSAL
Murillo Q NickaFranceStephen Shaw NEW
Costa S TollnerGermanyStephen Shaw UNQUALIFIED
David Q BowleyRussiaAmy Elsner PROPOSAL
David R GarufiSpainAsiya Javayant UNQUALIFIED
Leja H OldroydItalyBernardo Dominic UNQUALIFIED
Francesco S MaletAustraliaIvan Magalhaes RENEWAL
Alejandro J RimSpainIvan Magalhaes NEGOTIATION
Cody P DoeUnited KingdomOnyama Limba QUALIFIED
Arvin A WhobreyJapanIvan Magalhaes NEGOTIATION
Costa E MacleadCanadaIvan Magalhaes QUALIFIED
Murillo K KuskoUnited KingdomAmy Elsner NEGOTIATION
Nicolas O MorascaItalyXuxue Feng UNQUALIFIED
Clifford U ChuiSpainXuxue Feng NEGOTIATION
Salvatore B RutaRussiaElwin Sharvill NEGOTIATION
Antonio X OstroskyItalyAmy Elsner NEGOTIATION
Wickens I GauchoItalyAmy Elsner NEW
Adams K TollnerRussiaOnyama Limba NEW
Adams O BologniaSpainOnyama Limba PROPOSAL
Adams M RulapaughIndiaAsiya Javayant NEW
Munro W GillianSpainAmy Elsner QUALIFIED
Alejandro M GillianUnited KingdomBernardo Dominic QUALIFIED
Emily K SlusarskiAustraliaStephen Shaw UNQUALIFIED
Rodrigues T PaprockiItalyIoni Bowcher PROPOSAL
Octavia D KolmetzGermanyStephen Shaw NEW
Leon L NestleJapanIoni Bowcher PROPOSAL
Salvatore A RoysterBrazilIvan Magalhaes NEW
Leon I WaycottArgentinaAsiya Javayant QUALIFIED
Smith E PerinRussiaElwin Sharvill NEGOTIATION
Misaki Q MorascaItalyAnna Fali RENEWAL
Francesco G PaprockiItalyXuxue Feng PROPOSAL
Leja L AlbaresJapanBernardo Dominic NEGOTIATION
Tony X RimBrazilBernardo Dominic QUALIFIED
Munro K StockhamRussiaAsiya Javayant QUALIFIED
Francesco Z VenereJapanElwin Sharvill NEGOTIATION
Alejandro Q PerinAustraliaXuxue Feng UNQUALIFIED
James Q IturbideAustraliaAmy Elsner RENEWAL
Kadeem D NestleBrazilIvan Magalhaes NEW
Murillo V WaycottIndiaIoni Bowcher NEGOTIATION
Deepesh J GarufiItalyIoni Bowcher 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>