All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.holonplatform.vaadin.components.ItemListing Maven / Gradle / Ivy

There is a newer version: 5.4.0
Show newest version
/*
 * Copyright 2016-2017 Axioma srl.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.holonplatform.vaadin.components;

import java.io.Serializable;
import java.util.List;
import java.util.Optional;

import com.holonplatform.vaadin.data.ItemDataSource.ItemSort;
import com.vaadin.shared.MouseEventDetails;
import com.vaadin.ui.Component;

/**
 * A component to display a set of items as tabular data, using item properties as column ids.
 * 
 * @param  Item data type
 * @param 

Item property type * * @since 5.0.0 */ public interface ItemListing extends ItemSet, Selectable, Component { /** * Gets the current displayed item properties as listing columns * @return Property columns list, in the order they are displayed */ List

getPropertyColumns(); /** * Show or hide the column bound to given property. * @param property Property to show or hide (not null) * @param visible true to show the column bound to given property, false to * hide it * @throws IllegalArgumentException If specified property is not bound to any column */ void setPropertyColumnVisible(P property, boolean visible); /** * Returns whether the listing footer is visible. * @return true if footer is visible, false otherwise */ boolean isFooterVisible(); /** * Sets whether the listing footer is visible. * @param visible true to set the footer visible, false otherwise */ void setFooterVisible(boolean visible); /** * Gets whether the row details component for given item is visible. * @param item Item to check whether the row details component is visible (not null) * @return true if row details component is visible for given item, false otherwise */ boolean isItemDetailsVisible(T item); /** * Set whether to show the row details component for given item. * @param item Item for which to show or hide the row details (not null) * @param visible true to show the row details component, false to hide it * @throws UnsupportedOperationException If the concrete listing component does not support a row details component */ void setItemDetailsVisible(T item, boolean visible) throws UnsupportedOperationException; /** * Scrolls listing viewport to show the given item, if present. *

* This operation is available only in buffered mode. *

* @param item Item to scroll to (not null) * @throws NotBufferedException If the listing is not in buffered mode * @see #isBuffered() */ void scrollToItem(T item); /** * Scrolls listing viewport to show the item at given index, if present. * @param index zero based index of the item to scroll to in the current viewport. */ void scrollToIndex(int index); /** * Scrolls listing rows to top (i.e. to the first row, if any) */ void scrollToTop(); /** * Scrolls to the end of the last data row. */ void scrollToEnd(); /** * Sort the listing using given {@link ItemSort} directives. * @param sorts Item sorts to apply */ @SuppressWarnings("unchecked") void sort(ItemSort

... sorts); /** * When in buffered mode, clear the buffered items in the internal cache. *

* When not in buffered mode, simply reset the selection, if the listing is slectable. *

* @see #isBuffered() */ void clear(); /** * Set the listing selection mode * @param selectionMode The selection mode to set (not null) */ void setSelectionMode(SelectionMode selectionMode); /** * Select all available items. */ void selectAll(); /** * Sets whether it's allowed to deselect the selected row through the UI. Deselection is allowed by default. * @param deselectAllowed true if the selected row can be deselected without selecting another row * instead; otherwise false. */ void setDeselectAllowed(boolean deselectAllowed); /** * Gets whether it's allowed to deselect the selected row through the UI. * @return true if deselection is allowed; otherwise false */ boolean isDeselectAllowed(); /** * Get the item identified by given itemId. *

* This operation is available only in buffered mode. *

* @param itemId Item id (not null) * @return Optional item identified by given itemId, empty if not found * @throws NotBufferedException If the listing is not in buffered mode * @see #isBuffered() */ Optional getItem(Object itemId); /** * Adds an item to the data source. * @param item The item to add (not null) * @return Id of the added item */ Object addItem(T item); /** * Removes given item from the data source. * @param item Item to remove (not null) * @return true if the item was successfully removed from data source */ boolean removeItem(T item); /** * Refresh given item in data source * @param item Item to refresh (not null) * @throws UnsupportedOperationException If the refresh operation is not supported by concrete data store */ void refreshItem(T item); /** * Updates all changes since the previous commit. *

* This operation is available only in buffered mode. *

* @throws NotBufferedException If the listing is not in buffered mode * @see #isBuffered() */ void commit(); /** * Discards all changes since last commit. *

* This operation is available only in buffered mode. *

* @throws NotBufferedException If the listing is not in buffered mode * @see #isBuffered() */ void discard(); /** * Get whether the listing is in buffered mode, i.e. an internal item cache is used. * @return whether the listing is in buffered mode */ boolean isBuffered(); /** * Set whether the listing is editable by the user. * @param editable true to set the listing as editable, false otherwise */ void setEditable(boolean editable); /** * Get whether the listing is editable by the user. * @return true if the listing is editable, false otherwise */ boolean isEditable(); /** * Opens the editor interface for the provided row. Scrolls the listing to bring the row to view if it is not * already visible. * @param rowNumber the row number of the edited item * @throws IllegalStateException if the editor is not enabled or already editing a different item in buffered mode * @throws IllegalArgumentException if the rowNumber is not in the backing data provider */ void editRow(int rowNumber); /** * If the listing {@link #isEditable()} adn the item editor is open, closes the editor discarding any unsaved * changes. * @throws IllegalStateException If the listing is not editable */ void cancelEditing(); // ------- /** * Enumeration of column content alignment options */ public enum ColumnAlignment { /** * Left aligned column content */ LEFT, /** * Centered column content */ CENTER, /** * Right aligned column content */ RIGHT; } /** * Generator to provide the style names for a cell. * @param Item type * @param

Item property type */ @FunctionalInterface public interface CellStyleGenerator extends Serializable { /** * Get the style names for the cell bound to given property column and item row. * @param property Cell property (column) * @param item Item bound to the row for which to generate the cell style * @return Cell style names, null for none */ String getCellStyle(P property, T item); } /** * Generator to provide the style names for an item row. * @param Item type */ @FunctionalInterface public interface RowStyleGenerator extends Serializable { /** * Get the style names for the row bound to given item. * @param item Item bound to the row for which to generate the style * @return Row style names, null for none */ String getRowStyle(T item); } /** * Listener for user click events on an item (a listing row). * @param Item type * @param

Item property type */ @FunctionalInterface public interface ItemClickListener extends Serializable { /** * Triggered when user clicks on an item. * @param item Item bound to clicked row * @param clickedProperty Clicked column property * @param rowIndex The clicked row index * @param clickEvent Event details to obtain informations on mouse button and clicked point */ void onItemClick(T item, P clickedProperty, int rowIndex, MouseEventDetails clickEvent); /** * Triggered when user clicks on an item. * @param item Item bound to clicked row * @param clickedProperty Clicked column property * @param clickEvent Event details to obtain informations on mouse button and clicked point * @deprecated Use {@link #onItemClick(Object, Object, int, MouseEventDetails)} */ @Deprecated default void onItemClick(T item, P clickedProperty, MouseEventDetails clickEvent) { onItemClick(item, clickedProperty, -1, clickEvent); } } /** * Listener for column reordering events. */ @FunctionalInterface public interface PropertyReorderListener

extends Serializable { /** * Triggered when the columns order changes. * @param properties New columns order, expressed through a list of column properties * @param userOriginated true if the reordering event is originated from a user action */ void onPropertyReordered(List

properties, boolean userOriginated); } /** * Listener for column resizing events. */ @FunctionalInterface public interface PropertyResizeListener

extends Serializable { /** * Triggered when a column size changes. * @param property Property bound to resized column * @param widthInPixel New column with in pixels * @param userOriginated true if the resizing event is originated from a user action */ void onPropertyResized(P property, int widthInPixel, boolean userOriginated); } /** * Listener for column visibility change events. */ @FunctionalInterface public interface PropertyVisibilityListener

extends Serializable { /** * Triggered when a table columns visibility changes. * @param property Property bound to resized column * @param hidden New visibility state * @param userOriginated true if the event is originated from a user action */ void onPropertyVisibilityChanged(P property, boolean hidden, boolean userOriginated); } /** * Generator for item (row) details components. * @param Item type */ @FunctionalInterface public interface ItemDetailsGenerator extends Serializable { /** * Get the row details component for given item. * @param item Item bound to the row for which to generate the details component * @return Row details component */ Component getItemDetails(T item); } /** * Exception thrown when a listing operation is invoked and it is valid only in buffered mode. */ public class NotBufferedException extends RuntimeException { private static final long serialVersionUID = 6014290672296737254L; /** * Constructor * @param message Error message */ public NotBufferedException(String message) { super(message); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy