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 I InouyeRussiaElwin Sharvill NEW
Rodrigues X SlusarskiIndiaBernardo Dominic UNQUALIFIED
Tony R OstroskyArgentinaStephen Shaw RENEWAL
Leon O NickaRussiaBernardo Dominic QUALIFIED
Aditya L GillianFranceBernardo Dominic RENEWAL
Greenwood L GauchoFranceBernardo Dominic PROPOSAL
Nicolas Z BowleyFranceXuxue Feng PROPOSAL
Ivar V MacleadCanadaBernardo Dominic PROPOSAL
Ashley K GarufiBrazilStephen Shaw PROPOSAL
Leon R MarrierItalyStephen Shaw RENEWAL
Jones U BriddickItalyXuxue Feng NEGOTIATION
Johnson O GauchoSpainIvan Magalhaes NEW
Maria O BowleyItalyIvan Magalhaes NEW
Munro E FigeroaBrazilAsiya Javayant NEW
Izzy P CaldareraFranceAmy Elsner NEW
Isabel G RoysterFranceOnyama Limba NEGOTIATION
Murillo K SergiArgentinaStephen Shaw NEGOTIATION
Claire Y FlosiGermanyAnna Fali NEGOTIATION
Francesco H BowleySpainStephen Shaw UNQUALIFIED
Francesco I DarakjyCanadaIoni Bowcher QUALIFIED
Salvatore P BologniaCanadaXuxue Feng UNQUALIFIED
Chavez P VenereGermanyAmy Elsner NEW
Clifford H GlickJapanStephen Shaw UNQUALIFIED
Cody W MaletBrazilStephen Shaw UNQUALIFIED
Kadeem D PaprockiUnited KingdomElwin Sharvill RENEWAL
Ashley A CaudySpainElwin Sharvill PROPOSAL
Leja M FigeroaCanadaOnyama Limba QUALIFIED
Maisha O MaletUnited KingdomIvan Magalhaes UNQUALIFIED
Leon X NestleIndiaXuxue Feng UNQUALIFIED
Maisha S FerenczRussiaAmy Elsner RENEWAL
Alejandro A InouyeUnited KingdomXuxue Feng NEGOTIATION
Johnson K FigeroaItalyElwin Sharvill NEW
Jones V StockhamBrazilIoni Bowcher RENEWAL
Maisha A WieserCanadaIvan Magalhaes NEGOTIATION
Sinclair N WaycottArgentinaIoni Bowcher UNQUALIFIED
Greenwood N NestleFranceAsiya Javayant UNQUALIFIED
Morrow D SaylorsIndiaAnna Fali UNQUALIFIED
Stacey P KuskoUnited KingdomIvan Magalhaes NEGOTIATION
Ivar N CaudyBrazilStephen Shaw NEGOTIATION
Morrow P CaldareraItalyXuxue Feng RENEWAL
Aika I NickaFranceStephen Shaw RENEWAL
Maisha V WaycottRussiaBernardo Dominic NEW
Rodrigues L RulapaughGermanyOnyama Limba QUALIFIED
Mayumi R NickaAustraliaXuxue Feng NEW
Mayumi P AmigonFranceAnna Fali RENEWAL
Kaitlin G StockhamGermanyAmy Elsner QUALIFIED
Aika T ShinkoFranceAmy Elsner PROPOSAL
Leon D FerenczItalyXuxue Feng RENEWAL
Octavia V MacleadUnited KingdomIvan Magalhaes UNQUALIFIED
Octavia A SergiBrazilAmy Elsner QUALIFIED
Horizontal
NameCountryRepresentativeStatus
Johnson F MacleadJapanIvan Magalhaes UNQUALIFIED
Jeanfrancois A RulapaughItalyXuxue Feng RENEWAL
Faith D WieserSpainIvan Magalhaes QUALIFIED
Misaki G PoquetteSpainAsiya Javayant QUALIFIED
Claire Z FollerIndiaAnna Fali NEW
Kaitlin C RulapaughJapanAmy Elsner RENEWAL
Clifford L GillianArgentinaStephen Shaw UNQUALIFIED
Julie V BologniaItalyIoni Bowcher PROPOSAL
Mayumi S SchemmerGermanyAsiya Javayant PROPOSAL
Rodrigues V BologniaItalyAnna Fali PROPOSAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Chavez K OldroydGermany2024-06-06King, Christopher A Esq NEGOTIATION43Stephen Shaw
1001Jeanfrancois K AmigonBrazil2024-05-26Rangoni Of Florence NEGOTIATION33Anna Fali
1002Ashley X RimSpain2024-06-23Chapman, Ross E Esq RENEWAL74Ivan Magalhaes
1003Kaitlin K BriddickSpain2024-05-30Morlong Associates RENEWAL17Ioni Bowcher
1004Alejandro R IturbideSpain2024-05-27Benton, John B Jr PROPOSAL23Ivan Magalhaes
1005Julie E KolmetzCanada2024-06-17Rangoni Of Florence NEW72Xuxue Feng
1006Smith B InouyeUnited Kingdom2024-06-11Rangoni Of Florence QUALIFIED80Elwin Sharvill
1007Sinclair F SlusarskiSpain2024-06-18Rangoni Of Florence NEW0Ioni Bowcher
1008Salvatore G SchemmerItaly2024-06-18Benton, John B Jr RENEWAL40Stephen Shaw
1009Sinclair X CaldareraBrazil2024-06-07Morlong Associates UNQUALIFIED24Anna Fali
1010Kaitlin L RutaUnited Kingdom2024-06-14Rousseaux, Michael Esq NEGOTIATION65Bernardo Dominic
1011Adams P KolmetzItaly2024-06-17Printing Dimensions PROPOSAL72Onyama Limba
1012Jeanfrancois K OldroydGermany2024-06-13Feiner Bros RENEWAL82Onyama Limba
1013Mayumi D SlusarskiCanada2024-05-28Chanay, Jeffrey A Esq QUALIFIED35Bernardo Dominic
1014James G FollerItaly2024-06-14Feiner Bros QUALIFIED49Amy Elsner
1015Deepesh K ShinkoCanada2024-05-31Rousseaux, Michael Esq RENEWAL69Onyama Limba
1016Ricardo Z WaycottItaly2024-06-19Truhlar And Truhlar Attys NEW68Xuxue Feng
1017Jones H FollerSpain2024-05-26Printing Dimensions RENEWAL7Bernardo Dominic
1018Isabel E DoeRussia2024-06-05Feiner Bros PROPOSAL19Ioni Bowcher
1019Kadeem X SlusarskiFrance2024-06-03Rousseaux, Michael Esq RENEWAL10Ioni Bowcher
1020Claire D RimFrance2024-06-16Rousseaux, Michael Esq PROPOSAL83Ioni Bowcher
1021Kadeem Q WaycottIndia2024-06-08Rousseaux, Michael Esq UNQUALIFIED66Elwin Sharvill
1022Misaki L WaycottAustralia2024-06-10Buckley Miller Wright QUALIFIED15Asiya Javayant
1023James G CaudyUnited Kingdom2024-06-13King, Christopher A Esq NEW16Stephen Shaw
1024Izzy U AmigonUnited Kingdom2024-06-04Rangoni Of Florence UNQUALIFIED21Stephen Shaw
1025Kaitlin L KuskoRussia2024-06-15Benton, John B Jr QUALIFIED86Ivan Magalhaes
1026Johnson Z FerenczRussia2024-06-21Truhlar And Truhlar Attys NEW71Amy Elsner
1027Jeanfrancois N FollerFrance2024-06-03Rangoni Of Florence RENEWAL3Amy Elsner
1028Ricardo R FerenczIndia2024-05-31Buckley Miller Wright RENEWAL3Ivan Magalhaes
1029Izzy R CampainIndia2024-06-02Truhlar And Truhlar Attys PROPOSAL67Stephen Shaw
1030Maisha L WhobreyFrance2024-05-31King, Christopher A Esq QUALIFIED45Elwin Sharvill
1031Isabel M RimSpain2024-06-06Benton, John B Jr NEW41Elwin Sharvill
1032Faith D CampainArgentina2024-06-23Feltz Printing Service NEW76Ioni Bowcher
1033Kaitlin D MacleadCanada2024-05-30Buckley Miller Wright NEW83Asiya Javayant
1034Isabel C ButtUnited Kingdom2024-06-09Dorl, James J Esq NEGOTIATION50Asiya Javayant
1035Kaitlin S FlosiBrazil2024-06-01Feiner Bros PROPOSAL14Elwin Sharvill
1036Costa H WieserArgentina2024-06-02Rangoni Of Florence NEGOTIATION31Xuxue Feng
1037Jefferson S IturbideSpain2024-05-26Feiner Bros NEW86Asiya Javayant
1038Aika R WhobreyArgentina2024-06-01King, Christopher A Esq NEW30Ivan Magalhaes
1039Ivar D SchemmerItaly2024-06-13Feltz Printing Service NEGOTIATION97Elwin Sharvill
1040Morrow N ChuiCanada2024-06-20Chemel, James L Cpa UNQUALIFIED13Amy Elsner
1041Nicolas W MaletAustralia2024-06-22Dorl, James J Esq NEW89Stephen Shaw
1042Darci U KolmetzJapan2024-06-09Feltz Printing Service QUALIFIED93Ioni Bowcher
1043Maria Z CaldareraAustralia2024-06-19Printing Dimensions NEW77Bernardo Dominic
1044Maria A MacleadArgentina2024-06-15Morlong Associates NEW99Bernardo Dominic
1045Morrow L FlosiFrance2024-05-28Commercial Press NEGOTIATION8Bernardo Dominic
1046Cody V OstroskyIndia2024-06-01Truhlar And Truhlar Attys NEGOTIATION59Elwin Sharvill
1047Juan I FigeroaBrazil2024-06-19Feltz Printing Service NEW32Ioni Bowcher
1048Julie N MorascaFrance2024-05-28Rousseaux, Michael Esq NEGOTIATION50Ioni Bowcher
1049Jeanfrancois N GlickIndia2024-05-28Commercial Press UNQUALIFIED90Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Maisha N OldroydRussiaXuxue Feng PROPOSAL
Misaki C InouyeRussiaOnyama Limba UNQUALIFIED
Leon H IturbideArgentinaXuxue Feng PROPOSAL
Silvio X RutaArgentinaElwin Sharvill QUALIFIED
Chavez K SlusarskiGermanyIvan Magalhaes RENEWAL
Adams X NickaIndiaOnyama Limba NEW
Isabel M StensethSpainBernardo Dominic RENEWAL
Maisha U BowleyArgentinaAsiya Javayant RENEWAL
Misaki D WhobreyAustraliaAnna Fali UNQUALIFIED
Jones L SlusarskiJapanAnna Fali NEGOTIATION
Greenwood N RimIndiaAmy Elsner NEGOTIATION
Rodrigues U TollnerFranceAsiya Javayant NEW
Adams H NickaAustraliaBernardo Dominic QUALIFIED
Leja J KuskoSpainIvan Magalhaes PROPOSAL
Clifford T RoysterAustraliaStephen Shaw NEW
Kaitlin G GillianUnited KingdomAmy Elsner UNQUALIFIED
Rodrigues I PaprockiBrazilAsiya Javayant NEW
Jeanfrancois E TollnerAustraliaAsiya Javayant NEGOTIATION
Izzy A WieserItalyAsiya Javayant NEW
Smith W ButtRussiaXuxue Feng UNQUALIFIED
Arvin T PaprockiItalyAsiya Javayant UNQUALIFIED
Aruna E SaylorsBrazilBernardo Dominic PROPOSAL
Aika A NestleAustraliaAsiya Javayant UNQUALIFIED
Costa Z WieserGermanyIvan Magalhaes NEW
Francesco M RoysterJapanBernardo Dominic QUALIFIED
Deepesh H RimAustraliaElwin Sharvill QUALIFIED
David S MacleadIndiaBernardo Dominic RENEWAL
Ashley Z AlbaresFranceIoni Bowcher PROPOSAL
Julie H CaudyCanadaAsiya Javayant QUALIFIED
Munro B GauchoSpainAmy Elsner PROPOSAL
Ricardo V ButtJapanAsiya Javayant QUALIFIED
Misaki N FlosiGermanyIvan Magalhaes NEW
Octavia J IturbideCanadaElwin Sharvill UNQUALIFIED
Sinclair Q FigeroaSpainIvan Magalhaes RENEWAL
Adams G DoeJapanOnyama Limba NEGOTIATION
Greenwood Y BologniaArgentinaAsiya Javayant NEGOTIATION
Claire V ChuiArgentinaBernardo Dominic RENEWAL
Ashley O InouyeUnited KingdomIvan Magalhaes QUALIFIED
Leon P GlickArgentinaIoni Bowcher RENEWAL
Faith E AmigonItalyAsiya Javayant QUALIFIED
Darci Q PoquetteItalyElwin Sharvill PROPOSAL
Darci L PerinArgentinaAnna Fali PROPOSAL
Costa W FlosiArgentinaIvan Magalhaes NEGOTIATION
Juan J MaletRussiaAsiya Javayant NEW
Octavia C SaylorsArgentinaIvan Magalhaes NEGOTIATION
Morrow B GauchoAustraliaAnna Fali UNQUALIFIED
Clifford T WhobreyCanadaAsiya Javayant QUALIFIED
Leja Z TollnerJapanAmy Elsner RENEWAL
Sinclair U BologniaGermanyAsiya Javayant RENEWAL
Ashley O NestleBrazilOnyama Limba RENEWAL
Frozen Columns
Name
Tony O Caudy
Maria C Wieser
Sinclair W Bolognia
Francesco N Rulapaugh
Clifford S Wieser
Deepesh L Poquette
Clifford X Flosi
Izzy M Chui
Chavez T Tollner
Mujtaba Y Shinko
Tony W Inouye
Faith N Shinko
Clifford G Saylors
Faith L Bowley
Ashley U Slusarski
Octavia G Foller
Deepesh E Inouye
Faith H Gillian
Isabel T Briddick
Aruna F Sergi
Stacey O Bowley
Ivar J Caldarera
Kadeem D Stockham
Jefferson G Wieser
Jones U Rim
Greenwood B Rulapaugh
Julie P Gaucho
Nicolas O Figeroa
Munro B Briddick
Misaki B Tollner
Misaki A Stenseth
Adams X Tollner
Costa R Marrier
Antonio H Flosi
Sinclair I Saylors
Aruna O Malet
Leon H Garufi
Misaki U Poquette
Jeanfrancois R Saylors
Aika Y Morasca
Jones O Sergi
Ricardo B Glick
Ricardo I Bolognia
Alejandro M Butt
Leon V Ostrosky
Izzy G Waycott
Maisha K Iturbide
Johnson R Briddick
David T Figeroa
Juan Z Inouye
IdCountryDate
1000India2024-06-24
1001Brazil2024-06-12
1002Brazil2024-06-21
1003France2024-05-27
1004Australia2024-06-04
1005Italy2024-06-01
1006Italy2024-06-17
1007Canada2024-06-15
1008Australia2024-06-24
1009Spain2024-06-05
1010Germany2024-06-22
1011Spain2024-06-04
1012Canada2024-06-20
1013Italy2024-06-18
1014Japan2024-06-11
1015Argentina2024-06-22
1016Brazil2024-05-29
1017Canada2024-06-05
1018United Kingdom2024-06-05
1019Argentina2024-05-29
1020France2024-06-18
1021Brazil2024-06-06
1022Germany2024-06-24
1023Brazil2024-05-30
1024Italy2024-06-01
1025Brazil2024-06-02
1026Germany2024-06-05
1027Italy2024-06-01
1028India2024-06-11
1029Canada2024-06-13
1030Australia2024-06-16
1031Brazil2024-06-14
1032France2024-06-08
1033Italy2024-05-26
1034United Kingdom2024-06-11
1035Russia2024-06-04
1036Canada2024-06-06
1037Russia2024-06-20
1038France2024-06-24
1039Brazil2024-06-17
1040Brazil2024-05-28
1041Russia2024-06-18
1042France2024-06-19
1043Germany2024-06-22
1044Brazil2024-06-08
1045India2024-06-11
1046India2024-06-18
1047Germany2024-05-31
1048Italy2024-06-13
1049France2024-05-28

