From a5b1594130419c1523b3786d0bbb12adfd1e4d7b Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Thu, 10 May 2012 17:34:17 -0400
Subject: [PATCH] Adjustments to custom fields in Manager

---
 src/com/gitblit/models/SettingModel.java         |   18 +++++++++
 src/com/gitblit/models/ServerSettings.java       |    8 +++
 src/com/gitblit/client/RepositoriesPanel.java    |    6 ++
 src/com/gitblit/client/EditRepositoryDialog.java |   65 +++++++++++++++++++++-----------
 4 files changed, 73 insertions(+), 24 deletions(-)

diff --git a/src/com/gitblit/client/EditRepositoryDialog.java b/src/com/gitblit/client/EditRepositoryDialog.java
index cc22512..96c0dd1 100644
--- a/src/com/gitblit/client/EditRepositoryDialog.java
+++ b/src/com/gitblit/client/EditRepositoryDialog.java
@@ -28,12 +28,12 @@
 import java.text.MessageFormat;
 import java.util.ArrayList;
 import java.util.Arrays;
-import java.util.HashMap;
 import java.util.HashSet;
+import java.util.LinkedHashMap;
 import java.util.List;
+import java.util.Map;
 import java.util.Set;
 
-import javax.swing.Box;
 import javax.swing.BoxLayout;
 import javax.swing.DefaultComboBoxModel;
 import javax.swing.ImageIcon;
@@ -124,6 +124,8 @@
 	private Set<String> repositoryNames;
 	
 	private JPanel customFieldsPanel;
+	
+	private List<JTextField> customTextfields;
 
 	public EditRepositoryDialog(int protocolVersion) {
 		this(protocolVersion, new RepositoryModel());
@@ -470,13 +472,14 @@
 		repository.postReceiveScripts = postReceivePalette.getSelections();
 		
 		// Custom Fields
-		repository.customFields = new HashMap<String, String>();
-		
-		for (Component aCustomFieldPanel : customFieldsPanel.getComponents()) {
-			JTextField textField = (JTextField) ((JPanel)aCustomFieldPanel).getComponent(1);
-			repository.customFields.put(textField.getName(), textField.getText());
+		repository.customFields = new LinkedHashMap<String, String>();
+		if (customTextfields != null) {
+			for (JTextField field : customTextfields) {
+				String key = field.getName();
+				String value = field.getText();
+				repository.customFields.put(key, value);
+			}
 		}
-		
 		return true;
 	}
 
@@ -555,24 +558,42 @@
 		return teamsPalette.getSelections();
 	}
 	
