Locale

Change the locale of the datepicker, schedule and client side validation messages.

Language
English
French
German
Italian
Korean
Spanish
Catalan
Dutch
Portuguese
Portuguese
Arabic
Czech
Greek
Persian
Hindi
Indonesian
Croatian
Japanese
Hungarian
Hebrew
Georgian
Lithuanian
Latvian
Norwegian
Polish
Romanian
Russian
Slovak
Slovenian
Serbian
Swedish
Turkish
Ukrainian
Vietnamese
Chinese
Chinese

Input Style

Free Themes

Built-in component themes created by the PrimeFaces Theme Designer.

PrimeOne Design

Saga Saga
Vela Vela
Arya Arya

Premium Themes

Premium themes are only available exclusively for PrimeFaces Theme Designer subscribers and therefore not included in PrimeFaces core.

Bootstrap light blue and dark blue themes are also included in PrimeFaces 10.x builds for Elite subscribers.

bootstrap4-blue-light Bootstrap Blue
bootstrap4-purple-light Bootstrap Purple
bootstrap4-blue-dark Bootstrap Blue
bootstrap4-purple-dark Bootstrap Purple

Legacy Free Themes

Luna Amber Luna Amber
Luna Blue Luna Blue
Luna Green Luna Green
Luna Pink Luna Pink
Nova Nova
Nova Nova Alt
Nova Nova Accent

PREMIUM TEMPLATES

Create awesome applications in no time using the premium templates and impress your users.

DataTable Scroll

Both vertical and horizontal scrolling of the data is supported with optional frozen rows-columns and on-demand loading features.

