Improve ConfigItems and fix some related bugs
[fanfix.git] / src / be / nikiroo / utils / ui / ConfigEditor.java
index b384c9dc49631f37d5998385f745408570a1043c..2bc9dc9ff36652db8d4cd7dbbb3e1b1da2f9f2e8 100644 (file)
@@ -5,6 +5,7 @@ import java.awt.Color;
 import java.awt.event.ActionEvent;
 import java.awt.event.ActionListener;
 import java.io.IOException;
+import java.util.ArrayList;
 import java.util.List;
 
 import javax.swing.BoxLayout;
@@ -57,11 +58,13 @@ public class ConfigEditor<E extends Enum<E>> extends JPanel {
 
                main.setLayout(new BoxLayout(main, BoxLayout.PAGE_AXIS));
                main.setBorder(new EmptyBorder(5, 5, 5, 5));
-               
+
                main.add(new JLabel(title));
 
-               items = MetaInfo.getItems(type, bundle);
-               for (MetaInfo<E> item : items) {
+               items = new ArrayList<MetaInfo<E>>();
+               List<MetaInfo<E>> groupedItems = MetaInfo.getItems(type, bundle);
+               for (MetaInfo<E> item : groupedItems) {
+                       // will init this.items
                        addItem(main, item, 0);
                }
 
@@ -91,7 +94,7 @@ public class ConfigEditor<E extends Enum<E>> extends JPanel {
                        @Override
                        public void actionPerformed(ActionEvent e) {
                                for (MetaInfo<E> item : items) {
-                                       item.save();
+                                       item.save(true);
                                }
 
                                try {
@@ -114,6 +117,7 @@ public class ConfigEditor<E extends Enum<E>> extends JPanel {
                        String info = item.getDescription();
                        info = StringUtils.justifyTexts(info, 100);
                        if (!info.isEmpty()) {
+                               info = info + "\n";
                                JTextArea text = new JTextArea(info);
                                text.setWrapStyleWord(true);
                                text.setOpaque(false);
@@ -128,6 +132,7 @@ public class ConfigEditor<E extends Enum<E>> extends JPanel {
                        bpane.add(pane, BorderLayout.CENTER);
                        main.add(bpane);
                } else {
+                       items.add(item);
                        main.add(new ConfigItem<E>(item, nhgap));
                }
        }