org.datacleaner.widgets.properties.AbstractPropertyWidget Maven / Gradle / Ivy
/**
* DataCleaner (community edition)
* Copyright (C) 2014 Neopost - Customer Information Management
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.datacleaner.widgets.properties;
import java.awt.Component;
import java.awt.GridLayout;
import java.awt.LayoutManager;
import javax.swing.JComponent;
import javax.swing.border.Border;
import org.datacleaner.descriptors.ConfiguredPropertyDescriptor;
import org.datacleaner.job.builder.ComponentBuilder;
import org.datacleaner.panels.DCPanel;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Abstract implementation of the PropertyWidget interface. An implementing
* class should preferably:
*
*
* - add(...) a single widget in the constructor.
* - call fireValueChanged() each time the contents/value of the widget has
* changed.
*
*
* @param
*/
public abstract class AbstractPropertyWidget extends MinimalPropertyWidget {
private static final Logger logger = LoggerFactory.getLogger(AbstractPropertyWidget.class);
private final DCPanel _panel;
// counter which is used to indicate whether a "UI batchupdate" is running
// or not". Subclasses can fire batch
private volatile int _batchUpdateCounter;
public AbstractPropertyWidget(ComponentBuilder componentBuilder,
ConfiguredPropertyDescriptor propertyDescriptor) {
super(componentBuilder, propertyDescriptor);
_batchUpdateCounter = 0;
_panel = new DCPanel() {
private static final long serialVersionUID = 1L;
public void addNotify() {
super.addNotify();
onPanelAdd();
};
public void removeNotify() {
super.removeNotify();
onPanelRemove();
};
};
setLayout(new GridLayout(1, 1));
}
/**
* Executes a "widget batch update". Listeners and other effects of updating
* individual parts of a widget may be turned off during batch updates.
*
* @param action
* the action to execute
*/
public final void batchUpdateWidget(Runnable action) {
_batchUpdateCounter++;
try {
action.run();
} catch (RuntimeException e) {
logger.error("Exception occurred in widget batch update, fireValueChanged() will not be invoked", e);
throw e;
} finally {
_batchUpdateCounter--;
}
if (_batchUpdateCounter == 0) {
onBatchFinished();
}
}
protected void onBatchFinished() {
fireValueChanged();
}
public final boolean isBatchUpdating() {
return _batchUpdateCounter > 0;
}
protected void setLayout(LayoutManager layout) {
_panel.setLayout(layout);
}
protected void removeAll() {
_panel.removeAll();
}
/**
* Notification method added for backwards compatibility
*
* @deprecated use {@link #onPanelRemove()} instead.
*/
@Deprecated
protected void removeNotify() {
}
/**
* Notification method added for backwards compatibility
*
* @deprecated use {@link #onPanelAdd()} instead.
*/
@Deprecated
protected void addNotify() {
}
/**
* Notification method invoked when the resulting panel is added to the UI.
*/
protected void onPanelAdd() {
addNotify();
}
/**
* Notification method invoked when the resulting panel is removed from the
* UI.
*/
protected void onPanelRemove() {
removeNotify();
}
protected void add(Component component, int index) {
if (_panel.getComponentCount() <= index) {
_panel.add(component);
} else {
_panel.add(component, index);
}
}
protected Component[] getComponents() {
return _panel.getComponents();
}
protected void add(Component component) {
_panel.add(component);
}
protected void add(Component component, Object constraints) {
_panel.add(component, constraints);
}
protected void remove(Component component) {
_panel.remove(component);
}
protected void updateUI() {
_panel.updateUI();
}
protected void setBorder(Border border) {
_panel.setBorder(border);
}
@Override
public final JComponent getWidget() {
return _panel;
}
/**
* Determines if the widget is currently visible.
*
* @return
*/
protected boolean isVisible() {
return _panel.isVisible();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy