/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright 2013 Oracle and/or its affiliates. All rights reserved. * * Oracle and Java are registered trademarks of Oracle and/or its affiliates. * Other names may be trademarks of their respective owners. * * The contents of this file are subject to the terms of either the GNU * General Public License Version 2 only ("GPL") or the Common * Development and Distribution License("CDDL") (collectively, the * "License"). You may not use this file except in compliance with the * License. You can obtain a copy of the License at * http://www.netbeans.org/cddl-gplv2.html * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the * specific language governing permissions and limitations under the * License. When distributing the software, include this License Header * Notice in each file and include the License file at * nbbuild/licenses/CDDL-GPL-2-CP. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the GPL Version 2 section of the License file that * accompanied this code. If applicable, add the following below the * License Header, with the fields enclosed by brackets [] replaced by * your own identifying information: * "Portions Copyrighted [year] [name of copyright owner]" * * If you wish your version of this file to be governed by only the CDDL * or only the GPL Version 2, indicate your decision by adding * "[Contributor] elects to include this software in this distribution * under the [CDDL or GPL Version 2] license." If you do not indicate a * single choice of license, a recipient has the option to distribute * your version of this file under either the CDDL, the GPL Version 2 or * to extend the choice of license to its licensees as provided above. * However, if you add GPL Version 2 code and therefore, elected the GPL * Version 2 license, then the option applies only if the new code is * made subject to such option by the copyright holder. * * Contributor(s): * * Portions Copyrighted 2013 Sun Microsystems, Inc. */ package ca.weblite.netbeans.mirah.support.wizard; import java.awt.Component; import java.io.IOException; import java.util.List; import java.util.NoSuchElementException; import java.util.Set; import javax.swing.JComponent; import javax.swing.event.ChangeListener; import org.netbeans.api.project.Project; import org.netbeans.api.project.SourceGroup; import org.netbeans.spi.java.project.support.ui.templates.JavaTemplates; import org.netbeans.spi.project.ui.templates.support.Templates; import org.openide.WizardDescriptor; import org.openide.filesystems.FileObject; import org.openide.util.ChangeSupport; /** * Abstract file wizard iterator independent on any mirah related code. Implementor * should provide only the list of {@link SourceGroup} that he want to show in package * chooser. * * @author Martin Janicek */ public abstract class AbstractFileWizard implements WizardDescriptor.ProgressInstantiatingIterator { private static final long serialVersionUID = 1L; private final ChangeSupport changeSupport = new ChangeSupport(this); private transient int index; private transient WizardDescriptor.Panel[] panels; protected transient WizardDescriptor wiz; protected transient Project project; protected AbstractFileWizard() { } /** * List of {@link SourceGroup}s that should be shown in the wizard package chooser. * * @return list of {@link SourceGroup}s */ protected abstract List<SourceGroup> getSourceGroups(); @Override public void initialize(WizardDescriptor wiz) { this.wiz = wiz; this.project = Templates.getProject(wiz); index = 0; panels = createPanels(); // Make sure list of steps is accurate. String[] beforeSteps = null; Object prop = wiz.getProperty(WizardDescriptor.PROP_CONTENT_DATA); // NOI18N if (prop != null && prop instanceof String[]) { beforeSteps = (String[]) prop; } String[] steps = createSteps(beforeSteps, panels); for (int i = 0; i < panels.length; i++) { Component c = panels[i].getComponent(); if (steps[i] == null) { // Default step name to component name of panel. // Mainly useful for getting the name of the target // chooser to appear in the list of steps. steps[i] = c.getName(); } if (c instanceof JComponent) { // assume Swing components JComponent jc = (JComponent) c; // Step #. jc.putClientProperty(WizardDescriptor.PROP_CONTENT_SELECTED_INDEX, Integer.valueOf(i)); // NOI18N // Step name (actually the whole list for reference). jc.putClientProperty(WizardDescriptor.PROP_CONTENT_DATA, steps); // NOI18N } } } private WizardDescriptor.Panel[] createPanels() { return new WizardDescriptor.Panel[] { JavaTemplates.createPackageChooser(project, sourceGroupToArray(getSourceGroups())) }; } protected final SourceGroup[] sourceGroupToArray(List<SourceGroup> groups) { return groups.toArray(new SourceGroup[groups.size()]); } private String[] createSteps(String[] before, WizardDescriptor.Panel[] panels) { assert panels != null; // hack to use the steps set before this panel processed int diff = 0; if (before == null) { before = new String[0]; } else if (before.length > 0) { diff = ("...".equals(before[before.length - 1])) ? 1 : 0; // NOI18N } String[] res = new String[ (before.length - diff) + panels.length]; for (int i = 0; i < res.length; i++) { if (i < (before.length - diff)) { res[i] = before[i]; } else { res[i] = panels[i - before.length + diff].getComponent().getName(); } } return res; } @Override public Set<FileObject> instantiate() throws IOException { assert false : "This method cannot be called if the class implements WizardDescriptor.ProgressInstantiatingIterator."; return null; } @Override public void uninitialize(WizardDescriptor wiz) { this.wiz = null; panels = null; } @Override public String name() { return ""; // NOI18N } @Override public boolean hasNext() { return index < panels.length - 1; } @Override public boolean hasPrevious() { return index > 0; } @Override public void nextPanel() { if (!hasNext()) { throw new NoSuchElementException(); } index++; } @Override public void previousPanel() { if (!hasPrevious()) { throw new NoSuchElementException(); } index--; } @Override public WizardDescriptor.Panel current() { return panels[index]; } @Override public final void addChangeListener(ChangeListener l) { changeSupport.addChangeListener(l); } @Override public final void removeChangeListener(ChangeListener l) { changeSupport.removeChangeListener(l); } protected final void fireChangeEvent() { changeSupport.fireChange(); } }