Vertical
NameCountryRepresentativeStatus
Arvin J PerinFranceElwin Sharvill RENEWAL
Johnson U MaletGermanyStephen Shaw QUALIFIED
Emily F RulapaughItalyXuxue Feng NEW
Kaitlin S ShinkoGermanyBernardo Dominic NEW
Ricardo S ButtItalyStephen Shaw PROPOSAL
Greenwood O StensethGermanyOnyama Limba UNQUALIFIED
Antonio P RutaIndiaBernardo Dominic UNQUALIFIED
Salvatore C RulapaughArgentinaIvan Magalhaes NEW
Julie Z StockhamArgentinaIoni Bowcher QUALIFIED
Adams K ButtUnited KingdomStephen Shaw RENEWAL
Murillo Q PerinIndiaIoni Bowcher PROPOSAL
Leja E SergiCanadaOnyama Limba NEGOTIATION
Nicolas C GauchoBrazilStephen Shaw NEGOTIATION
Leon T CaldareraIndiaIvan Magalhaes NEGOTIATION
Ivar T MaletIndiaAmy Elsner QUALIFIED
Faith R SergiArgentinaAmy Elsner PROPOSAL
Alejandro R SaylorsJapanXuxue Feng QUALIFIED
Ricardo C DoeIndiaBernardo Dominic RENEWAL
Alejandro N OstroskyRussiaBernardo Dominic NEW
Mayumi C NickaArgentinaOnyama Limba RENEWAL
Chavez X CampainFranceXuxue Feng RENEWAL
Mayumi H NickaGermanyIoni Bowcher NEGOTIATION
Jones T ShinkoArgentinaBernardo Dominic UNQUALIFIED
Munro F WieserRussiaOnyama Limba NEW
Alejandro J PoquetteAustraliaStephen Shaw NEW
Mujtaba O CampainArgentinaStephen Shaw QUALIFIED
Wickens Z VocelkaCanadaStephen Shaw NEW
Smith T ShinkoAustraliaAsiya Javayant PROPOSAL
Ricardo A FigeroaGermanyIoni Bowcher NEW
Jefferson U RulapaughItalyIoni Bowcher PROPOSAL
Smith T NestleIndiaXuxue Feng UNQUALIFIED
Mujtaba M BologniaBrazilAmy Elsner PROPOSAL
Rodrigues W DarakjyFranceAnna Fali QUALIFIED
Isabel K ChuiCanadaAsiya Javayant QUALIFIED
Octavia L StensethFranceAnna Fali NEGOTIATION
Faith D CaudyAustraliaElwin Sharvill UNQUALIFIED
Mujtaba U StockhamFranceElwin Sharvill NEW
James Q ChuiGermanyOnyama Limba RENEWAL
David K VenereBrazilBernardo Dominic NEGOTIATION
Deepesh A PerinGermanyOnyama Limba RENEWAL
Kadeem S WhobreyGermanyIoni Bowcher RENEWAL
Nicolas M OstroskyIndiaXuxue Feng UNQUALIFIED
Smith Z RutaIndiaIvan Magalhaes NEGOTIATION
Jefferson G ShinkoSpainAmy Elsner PROPOSAL
Stacey Q DoeJapanBernardo Dominic NEW
Izzy C SaylorsSpainIoni Bowcher UNQUALIFIED
Costa H DoeRussiaAmy Elsner PROPOSAL
David Y DilliardGermanyAmy Elsner UNQUALIFIED
Mayumi D IturbideGermanyIoni Bowcher NEGOTIATION
Isabel M IturbideCanadaStephen Shaw PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Tony M MarrierGermanyAmy Elsner PROPOSAL
Ashley H GillianIndiaStephen Shaw RENEWAL
Izzy A SergiUnited KingdomAnna Fali PROPOSAL
Maria L TollnerAustraliaBernardo Dominic UNQUALIFIED
Tony N PerinIndiaStephen Shaw NEW
Murillo M IturbideSpainAmy Elsner NEGOTIATION
Jennifer W AmigonIndiaIoni Bowcher NEW
Smith W SchemmerArgentinaAmy Elsner QUALIFIED
Emily T RutaFranceXuxue Feng UNQUALIFIED
Adams T GlickArgentinaIoni Bowcher UNQUALIFIED
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Ivar Q KuskoItaly2024-04-23Benton, John B Jr NEGOTIATION43Xuxue Feng
1001Antonio O NestleAustralia2024-03-31Feiner Bros PROPOSAL68Amy Elsner
1002Kadeem H GauchoRussia2024-04-23Feiner Bros PROPOSAL47Anna Fali
1003Alejandro G MacleadJapan2024-04-04Truhlar And Truhlar Attys PROPOSAL47Ivan Magalhaes
1004Antonio Z ButtItaly2024-04-01Chanay, Jeffrey A Esq NEGOTIATION72Xuxue Feng
1005Murillo H WhobreyItaly2024-04-15Commercial Press RENEWAL35Anna Fali
1006Aika V RulapaughJapan2024-04-23King, Christopher A Esq QUALIFIED19Onyama Limba
1007Mujtaba Y NestleAustralia2024-04-10Benton, John B Jr QUALIFIED39Onyama Limba
1008Jennifer G SergiBrazil2024-03-31Chapman, Ross E Esq NEGOTIATION80Anna Fali
1009Deepesh I AlbaresCanada2024-04-18Buckley Miller Wright UNQUALIFIED22Stephen Shaw
1010Isabel E InouyeCanada2024-04-04Morlong Associates UNQUALIFIED11Xuxue Feng
1011Costa X BriddickIndia2024-04-18Dorl, James J Esq NEW98Onyama Limba
1012Munro J KolmetzFrance2024-04-19Printing Dimensions NEGOTIATION36Xuxue Feng
1013Juan Q MaletIndia2024-04-20Rangoni Of Florence NEGOTIATION55Bernardo Dominic
1014Nicolas Y ButtSpain2024-04-23Feiner Bros PROPOSAL31Onyama Limba
1015Juan M MacleadItaly2024-04-19Commercial Press NEGOTIATION65Elwin Sharvill
1016Rodrigues N RulapaughGermany2024-04-05Printing Dimensions RENEWAL99Xuxue Feng
1017Costa X MaletRussia2024-04-17Rousseaux, Michael Esq RENEWAL19Xuxue Feng
1018Johnson B CaudyUnited Kingdom2024-04-27Dorl, James J Esq QUALIFIED80Stephen Shaw
1019Arvin S PoquetteRussia2024-04-01King, Christopher A Esq NEW65Anna Fali
1020Clifford O GarufiArgentina2024-03-30King, Christopher A Esq PROPOSAL20Ivan Magalhaes
1021Aruna A ChuiRussia2024-03-30Chemel, James L Cpa NEGOTIATION16Ioni Bowcher
1022Maisha V CaldareraSpain2024-04-13Rousseaux, Michael Esq RENEWAL23Anna Fali
1023Aruna N DoeSpain2024-04-26Printing Dimensions PROPOSAL16Amy Elsner
1024Ricardo T FigeroaIndia2024-04-08Chapman, Ross E Esq RENEWAL48Xuxue Feng
1025Emily H SlusarskiCanada2024-04-06Morlong Associates QUALIFIED43Anna Fali
1026Ricardo K WaycottSpain2024-04-03Dorl, James J Esq NEGOTIATION21Stephen Shaw
1027Octavia T KolmetzSpain2024-04-08Feltz Printing Service QUALIFIED68Onyama Limba
1028James E GarufiJapan2024-04-08Chapman, Ross E Esq RENEWAL97Ivan Magalhaes
1029Antonio I SlusarskiRussia2024-04-10Rangoni Of Florence NEGOTIATION12Ioni Bowcher
1030Juan E WaycottJapan2024-04-21Morlong Associates RENEWAL13Onyama Limba
1031David B PoquetteBrazil2024-04-25Rousseaux, Michael Esq UNQUALIFIED70Amy Elsner
1032Misaki T PerinFrance2024-04-13Rousseaux, Michael Esq PROPOSAL75Elwin Sharvill
1033Jefferson P OldroydRussia2024-04-22Chapman, Ross E Esq NEW95Elwin Sharvill
1034Maria I PaprockiArgentina2024-04-06Chapman, Ross E Esq UNQUALIFIED84Stephen Shaw
1035Chavez A MaletFrance2024-04-15Benton, John B Jr UNQUALIFIED55Onyama Limba
1036Aditya K SlusarskiBrazil2024-04-03Buckley Miller Wright QUALIFIED72Amy Elsner
1037Silvio M BowleyBrazil2024-04-04Benton, John B Jr RENEWAL45Ioni Bowcher
1038Morrow U MacleadBrazil2024-04-01King, Christopher A Esq NEGOTIATION16Ioni Bowcher
1039Aika K FollerJapan2024-04-24Chemel, James L Cpa UNQUALIFIED55Ioni Bowcher
1040Greenwood K NestleItaly2024-04-16Morlong Associates QUALIFIED88Xuxue Feng
1041Claire M BowleyUnited Kingdom2024-04-22Chemel, James L Cpa QUALIFIED65Ioni Bowcher
1042Aruna C DilliardArgentina2024-04-24King, Christopher A Esq QUALIFIED46Elwin Sharvill
1043Antonio D VocelkaItaly2024-04-12Commercial Press NEGOTIATION20Ioni Bowcher
1044Ivar Y OldroydGermany2024-04-05King, Christopher A Esq NEGOTIATION48Asiya Javayant
1045Faith K ChuiRussia2024-04-12Rousseaux, Michael Esq QUALIFIED46Xuxue Feng
1046Stacey Y AlbaresRussia2024-04-03Printing Dimensions QUALIFIED5Ioni Bowcher
1047Izzy C GlickUnited Kingdom2024-04-28Feltz Printing Service QUALIFIED36Xuxue Feng
1048Alejandro L VocelkaBrazil2024-04-24Feltz Printing Service UNQUALIFIED75Amy Elsner
1049Rodrigues A VocelkaItaly2024-04-21Rousseaux, Michael Esq QUALIFIED47Onyama Limba
Frozen Rows
NameCountryRepresentativeStatus
Stacey P SlusarskiSpainAsiya Javayant NEGOTIATION
Stacey D KolmetzCanadaBernardo Dominic UNQUALIFIED
Greenwood D IturbideGermanyIvan Magalhaes PROPOSAL
Silvio K WhobreyJapanAsiya Javayant PROPOSAL
Kaitlin W MacleadIndiaElwin Sharvill PROPOSAL
Nicolas H MorascaFranceStephen Shaw RENEWAL
Juan L VenereRussiaOnyama Limba RENEWAL
Rodrigues T PerinSpainAsiya Javayant NEW
Jefferson I AmigonJapanIoni Bowcher UNQUALIFIED
Faith D GauchoJapanXuxue Feng QUALIFIED
Leon X NickaUnited KingdomIvan Magalhaes QUALIFIED
Kadeem I ShinkoUnited KingdomIvan Magalhaes RENEWAL
Octavia L AmigonFranceBernardo Dominic UNQUALIFIED
Jones O AlbaresJapanIvan Magalhaes NEGOTIATION
Morrow G CaldareraCanadaIoni Bowcher UNQUALIFIED
Smith L PerinSpainIvan Magalhaes RENEWAL
Aruna P RutaJapanXuxue Feng UNQUALIFIED
Maria S StockhamIndiaIoni Bowcher QUALIFIED
Ivar K FollerArgentinaXuxue Feng NEGOTIATION
Adams D ButtJapanIvan Magalhaes RENEWAL
Darci G GauchoFranceAnna Fali RENEWAL
Smith O BowleyItalyElwin Sharvill PROPOSAL
Mujtaba I DilliardArgentinaElwin Sharvill QUALIFIED
Leon Z RutaFranceBernardo Dominic RENEWAL
Nicolas J WieserAustraliaIvan Magalhaes QUALIFIED
Jones S MorascaSpainAnna Fali NEGOTIATION
James L MaletItalyElwin Sharvill QUALIFIED
Munro X RutaItalyIoni Bowcher UNQUALIFIED
Aditya L ShinkoFranceAmy Elsner PROPOSAL
Isabel N WieserItalyAnna Fali PROPOSAL
Emily F OldroydGermanyAmy Elsner PROPOSAL
Wickens K KuskoIndiaAnna Fali PROPOSAL
James E PoquetteItalyElwin Sharvill PROPOSAL
Leon I WieserCanadaStephen Shaw NEGOTIATION
Ashley N CaudyGermanyAnna Fali QUALIFIED
Tony S SergiSpainAnna Fali NEGOTIATION
Leon Q FerenczSpainIoni Bowcher NEW
Sinclair Y SaylorsItalyIvan Magalhaes NEGOTIATION
Ricardo M SlusarskiAustraliaIoni Bowcher QUALIFIED
David U CampainGermanyAsiya Javayant PROPOSAL
Tony W StensethItalyStephen Shaw NEW
Ricardo V AlbaresGermanyAnna Fali UNQUALIFIED
Kaitlin Q PoquetteCanadaAmy Elsner NEW
James H MarrierCanadaElwin Sharvill QUALIFIED
Morrow C FerenczCanadaBernardo Dominic UNQUALIFIED
Aditya Y DilliardIndiaBernardo Dominic RENEWAL
Chavez Q PaprockiAustraliaIvan Magalhaes NEW
Mujtaba I StensethJapanOnyama Limba UNQUALIFIED
Leon W SergiCanadaIoni Bowcher UNQUALIFIED
Leon M BowleyBrazilIvan Magalhaes NEGOTIATION
Frozen Columns
Name
Ivar P Ostrosky
Morrow G Oldroyd
Faith A Stenseth
Deepesh I Amigon
Kaitlin C Sergi
Isabel S Ostrosky
Darci Q Waycott
Mayumi U Waycott
Ricardo O Ferencz
Munro B Paprocki
Jennifer E Maclead
Juan D Paprocki
Salvatore U Ferencz
Clifford G Gaucho
Francesco X Venere
Octavia M Flosi
Jones I Malet
Juan U Darakjy
Johnson P Kolmetz
Isabel T Malet
Nicolas R Poquette
Jones T Bolognia
Octavia U Paprocki
Leja X Malet
Aika O Chui
Juan E Gaucho
Juan J Rim
Murillo F Tollner
David T Iturbide
Mujtaba Z Caldarera
Smith E Garufi
Faith K Maclead
Isabel Q Bowley
Alejandro H Caldarera
Jeanfrancois T Marrier
Murillo N Tollner
Greenwood D Doe
Faith Y Whobrey
Sinclair O Rim
Tony H Kolmetz
Johnson B Doe
Emily D Garufi
Johnson K Malet
Cody A Vocelka
Clifford P Flosi
Darci K Garufi
Salvatore O Saylors
Ivar C Ferencz
Ivar R Gaucho
Claire N Kusko
IdCountryDate
1000United Kingdom2024-04-13
1001Australia2024-04-10
1002France2024-04-25
1003Germany2024-04-11
1004Argentina2024-04-15
1005Japan2024-04-13
1006United Kingdom2024-04-18
1007Brazil2024-04-20
1008France2024-04-07
1009United Kingdom2024-04-10
1010Germany2024-04-11
1011Russia2024-04-03
1012Australia2024-04-05
1013Argentina2024-04-25
1014Germany2024-04-06
1015Italy2024-04-20
1016Canada2024-04-28
1017Russia2024-04-21
1018Japan2024-04-24
1019Argentina2024-04-10
1020Spain2024-04-27
1021Brazil2024-04-08
1022Italy2024-03-31
1023Russia2024-04-22
1024Russia2024-04-12
1025India2024-04-01
1026France2024-03-30
1027Brazil2024-03-30
1028India2024-04-10
1029United Kingdom2024-04-02
1030Brazil2024-04-25
1031Russia2024-04-27
1032United Kingdom2024-04-01
1033Australia2024-04-20
1034Japan2024-04-24
1035Japan2024-04-16
1036Spain2024-04-01
1037Argentina2024-04-27
1038Canada2024-04-22
1039Canada2024-04-17
1040Germany2024-03-31
1041Italy2024-04-06
1042Canada2024-04-11
1043Italy2024-04-09
1044France2024-04-10
1045Germany2024-04-13
1046Argentina2024-04-21
1047Germany2024-04-26
1048France2024-04-17
1049Russia2024-04-20