On-Demand Data

NameIdCountryDate
Aika R Rim1000Russia2024-06-24
Jones L Garufi1001Argentina2024-05-27
Jeanfrancois U Butt1002Canada2024-05-31
Alejandro M Ferencz1003Japan2024-06-02
Sinclair O Ruta1004Japan2024-06-08
Munro O Campain1005United Kingdom2024-06-17
Sinclair B Darakjy1006United Kingdom2024-06-05
Aika U Chui1007France2024-06-20
Salvatore V Kolmetz1008Australia2024-06-20
Murillo G Kusko1009Germany2024-06-24
Aruna D Albares1010Germany2024-06-17
Ashley J Dilliard1011Canada2024-06-08
Leon Z Campain1012Canada2024-05-27
Morrow M Malet1013Russia2024-06-08
Rodrigues V Malet1014France2024-06-24
Aditya T Shinko1015United Kingdom2024-06-14
Aditya J Shinko1016Russia2024-06-24
Chavez A Oldroyd1017Argentina2024-05-27
Aditya H Whobrey1018India2024-06-12
Maisha U Nicka1019Brazil2024-06-07
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Greenwood X AlbaresAustraliaIoni Bowcher RENEWAL
Jones Z BologniaItalyAnna Fali UNQUALIFIED
Kadeem N RimIndiaStephen Shaw NEGOTIATION
Ricardo Y OstroskyItalyIoni Bowcher NEGOTIATION
Rodrigues D MacleadArgentinaBernardo Dominic UNQUALIFIED
Mayumi W DilliardItalyStephen Shaw NEGOTIATION
Julie H GauchoIndiaStephen Shaw RENEWAL
Misaki C FollerSpainAnna Fali UNQUALIFIED
Mayumi K FerenczCanadaAnna Fali NEW
Mujtaba N CaudyGermanyIoni Bowcher NEGOTIATION
Deepesh V GillianBrazilElwin Sharvill NEGOTIATION
Isabel Q SergiItalyOnyama Limba NEW
Smith B BologniaItalyIoni Bowcher PROPOSAL
Mayumi L PoquetteArgentinaBernardo Dominic PROPOSAL
Jennifer P OldroydGermanyStephen Shaw NEW
Juan X RoysterBrazilAnna Fali NEGOTIATION
Kaitlin M WieserIndiaIoni Bowcher NEW
Kaitlin N DoeSpainIoni Bowcher UNQUALIFIED
Arvin I InouyeCanadaAsiya Javayant UNQUALIFIED
Sinclair G CaudyUnited KingdomIoni Bowcher QUALIFIED
Leon A GauchoUnited KingdomAmy Elsner NEW
Aditya S BriddickArgentinaIoni Bowcher NEW
Ashley V MaletUnited KingdomBernardo Dominic NEGOTIATION
Mujtaba C VocelkaGermanyIoni Bowcher NEW
Wickens S PoquetteJapanElwin Sharvill NEGOTIATION
Izzy R RutaSpainAsiya Javayant NEW
Emily F OldroydSpainAmy Elsner UNQUALIFIED
Izzy F MacleadRussiaBernardo Dominic RENEWAL
Clifford C NickaRussiaIoni Bowcher NEW
Stacey C StensethArgentinaAsiya Javayant QUALIFIED
Ashley Y PerinFranceAmy Elsner NEW
Mujtaba D KolmetzJapanAnna Fali UNQUALIFIED
Octavia D MarrierCanadaStephen Shaw NEGOTIATION
Adams K GillianSpainIvan Magalhaes RENEWAL
Kadeem V FlosiSpainAmy Elsner NEGOTIATION
James Q SlusarskiGermanyElwin Sharvill QUALIFIED
Ashley Q WhobreyArgentinaAmy Elsner QUALIFIED
Adams D NestleBrazilAsiya Javayant QUALIFIED
Ricardo U CampainJapanElwin Sharvill PROPOSAL
Silvio N MarrierItalyAsiya Javayant 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>