From 8a84d555058e1bb13dd0bc3931da3392c4e4579c Mon Sep 17 00:00:00 2001 From: Pavel Braginskiy Date: Fri, 3 Jan 2025 18:25:33 -0800 Subject: [PATCH] New ways to open a new tab --- .../src/megameklab/ui/MegaMekLabTabbedUI.java | 95 +++++++++++++++++-- megameklab/src/megameklab/ui/MenuBar.java | 2 +- 2 files changed, 89 insertions(+), 8 deletions(-) diff --git a/megameklab/src/megameklab/ui/MegaMekLabTabbedUI.java b/megameklab/src/megameklab/ui/MegaMekLabTabbedUI.java index 0d8fae8da..908ca51cb 100644 --- a/megameklab/src/megameklab/ui/MegaMekLabTabbedUI.java +++ b/megameklab/src/megameklab/ui/MegaMekLabTabbedUI.java @@ -348,17 +348,98 @@ public MenuBar getMMLMenuBar() { private class NewTabButton extends JPanel { public NewTabButton() { setOpaque(false); - var button = new JButton("➕"); - button.setForeground(Color.GREEN); - button.setFont(Font.getFont("Symbola")); - button.setFocusable(false); - button.setBorder(BorderFactory.createEmptyBorder()); + var newUnitButton = new JButton("➕"); + newUnitButton.setForeground(Color.GREEN); + newUnitButton.setFont(Font.getFont("Symbola")); + newUnitButton.setFocusable(false); + newUnitButton.setBorder(BorderFactory.createEmptyBorder()); + newUnitButton.setToolTipText("New Blank Mek
Right Click: Select Unit Type"); + + newUnitButton.addActionListener(e -> newTab()); + newUnitButton.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent e) { + if (e.isPopupTrigger()) { + newUnitPopupMenu().show(e.getComponent(), e.getX(), e.getY()); + } + } + + public void mouseReleased(MouseEvent e) { + if (e.isPopupTrigger()) { + newUnitPopupMenu().show(e.getComponent(), e.getX(), e.getY()); + } + } + }); + + add(newUnitButton); + + var loadUnitButton = new JButton("⌸"); + loadUnitButton.setFont(Font.getFont("Symbola")); + loadUnitButton.setForeground(Color.CYAN); + loadUnitButton.setFocusable(false); + loadUnitButton.setBorder(BorderFactory.createEmptyBorder()); + loadUnitButton.setToolTipText("Load unit from cache
Right Click: Load Unit Menu"); + + loadUnitButton.addActionListener(e -> StartupGUI.selectAndLoadUnitFromCache(MegaMekLabTabbedUI.this)); + loadUnitButton.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent e) { + if (e.isPopupTrigger()) { + loadUnitMenu().show(e.getComponent(), e.getX(), e.getY()); + } + } + public void mouseReleased(MouseEvent e) { + if (e.isPopupTrigger()) { + loadUnitMenu().show(e.getComponent(), e.getX(), e.getY()); + } + } + }); - button.addActionListener(e -> { + add(loadUnitButton); + } + + private JPopupMenu newUnitPopupMenu() { + var menu = new JPopupMenu(); + menu.add(newUnitItem("New Mek", Entity.ETYPE_MEK, false)); + menu.add(newUnitItem("New Fighter", Entity.ETYPE_AERO, false)); + menu.add(newUnitItem("New DropShip/Small Craft", Entity.ETYPE_DROPSHIP, false)); + menu.add(newUnitItem("New Advanced Aerospace", Entity.ETYPE_JUMPSHIP, false)); + menu.add(newUnitItem("New Tank", Entity.ETYPE_TANK, false)); + menu.add(newUnitItem("New Support Vehicle", Entity.ETYPE_SUPPORT_TANK, false)); + menu.add(newUnitItem("New Battle Armor", Entity.ETYPE_BATTLEARMOR, false)); + menu.add(newUnitItem("New Conventional Infantry", Entity.ETYPE_INFANTRY, false)); + menu.add(newUnitItem("New ProtoMek", Entity.ETYPE_PROTOMEK, false)); + + var primitive = new JMenu("New Primitive..."); + primitive.add(newUnitItem("New Mek", Entity.ETYPE_MEK, true)); + primitive.add(newUnitItem("New Fighter", Entity.ETYPE_AERO, true)); + primitive.add(newUnitItem("New DropShip/Small Craft", Entity.ETYPE_DROPSHIP, true)); + primitive.add(newUnitItem("New JumpShip", Entity.ETYPE_JUMPSHIP, true)); + + menu.add(primitive); + + return menu; + } + + private JMenuItem newUnitItem(String name, long entityType, boolean primitive) { + var item = new JMenuItem(name); + item.addActionListener(e -> { newTab(); + newUnit(entityType, primitive); }); + return item; + } + + private JPopupMenu loadUnitMenu() { + var menu = new JPopupMenu(); + + var fromCache = new JMenuItem("Load from cache"); + fromCache.addActionListener(e -> StartupGUI.selectAndLoadUnitFromCache(MegaMekLabTabbedUI.this)); + menu.add(fromCache); + + var fromFile = new JMenuItem("Load from file"); + fromFile.addActionListener(e -> getMMLMenuBar().loadUnitFromFile(-1)); + menu.add(fromFile); - add(button); + return menu; } } diff --git a/megameklab/src/megameklab/ui/MenuBar.java b/megameklab/src/megameklab/ui/MenuBar.java index 4ff5dd196..539e88a0a 100644 --- a/megameklab/src/megameklab/ui/MenuBar.java +++ b/megameklab/src/megameklab/ui/MenuBar.java @@ -1216,7 +1216,7 @@ private void exportSummary(ViewFormatting formatting) { } } - private void loadUnitFromFile(int fileNumber) { + public void loadUnitFromFile(int fileNumber) { File unitFile; if (fileNumber > 0) { String recentFileName = CConfig.getRecentFile(fileNumber);