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
Izzy U SergiFranceBernardo Dominic NEGOTIATION
Chavez Y BologniaSpainStephen Shaw UNQUALIFIED
Cody E FigeroaIndiaOnyama Limba QUALIFIED
Alejandro C RulapaughJapanAmy Elsner NEGOTIATION
Adams G InouyeGermanyBernardo Dominic UNQUALIFIED
Sinclair T RulapaughGermanyAnna Fali QUALIFIED
Isabel E BologniaGermanyAsiya Javayant NEGOTIATION
Aruna M VenereBrazilXuxue Feng RENEWAL
Greenwood T GillianJapanIoni Bowcher RENEWAL
Maisha B KuskoBrazilOnyama Limba NEW
Julie S BowleyBrazilBernardo Dominic NEGOTIATION
Leon Q GauchoJapanIoni Bowcher RENEWAL
Claire Q SlusarskiArgentinaXuxue Feng NEGOTIATION
Jeanfrancois M RimIndiaXuxue Feng NEW
Silvio B MacleadIndiaIoni Bowcher UNQUALIFIED
Stacey H OstroskyBrazilIoni Bowcher QUALIFIED
Morrow S DilliardUnited KingdomIoni Bowcher NEGOTIATION
Chavez U BologniaAustraliaElwin Sharvill NEW
Sinclair Z ButtIndiaOnyama Limba NEGOTIATION
Munro W StockhamAustraliaBernardo Dominic NEW
Maria V FlosiArgentinaOnyama Limba PROPOSAL
Murillo W InouyeItalyStephen Shaw UNQUALIFIED
Deepesh C RoysterIndiaBernardo Dominic PROPOSAL
Faith O RutaAustraliaIoni Bowcher NEGOTIATION
Jones Y AlbaresIndiaElwin Sharvill RENEWAL
Wickens D WhobreyUnited KingdomIvan Magalhaes PROPOSAL
Maria K PerinBrazilStephen Shaw PROPOSAL
Claire A DoeRussiaAnna Fali PROPOSAL
Arvin Q AmigonArgentinaOnyama Limba NEW
Francesco E SlusarskiItalyAnna Fali NEW
Jefferson Z NickaBrazilElwin Sharvill NEW
James B NickaJapanIoni Bowcher QUALIFIED
Sinclair D TollnerSpainAmy Elsner NEGOTIATION
Ivar P SaylorsJapanAnna Fali RENEWAL
Costa X DoeUnited KingdomElwin Sharvill RENEWAL
Julie Q GillianSpainAnna Fali PROPOSAL
Tony O NickaGermanyOnyama Limba NEW
Murillo T FollerCanadaStephen Shaw NEW
Mayumi P KuskoRussiaAmy Elsner QUALIFIED
Jennifer T MaletItalyIoni Bowcher UNQUALIFIED
Adams K BriddickIndiaElwin Sharvill PROPOSAL
David D AlbaresArgentinaAnna Fali UNQUALIFIED
Jennifer M PaprockiJapanBernardo Dominic NEGOTIATION
Rodrigues M DarakjyCanadaIoni Bowcher PROPOSAL
Deepesh H CaldareraUnited KingdomOnyama Limba NEGOTIATION
Jones N OstroskyGermanyAmy Elsner NEW
Munro L DarakjyIndiaIoni Bowcher UNQUALIFIED
Faith V ButtItalyXuxue Feng QUALIFIED
Darci G CaudyAustraliaAmy Elsner NEGOTIATION
Wickens A RimUnited KingdomAnna Fali PROPOSAL
Horizontal
NameCountryRepresentativeStatus
Kadeem D TollnerRussiaIvan Magalhaes NEGOTIATION
David K GauchoUnited KingdomAmy Elsner QUALIFIED
Munro N FlosiIndiaIvan Magalhaes UNQUALIFIED
Aditya T BowleyAustraliaBernardo Dominic NEGOTIATION
Clifford F MarrierUnited KingdomStephen Shaw PROPOSAL
Antonio Q PaprockiFranceAnna Fali NEW
Aruna Y ChuiIndiaAmy Elsner PROPOSAL
Johnson L GlickArgentinaXuxue Feng NEW
Mujtaba E BriddickCanadaStephen Shaw NEW
Nicolas L ShinkoArgentinaAnna Fali RENEWAL
Horizontal and Vertical
IdNameCountryDateCompanyStatusActivityRepresentative
1000Greenwood N CampainUnited Kingdom2024-04-19Morlong Associates QUALIFIED18Xuxue Feng
1001Jeanfrancois R CaldareraBrazil2024-03-30Rousseaux, Michael Esq PROPOSAL4Asiya Javayant
1002Jeanfrancois Y AlbaresAustralia2024-04-10Commercial Press NEW24Amy Elsner
1003Rodrigues L DoeJapan2024-04-23Benton, John B Jr PROPOSAL34Bernardo Dominic
1004Aika K SchemmerAustralia2024-04-01Dorl, James J Esq NEW75Xuxue Feng
1005Isabel S RutaAustralia2024-04-05Benton, John B Jr UNQUALIFIED33Onyama Limba
1006Aruna F MaletFrance2024-04-14Printing Dimensions NEGOTIATION48Anna Fali
1007Ricardo D BriddickSpain2024-04-10Rangoni Of Florence NEW32Ivan Magalhaes
1008Leon G MorascaRussia2024-04-23King, Christopher A Esq QUALIFIED58Bernardo Dominic
1009Julie N VocelkaItaly2024-04-08Feiner Bros NEGOTIATION57Ioni Bowcher
1010Aruna P ShinkoRussia2024-04-01Feiner Bros PROPOSAL59Ioni Bowcher
1011Julie F CaudyCanada2024-04-03Feiner Bros PROPOSAL34Ioni Bowcher
1012Darci O NickaIndia2024-04-05Rousseaux, Michael Esq UNQUALIFIED85Xuxue Feng
1013Francesco U FollerGermany2024-04-12Buckley Miller Wright QUALIFIED20Asiya Javayant
1014Kadeem X RutaBrazil2024-04-01Buckley Miller Wright QUALIFIED80Ivan Magalhaes
1015Smith E OldroydItaly2024-04-08Benton, John B Jr RENEWAL20Asiya Javayant
1016Costa S GauchoUnited Kingdom2024-04-21Truhlar And Truhlar Attys UNQUALIFIED78Xuxue Feng
1017Smith W CaldareraItaly2024-03-29Truhlar And Truhlar Attys QUALIFIED11Ivan Magalhaes
1018Leon D FlosiSpain2024-04-02Morlong Associates UNQUALIFIED40Onyama Limba
1019Mayumi M WhobreyArgentina2024-03-29Feiner Bros QUALIFIED25Ivan Magalhaes
1020Munro F ButtJapan2024-04-22Feltz Printing Service PROPOSAL15Anna Fali
1021Julie B MorascaAustralia2024-04-14Rangoni Of Florence NEGOTIATION50Xuxue Feng
1022Salvatore N SergiJapan2024-04-03Printing Dimensions RENEWAL68Amy Elsner
1023Cody P IturbideJapan2024-03-30Benton, John B Jr UNQUALIFIED67Stephen Shaw
1024Smith W StensethFrance2024-04-08Rangoni Of Florence PROPOSAL11Onyama Limba
1025Antonio Y WaycottCanada2024-03-28Rangoni Of Florence QUALIFIED84Ivan Magalhaes
1026Darci I VenereCanada2024-04-12Feiner Bros NEGOTIATION52Xuxue Feng
1027Maria U MaletItaly2024-04-08Benton, John B Jr RENEWAL35Anna Fali
1028Ricardo F MaletArgentina2024-04-09Benton, John B Jr NEW38Elwin Sharvill
1029Maria H KuskoBrazil2024-04-14Feltz Printing Service NEGOTIATION35Ivan Magalhaes
1030Salvatore E StensethJapan2024-04-18Feltz Printing Service QUALIFIED82Anna Fali
1031Rodrigues A SlusarskiItaly2024-04-10Printing Dimensions QUALIFIED83Xuxue Feng
1032Ashley R StockhamSpain2024-04-07Benton, John B Jr NEGOTIATION31Asiya Javayant
1033Maisha Z PaprockiItaly2024-04-11Feltz Printing Service UNQUALIFIED15Ivan Magalhaes
1034Salvatore F WieserFrance2024-03-31Chapman, Ross E Esq PROPOSAL4Asiya Javayant
1035Julie F WhobreyAustralia2024-04-24Chapman, Ross E Esq QUALIFIED8Ioni Bowcher
1036Jefferson J ButtSpain2024-04-20Dorl, James J Esq QUALIFIED81Ioni Bowcher
1037Aditya X SchemmerUnited Kingdom2024-04-15Printing Dimensions NEGOTIATION96Asiya Javayant
1038Sinclair K WhobreyAustralia2024-04-13Rangoni Of Florence QUALIFIED44Anna Fali
1039Deepesh R BriddickBrazil2024-04-03Chemel, James L Cpa QUALIFIED53Onyama Limba
1040Clifford Y BowleyFrance2024-04-21Commercial Press QUALIFIED77Ivan Magalhaes
1041Julie C GarufiItaly2024-04-13Benton, John B Jr RENEWAL68Ioni Bowcher
1042Aruna J MarrierIndia2024-04-06Dorl, James J Esq RENEWAL72Onyama Limba
1043Costa I SlusarskiSpain2024-04-06King, Christopher A Esq RENEWAL1Amy Elsner
1044Morrow M WaycottGermany2024-04-17Printing Dimensions QUALIFIED84Asiya Javayant
1045Sinclair L CampainFrance2024-04-07Printing Dimensions NEGOTIATION86Stephen Shaw
1046Misaki K PaprockiArgentina2024-03-27Rangoni Of Florence RENEWAL40Elwin Sharvill
1047Leon K GillianUnited Kingdom2024-04-21Chapman, Ross E Esq QUALIFIED76Stephen Shaw
1048Adams V FerenczSpain2024-04-24Printing Dimensions NEW59Elwin Sharvill
1049Juan Z NestleSpain2024-03-31Morlong Associates RENEWAL90Xuxue Feng
Frozen Rows
NameCountryRepresentativeStatus
Ivar L RoysterGermanyAsiya Javayant QUALIFIED
Aruna H BowleyBrazilIoni Bowcher NEW
Greenwood Z KuskoCanadaAnna Fali NEGOTIATION
Morrow B StensethSpainAmy Elsner PROPOSAL
Clifford R SchemmerUnited KingdomXuxue Feng NEW
Misaki L NickaCanadaOnyama Limba PROPOSAL
Emily Z FollerArgentinaAsiya Javayant NEGOTIATION
Octavia L StockhamCanadaIvan Magalhaes QUALIFIED
Maisha R PoquetteFranceAsiya Javayant QUALIFIED
Arvin Y TollnerBrazilXuxue Feng PROPOSAL
Murillo R BologniaJapanElwin Sharvill PROPOSAL
Mujtaba Y RoysterAustraliaAmy Elsner PROPOSAL
Antonio B MaletSpainAmy Elsner PROPOSAL
Francesco C RoysterAustraliaBernardo Dominic QUALIFIED
Ashley E DoeBrazilOnyama Limba UNQUALIFIED
Jennifer A StockhamIndiaOnyama Limba RENEWAL
Smith K DilliardAustraliaBernardo Dominic RENEWAL
Tony R NestleUnited KingdomElwin Sharvill UNQUALIFIED
Aika S MaletRussiaAnna Fali PROPOSAL
Octavia S SchemmerAustraliaStephen Shaw NEGOTIATION
Aruna K FigeroaArgentinaOnyama Limba QUALIFIED
Ricardo D StockhamCanadaAsiya Javayant RENEWAL
Costa Y SaylorsUnited KingdomAnna Fali NEW
Mujtaba G VenereJapanAsiya Javayant QUALIFIED
Jennifer U SergiAustraliaAnna Fali QUALIFIED
Mujtaba A MaletIndiaAnna Fali QUALIFIED
Faith L WhobreySpainXuxue Feng QUALIFIED
Salvatore P MacleadRussiaOnyama Limba PROPOSAL
Octavia B PaprockiGermanyBernardo Dominic RENEWAL
Clifford O MacleadFranceStephen Shaw NEW
Octavia A VocelkaArgentinaAnna Fali RENEWAL
Greenwood S RutaFranceOnyama Limba NEGOTIATION
Rodrigues E GlickSpainAnna Fali UNQUALIFIED
Leon D FerenczFranceAsiya Javayant UNQUALIFIED
Murillo P DilliardArgentinaAnna Fali UNQUALIFIED
Izzy K StockhamRussiaAnna Fali PROPOSAL
Cody I MaletAustraliaElwin Sharvill NEW
Francesco X DarakjyRussiaAsiya Javayant NEGOTIATION
Arvin L GarufiUnited KingdomAsiya Javayant NEW
Aditya B BologniaCanadaIoni Bowcher RENEWAL
Emily U RimCanadaAmy Elsner UNQUALIFIED
Aditya Y MaletCanadaStephen Shaw PROPOSAL
Claire F BriddickGermanyIoni Bowcher NEGOTIATION
Jones A SlusarskiUnited KingdomAmy Elsner NEW
Misaki G DilliardCanadaElwin Sharvill RENEWAL
Munro B ChuiJapanIoni Bowcher NEGOTIATION
Jones U BowleyGermanyAnna Fali QUALIFIED
Greenwood F FollerCanadaBernardo Dominic RENEWAL
Jones B MarrierFranceElwin Sharvill NEW
Izzy J CampainArgentinaIoni Bowcher UNQUALIFIED
Frozen Columns
Name
Kaitlin Y Ferencz
Silvio U Caldarera
Misaki B Ostrosky
David V Darakjy
Nicolas L Oldroyd
Juan L Bowley
Cody R Kusko
Silvio F Shinko
Sinclair O Royster
Arvin N Vocelka
Kaitlin Y Bowley
Silvio Y Oldroyd
Juan H Dilliard
Isabel V Gillian
Octavia C Garufi
Jefferson W Stenseth
Alejandro B Malet
Faith B Shinko
Aika F Garufi
Isabel V Chui
Emily U Flosi
James S Maclead
Izzy G Briddick
Izzy N Oldroyd
Jennifer U Rim
Munro A Albares
Isabel Y Albares
Aditya D Albares
Mayumi S Stenseth
Salvatore A Perin
Salvatore I Inouye
Maria X Royster
Misaki P Malet
Misaki G Maclead
Munro R Ferencz
Smith G Vocelka
Kadeem Y Royster
Ashley M Nestle
Deepesh R Whobrey
Munro H Bolognia
Jefferson S Kolmetz
Sinclair D Gaucho
Kaitlin V Poquette
Julie I Wieser
Ashley N Waycott
Silvio V Caudy
Juan V Campain
Aika X Rim
Darci Z Marrier
Tony J Kolmetz
IdCountryDate
1000Japan2024-04-02
1001Russia2024-03-30
1002Japan2024-03-28
1003Spain2024-04-11
1004Japan2024-04-13
1005Germany2024-04-10
1006Brazil2024-04-20
1007France2024-04-17
1008Germany2024-04-12
1009Germany2024-04-15
1010Brazil2024-04-02
1011Argentina2024-03-28
1012Australia2024-03-31
1013Italy2024-04-20
1014Germany2024-04-09
1015France2024-03-27
1016Australia2024-03-30
1017Italy2024-03-30
1018United Kingdom2024-04-14
1019France2024-04-12
1020Germany2024-04-20
1021Japan2024-04-22
1022Canada2024-04-24
1023Argentina2024-04-21
1024Italy2024-04-06
1025Australia2024-04-17
1026Australia2024-04-23
1027Canada2024-03-27
1028Australia2024-04-12
1029Spain2024-04-21
1030Germany2024-04-06
1031Spain2024-04-14
1032Russia2024-04-21
1033Germany2024-04-17
1034Italy2024-04-21
1035France2024-04-01
1036India2024-04-25
1037France2024-04-15
1038Japan2024-04-09
1039France2024-03-27
1040Brazil2024-04-04
1041Argentina2024-04-01
1042France2024-04-02
1043Russia2024-04-13
1044Argentina2024-04-08
1045Australia2024-04-25
1046India2024-04-04
1047Japan2024-03-30
1048Russia2024-04-06
1049Japan2024-04-03

