123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252 |
- /*
- * Copyright (c) 2006-2010 Chris Smith, Shane Mc Cormack, Gregory Holmes
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
-
- package com.dmdirc.addons.ui_swing.components.expandingsettings;
-
- import com.dmdirc.config.Identity;
- import com.dmdirc.addons.ui_swing.components.text.TextLabel;
- import com.dmdirc.addons.ui_swing.UIUtilities;
-
- import java.util.LinkedHashMap;
- import java.util.Map;
- import java.util.Map.Entry;
-
- import javax.swing.BorderFactory;
- import javax.swing.JPanel;
- import javax.swing.JScrollPane;
-
- import javax.swing.UIManager;
- import net.miginfocom.swing.MigLayout;
-
- /**
- * Settings panel.
- */
- public final class SettingsPanel extends JPanel {
-
- /**
- * A version number for this class. It should be changed whenever the class
- * structure is changed (or anything else that would prevent serialized
- * objects being unserialized with the new class).
- */
- private static final long serialVersionUID = 2;
- /** Config manager. */
- private final transient Identity config;
-
- /** Valid option types. */
- public enum OptionType {
-
- /** Text field. */
- TEXTFIELD,
- /** Check box. */
- CHECKBOX,
- /** Colour chooser. */
- COLOUR,
- /** Number spinner. */
- SPINNER,
- /** Font picker. */
- FONT,
- /** Combo box. */
- COMBOBOX,
- }
-
- /** config option -> name. */
- private Map<String, String> names;
- /** config option -> type. */
- private Map<String, OptionType> types;
- /** Info label. */
- private TextLabel infoLabel;
- /** Current options panel. */
- private CurrentOptionsPanel currentOptionsPanel;
- /** Add option panel. */
- private AddOptionPanel addOptionPanel;
- /** Current options scroll pane. */
- private JScrollPane scrollPane;
-
- /**
- * Creates a new instance of SettingsPanel.
- *
- * @param config Config to use
- * @param infoText Info blurb.
- */
- public SettingsPanel(final Identity config, final String infoText) {
- super();
-
- this.setOpaque(UIUtilities.getTabbedPaneOpaque());
- this.config = config;
-
- initComponents(infoText);
- layoutComponents();
- }
-
- /**
- * Initialises the components.
- *
- * @param infoText Info blurb.
- */
- private void initComponents(final String infoText) {
- names = new LinkedHashMap<String, String>();
- types = new LinkedHashMap<String, OptionType>();
-
- infoLabel = new TextLabel(infoText);
-
- addOptionPanel =
- new AddOptionPanel(this);
- currentOptionsPanel =
- new CurrentOptionsPanel(this);
- scrollPane = new JScrollPane(currentOptionsPanel);
-
- scrollPane.setBorder(BorderFactory.createTitledBorder(UIManager.
- getBorder("TitledBorder.border"), "Current settings"));
- addOptionPanel.setBorder(BorderFactory.createTitledBorder(UIManager.
- getBorder("TitledBorder.border"), "Add new setting"));
-
- scrollPane.setOpaque(UIUtilities.getTabbedPaneOpaque());
- scrollPane.getViewport().setOpaque(UIUtilities.getTabbedPaneOpaque());
- }
-
- /**
- * Lays out the components.
- */
- private void layoutComponents() {
- setLayout(new MigLayout("fill, wrap 1"));
-
- add(infoLabel, "growx, pushx");
- add(scrollPane, "grow, push");
- add(addOptionPanel, "growx, pushx");
- }
-
- /**
- * Adds an option to the settings panel.
- *
- * @param optionName Option name
- * @param displayName Display name
- * @param type Option type
- */
- public void addOption(final String optionName,
- final String displayName,
- final OptionType type) {
- if (config == null) {
- return;
- }
-
- if (optionName.indexOf('.') == -1) {
- return;
- }
- final String[] splitOption = optionName.split("\\.");
-
- names.put(optionName, displayName);
- types.put(optionName, type);
-
- if (config.hasOptionString(splitOption[0], splitOption[1])) {
- addCurrentOption(optionName, type,
- config.getOption(splitOption[0], splitOption[1]));
- } else {
- addAddableOption(optionName);
- }
- }
-
- /** Updates the options. */
- public void update() {
- addOptionPanel.clearOptions();
- currentOptionsPanel.clearOptions();
-
- for (Entry<String, OptionType> entry : types.entrySet()) {
- final String[] splitOption = entry.getKey().split("\\.");
-
- if (config.hasOptionString(splitOption[0], splitOption[1])) {
- addCurrentOption(entry.getKey(), entry.getValue(),
- config.getOption(splitOption[0], splitOption[1]));
- } else {
- addAddableOption(entry.getKey());
- }
- }
- }
-
- /** Saves the options to the config. */
- public void save() {
- for (Entry<String, OptionType> entry : types.entrySet()) {
- final String value =
- currentOptionsPanel.getOption(entry.getKey(),
- entry.getValue());
- final String[] splitOption = entry.getKey().split("\\.");
- if (value == null) {
- config.unsetOption(splitOption[0], splitOption[1]);
- } else {
- config.setOption(splitOption[0], splitOption[1], value);
- }
- }
- }
-
- /**
- * Adds a current option.
- *
- * @param optionName option to add
- * @param type Option type
- * @param value Option value
- */
- protected void addCurrentOption(final String optionName,
- final OptionType type, final String value) {
- currentOptionsPanel.addOption(optionName, type, value);
- }
-
- /**
- * Deletes a current option.
- *
- * @param optionName Option to delete
- * @param type Option type
- */
- protected void removeCurrentOption(final String optionName,
- final OptionType type) {
- currentOptionsPanel.delOption(optionName, type);
- }
-
- /**
- * Adds an addable option.
- *
- * @param optionName Option name
- */
- protected void addAddableOption(final String optionName) {
- addOptionPanel.addOption(optionName);
- }
-
- /**
- * Returns the display name for a config option.
- *
- * @param optionName Option name to return the name for
- *
- * @return Display name for a specified option
- */
- public String getOptionName(final String optionName) {
- return names.get(optionName);
- }
-
- /**
- * Returns the option type for a config option.
- *
- * @param optionName Option name to return the type of
- *
- * @return Option type for a specified option
- */
- public OptionType getOptionType(final String optionName) {
- return types.get(optionName);
- }
- }
|