Allow PluginPanels to opt-out of the scrollbar

For panels with tabs it is best to have the scrollbar inside of the tab pane, not around it.
This commit is contained in:
Max Weber
2018-04-21 08:56:10 -06:00
committed by Adam
parent 16aca14f7f
commit 7645d6a04f

View File

@@ -36,10 +36,11 @@ import lombok.Getter;
public abstract class PluginPanel extends JPanel public abstract class PluginPanel extends JPanel
{ {
static final int PANEL_WIDTH = 225; public static final int PANEL_WIDTH = 225;
static final int SCROLLBAR_WIDTH = 17; static final int SCROLLBAR_WIDTH = 17;
private static final int OFFSET = 6; private static final int OFFSET = 6;
private static final EmptyBorder BORDER_PADDING = new EmptyBorder(OFFSET, OFFSET, OFFSET, OFFSET); private static final EmptyBorder BORDER_PADDING = new EmptyBorder(OFFSET, OFFSET, OFFSET, OFFSET);
private static final Dimension OUTER_PREFERRED_SIZE = new Dimension(PluginPanel.PANEL_WIDTH + SCROLLBAR_WIDTH, 0);
@Getter(AccessLevel.PROTECTED) @Getter(AccessLevel.PROTECTED)
private final JScrollPane scrollPane; private final JScrollPane scrollPane;
@@ -47,9 +48,16 @@ public abstract class PluginPanel extends JPanel
@Getter(AccessLevel.PACKAGE) @Getter(AccessLevel.PACKAGE)
private final JPanel wrappedPanel; private final JPanel wrappedPanel;
public PluginPanel() protected PluginPanel()
{
this(true);
}
protected PluginPanel(boolean wrap)
{ {
super(); super();
if (wrap)
{
setBorder(BORDER_PADDING); setBorder(BORDER_PADDING);
setLayout(new GridLayout(0, 1, 0, 3)); setLayout(new GridLayout(0, 1, 0, 3));
@@ -65,15 +73,22 @@ public abstract class PluginPanel extends JPanel
// Adjust the preferred size to expand to width of scrollbar to // Adjust the preferred size to expand to width of scrollbar to
// to preven scrollbar overlapping over contents // to preven scrollbar overlapping over contents
wrappedPanel.setPreferredSize(new Dimension(PluginPanel.PANEL_WIDTH + SCROLLBAR_WIDTH, 0)); wrappedPanel.setPreferredSize(OUTER_PREFERRED_SIZE);
wrappedPanel.setLayout(new BorderLayout()); wrappedPanel.setLayout(new BorderLayout());
wrappedPanel.add(scrollPane, BorderLayout.CENTER); wrappedPanel.add(scrollPane, BorderLayout.CENTER);
} }
else
{
scrollPane = null;
wrappedPanel = this;
}
}
@Override @Override
public Dimension getPreferredSize() public Dimension getPreferredSize()
{ {
return new Dimension(PANEL_WIDTH, super.getPreferredSize().height); int width = this == wrappedPanel ? PANEL_WIDTH + SCROLLBAR_WIDTH : PANEL_WIDTH;
return new Dimension(width, super.getPreferredSize().height);
} }
public void onActivate() public void onActivate()