org.openide.nodes.NodeOperation Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.openide.nodes;
import org.openide.util.Lookup;
import org.openide.util.UserCancelException;
import java.awt.Component;
import javax.swing.*;
/** Provides common operations on nodes.
* Any component may
* ask to open a customizer for, or explore, any node.
* @since 3.14
*/
public abstract class NodeOperation {
/** Subclass constructor. */
protected NodeOperation() {
}
/** Get default instance from lookup.
* @return some instance
*/
public static NodeOperation getDefault() {
NodeOperation no = Lookup.getDefault().lookup(NodeOperation.class);
if (no == null) {
throw new IllegalStateException(
"To use NodeOperation you should have its implementation around. For example one from openide-explorer.jar" // NOI18N
);
}
return no;
}
/** Tries to open a customization dialog for the specified node.
* The dialog is
* modal and the function returns only after
* customization is finished, if it was possible.
*
* @param n the node to customize
* @return true
if the node had a customizer,
* false
if not
* @see Node#hasCustomizer
* @see Node#getCustomizer
*/
public abstract boolean customize(Node n);
/** Explore a node (and its subhierarchy).
* It will be opened in a new Explorer view, as the root node of that window.
* @param n the node to explore
*/
public abstract void explore(Node n);
/** Open a modal Property Sheet on a node.
* @param n the node to show properties of
*/
public abstract void showProperties(Node n);
/** Open a modal Property Sheet on a set of nodes.
* @param n the array of nodes to show properties of
* @see #showProperties(Node)
*/
public abstract void showProperties(Node[] n);
/**
* Shows a modal dialog with the custom editor of given property, just like
* it would be invoked when clicking the [...] button next to a property in
* the property sheet. The property value is updated if the dialog is
* successfully closed via the OK button.
* @param property The property to be edited (its property editor to be used).
* @param beans The objects the property belongs to. Typically one item
* array with the Node of the property. The meaning is the same as in
* PropertyEnv#getBeans().
* @since 7.24
*/
public void showCustomEditorDialog(Node.Property> property, Object... beans) {
throw new UnsupportedOperationException();
}
/** Open a modal Explorer on a root node, permitting a node selection to be returned.
* The acceptor
* should be asked each time the set of selected nodes changes, whether to accept or
* reject the current result. This will affect for example the
* display of the "OK" button.
*
* @param title title of the dialog
* @param rootTitle label at root of dialog. May use &
for a {@link javax.swing.JLabel#setDisplayedMnemonic(int) mnemonic}.
* @param root root node to explore
* @param acceptor class asked to accept or reject current selection
* @param top an extra component to be placed on the dialog (may be null
)
* @return an array of selected (and accepted) nodes
*
* @exception UserCancelException if the selection is interrupted by the user
*/
public abstract Node[] select(String title, String rootTitle, Node root, NodeAcceptor acceptor, Component top)
throws UserCancelException;
/** Open a modal Explorer without any extra dialog component.
* @param title title of the dialog
* @param rootTitle label at root of dialog. May use &
for a {@link javax.swing.JLabel#setDisplayedMnemonic(int) mnemonic}.
* @param root root node to explore
* @param acceptor class asked to accept or reject current selection
* @return an array of selected (and accepted) nodes
*
* @exception UserCancelException if the selection is interrupted by the user
* @see #select(String, String, Node, NodeAcceptor, Component)
*/
public Node[] select(String title, String rootTitle, Node root, NodeAcceptor acceptor)
throws UserCancelException {
return select(title, rootTitle, root, acceptor, null);
}
/** Open a modal Explorer accepting only a single node.
* @param title title of the dialog
* @param rootTitle label at root of dialog. May use &
for a {@link javax.swing.JLabel#setDisplayedMnemonic(int) mnemonic}.
* @param root root node to explore
* @return the selected node
*
* @exception UserCancelException if the selection is interrupted by the user
* @see #select(String, String, Node, NodeAcceptor)
*/
public final Node select(String title, String rootTitle, Node root)
throws UserCancelException {
return select(
title, rootTitle, root,
new NodeAcceptor() {
public boolean acceptNodes(Node[] nodes) {
return nodes.length == 1;
}
}
)[0];
}
}