|
What this is
Other links
The source code/* * Sun Public License Notice * * The contents of this file are subject to the Sun Public License * Version 1.0 (the "License"). You may not use this file except in * compliance with the License. A copy of the License is available at * http://www.sun.com/ * * The Original Code is NetBeans. The Initial Developer of the Original * Code is Sun Microsystems, Inc. Portions Copyright 1997-2000 Sun * Microsystems, Inc. All Rights Reserved. */ package org.netbeans.modules.editor.options; import java.awt.Component; import java.beans.*; import java.util.*; import javax.swing.event.*; import org.openide.util.HelpCtx; import org.openide.util.NbBundle; /** * KeyBindingsEditor is editor for MultiKeyBindings settings of Editor, * operates over java.util.List, where single MultiKeyBindings are stored. * First item in List (with index 0) is used for transferring kitClass. * * @author Petr Nejedly */ public class KeyBindingsEditor extends PropertyEditorSupport { private KeyBindingsEditorPanel editorPanel; private static final String HELP_ID = "editing.keybindings"; // !!! NOI18N protected HelpCtx getHelpCtx () { return new HelpCtx (HELP_ID); } /** * Tell the world that we have nice editor Component */ public boolean supportsCustomEditor() { return true; } /** * Create custom editor tightly coupled with this editor */ public java.awt.Component getCustomEditor() { if( editorPanel == null ) { editorPanel = new KeyBindingsEditorPanel( this ); HelpCtx.setHelpIDString( editorPanel, getHelpCtx().getHelpID() ); } refreshEditor(); return editorPanel; } private void refreshEditor() { if( editorPanel != null ) { editorPanel.setValue( (List)getValue() ); } } /** * Sets the value for editor / customEditor */ public void setValue( Object obj ) { Object oldValue = getValue(); if( (obj != null) && (! obj.equals( oldValue ) ) ) { super.setValue( obj ); if( ( editorPanel != null ) && (! editorPanel.getValue().equals( getValue() ) ) ) { refreshEditor(); } } } /** * The way our customEditor notifies us when user changes something. */ protected void customEditorChange() { // forward it to parent, which will fire propertyChange super.setValue( editorPanel.getValue() ); } /** * Return the label to be shown in the PropertySheet */ public String getAsText() { // return "KeyBindings"; return NbBundle.getBundle( KeyBindingsEditor.class ).getString( "PROP_KeyBindings" ); // NOI18N } /** * Don't bother if the user tried to edit our label in the PropertySheet */ public void setAsText( String s ) { } } |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2021 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.