Package org.objectstyle.wolips.eomodeler.editors.fetchspec

Source Code of org.objectstyle.wolips.eomodeler.editors.fetchspec.EOFetchSpecSQLEditorSection$StoredProcedureChangedHandler

/*
* ====================================================================
*
* The ObjectStyle Group Software License, Version 1.0
*
* Copyright (c) 2006 The ObjectStyle Group and individual authors of the
* software. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* 3. The end-user documentation included with the redistribution, if any, must
* include the following acknowlegement: "This product includes software
* developed by the ObjectStyle Group (http://objectstyle.org/)." Alternately,
* this acknowlegement may appear in the software itself, if and wherever such
* third-party acknowlegements normally appear.
*
* 4. The names "ObjectStyle Group" and "Cayenne" must not be used to endorse or
* promote products derived from this software without prior written permission.
* For written permission, please contact andrus@objectstyle.org.
*
* 5. Products derived from this software may not be called "ObjectStyle" nor
* may "ObjectStyle" appear in their names without prior written permission of
* the ObjectStyle Group.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* OBJECTSTYLE GROUP OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many individuals on
* behalf of the ObjectStyle Group. For more information on the ObjectStyle
* Group, please see <http://objectstyle.org/>.
*/
package org.objectstyle.wolips.eomodeler.editors.fetchspec;

import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;
import java.util.Iterator;

import org.eclipse.core.databinding.DataBindingContext;
import org.eclipse.core.databinding.beans.BeansObservables;
import org.eclipse.jface.databinding.swt.SWTObservables;
import org.eclipse.jface.viewers.ISelection;
import org.eclipse.jface.viewers.ISelectionChangedListener;
import org.eclipse.jface.viewers.IStructuredSelection;
import org.eclipse.jface.viewers.SelectionChangedEvent;
import org.eclipse.jface.viewers.StructuredSelection;
import org.eclipse.jface.viewers.TableViewer;
import org.eclipse.swt.SWT;
import org.eclipse.swt.events.SelectionEvent;
import org.eclipse.swt.events.SelectionListener;
import org.eclipse.swt.layout.FormLayout;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Text;
import org.eclipse.ui.IWorkbenchPart;
import org.eclipse.ui.views.properties.tabbed.AbstractPropertySection;
import org.eclipse.ui.views.properties.tabbed.TabbedPropertySheetPage;
import org.objectstyle.wolips.baseforplugins.util.ComparisonUtils;
import org.objectstyle.wolips.eomodeler.Messages;
import org.objectstyle.wolips.eomodeler.core.model.EOFetchSpecification;
import org.objectstyle.wolips.eomodeler.core.model.EOModel;
import org.objectstyle.wolips.eomodeler.core.model.EOStoredProcedure;
import org.objectstyle.wolips.eomodeler.editors.storedProcedures.EOStoredProceduresConstants;
import org.objectstyle.wolips.eomodeler.editors.storedProcedures.EOStoredProceduresContentProvider;
import org.objectstyle.wolips.eomodeler.utils.FormUtils;
import org.objectstyle.wolips.eomodeler.utils.TablePropertyLabelProvider;
import org.objectstyle.wolips.eomodeler.utils.TablePropertyViewerSorter;
import org.objectstyle.wolips.eomodeler.utils.TableRefreshPropertyListener;
import org.objectstyle.wolips.eomodeler.utils.TableUtils;

public class EOFetchSpecSQLEditorSection extends AbstractPropertySection implements ISelectionChangedListener, SelectionListener {
  private EOFetchSpecification _fetchSpecification;

  private Text _rawSQLText;

  private TableViewer _storedProcedureTableViewer;

  private TableRefreshPropertyListener _storedProcedureChangedRefresher;

  private StoredProcedureChangedHandler _storedProcedureChangedHandler;

  private Button _useQualifierButton;

  private Button _useRawSQLButton;

  private Button _useStoredProcedureButton;

  private DataBindingContext _bindingContext;

