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

org.netbeans.spi.palette.PaletteActions 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.netbeans.spi.palette;

import javax.swing.Action;
import org.openide.util.Lookup;

/**
 * 

An interface implemented by palette clients to provide custom actions * for popup menus and actions for import of new items.

* * @author S. Aubrecht. */ public abstract class PaletteActions { /** * @return An array of action that will be used to construct buttons for import * of new palette item in palette manager window. * */ public abstract Action[] getImportActions(); /** * @return Custom actions to be added to the top of palette's default popup menu. */ public abstract Action[] getCustomPaletteActions(); /** * @param category Lookup representing palette's category. * * @return Custom actions to be added to the top of default popup menu for the given category. */ public abstract Action[] getCustomCategoryActions( Lookup category ); /** * @param item Lookup representing palette's item. * * @return Custom actions to be added to the top of the default popup menu for the given palette item. */ public abstract Action[] getCustomItemActions( Lookup item ); /** * @param item Lookup representing palette's item. * * @return An action to be invoked when user double-clicks the item in the * palette (e.g. insert item at editor's default location). * Return null to disable preferred action for this item. */ public abstract Action getPreferredAction( Lookup item ); /** * An action that will be invoked as part of the palette refresh logic, * for example when user chooses "Refresh" in palette's popup menu. Can be null. * The action properties (label, icon) are not displayed to the user, the Palette module * will provide its own. * @return Custom refresh action or null. * @since 1.9 */ public Action getRefreshAction() { return null; } /** * An action that resets the palette content to its default state. The action can be * invoked by the user from palette's popup menu for from the Palette Manager window. * The action properties (label, icon) are not displayed to the user, the Palette module * provides its own. * @return Custom reset action or null to use the default one that removes all user's * modifications to the XML layer files. * @since 1.11 */ public Action getResetAction() { return null; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy