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
Alejandro R MorascaFranceStephen Shaw PROPOSAL
Kaitlin J OldroydIndiaStephen Shaw QUALIFIED
Salvatore B StockhamCanadaElwin Sharvill UNQUALIFIED
Isabel G WaycottBrazilOnyama Limba RENEWAL
Johnson W GillianArgentinaAmy Elsner NEGOTIATION
Jeanfrancois S GlickIndiaAnna Fali NEW
Emily E IturbideGermanyStephen Shaw QUALIFIED
Jefferson K BriddickItalyAmy Elsner NEGOTIATION
Mayumi U VenereCanadaBernardo Dominic RENEWAL
Deepesh I MaletJapanElwin Sharvill UNQUALIFIED
Isabel A NestleRussiaXuxue Feng NEW
Alejandro H TollnerIndiaAsiya Javayant NEW
Leon E ButtItalyAsiya Javayant NEW
Rodrigues A PaprockiRussiaAmy Elsner RENEWAL
Juan X IturbideSpainStephen Shaw RENEWAL
Costa E WaycottArgentinaElwin Sharvill RENEWAL
Antonio P FigeroaBrazilOnyama Limba NEW
Adams P CampainAustraliaIvan Magalhaes RENEWAL
Nicolas Y SaylorsBrazilIvan Magalhaes QUALIFIED
Clifford V KuskoRussiaIoni Bowcher NEW
Mayumi X DoeArgentinaAmy Elsner NEGOTIATION
Octavia U ButtIndiaAmy Elsner PROPOSAL
Octavia C NestleItalyAmy Elsner NEW
Isabel H DoeBrazilIvan Magalhaes QUALIFIED
Claire G SlusarskiUnited KingdomAnna Fali UNQUALIFIED
Claire O InouyeItalyBernardo Dominic NEGOTIATION
Juan H KolmetzIndiaBernardo Dominic PROPOSAL
Emily P DilliardSpainAnna Fali NEGOTIATION
Tony A GillianCanadaAnna Fali RENEWAL
Jeanfrancois H SaylorsSpainIvan Magalhaes UNQUALIFIED
Aruna J PaprockiCanadaElwin Sharvill NEGOTIATION
Murillo D RulapaughUnited KingdomElwin Sharvill NEW
Morrow B KolmetzItalyIvan Magalhaes NEGOTIATION
Tony K AmigonRussiaBernardo Dominic UNQUALIFIED
Claire F VenereJapanIvan Magalhaes PROPOSAL
Aika R CaudyRussiaXuxue Feng UNQUALIFIED
Ricardo Q FlosiGermanyOnyama Limba PROPOSAL
Wickens K GarufiFranceIvan Magalhaes RENEWAL
Cody G AlbaresItalyIoni Bowcher UNQUALIFIED
Nicolas C RimIndiaBernardo Dominic RENEWAL
Wickens X StockhamIndiaXuxue Feng QUALIFIED
Maria U PerinGermanyBernardo Dominic NEGOTIATION
Aditya Q BriddickJapanAsiya Javayant UNQUALIFIED
Stacey G VenereGermanyStephen Shaw UNQUALIFIED
Juan D GarufiCanadaXuxue Feng UNQUALIFIED
Aika B DoeFranceOnyama Limba NEW
Kadeem P MorascaIndiaBernardo Dominic NEGOTIATION
Francesco X FigeroaBrazilIvan Magalhaes QUALIFIED
Jennifer C SchemmerAustraliaElwin Sharvill UNQUALIFIED
Mayumi Q FerenczRussiaBernardo Dominic RENEWAL
Horizontal
NameCountryRepresentativeStatus
David N RoysterIndiaAsiya Javayant NEW
Silvio H SaylorsSpainBernardo Dominic UNQUALIFIED
Juan Z FollerGermanyStephen Shaw PROPOSAL
Mayumi F IturbideIndiaAmy Elsner NEW
Darci O DarakjyUnited KingdomStephen Shaw QUALIFIED
Clifford Y PaprockiBrazilAnna Fali RENEWAL
Jeanfrancois O SergiAustraliaElwin Sharvill QUALIFIED
Deepesh Y IturbideRussiaStephen Shaw NEGOTIATION
Munro D WieserCanadaStephen Shaw UNQUALIFIED
Mayumi O KolmetzRussiaIoni Bowcher NEGOTIATION
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Jones D FlosiSpain2024-09-13Chemel, James L Cpa QUALIFIED35Ioni Bowcher
1001Salvatore L ButtItaly2024-09-10Chemel, James L Cpa NEW11Stephen Shaw
1002Ashley O TollnerArgentina2024-09-17Feiner Bros NEGOTIATION61Bernardo Dominic
1003Cody W VenereAustralia2024-08-30Printing Dimensions PROPOSAL52Bernardo Dominic
1004Francesco I OstroskyGermany2024-09-21Chemel, James L Cpa RENEWAL10Amy Elsner
1005Jeanfrancois D OldroydUnited Kingdom2024-09-21Benton, John B Jr PROPOSAL19Ivan Magalhaes
1006Silvio O MaletItaly2024-09-14Rousseaux, Michael Esq UNQUALIFIED28Ioni Bowcher
1007Octavia W WhobreyRussia2024-09-14Dorl, James J Esq PROPOSAL49Ioni Bowcher
1008Salvatore D MarrierFrance2024-09-07Feltz Printing Service NEGOTIATION67Asiya Javayant
1009Morrow C IturbideFrance2024-08-27Feltz Printing Service UNQUALIFIED66Stephen Shaw
1010Arvin L MaletFrance2024-09-05King, Christopher A Esq PROPOSAL72Ivan Magalhaes
1011Aditya V IturbideJapan2024-09-12Rousseaux, Michael Esq UNQUALIFIED87Elwin Sharvill
1012Aika V TollnerGermany2024-09-23Chemel, James L Cpa QUALIFIED33Stephen Shaw
1013Kadeem Z MaletArgentina2024-09-12King, Christopher A Esq QUALIFIED94Stephen Shaw
1014Ashley Q FerenczUnited Kingdom2024-09-14Morlong Associates NEGOTIATION58Amy Elsner
1015Darci S WaycottJapan2024-09-10Rousseaux, Michael Esq QUALIFIED94Onyama Limba
1016Aruna S VocelkaItaly2024-09-08Benton, John B Jr NEGOTIATION7Anna Fali
1017Rodrigues J FlosiAustralia2024-09-17Morlong Associates PROPOSAL33Ivan Magalhaes
1018Izzy F GauchoAustralia2024-09-08Chemel, James L Cpa UNQUALIFIED85Onyama Limba
1019Emily L RimArgentina2024-09-06Dorl, James J Esq NEGOTIATION91Asiya Javayant
1020Jeanfrancois K RimIndia2024-09-03Truhlar And Truhlar Attys PROPOSAL36Elwin Sharvill
1021Tony J FlosiRussia2024-09-22Chapman, Ross E Esq RENEWAL6Xuxue Feng
1022Jeanfrancois E MorascaArgentina2024-08-26Dorl, James J Esq NEGOTIATION80Ivan Magalhaes
1023Aditya L ButtArgentina2024-08-30Feiner Bros PROPOSAL95Anna Fali
1024Julie W BowleyItaly2024-08-26Truhlar And Truhlar Attys PROPOSAL84Bernardo Dominic
1025Leon T MaletAustralia2024-09-20Feiner Bros RENEWAL23Xuxue Feng
1026Ashley M NestleJapan2024-09-02Feltz Printing Service NEGOTIATION52Ivan Magalhaes
1027Nicolas O RimFrance2024-08-30King, Christopher A Esq NEGOTIATION9Elwin Sharvill
1028Claire Y SchemmerCanada2024-09-04Commercial Press PROPOSAL86Anna Fali
1029Arvin I FlosiItaly2024-09-12Feltz Printing Service NEW50Bernardo Dominic
1030Ricardo R MaletJapan2024-09-09Chemel, James L Cpa NEW76Xuxue Feng
1031Murillo W VocelkaUnited Kingdom2024-09-01Buckley Miller Wright QUALIFIED9Bernardo Dominic
1032Julie V FollerUnited Kingdom2024-09-02Rousseaux, Michael Esq RENEWAL95Ivan Magalhaes
1033Nicolas N KuskoRussia2024-08-28Chemel, James L Cpa NEGOTIATION90Onyama Limba
1034Misaki K CampainFrance2024-08-28Printing Dimensions PROPOSAL82Ioni Bowcher
1035Nicolas L DoeBrazil2024-08-30Morlong Associates PROPOSAL23Ivan Magalhaes
1036Morrow R FerenczJapan2024-08-28Rousseaux, Michael Esq NEW20Bernardo Dominic
1037Kadeem K OstroskyRussia2024-09-21Chapman, Ross E Esq RENEWAL97Amy Elsner
1038Wickens B FerenczRussia2024-09-18Chapman, Ross E Esq NEGOTIATION75Stephen Shaw
1039Mayumi J GlickJapan2024-09-06Rangoni Of Florence UNQUALIFIED68Asiya Javayant
1040Darci C FollerUnited Kingdom2024-09-20Chapman, Ross E Esq NEGOTIATION95Bernardo Dominic
1041Jennifer O StensethAustralia2024-09-02Dorl, James J Esq RENEWAL53Elwin Sharvill
1042Aika E FerenczJapan2024-09-11Morlong Associates NEW35Ioni Bowcher
1043Wickens Q TollnerAustralia2024-09-20Rangoni Of Florence NEW47Ivan Magalhaes
1044Juan B IturbideGermany2024-09-18Commercial Press NEGOTIATION94Ioni Bowcher
1045Mayumi Y PoquetteItaly2024-08-25King, Christopher A Esq QUALIFIED40Elwin Sharvill
1046Julie R StensethBrazil2024-09-14Feiner Bros UNQUALIFIED32Bernardo Dominic
1047Alejandro I KolmetzJapan2024-09-18Morlong Associates UNQUALIFIED50Onyama Limba
1048Silvio H SlusarskiGermany2024-09-10Rousseaux, Michael Esq UNQUALIFIED14Amy Elsner
1049Smith B RulapaughRussia2024-08-27Chemel, James L Cpa RENEWAL74Asiya Javayant
Frozen Rows
NameCountryRepresentativeStatus
Deepesh B SaylorsIndiaXuxue Feng UNQUALIFIED
Ricardo L VocelkaJapanAmy Elsner NEW
Maria Y VocelkaJapanAmy Elsner QUALIFIED
Ashley X CampainUnited KingdomOnyama Limba UNQUALIFIED
Aruna R KolmetzJapanElwin Sharvill NEGOTIATION
Silvio W SergiItalyIoni Bowcher PROPOSAL
Emily I StockhamRussiaIvan Magalhaes NEW
Greenwood S FigeroaJapanElwin Sharvill RENEWAL
Munro L BriddickFranceStephen Shaw PROPOSAL
Leon D CaldareraBrazilAsiya Javayant PROPOSAL
Aika B RimRussiaStephen Shaw RENEWAL
Alejandro J SergiRussiaAsiya Javayant NEGOTIATION
Ivar K ChuiSpainXuxue Feng QUALIFIED
Jones Y SlusarskiUnited KingdomBernardo Dominic RENEWAL
Aditya G TollnerFranceIoni Bowcher NEGOTIATION
Leon N GarufiIndiaBernardo Dominic NEGOTIATION
Mayumi W IturbideGermanyOnyama Limba QUALIFIED
Aruna R SlusarskiJapanAsiya Javayant PROPOSAL
Claire W VenereArgentinaOnyama Limba RENEWAL
Arvin Y MarrierFranceIvan Magalhaes UNQUALIFIED
Smith B SergiAustraliaElwin Sharvill QUALIFIED
Jeanfrancois G VocelkaArgentinaBernardo Dominic QUALIFIED
Alejandro L DilliardFranceIvan Magalhaes QUALIFIED
Izzy D MaletGermanyAnna Fali RENEWAL
Morrow G SchemmerItalyOnyama Limba QUALIFIED
Faith B CampainUnited KingdomAmy Elsner RENEWAL
James I MaletItalyAnna Fali NEW
Leon O PerinGermanyXuxue Feng UNQUALIFIED
Izzy W SchemmerBrazilOnyama Limba UNQUALIFIED
Isabel I FollerFranceAnna Fali UNQUALIFIED
Aika Y FigeroaArgentinaBernardo Dominic NEW
James W VocelkaCanadaAmy Elsner PROPOSAL
Johnson M KolmetzArgentinaAsiya Javayant NEW
Arvin G VocelkaJapanAmy Elsner NEW
Mujtaba H FerenczJapanXuxue Feng NEW
Ashley A CaldareraBrazilAmy Elsner NEW
Isabel E DoeFranceIoni Bowcher QUALIFIED
Darci R OstroskyUnited KingdomElwin Sharvill QUALIFIED
Maisha F SlusarskiIndiaElwin Sharvill NEW
Aika Q PoquetteBrazilStephen Shaw PROPOSAL
Morrow Y CaldareraSpainElwin Sharvill NEGOTIATION
Jeanfrancois P WaycottRussiaXuxue Feng NEW
James A TollnerItalyStephen Shaw RENEWAL
Aika J GillianJapanAsiya Javayant QUALIFIED
Nicolas R BriddickRussiaStephen Shaw RENEWAL
Cody I IturbideCanadaIoni Bowcher NEGOTIATION
Salvatore M GillianCanadaElwin Sharvill RENEWAL
David S TollnerBrazilIvan Magalhaes QUALIFIED
Johnson C DoeBrazilIoni Bowcher UNQUALIFIED
James T MacleadIndiaAmy Elsner UNQUALIFIED
Frozen Columns
Name
Darci K Ruta
Johnson L Gillian
Izzy L Campain
Leja U Wieser
Juan Q Glick
Morrow B Tollner
Antonio N Caudy
Emily J Saylors
Morrow Z Waycott
Jeanfrancois U Stockham
Julie F Ostrosky
James W Slusarski
Stacey A Ostrosky
Leja R Bolognia
Wickens C Bolognia
Tony W Darakjy
Octavia O Nicka
Octavia I Ruta
Aruna S Maclead
Kadeem M Tollner
Silvio N Bolognia
Leja Z Saylors
Rodrigues D Caudy
Jefferson B Slusarski
Jennifer R Doe
Sinclair Q Malet
James B Rulapaugh
Munro K Venere
Juan S Oldroyd
Mayumi A Campain
Octavia X Tollner
James D Sergi
Morrow X Campain
Jones P Ruta
Leon W Wieser
Rodrigues U Kolmetz
Stacey I Campain
Emily F Nestle
Greenwood O Bolognia
Arvin E Butt
Jefferson H Malet
Cody B Gaucho
Izzy M Ferencz
Alejandro D Inouye
Cody P Morasca
Emily F Schemmer
Johnson T Foller
Jeanfrancois M Morasca
David W Stockham
Costa A Ostrosky
IdCountryDate
1000Canada2024-09-07
1001Brazil2024-08-25
1002Germany2024-09-19
1003Australia2024-09-10
1004Germany2024-09-22
1005France2024-09-01
1006Argentina2024-09-17
1007Germany2024-09-19
1008Australia2024-08-25
1009Japan2024-09-19
1010France2024-09-14
1011Germany2024-08-27
1012United Kingdom2024-09-13
1013France2024-09-21
1014Canada2024-09-15
1015Australia2024-09-09
1016Canada2024-09-19
1017India2024-08-30
1018India2024-09-09
1019Italy2024-09-04
1020Brazil2024-08-25
1021Spain2024-08-25
1022India2024-09-07
1023Italy2024-08-30
1024France2024-09-12
1025Italy2024-09-23
1026Canada2024-08-29
1027Spain2024-09-10
1028Russia2024-09-18
1029Spain2024-08-27
1030Japan2024-09-01
1031Japan2024-09-13
1032Germany2024-08-30
1033Japan2024-08-26
1034Russia2024-09-19
1035Japan2024-09-06
1036Italy2024-09-22
1037Canada2024-09-22
1038Japan2024-09-20
1039France2024-09-21
1040Germany2024-08-25
1041Argentina2024-09-21
1042Canada2024-08-25
1043Russia2024-09-04
1044Australia2024-09-08
1045Japan2024-08-31
1046Brazil2024-09-05
1047Italy2024-09-16
1048Spain2024-09-15
1049Brazil2024-09-23

