transfersettingspreference.java

来自「开源项目openfire的完整源程序」· Java 代码 · 共 121 行

JAVA
121
字号
package org.jivesoftware.spark.plugins.transfersettings;

import org.jivesoftware.spark.preference.Preference;
import org.jivesoftware.spark.preference.PreferenceManager;
import org.jivesoftware.spark.plugins.transfersettings.FileTransferSettings;
import org.jivesoftware.spark.plugins.transfersettings.TransferSettingsPanel;

import javax.swing.Icon;
import javax.swing.ImageIcon;

/**
 * Preference object for file transfer settings. Used by Spark to show the associated UI and commit changes to preference settings.
 */
public class TransferSettingsPreference implements Preference {
    private TransferSettingsPanel gui = new TransferSettingsPanel();
    private FileTransferSettings settings = new FileTransferSettings();

    /**
     * Called when preference settings should be persisted.
     */
    public void commit() {
        gui.storeSettings(settings);
        settings.store();
    }

    /**
     * Returns the underlying data object. In this case it is a {@link FileTransferSettings} instance.
     *
     * @return object data
     */
    public Object getData() {
        return settings;
    }

    /**
     * Returns an error message to display if calls to {@link #isDataValid} return false.
     *
     * @return an error message to display if calls to {@link #isDataValid} return false.
     */
    public String getErrorMessage() {
        return "What happend here?";
    }

    /**
     * Returns the GUI for setting and viewing preference settings.
     *
     * @return the GUI for setting and viewing preference settings.
     */
    public javax.swing.JComponent getGUI() {
        gui.applySettings(settings);
        return gui;
    }

    /**
     * Returns the {@link Icon} to show in the preferences ui.
     *
     * @return the {@link Icon} to show in the preferences ui.
     */
    public javax.swing.Icon getIcon() {
        return new ImageIcon(getClass().getResource("/images/knight.png"));
    }

    /**
     * Returns the name displayed in the list of preferences.
     *
     * @return the name displayed in the list of preferences.
     */
    public String getListName() {
        return "Transfer Guard";
    }

    /**
     * Returns the key to retrive this instance from the {@link PreferenceManager}.
     *
     * @return the key to retrive this instance from the {@link PreferenceManager}.
     */
    public String getNamespace() {
        return "transferSettings";
    }

    /**
     * Returns the title of the preference panel for this preference.
     *
     * @return the title of the preference panel for this preference.
     */
    public String getTitle() {
        return "File Transfer Settings";
    }

    /**
     * Returns the tooltip text to display in the preferences list.
     *
     * @return the tooltip text to display in the preferences list.
     */
    public String getTooltip() {
        return "Configure allowed file transfer types, sizes, and senders";
    }

    /**
     * Returns true if the supplied preference settings are valid. If not, an associated error message
     * can be retrieved by a call to {@link #getErrorMessage}. This implementation always returns true.
     *
     * @return true.
     */
    public boolean isDataValid() {
        return true;
    }

    /**
     * Called when data should be loaded from the persistent stor.
     */
    public void load() {
        settings.load();
    }

    /**
     * Called when the application shuts down.
     */
    public void shutdown() {
    }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?