Header of the datatable can be fixed to keep it in viewport during scroll.
DocumentationId | Year | Brand | Color |
---|---|---|---|
4d35f56d | 2003 | Honda | Black |
fe459842 | 1975 | BMW | Red |
08089fc9 | 1987 | Volvo | Silver |
ea5ffe95 | 1988 | Audi | Blue |
a5724c0d | 1971 | Fiat | Silver |
e499e109 | 1983 | Volkswagen | Black |
e0252e14 | 1967 | Mercedes | Orange |
fd0f73b5 | 1973 | BMW | Black |
fb12cc45 | 2003 | Volkswagen | Green |
dd6e4849 | 1960 | BMW | Green |
70071e88 | 1979 | Ford | Blue |
c4c14013 | 2000 | Ford | Orange |
65e36ce2 | 1969 | Renault | Black |
ebf42549 | 1975 | Mercedes | Green |
9d24fd13 | 2002 | BMW | Orange |
a7690077 | 1997 | Renault | Blue |
d4c71d37 | 2004 | Volkswagen | Black |
413fef02 | 1993 | Volkswagen | Green |
73474c99 | 2001 | Honda | White |
b5cb9da9 | 1985 | Renault | Maroon |
6f6edae7 | 2007 | Volkswagen | Red |
b32cd319 | 1990 | BMW | Black |
daf648ef | 1990 | Volvo | Blue |
72718936 | 1983 | Volkswagen | Black |
3e23702b | 1991 | Jaguar | White |
4ea7c4ba | 1977 | Mercedes | Yellow |
2afc659a | 1963 | Audi | Red |
2cd80027 | 1973 | Audi | Black |
b63338ea | 1994 | Volkswagen | Green |
b9543052 | 1962 | Fiat | Red |
5d0552c8 | 2002 | Volvo | Green |
b4093a38 | 2006 | Mercedes | Maroon |
8043f2f9 | 2006 | Volkswagen | Blue |
062f1205 | 1965 | Jaguar | Maroon |
5b2d1806 | 1980 | Volkswagen | Orange |
b23d1f9e | 1987 | BMW | Black |
aca4e81d | 1960 | Ford | Red |
6704d9c4 | 1997 | Renault | Silver |
eaea7604 | 1981 | BMW | Yellow |
f460dc92 | 1968 | Volvo | Silver |
5395f7af | 2005 | Ford | White |
7577c7a0 | 1989 | Mercedes | Yellow |
2384d016 | 2008 | Honda | Brown |
1739df02 | 2002 | BMW | Brown |
5bede90b | 1985 | Honda | Black |
6b3a5936 | 1979 | Audi | Maroon |
178e3d1c | 2004 | Honda | Orange |
b24d3cdb | 1963 | Mercedes | Red |
b57bd937 | 1983 | Renault | Green |
d53b114c | 1969 | Ford | Yellow |
<p:dataTable var="car" value="#{dtStickyView.cars}" stickyHeader="true" stickyTopAt=".layout-topbar"> <p:column headerText="Id"> <h:outputText value="#{car.id}" /> </p:column> <p:column headerText="Year"> <h:outputText value="#{car.year}" /> </p:column> <p:column headerText="Brand"> <h:outputText value="#{car.brand}" /> </p:column> <p:column headerText="Color"> <h:outputText value="#{car.color}" /> </p:column> </p:dataTable>
@Named("dtStickyView") @RequestScoped public class StickyView implements Serializable { private List<Car> cars; @Inject private CarService service; @PostConstruct public void init() { cars = service.createCars(50); } public List<Car> getCars() { return cars; } public void setService(CarService service) { this.service = service; } }
@Named @ApplicationScoped public class CarService { private final static String[] colors; private final static String[] brands; static { colors = new String[10]; colors[0] = "Black"; colors[1] = "White"; colors[2] = "Green"; colors[3] = "Red"; colors[4] = "Blue"; colors[5] = "Orange"; colors[6] = "Silver"; colors[7] = "Yellow"; colors[8] = "Brown"; colors[9] = "Maroon"; brands = new String[10]; brands[0] = "BMW"; brands[1] = "Mercedes"; brands[2] = "Volvo"; brands[3] = "Audi"; brands[4] = "Renault"; brands[5] = "Fiat"; brands[6] = "Volkswagen"; brands[7] = "Honda"; brands[8] = "Jaguar"; brands[9] = "Ford"; } public List<Car> createCars(int size) { List<Car> list = new ArrayList<Car>(); for(int i = 0 ; i < size ; i++) { list.add(new Car(getRandomId(), getRandomBrand(), getRandomYear(), getRandomColor(), getRandomPrice(), getRandomSoldState())); } return list; } private String getRandomId() { return UUID.randomUUID().toString().substring(0, 8); } private int getRandomYear() { return (int) (Math.random() * 50 + 1960); } private String getRandomColor() { return colors[(int) (Math.random() * 10)]; } private String getRandomBrand() { return brands[(int) (Math.random() * 10)]; } private int getRandomPrice() { return (int) (Math.random() * 100000); } private boolean getRandomSoldState() { return (Math.random() > 0.5) ? true: false; } public List<String> getColors() { return Arrays.asList(colors); } public List<String> getBrands() { return Arrays.asList(brands); } }