On-Demand Data

NameIdCountryDate
Jefferson P Rulapaugh1000Canada2024-09-01
Juan S Ostrosky1001Spain2024-09-20
Jeanfrancois S Caldarera1002United Kingdom2024-09-03
Salvatore B Darakjy1003Spain2024-09-11
Salvatore S Vocelka1004Spain2024-09-20
Ashley G Rim1005France2024-09-17
Morrow E Malet1006Canada2024-09-05
Alejandro V Malet1007Australia2024-08-25
Nicolas G Saylors1008France2024-09-04
Kaitlin B Dilliard1009Spain2024-09-18
Mujtaba Q Shinko1010Argentina2024-09-06
Arvin X Dilliard1011Russia2024-09-20
Kadeem R Maclead1012Australia2024-08-30
Murillo V Ruta1013India2024-09-06
Misaki M Gillian1014Argentina2024-09-03
Mujtaba I Malet1015Russia2024-09-15
Cody C Rim1016India2024-09-12
Isabel D Chui1017India2024-09-13
Chavez O Chui1018Italy2024-09-07
Darci Y Doe1019United Kingdom2024-09-22
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Johnson F MarrierGermanyXuxue Feng UNQUALIFIED
Silvio U ButtGermanyXuxue Feng UNQUALIFIED
Silvio S ButtItalyElwin Sharvill PROPOSAL
Aika T RoysterJapanIoni Bowcher UNQUALIFIED
Nicolas I GlickArgentinaIoni Bowcher NEGOTIATION
Chavez I MorascaAustraliaXuxue Feng NEGOTIATION
Leon W InouyeAustraliaElwin Sharvill NEGOTIATION
Cody O FerenczFranceBernardo Dominic QUALIFIED
Adams J InouyeUnited KingdomBernardo Dominic UNQUALIFIED
Silvio N FollerIndiaXuxue Feng NEW
James U CampainRussiaBernardo Dominic NEW
Kaitlin C WhobreyFranceIoni Bowcher PROPOSAL
David F GillianItalyAsiya Javayant NEGOTIATION
Jefferson E CampainUnited KingdomOnyama Limba QUALIFIED
Faith Q AlbaresRussiaIoni Bowcher QUALIFIED
Greenwood W FollerFranceAnna Fali UNQUALIFIED
Julie L ChuiSpainBernardo Dominic QUALIFIED
Francesco K StensethItalyAmy Elsner RENEWAL
Ashley N PoquetteFranceElwin Sharvill NEGOTIATION
Deepesh T FigeroaAustraliaOnyama Limba NEGOTIATION
Sinclair Q GillianUnited KingdomStephen Shaw NEGOTIATION
Antonio N GlickGermanyOnyama Limba RENEWAL
Isabel Y WaycottArgentinaElwin Sharvill RENEWAL
Izzy N AmigonItalyBernardo Dominic RENEWAL
Mayumi C MorascaUnited KingdomAsiya Javayant QUALIFIED
Alejandro M OstroskyGermanyIoni Bowcher UNQUALIFIED
David Z VenereArgentinaAsiya Javayant PROPOSAL
Jeanfrancois Z ButtBrazilAnna Fali NEGOTIATION
Claire I SergiBrazilAmy Elsner UNQUALIFIED
Aika E CampainJapanAsiya Javayant NEW
Chavez R KolmetzUnited KingdomStephen Shaw QUALIFIED
David K StensethGermanyIvan Magalhaes RENEWAL
Chavez O SchemmerArgentinaAnna Fali RENEWAL
Rodrigues S ChuiUnited KingdomAmy Elsner PROPOSAL
Nicolas M KolmetzUnited KingdomAsiya Javayant UNQUALIFIED
Tony O VocelkaCanadaOnyama Limba NEW
Munro S OldroydArgentinaAsiya Javayant NEW
Silvio V SaylorsBrazilElwin Sharvill RENEWAL
Stacey R OldroydUnited KingdomAsiya Javayant RENEWAL
Ivar L RoysterSpainOnyama Limba 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>