X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Futils%2Fui%2FConfigEditor.java;h=2bc9dc9ff36652db8d4cd7dbbb3e1b1da2f9f2e8;hb=d5026c096121da14c20d69893520594a36d088bb;hp=b2182adb34fd689717cbca9d3ea147f348d1842f;hpb=76b51de96af0b8dfa9615db37823fffd093fcfe3;p=fanfix.git diff --git a/src/be/nikiroo/utils/ui/ConfigEditor.java b/src/be/nikiroo/utils/ui/ConfigEditor.java index b2182ad..2bc9dc9 100644 --- a/src/be/nikiroo/utils/ui/ConfigEditor.java +++ b/src/be/nikiroo/utils/ui/ConfigEditor.java @@ -1,9 +1,11 @@ package be.nikiroo.utils.ui; import java.awt.BorderLayout; +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; @@ -12,8 +14,11 @@ import javax.swing.JComponent; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JScrollPane; +import javax.swing.JTextArea; import javax.swing.border.EmptyBorder; +import javax.swing.border.TitledBorder; +import be.nikiroo.utils.StringUtils; import be.nikiroo.utils.resources.Bundle; import be.nikiroo.utils.resources.MetaInfo; @@ -52,12 +57,15 @@ public class ConfigEditor> extends JPanel { this.add(scroll, BorderLayout.CENTER); 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 item : items) { - addItem(main, item); + items = new ArrayList>(); + List> groupedItems = MetaInfo.getItems(type, bundle); + for (MetaInfo item : groupedItems) { + // will init this.items + addItem(main, item, 0); } main.add(createButton("Reset", new ActionListener() { @@ -86,7 +94,7 @@ public class ConfigEditor> extends JPanel { @Override public void actionPerformed(ActionEvent e) { for (MetaInfo item : items) { - item.save(); + item.save(true); } try { @@ -98,14 +106,34 @@ public class ConfigEditor> extends JPanel { })); } - private void addItem(JPanel main, MetaInfo item) { + private void addItem(JPanel main, MetaInfo item, int nhgap) { if (item.isGroup()) { - // TODO + JPanel bpane = new JPanel(new BorderLayout()); + bpane.setBorder(new TitledBorder(item.getName())); + JPanel pane = new JPanel(); + pane.setBorder(new EmptyBorder(5, 5, 5, 5)); + pane.setLayout(new BoxLayout(pane, BoxLayout.Y_AXIS)); + + 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); + text.setForeground(new Color(100, 100, 180)); + text.setEditable(false); + pane.add(text); + } + for (MetaInfo subitem : item) { - addItem(main, subitem); + addItem(pane, subitem, nhgap + 11); } + bpane.add(pane, BorderLayout.CENTER); + main.add(bpane); } else { - main.add(new ConfigItem(item)); + items.add(item); + main.add(new ConfigItem(item, nhgap)); } }