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

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