  public EOFetchSpecSQLEditorSection() {
    _storedProcedureChangedHandler = new StoredProcedureChangedHandler();
  }
 
  @Override
  public boolean shouldUseExtraSpace() {
    return true;
  }

  public void createControls(Composite parent, TabbedPropertySheetPage tabbedPropertySheetPage) {
    super.createControls(parent, tabbedPropertySheetPage);
    Composite form = getWidgetFactory().createFlatFormComposite(parent);
    FormLayout formLayout = new FormLayout();
    form.setLayout(formLayout);

    Composite topForm = FormUtils.createForm(getWidgetFactory(), form, 1);

    _useQualifierButton = new Button(topForm, SWT.RADIO);
    _useQualifierButton.setText(Messages.getString("EOFetchSpecSQLEditorSection.useQualifier")); //$NON-NLS-1$
    _useRawSQLButton = new Button(topForm, SWT.RADIO);
    _useRawSQLButton.setText(Messages.getString("EOFetchSpecSQLEditorSection.useRawSQL")); //$NON-NLS-1$

    _rawSQLText = new Text(topForm, SWT.BORDER);
    GridData nameLayoutData = new GridData(GridData.FILL_HORIZONTAL);
    _rawSQLText.setLayoutData(nameLayoutData);

    _useStoredProcedureButton = new Button(topForm, SWT.RADIO);
    _useStoredProcedureButton.setText(Messages.getString("EOFetchSpecSQLEditorSection.useStoredProcedure")); //$NON-NLS-1$

    _storedProcedureTableViewer = TableUtils.createTableViewer(topForm, "EOStoredProcedure", EOStoredProceduresConstants.COLUMNS, new EOStoredProceduresContentProvider(), new TablePropertyLabelProvider(EOStoredProceduresConstants.COLUMNS), new TablePropertyViewerSorter(EOStoredProceduresConstants.COLUMNS));
    GridData rawRowKeyPathsTableLayoutData = new GridData(GridData.FILL_BOTH);
    rawRowKeyPathsTableLayoutData.heightHint = 100;
    _storedProcedureTableViewer.getTable().setLayoutData(rawRowKeyPathsTableLayoutData);
    _storedProcedureTableViewer.addSelectionChangedListener(this);
    _storedProcedureChangedRefresher = new TableRefreshPropertyListener("StoredProcedureChanged", _storedProcedureTableViewer);
  }

  public void setInput(IWorkbenchPart part, ISelection selection) {
    if (ComparisonUtils.equals(selection, getSelection())) {
      return;
    }
   
    super.setInput(part, selection);
    disposeBindings();

    Object selectedObject = ((IStructuredSelection) selection).getFirstElement();
    _fetchSpecification = (EOFetchSpecification) selectedObject;
    if (_fetchSpecification != null) {
      addBindings();
      _storedProcedureTableViewer.setInput(_fetchSpecification);
      TableUtils.packTableColumns(_storedProcedureTableViewer);
      updateButtonsEnabled();
    }
  }

  protected void addBindings() {
    if (_fetchSpecification != null) {
      _bindingContext = new DataBindingContext();
      _bindingContext.bindValue(SWTObservables.observeText(_rawSQLText, SWT.Modify), BeansObservables.observeValue(_fetchSpecification, EOFetchSpecification.CUSTOM_QUERY_EXPRESSION), null, null);
      _fetchSpecification.getEntity().getModel().addPropertyChangeListener(EOModel.STORED_PROCEDURES, _storedProcedureChangedRefresher);
      _fetchSpecification.getEntity().getModel().addPropertyChangeListener(EOModel.STORED_PROCEDURE, _storedProcedureChangedRefresher);
      _fetchSpecification.addPropertyChangeListener(EOFetchSpecification.STORED_PROCEDURE, _storedProcedureChangedHandler);
      _fetchSpecification.addPropertyChangeListener(EOFetchSpecification.CUSTOM_QUERY_EXPRESSION, _storedProcedureChangedHandler);
    }
  }

