Carousel displays data using a slide effect.
<style>
.product-item .product-item-content {
border: 1px solid var(--surface-d);
border-radius: 3px;
margin: .3rem;
text-align: center;
padding: 2rem 0;
}
.product-item .product-image {
width: 50%;
box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23)
}
</style>
<h:form id="form">
<div class="card">
<p:carousel value="#{carouselView.products}" var="product" numVisible="3" numScroll="3"
responsiveOptions="#{carouselView.responsiveOptions}">
<f:facet name="header">
<h5>Basic</h5>
</f:facet>
<div class="product-item">
<div class="product-item-content">
<div class="mb-3">
<p:graphicImage name="demo/images/product/#{product.image}" styleClass="product-image"/>
</div>
<div>
<h4 class="mb-1">#{product.name}</h4>
<h6 class="mt-0 mb-3">
<h:outputText value="#{product.price}">
<f:convertNumber type="currency" pattern="¤#0" currencySymbol="$" />
</h:outputText>
</h6>
<span class="product-badge status-#{product.inventoryStatus.statusName}">#{product.inventoryStatus.text}</span>
<div class="mt-5">
<p:commandButton type="button" icon="pi pi-search" styleClass="rounded-button mr-2" />
<p:commandButton type="button" icon="pi pi-star" styleClass="ui-button-success rounded-button mr-2" />
<p:commandButton type="button" icon="pi pi-cog" styleClass="ui-button-help rounded-button" />
</div>
</div>
</div>
</div>
</p:carousel>
</div>
<div class="card">
<p:carousel value="#{carouselView.products}" var="product" circular="true" autoplayInterval="3000"
responsiveOptions="#{carouselView.responsiveOptions}" numVisible="3" numScroll="1">
<f:facet name="header">
<h5>Circular, AutoPlay, 3 Items per Page and Scroll by 1</h5>
</f:facet>
<div class="product-item">
<div class="product-item-content">
<div class="mb-3">
<p:graphicImage name="demo/images/product/#{product.image}" styleClass="product-image"/>
</div>
<div>
<h4 class="mb-1">#{product.name}</h4>
<h6 class="mt-0 mb-3">
<h:outputText value="#{product.price}">
<f:convertNumber type="currency" pattern="¤#0" currencySymbol="$" />
</h:outputText>
</h6>
<span class="product-badge status-#{product.inventoryStatus.statusName}">#{product.inventoryStatus.text}</span>
<div class="mt-5">
<p:commandButton type="button" icon="pi pi-search" styleClass="rounded-button mr-2" />
<p:commandButton type="button" icon="pi pi-star" styleClass="ui-button-success rounded-button mr-2" />
<p:commandButton type="button" icon="pi pi-cog" styleClass="ui-button-help rounded-button" />
</div>
</div>
</div>
</div>
</p:carousel>
</div>
<div class="card">
<p:carousel value="#{carouselView.products}" var="product" orientation="vertical"
verticalViewPortHeight="352px" style="max-width: 400px;margin-top: 2em;">
<f:facet name="header">
<h5>Vertical</h5>
</f:facet>
<div class="product-item">
<div class="product-item-content">
<div class="mb-3">
<p:graphicImage name="demo/images/product/#{product.image}" styleClass="product-image"/>
</div>
<div>
<h4 class="mb-1">#{product.name}</h4>
<h6 class="mt-0 mb-3">
<h:outputText value="#{product.price}">
<f:convertNumber type="currency" pattern="¤#0" currencySymbol="$" />
</h:outputText>
</h6>
<span class="product-badge status-#{product.inventoryStatus.statusName}">#{product.inventoryStatus.text}</span>
<div class="mt-5">
<p:commandButton type="button" icon="pi pi-search" styleClass="rounded-button mr-2" />
<p:commandButton type="button" icon="pi pi-star" styleClass="ui-button-success rounded-button mr-2" />
<p:commandButton type="button" icon="pi pi-cog" styleClass="ui-button-help rounded-button" />
</div>
</div>
</div>
</div>
</p:carousel>
</div>
<div class="card">
<p:carousel circular="true" paginator="false">
<f:facet name="header">
<h5>Tabs</h5>
</f:facet>
<p:tab>
<p class="m-0 p-3">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,
quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum
dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
</p>
</p:tab>
<p:tab>
<p class="m-0 p-3">
Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab
illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut
odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Consectetur, adipisci velit, sed quia non numquam eius modi.
</p>
</p:tab>
<p:tab>
<p class="m-0 p-3">
At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores
et quas molestias excepturi sint occaecati cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga.
Et harum quidem rerum facilis est et expedita distinctio. Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.
</p>
</p:tab>
</p:carousel>
</div>
</h:form>
package org.primefaces.showcase.view.data;
import jakarta.annotation.PostConstruct;
import jakarta.faces.view.ViewScoped;
import jakarta.inject.Inject;
import jakarta.inject.Named;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import io.quarkus.runtime.annotations.RegisterForReflection;
import org.primefaces.model.ResponsiveOption;
import org.primefaces.showcase.domain.Product;
import org.primefaces.showcase.service.ProductService;
@Named
@ViewScoped
@RegisterForReflection(serialization = true)
public class CarouselView implements Serializable {
@Inject
ProductService service;
private List<Product> products;
private List<ResponsiveOption> responsiveOptions;
@PostConstruct
public void init() {
products = service.getProducts(9);
responsiveOptions = new ArrayList<>();
responsiveOptions.add(new ResponsiveOption("1024px", 3, 3));
responsiveOptions.add(new ResponsiveOption("768px", 2, 2));
responsiveOptions.add(new ResponsiveOption("560px", 1, 1));
}
public List<Product> getProducts() {
return products;
}
public void setService(ProductService service) {
this.service = service;
}
public List<ResponsiveOption> getResponsiveOptions() {
return responsiveOptions;
}
public void setResponsiveOptions(List<ResponsiveOption> responsiveOptions) {
this.responsiveOptions = responsiveOptions;
}
}
package org.primefaces.showcase.service;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.UUID;
import jakarta.annotation.PostConstruct;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.inject.Named;
import org.primefaces.showcase.domain.InventoryStatus;
import org.primefaces.showcase.domain.Product;
@Named
@ApplicationScoped
public class ProductService {
private List<Product> products;
@PostConstruct
public void init() {
products = new ArrayList<>();
products.add(new Product(1000, "f230fh0g3", "Bamboo Watch", "Product Description", "bamboo-watch.jpg", 65,
"Accessories", 24, InventoryStatus.INSTOCK, 5));
products.add(new Product(1001, "nvklal433", "Black Watch", "Product Description", "black-watch.jpg", 72,
"Accessories", 61, InventoryStatus.INSTOCK, 4));
products.add(new Product(1002, "zz21cz3c1", "Blue Band", "Product Description", "blue-band.jpg", 79,
"Fitness", 2, InventoryStatus.LOWSTOCK, 3));
products.add(new Product(1003, "244wgerg2", "Blue T-Shirt", "Product Description", "blue-t-shirt.jpg", 29,
"Clothing", 25, InventoryStatus.INSTOCK, 5));
products.add(new Product(1004, "h456wer53", "Bracelet", "Product Description", "bracelet.jpg", 15,
"Accessories", 73, InventoryStatus.INSTOCK, 4));
products.add(new Product(1005, "av2231fwg", "Brown Purse", "Product Description", "brown-purse.jpg", 120,
"Accessories", 0, InventoryStatus.OUTOFSTOCK, 4));
products.add(new Product(1006, "bib36pfvm", "Chakra Bracelet", "Product Description", "chakra-bracelet.jpg", 32,
"Accessories", 5, InventoryStatus.LOWSTOCK, 3));
products.add(new Product(1007, "mbvjkgip5", "Galaxy Earrings", "Product Description", "galaxy-earrings.jpg", 34,
"Accessories", 23, InventoryStatus.INSTOCK, 5));
products.add(new Product(1008, "vbb124btr", "Game Controller", "Product Description", "game-controller.jpg", 99,
"Electronics", 2, InventoryStatus.LOWSTOCK, 4));
products.add(new Product(1009, "cm230f032", "Gaming Set", "Product Description", "gaming-set.jpg", 299,
"Electronics", 63, InventoryStatus.INSTOCK, 3));
products.add(new Product(1010, "plb34234v", "Gold Phone Case", "Product Description", "gold-phone-case.jpg", 24,
"Accessories", 0, InventoryStatus.OUTOFSTOCK, 4));
products.add(new Product(1011, "4920nnc2d", "Green Earbuds", "Product Description", "green-earbuds.jpg", 89,
"Electronics", 23, InventoryStatus.INSTOCK, 4));
products.add(new Product(1012, "250vm23cc", "Green T-Shirt", "Product Description", "green-t-shirt.jpg", 49,
"Clothing", 74, InventoryStatus.INSTOCK, 5));
products.add(new Product(1013, "fldsmn31b", "Grey T-Shirt", "Product Description", "grey-t-shirt.jpg", 48,
"Clothing", 0, InventoryStatus.OUTOFSTOCK, 3));
products.add(new Product(1014, "waas1x2as", "Headphones", "Product Description", "headphones.jpg", 175,
"Electronics", 8, InventoryStatus.LOWSTOCK, 5));
products.add(new Product(1015, "vb34btbg5", "Light Green T-Shirt", "Product Description", "light-green-t-shirt.jpg", 49,
"Clothing", 34, InventoryStatus.INSTOCK, 4));
products.add(new Product(1016, "k8l6j58jl", "Lime Band", "Product Description", "lime-band.jpg", 79,
"Fitness", 12, InventoryStatus.INSTOCK, 3));
products.add(new Product(1017, "v435nn85n", "Mini Speakers", "Product Description", "mini-speakers.jpg", 85,
"Clothing", 42, InventoryStatus.INSTOCK, 4));
products.add(new Product(1018, "09zx9c0zc", "Painted Phone Case", "Product Description", "painted-phone-case.jpg", 56,
"Accessories", 41, InventoryStatus.INSTOCK, 5));
products.add(new Product(1019, "mnb5mb2m5", "Pink Band", "Product Description", "pink-band.jpg", 79,
"Fitness", 63, InventoryStatus.INSTOCK, 4));
products.add(new Product(1020, "r23fwf2w3", "Pink Purse", "Product Description", "pink-purse.jpg", 110,
"Accessories", 0, InventoryStatus.OUTOFSTOCK, 4));
products.add(new Product(1021, "pxpzczo23", "Purple Band", "Product Description", "purple-band.jpg", 79,
"Fitness", 6, InventoryStatus.LOWSTOCK, 3));
products.add(new Product(1022, "2c42cb5cb", "Purple Gemstone Necklace", "Product Description", "purple-gemstone-necklace.jpg", 45,
"Accessories", 62, InventoryStatus.INSTOCK, 4));
products.add(new Product(1023, "5k43kkk23", "Purple T-Shirt", "Product Description", "purple-t-shirt.jpg", 49,
"Clothing", 2, InventoryStatus.LOWSTOCK, 5));
products.add(new Product(1024, "lm2tny2k4", "Shoes", "Product Description", "shoes.jpg", 64,
"Clothing", 0, InventoryStatus.INSTOCK, 4));
products.add(new Product(1025, "nbm5mv45n", "Sneakers", "Product Description", "sneakers.jpg", 78,
"Clothing", 52, InventoryStatus.INSTOCK, 4));
products.add(new Product(1026, "zx23zc42c", "Teal T-Shirt", "Product Description", "teal-t-shirt.jpg", 49,
"Clothing", 3, InventoryStatus.LOWSTOCK, 3));
products.add(new Product(1027, "acvx872gc", "Yellow Earbuds", "Product Description", "yellow-earbuds.jpg", 89,
"Electronics", 35, InventoryStatus.INSTOCK, 3));
products.add(new Product(1028, "tx125ck42", "Yoga Mat", "Product Description", "yoga-mat.jpg", 20,
"Fitness", 15, InventoryStatus.INSTOCK, 5));
products.add(new Product(1029, "gwuby345v", "Yoga Set", "Product Description", "yoga-set.jpg", 20,
"Fitness", 25, InventoryStatus.INSTOCK, 8));
}
public List<Product> getProducts() {
return new ArrayList<>(products);
}
public List<Product> getProducts(int size) {
if (size > products.size()) {
Random rand = new Random();
List<Product> randomList = new ArrayList<>();
for (int i = 0; i < size; i++) {
int randomIndex = rand.nextInt(products.size());
randomList.add(products.get(randomIndex));
}
return randomList;
}
else {
return new ArrayList<>(products.subList(0, size));
}
}
public List<Product> getClonedProducts(int size) {
List<Product> results = new ArrayList<>();
List<Product> originals = getProducts(size);
for (Product original : originals) {
results.add(original.clone());
}
// make sure to have unique codes
for (Product product : results) {
product.setCode(UUID.randomUUID().toString().replace("-", "").substring(0, 8));
}
return results;
}
}
package org.primefaces.showcase.domain;
import java.io.Serializable;
import java.util.List;
import java.util.Objects;
import io.quarkus.runtime.annotations.RegisterForReflection;
@RegisterForReflection
public class Product implements Serializable {
private int id;
private String code;
private String name;
private String description;
private String image;
private double price;
private String category;
private int quantity;
private InventoryStatus inventoryStatus;
private int rating;
private List<Order> orders;
public Product() {
}
public Product(int id, String code, String name, String description, String image, double price, String category, int quantity,
InventoryStatus inventoryStatus, int rating) {
this.id = id;
this.code = code;
this.name = name;
this.description = description;
this.image = image;
this.price = price;
this.category = category;
this.quantity = quantity;
this.inventoryStatus = inventoryStatus;
this.rating = rating;
}
@Override
public Product clone() {
return new Product(getId(), getCode(), getName(), getDescription(), getImage(), getPrice(), getCategory(), getQuantity(),
getInventoryStatus(), getRating());
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getImage() {
return image;
}
public void setImage(String image) {
this.image = image;
}
public double getPrice() {
return price;
}
public void setPrice(double price) {
this.price = price;
}
public String getCategory() {
return category;
}
public void setCategory(String category) {
this.category = category;
}
public int getQuantity() {
return quantity;
}
public void setQuantity(int quantity) {
this.quantity = quantity;
}
public InventoryStatus getInventoryStatus() {
return inventoryStatus;
}
public void setInventoryStatus(InventoryStatus inventoryStatus) {
this.inventoryStatus = inventoryStatus;
}
public int getRating() {
return rating;
}
public void setRating(int rating) {
this.rating = rating;
}
public List<Order> getOrders() {
return this.orders;
}
public void setOrders(List<Order> orders) {
this.orders = orders;
}
@Override
public int hashCode() {
return Objects.hashCode(code);
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
Product other = (Product) obj;
return Objects.equals(getCode(), other.getCode());
}
}
package org.primefaces.showcase.domain;
import java.util.Locale;
import io.quarkus.runtime.annotations.RegisterForReflection;
@RegisterForReflection
public enum InventoryStatus {
INSTOCK("In Stock"),
OUTOFSTOCK("Out of Stock"),
LOWSTOCK("Low Stock");
private final String text;
InventoryStatus(String text) {
this.text = text;
}
public String getText() {
return text;
}
public String getStatusName() {
return name().toLowerCase(Locale.ROOT);
}
}
package org.primefaces.showcase.domain;
import io.quarkus.runtime.annotations.RegisterForReflection;
@RegisterForReflection
public class Order implements java.io.Serializable {
private final int number;
private final String imagePath;
public Order(int number, String imagePath) {
this.number = number;
this.imagePath = imagePath;
}
public int getNumber() {
return number;
}
public String getImagePath() {
return imagePath;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Order order = (Order) o;
return number == order.number;
}
@Override
public int hashCode() {
return number;
}
}