X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fde%2Ftodesbaum%2Fjsite%2Fgui%2FPreferencesPage.java;h=251358246611de90cbf0fea57aed8d6260b25db3;hb=6363a6f5355700aea01514c2558f670470dcda82;hp=a2a13b0a26ced9e5d925e263d768f8b0d7375475;hpb=0e816bbf447dcd5d37f083f28a510f9aafef23bb;p=jSite.git
diff --git a/src/de/todesbaum/jsite/gui/PreferencesPage.java b/src/de/todesbaum/jsite/gui/PreferencesPage.java
index a2a13b0..2513582 100644
--- a/src/de/todesbaum/jsite/gui/PreferencesPage.java
+++ b/src/de/todesbaum/jsite/gui/PreferencesPage.java
@@ -29,6 +29,7 @@ import javax.swing.AbstractAction;
import javax.swing.Action;
import javax.swing.ButtonGroup;
import javax.swing.JButton;
+import javax.swing.JFileChooser;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JRadioButton;
@@ -46,6 +47,12 @@ import de.todesbaum.util.swing.TWizardPage;
*/
public class PreferencesPage extends TWizardPage {
+ /** Select default temp directory action. */
+ private Action selectDefaultTempDirectoryAction;
+
+ /** Select custom temp directory action. */
+ private Action selectCustomTempDirectoryAction;
+
/** Action that chooses a new temp directory. */
private Action chooseTempDirectoryAction;
@@ -55,6 +62,12 @@ public class PreferencesPage extends TWizardPage {
/** The temp directory. */
private String tempDirectory;
+ /** The âdefaultâ button. */
+ private JRadioButton defaultTempDirectory;
+
+ /** The âcustomâ button. */
+ private JRadioButton customTempDirectory;
+
/**
* Creates a new âpreferencesâ page.
*
@@ -102,6 +115,13 @@ public class PreferencesPage extends TWizardPage {
*/
public void setTempDirectory(String tempDirectory) {
this.tempDirectory = tempDirectory;
+ tempDirectoryTextField.setText((tempDirectory != null) ? tempDirectory : "");
+ if (tempDirectory != null) {
+ customTempDirectory.setSelected(true);
+ chooseTempDirectoryAction.setEnabled(true);
+ } else {
+ defaultTempDirectory.setSelected(true);
+ }
}
//
@@ -121,6 +141,28 @@ public class PreferencesPage extends TWizardPage {
* Creates all actions.
*/
private void createActions() {
+ selectDefaultTempDirectoryAction = new AbstractAction(I18n.getMessage("jsite.preferences.temp-directory.default")) {
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ @SuppressWarnings("synthetic-access")
+ public void actionPerformed(ActionEvent actionEvent) {
+ selectDefaultTempDirectory();
+ }
+ };
+ selectCustomTempDirectoryAction = new AbstractAction(I18n.getMessage("jsite.preferences.temp-directory.custom")) {
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ @SuppressWarnings("synthetic-access")
+ public void actionPerformed(ActionEvent actionEvent) {
+ selectCustomTempDirectory();
+ }
+ };
chooseTempDirectoryAction = new AbstractAction(I18n.getMessage("jsite.preferences.temp-directory.choose")) {
@Override
@@ -135,6 +177,8 @@ public class PreferencesPage extends TWizardPage {
@Override
@SuppressWarnings("synthetic-access")
public void run() {
+ selectDefaultTempDirectoryAction.putValue(Action.NAME, I18n.getMessage("jsite.preferences.temp-directory.default"));
+ selectCustomTempDirectoryAction.putValue(Action.NAME, I18n.getMessage("jsite.preferences.temp-directory.custom"));
chooseTempDirectoryAction.putValue(Action.NAME, I18n.getMessage("jsite.preferences.temp-directory.choose"));
}
});
@@ -154,10 +198,10 @@ public class PreferencesPage extends TWizardPage {
final JLabel tempDirectoryLabel = new JLabel("" + I18n.getMessage("jsite.preferences.temp-directory") + "");
tempDirectoryPanel.add(tempDirectoryLabel, new GridBagConstraints(0, 0, 3, 1, 1.0, 0.0, GridBagConstraints.LINE_START, GridBagConstraints.BOTH, new Insets(0, 0, 0, 0), 0, 0));
- final JRadioButton defaultTempDirectory = new JRadioButton(I18n.getMessage("jsite.preferences.temp-directory.default"));
+ defaultTempDirectory = new JRadioButton(selectDefaultTempDirectoryAction);
tempDirectoryPanel.add(defaultTempDirectory, new GridBagConstraints(0, 1, 3, 1, 1.0, 0.0, GridBagConstraints.LINE_START, GridBagConstraints.BOTH, new Insets(6, 18, 0, 0), 0, 0));
- final JRadioButton customTempDirectory = new JRadioButton(I18n.getMessage("jsite.preferences.temp-directory.custom"));
+ customTempDirectory = new JRadioButton(selectCustomTempDirectoryAction);
tempDirectoryPanel.add(customTempDirectory, new GridBagConstraints(0, 2, 1, 1, 0.0, 0.0, GridBagConstraints.LINE_START, GridBagConstraints.BOTH, new Insets(0, 18, 0, 0), 0, 0));
ButtonGroup tempDirectoryButtonGroup = new ButtonGroup();
@@ -165,6 +209,14 @@ public class PreferencesPage extends TWizardPage {
customTempDirectory.getModel().setGroup(tempDirectoryButtonGroup);
tempDirectoryTextField = new JTextField();
+ tempDirectoryTextField.setEditable(false);
+ if (tempDirectory != null) {
+ tempDirectoryTextField.setText(tempDirectory);
+ customTempDirectory.setSelected(true);
+ } else {
+ defaultTempDirectory.setSelected(true);
+ }
+ chooseTempDirectoryAction.setEnabled(tempDirectory != null);
tempDirectoryPanel.add(tempDirectoryTextField, new GridBagConstraints(1, 2, 1, 1, 1.0, 0.0, GridBagConstraints.LINE_START, GridBagConstraints.BOTH, new Insets(0, 6, 0, 0), 0, 0));
JButton chooseButton = new JButton(chooseTempDirectoryAction);
@@ -178,8 +230,6 @@ public class PreferencesPage extends TWizardPage {
@Override
public void run() {
tempDirectoryLabel.setText("" + I18n.getMessage("jsite.preferences.temp-directory") + "");
- defaultTempDirectory.setText(I18n.getMessage("jsite.preferences.temp-directory.default"));
- customTempDirectory.setText(I18n.getMessage("jsite.preferences.temp-directory.custom"));
}
});
@@ -187,10 +237,40 @@ public class PreferencesPage extends TWizardPage {
}
/**
+ * Activates the default temp directory radio button.
+ */
+ private void selectDefaultTempDirectory() {
+ tempDirectoryTextField.setEnabled(false);
+ chooseTempDirectoryAction.setEnabled(false);
+ tempDirectory = null;
+ }
+
+ /**
+ * Activates the custom temp directory radio button.
+ */
+ private void selectCustomTempDirectory() {
+ tempDirectoryTextField.setEnabled(true);
+ chooseTempDirectoryAction.setEnabled(true);
+ if (tempDirectoryTextField.getText().length() == 0) {
+ chooseTempDirectory();
+ if (tempDirectoryTextField.getText().length() == 0) {
+ defaultTempDirectory.setSelected(true);
+ }
+ }
+ }
+
+ /**
* Lets the user choose a new temp directory.
*/
private void chooseTempDirectory() {
- /* TODO */
+ JFileChooser fileChooser = new JFileChooser(tempDirectory);
+ fileChooser.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY);
+ int returnValue = fileChooser.showDialog(wizard, I18n.getMessage("jsite.preferences.temp-directory.choose.approve"));
+ if (returnValue == JFileChooser.CANCEL_OPTION) {
+ return;
+ }
+ tempDirectory = fileChooser.getSelectedFile().getPath();
+ tempDirectoryTextField.setText(tempDirectory);
}
}