-	public void setCustomFields(RepositoryModel repository, List<String> customFields) {
+	public void setCustomFields(RepositoryModel repository, Map<String, String> customFields) {
 		customFieldsPanel.removeAll();
+		customTextfields = new ArrayList<JTextField>();
 		
-		for (String customFieldDef : customFields) {
-			String[] customFieldProperty = customFieldDef.split("=");
-			String fieldName = customFieldProperty[0];
-			String fieldLabel = customFieldProperty[1];
-			
-			JTextField textField = new JTextField(repository.customFields.get(fieldName), 50);
-			textField.setName(fieldName);
-			
-			customFieldsPanel.add(newFieldPanel(fieldLabel, 250, textField));
-		}
+		final Insets insets = new Insets(5, 5, 5, 5);
+		JPanel fields = new JPanel(new GridLayout(0, 1, 0, 5)) {
+
+			private static final long serialVersionUID = 1L;
+
+			@Override
+			public Insets getInsets() {
+				return insets;
+			}
+		};		
 		
-		if (customFields.size() < 14) {
-			customFieldsPanel.add(Box.createVerticalGlue());
-			customFieldsPanel.add(Box.createRigidArea(new Dimension(300, 300 - (customFields.size() * 22))));
+		for (Map.Entry<String, String> entry : customFields.entrySet()) {
+			String field = entry.getKey();
+			String value = "";
+			if (repository.customFields != null && repository.customFields.containsKey(field)) {
+				value = repository.customFields.get(field);
+			}
+			JTextField textField = new JTextField(value);
+			textField.setName(field);
+			
+			textField.setPreferredSize(new Dimension(450, 26));
+			
+			fields.add(newFieldPanel(entry.getValue(), 250, textField));
+			
+			customTextfields.add(textField);
 		}
+		JScrollPane jsp = new JScrollPane(fields);		
+		jsp.getVerticalScrollBar().setBlockIncrement(100);
+		jsp.getVerticalScrollBar().setUnitIncrement(100);
+		jsp.setViewportBorder(null);
+		customFieldsPanel.setLayout(new FlowLayout(FlowLayout.LEFT));
+		customFieldsPanel.add(jsp);
 	}
 
 	/**
diff --git a/src/com/gitblit/client/RepositoriesPanel.java b/src/com/gitblit/client/RepositoriesPanel.java
index 89ec605..7cff4b6 100644
--- a/src/com/gitblit/client/RepositoriesPanel.java
+++ b/src/com/gitblit/client/RepositoriesPanel.java
@@ -29,6 +29,7 @@
 import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
+import java.util.Map;
 
 import javax.swing.JButton;
 import javax.swing.JLabel;
@@ -431,7 +432,10 @@
 				gitblit.getPreReceiveScriptsInherited(repository), repository.preReceiveScripts);
 		dialog.setPostReceiveScripts(gitblit.getPostReceiveScriptsUnused(repository),
 				gitblit.getPostReceiveScriptsInherited(repository), repository.postReceiveScripts);
-		dialog.setCustomFields(repository, gitblit.getSettings().get(Keys.repository.customFields).getStrings());
+		if (gitblit.getSettings().hasKey(Keys.groovy.customFields)) {
+			Map<String, String> map = gitblit.getSettings().get(Keys.groovy.customFields).getMap();
+			dialog.setCustomFields(repository, map);
+		}
 		dialog.setVisible(true);
 		final RepositoryModel revisedRepository = dialog.getRepository();
 		final List<String> permittedUsers = dialog.getPermittedUsers();
diff --git a/src/com/gitblit/models/ServerSettings.java b/src/com/gitblit/models/ServerSettings.java
index 3658096..27199b4 100644
--- a/src/com/gitblit/models/ServerSettings.java
+++ b/src/com/gitblit/models/ServerSettings.java
@@ -54,10 +54,16 @@
 	}
 
 	public void add(SettingModel setting) {
-		settings.put(setting.name, setting);
+		if (setting != null) {
+			settings.put(setting.name, setting);
+		}
 	}
 
 	public SettingModel get(String key) {
 		return settings.get(key);
 	}
+	
+	public boolean hasKey(String key) {
+		return settings.containsKey(key);
+	}
 }
diff --git a/src/com/gitblit/models/SettingModel.java b/src/com/gitblit/models/SettingModel.java
index 8a5c0c6..a04126e 100644
--- a/src/com/gitblit/models/SettingModel.java
+++ b/src/com/gitblit/models/SettingModel.java
@@ -17,7 +17,9 @@
 
 import java.io.Serializable;
 import java.util.ArrayList;
+import java.util.LinkedHashMap;
 import java.util.List;
+import java.util.Map;
 
 import com.gitblit.utils.StringUtils;
 
@@ -141,4 +143,20 @@
 		strings = StringUtils.getStringsFromValue(currentValue, separator);
 		return strings;
 	}
+	
+	/**
+	 * Returns a map of strings from the current value.
+	 * 
+	 * @return map of string, string
+	 */
+	public Map<String, String> getMap() {
+		Map<String, String> map = new LinkedHashMap<String, String>();
+		for (String string : getStrings()) {
+			String[] kvp = string.split("=", 2);
+			String key = kvp[0];
+			String value = kvp[1];				
+			map.put(key,  value);
+		}
+		return map;
+	}
 }

--
Gitblit v1.9.1