/* * Copyright 2012 Red Hat, Inc. and/or its affiliates. * * 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 org.kie.workbench.common.widgets.decoratedgrid.client.widget.events; import com.google.gwt.event.shared.EventHandler; import com.google.gwt.event.shared.GwtEvent; import org.kie.workbench.common.widgets.decoratedgrid.client.widget.AbstractMergableGridWidget; /** * Represents a change in the selected cell. */ public class SelectedCellChangeEvent extends GwtEvent<SelectedCellChangeEvent.Handler> { public static interface Handler extends EventHandler { void onSelectedCellChange( SelectedCellChangeEvent event ); } public static Type<Handler> TYPE = new Type<Handler>(); private AbstractMergableGridWidget.CellSelectionDetail cellDetails; /** * Creates a cell selection event for no selection */ public SelectedCellChangeEvent() { } /** * Creates a cell selection event * @param cellExtents details of selected cell */ public SelectedCellChangeEvent( AbstractMergableGridWidget.CellSelectionDetail cellDetails ) { if ( cellDetails == null ) { throw new IllegalArgumentException( "cellDetails cannot be null" ); } this.cellDetails = cellDetails; } /** * Gets the details of the selected cell * @return the details */ public AbstractMergableGridWidget.CellSelectionDetail getCellSelectionDetail() { return this.cellDetails; } @Override public final Type<Handler> getAssociatedType() { return TYPE; } @Override protected void dispatch( SelectedCellChangeEvent.Handler handler ) { handler.onSelectedCellChange( this ); } }