On-Demand Data

NameIdCountryDate
Mayumi E Glick1000United Kingdom2024-04-14
Jennifer Y Stenseth1001Canada2024-04-08
Faith O Doe1002Australia2024-04-04
Kadeem Y Poquette1003Canada2024-03-30
Murillo C Kolmetz1004Germany2024-04-05
Arvin V Rulapaugh1005Japan2024-04-10
Juan W Butt1006Italy2024-04-11
Stacey B Amigon1007France2024-04-22
Greenwood X Maclead1008Japan2024-04-14
Greenwood E Schemmer1009Russia2024-04-16
Murillo A Malet1010India2024-04-07
Antonio U Sergi1011United Kingdom2024-04-25
Claire N Bowley1012India2024-04-07
Greenwood L Tollner1013Australia2024-04-19
Mujtaba B Perin1014France2024-04-17
Adams F Saylors1015United Kingdom2024-03-30
Ivar M Figeroa1016Brazil2024-04-15
Ivar R Glick1017India2024-04-22
James J Rim1018Japan2024-03-28
Antonio E Iturbide1019Spain2024-04-23
Virtual Scrolling - 20000 Rows
NameCountryRepresentativeStatus
Salvatore N IturbideArgentinaOnyama Limba UNQUALIFIED
Mujtaba F StensethCanadaIoni Bowcher QUALIFIED
David E KolmetzCanadaElwin Sharvill NEW
Smith Z TollnerArgentinaOnyama Limba NEW
Juan U BriddickArgentinaAnna Fali NEW
Adams Y WhobreyCanadaAmy Elsner RENEWAL
Jeanfrancois U AmigonUnited KingdomAsiya Javayant RENEWAL
Darci N AlbaresItalyAnna Fali PROPOSAL
Smith P ChuiSpainIoni Bowcher QUALIFIED
Ricardo R RimUnited KingdomBernardo Dominic NEW
Ivar L FigeroaArgentinaAmy Elsner NEW
Kaitlin O SchemmerCanadaIoni Bowcher RENEWAL
David H FigeroaGermanyElwin Sharvill NEW
Kaitlin A RimIndiaAmy Elsner QUALIFIED
Greenwood H ChuiArgentinaXuxue Feng NEGOTIATION
Izzy H RutaCanadaStephen Shaw QUALIFIED
Jeanfrancois T SchemmerBrazilElwin Sharvill UNQUALIFIED
Aruna B SlusarskiItalyIoni Bowcher UNQUALIFIED
Munro R PoquetteUnited KingdomAnna Fali PROPOSAL
Salvatore T WaycottCanadaElwin Sharvill RENEWAL
Wickens B BriddickCanadaBernardo Dominic NEGOTIATION
James B GarufiRussiaAsiya Javayant PROPOSAL
Sinclair Q ShinkoSpainAnna Fali RENEWAL
David N WhobreyAustraliaAsiya Javayant NEGOTIATION
Munro E OstroskyCanadaAmy Elsner NEW
Antonio X FerenczRussiaAsiya Javayant QUALIFIED
Kaitlin Y CampainUnited KingdomStephen Shaw NEGOTIATION
Claire W SaylorsJapanElwin Sharvill NEGOTIATION
Mayumi X StockhamJapanBernardo Dominic UNQUALIFIED
Stacey Z SchemmerSpainAmy Elsner RENEWAL
Tony S DilliardIndiaIoni Bowcher NEW
Morrow B BologniaUnited KingdomXuxue Feng UNQUALIFIED
Rodrigues Y NickaBrazilStephen Shaw RENEWAL
Jefferson E KuskoUnited KingdomIvan Magalhaes PROPOSAL
Rodrigues X DarakjyRussiaBernardo Dominic NEGOTIATION
Cody G PoquetteBrazilAsiya Javayant NEGOTIATION
Ashley I PaprockiUnited KingdomStephen Shaw UNQUALIFIED
Izzy R PaprockiArgentinaBernardo Dominic PROPOSAL
Julie Z IturbideSpainAsiya Javayant PROPOSAL
Chavez D ShinkoUnited KingdomXuxue Feng RENEWAL

<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>