From 7da81bd54e5f0c8a962f81f9ca99a345421fe2b9 Mon Sep 17 00:00:00 2001 From: Kenneth VanderLinde Date: Thu, 26 Sep 2024 18:12:54 -0700 Subject: [PATCH] Add clear lights menu items only once, and always add them if possible --- .../client/ui/AbstractTokenPopupMenu.java | 43 +++++++++++-------- 1 file changed, 26 insertions(+), 17 deletions(-) diff --git a/src/main/java/net/rptools/maptool/client/ui/AbstractTokenPopupMenu.java b/src/main/java/net/rptools/maptool/client/ui/AbstractTokenPopupMenu.java index 6cb4f9f415..d7ed970207 100644 --- a/src/main/java/net/rptools/maptool/client/ui/AbstractTokenPopupMenu.java +++ b/src/main/java/net/rptools/maptool/client/ui/AbstractTokenPopupMenu.java @@ -120,24 +120,33 @@ public void actionPerformed(ActionEvent e) { protected JMenu createLightSourceMenu() { JMenu menu = new JMenu(I18N.getText("panel.MapExplorer.View.LIGHT_SOURCES")); - if (tokenUnderMouse.hasLightSources()) { + boolean hasAnyLights = false; + boolean hasLights = false; + boolean hasAuras = false; + boolean hasGmAuras = false; + boolean hasOwnerOnlyAuras = false; + + for (GUID tokenGUID : selectedTokenSet) { + Token token = renderer.getZone().getToken(tokenGUID); + hasAnyLights |= token.hasLightSources(); + hasLights |= token.hasLightSourceType(LightSource.Type.NORMAL); + hasAuras |= token.hasLightSourceType(LightSource.Type.AURA); + hasGmAuras |= token.hasGMAuras(); + hasOwnerOnlyAuras |= token.hasOwnerOnlyAuras(); + } + if (hasAnyLights) { menu.add(new ClearLightAction()); - - ZoneRenderer renderer = MapTool.getFrame().getCurrentZoneRenderer(); - for (GUID tokenGUID : selectedTokenSet) { - Token token = renderer.getZone().getToken(tokenGUID); - if (token.hasLightSourceType(LightSource.Type.NORMAL)) { - menu.add(new ClearLightsOnlyAction()); - } - if (token.hasLightSourceType(LightSource.Type.AURA)) { - menu.add(new ClearAurasOnlyAction()); - } - if (token.hasGMAuras()) { - menu.add(new ClearGMAurasOnlyAction()); - } - if (token.hasOwnerOnlyAuras()) { - menu.add(new ClearOwnerAurasOnlyAction()); - } + if (hasLights) { + menu.add(new ClearLightsOnlyAction()); + } + if (hasAuras) { + menu.add(new ClearAurasOnlyAction()); + } + if (hasGmAuras) { + menu.add(new ClearGMAurasOnlyAction()); + } + if (hasOwnerOnlyAuras) { + menu.add(new ClearOwnerAurasOnlyAction()); } menu.addSeparator(); }