On-Demand Data

NameIdCountryDate
Julie F Rim1000France2024-04-04
Mujtaba Y Sergi1001Canada2024-04-19
Silvio J Royster1002Brazil2024-04-05
Munro D Stenseth1003Japan2024-04-19
Emily B Saylors1004Argentina2024-04-06
Aika I Iturbide1005India2024-04-21
Octavia Q Malet1006Italy2024-04-24
Jones Y Shinko1007Australia2024-04-01
Clifford R Flosi1008Russia2024-04-06
Julie F Maclead1009Japan2024-04-02
Ivar T Albares1010Argentina2024-04-09
Misaki W Ostrosky1011Germany2024-04-25
Munro R Briddick1012Spain2024-04-16
Salvatore H Ostrosky1013Russia2024-04-20
Leja P Oldroyd1014Italy2024-04-27
Mujtaba D Nicka1015Russia2024-04-24
James N Malet1016Italy2024-04-22
Mayumi C Poquette1017Australia2024-04-13
Julie Y Flosi1018United Kingdom2024-04-06
Maria X Malet1019Argentina2024-04-26
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Octavia X FerenczJapanIoni Bowcher NEW
Greenwood U WaycottArgentinaAmy Elsner NEGOTIATION
Arvin O RutaSpainIoni Bowcher NEW
James V GillianArgentinaOnyama Limba QUALIFIED
Alejandro C SlusarskiFranceOnyama Limba NEGOTIATION
Izzy R WaycottUnited KingdomAsiya Javayant RENEWAL
Alejandro F DarakjySpainAnna Fali RENEWAL
David I SchemmerRussiaIoni Bowcher NEW
Silvio E ChuiSpainAmy Elsner NEW
Aruna E InouyeCanadaOnyama Limba NEW
Alejandro E FigeroaGermanyOnyama Limba NEW
Maisha N WaycottItalyBernardo Dominic NEW
Octavia F GarufiGermanyElwin Sharvill NEW
Antonio O NestleAustraliaElwin Sharvill QUALIFIED
Ricardo I GauchoJapanIvan Magalhaes NEW
Cody H FlosiIndiaOnyama Limba PROPOSAL
James I DilliardJapanBernardo Dominic RENEWAL
Ricardo B TollnerIndiaAsiya Javayant NEGOTIATION
Clifford C MaletUnited KingdomAnna Fali NEGOTIATION
Stacey V NickaUnited KingdomStephen Shaw NEGOTIATION
Misaki Q KolmetzArgentinaIvan Magalhaes QUALIFIED
Maisha Y CampainBrazilAnna Fali NEW
Francesco O AmigonGermanyOnyama Limba QUALIFIED
Silvio G MacleadArgentinaElwin Sharvill UNQUALIFIED
Izzy B CaudyCanadaIvan Magalhaes RENEWAL
Emily L DilliardUnited KingdomStephen Shaw NEGOTIATION
Silvio T DoeCanadaIoni Bowcher NEW
Cody N MorascaBrazilStephen Shaw NEW
Maisha Z RimFranceOnyama Limba PROPOSAL
Darci V StockhamBrazilStephen Shaw NEGOTIATION
Chavez V MarrierArgentinaBernardo Dominic QUALIFIED
Mujtaba S MaletArgentinaStephen Shaw QUALIFIED
Jones T PaprockiUnited KingdomStephen Shaw NEGOTIATION
Chavez S OldroydRussiaXuxue Feng NEW
Faith C MorascaGermanyIoni Bowcher RENEWAL
Ricardo U ButtSpainAsiya Javayant UNQUALIFIED
Maisha J KolmetzIndiaIoni Bowcher RENEWAL
Deepesh V MacleadUnited KingdomOnyama Limba PROPOSAL
Faith X MaletAustraliaIvan Magalhaes PROPOSAL
Kaitlin E GarufiArgentinaStephen Shaw 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>