/* * 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.DynamicColumn; /** * Represents a column resize event. */ public class ColumnResizeEvent extends GwtEvent<ColumnResizeEvent.Handler> { public static interface Handler extends EventHandler { void onColumnResize( ColumnResizeEvent event ); } public static final Type<Handler> TYPE = new Type<Handler>(); private final DynamicColumn<?> column; private final int width; /** * Creates a value change event. * @param column The column on which the resize event was triggered * @param width The new width of the column */ public ColumnResizeEvent( DynamicColumn<?> column, int width ) { if ( column == null ) { throw new IllegalArgumentException( "column cannot be null" ); } this.column = column; this.width = width; } /** * Gets the column to which the resize event relates. * @return the column */ public DynamicColumn<?> getColumn() { return this.column; } /** * Gets the width of the column * @return the width */ public int getWidth() { return this.width; } @Override public Type<Handler> getAssociatedType() { return TYPE; } @Override protected void dispatch( ColumnResizeEvent.Handler handler ) { handler.onColumnResize( this ); } }