James Moger
2011-12-22 e6935876b97a63bae2ec087b4fc390c832aef155
src/com/gitblit/client/EditRepositoryDialog.java
@@ -52,7 +52,6 @@
import com.gitblit.Constants.AccessRestrictionType;
import com.gitblit.Constants.FederationStrategy;
import com.gitblit.models.RepositoryModel;
import com.gitblit.models.TeamModel;
import com.gitblit.utils.StringUtils;
/**
@@ -90,6 +89,8 @@
   private JCheckBox isFrozen;
   private JTextField mailingListsField;
   private JComboBox accessRestriction;
   private JComboBox federationStrategy;
@@ -97,10 +98,14 @@
   private JComboBox ownerField;
   private JPalette<String> usersPalette;
   private JPalette<String> setsPalette;
   private JPalette<String> teamsPalette;
   private JPalette<String> preReceivePalette;
   private JPalette<String> postReceivePalette;
   private Set<String> repositoryNames;
@@ -159,6 +164,9 @@
            anRepository.skipSummaryMetrics);
      isFrozen = new JCheckBox(Translation.get("gb.isFrozenDescription"), anRepository.isFrozen);
      mailingListsField = new JTextField(anRepository.mailingLists == null ? ""
            : StringUtils.flattenStrings(anRepository.mailingLists, " "), 50);
      accessRestriction = new JComboBox(AccessRestrictionType.values());
      accessRestriction.setRenderer(new AccessRestrictionRenderer());
      accessRestriction.setSelectedItem(anRepository.accessRestriction);
@@ -190,6 +198,7 @@
      fieldsPanel
            .add(newFieldPanel(Translation.get("gb.skipSummaryMetrics"), skipSummaryMetrics));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.isFrozen"), isFrozen));
      fieldsPanel.add(newFieldPanel(Translation.get("gb.mailingLists"), mailingListsField));
      usersPalette = new JPalette<String>();
      JPanel accessPanel = new JPanel(new BorderLayout(5, 5));
@@ -211,6 +220,18 @@
      federationPanel.add(newFieldPanel(Translation.get("gb.federationSets"), setsPalette),
            BorderLayout.CENTER);
      preReceivePalette = new JPalette<String>(true);
      JPanel preReceivePanel = new JPanel(new BorderLayout(5, 5));
      preReceivePanel.add(
            newFieldPanel(Translation.get("gb.preReceiveScripts"), preReceivePalette),
            BorderLayout.CENTER);
      postReceivePalette = new JPalette<String>(true);
      JPanel postReceivePanel = new JPanel(new BorderLayout(5, 5));
      postReceivePanel.add(
            newFieldPanel(Translation.get("gb.postReceiveScripts"), postReceivePalette),
            BorderLayout.CENTER);
      JTabbedPane panel = new JTabbedPane(JTabbedPane.TOP);
      panel.addTab(Translation.get("gb.general"), fieldsPanel);
      panel.addTab(Translation.get("gb.accessRestriction"), accessPanel);
@@ -218,6 +239,8 @@
         panel.addTab(Translation.get("gb.teams"), teamsPanel);
      }
      panel.addTab(Translation.get("gb.federation"), federationPanel);
      panel.addTab(Translation.get("gb.preReceiveScripts"), preReceivePanel);
      panel.addTab(Translation.get("gb.postReceiveScripts"), postReceivePanel);
      JButton createButton = new JButton(Translation.get("gb.save"));
      createButton.addActionListener(new ActionListener() {
@@ -348,12 +371,27 @@
      repository.skipSummaryMetrics = skipSummaryMetrics.isSelected();
      repository.isFrozen = isFrozen.isSelected();
      String ml = mailingListsField.getText();
      if (!StringUtils.isEmpty(ml)) {
         Set<String> list = new HashSet<String>();
         for (String address : ml.split("(,|\\s)")) {
            if (StringUtils.isEmpty(address)) {
               continue;
            }
            list.add(address.toLowerCase());
         }
         repository.mailingLists = new ArrayList<String>(list);
      }
      repository.accessRestriction = (AccessRestrictionType) accessRestriction.getSelectedItem();
      repository.federationStrategy = (FederationStrategy) federationStrategy.getSelectedItem();
      if (repository.federationStrategy.exceeds(FederationStrategy.EXCLUDE)) {
         repository.federationSets = setsPalette.getSelections();
      }
      repository.preReceiveScripts = preReceivePalette.getSelections();
      repository.postReceiveScripts = postReceivePalette.getSelections();
      return true;
   }
@@ -369,7 +407,7 @@
      }
      usersPalette.setObjects(all, selected);
   }
   public void setTeams(List<String> all, List<String> selected) {
      teamsPalette.setObjects(all, selected);
   }
@@ -389,6 +427,14 @@
      setsPalette.setObjects(all, selected);
   }
   public void setPreReceiveScripts(List<String> all, List<String> selected) {
      preReceivePalette.setObjects(all, selected);
   }
   public void setPostReceiveScripts(List<String> all, List<String> selected) {
      postReceivePalette.setObjects(all, selected);
   }
   public RepositoryModel getRepository() {
      if (canceled) {
         return null;