  protected void disposeBindings() {
    if (_bindingContext != null) {
      _bindingContext.dispose();
    }
    if (_fetchSpecification != null) {
      _fetchSpecification.getEntity().getModel().removePropertyChangeListener(EOModel.STORED_PROCEDURES, _storedProcedureChangedRefresher);
      _fetchSpecification.getEntity().getModel().removePropertyChangeListener(EOModel.STORED_PROCEDURE, _storedProcedureChangedRefresher);
      _fetchSpecification.removePropertyChangeListener(EOFetchSpecification.STORED_PROCEDURE, _storedProcedureChangedHandler);
      _fetchSpecification.removePropertyChangeListener(EOFetchSpecification.CUSTOM_QUERY_EXPRESSION, _storedProcedureChangedHandler);
    }
  }

  protected void removeButtonListeners() {
    _useQualifierButton.removeSelectionListener(this);
    _useRawSQLButton.removeSelectionListener(this);
    _useStoredProcedureButton.removeSelectionListener(this);
  }

  protected void addButtonListeners() {
    _useQualifierButton.addSelectionListener(this);
    _useRawSQLButton.addSelectionListener(this);
    _useStoredProcedureButton.addSelectionListener(this);
  }

  public void dispose() {
    super.dispose();
    disposeBindings();
  }

  public void widgetDefaultSelected(SelectionEvent event) {
    widgetSelected(event);
  }

  public void widgetSelected(SelectionEvent event) {
    Button source = (Button) event.getSource();
    if (source.getSelection()) {
      disposeBindings();
      if (source == _useQualifierButton) {
        _fetchSpecification.useQualifier();
      } else if (source == _useRawSQLButton) {
        _fetchSpecification.useCustomQueryExpression();
      } else if (source == _useStoredProcedureButton) {
        Iterator storedProceduresIter = _fetchSpecification.getEntity().getModel().getStoredProcedures().iterator();
        if (storedProceduresIter.hasNext()) {
          EOStoredProcedure storedProcedure = (EOStoredProcedure) storedProceduresIter.next();
          _fetchSpecification.setStoredProcedure(storedProcedure);
        }
      }
      updateButtonsEnabled();
      addBindings();
    }
  }

  public void updateButtonsEnabled() {
    removeButtonListeners();
    _useQualifierButton.setSelection(_fetchSpecification.isUsingQualifier());
    _useRawSQLButton.setSelection(_fetchSpecification.isUsingCustomQuery());
    _useStoredProcedureButton.setSelection(_fetchSpecification.isUsingStoredProcedure());
    _rawSQLText.setEnabled(_fetchSpecification.isUsingCustomQuery());
    if (!_fetchSpecification.isUsingStoredProcedure() && !_storedProcedureTableViewer.getSelection().isEmpty()) {
      _storedProcedureTableViewer.setSelection(new StructuredSelection());
      _storedProcedureTableViewer.getTable().setEnabled(false);
    } else if (_fetchSpecification.isUsingStoredProcedure()) {
      _storedProcedureTableViewer.getTable().setEnabled(true);
      _storedProcedureTableViewer.setSelection(new StructuredSelection(_fetchSpecification.getStoredProcedure()));
    }
    addButtonListeners();
  }

  public void selectionChanged(SelectionChangedEvent event) {
    IStructuredSelection selection = (IStructuredSelection) event.getSelection();
    EOStoredProcedure storedProcedure = (EOStoredProcedure) selection.getFirstElement();
    _fetchSpecification.setStoredProcedure(storedProcedure);
  }

  protected class StoredProcedureChangedHandler implements PropertyChangeListener {
    public void propertyChange(PropertyChangeEvent event) {
      EOFetchSpecSQLEditorSection.this.updateButtonsEnabled();
    }
  }
}
TOP

Related Classes of org.objectstyle.wolips.eomodeler.editors.fetchspec.EOFetchSpecSQLEditorSection$StoredProcedureChangedHandler

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.