Skip to content

Commit

Permalink
Correctly track active campaigns from a client
Browse files Browse the repository at this point in the history
  • Loading branch information
sixlettervariables committed Mar 11, 2020
1 parent 34b1828 commit e15d675
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 1 deletion.
6 changes: 6 additions & 0 deletions MekHQ/src/mekhq/campaign/CampaignController.java
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,12 @@ public void removeActiveCampaign(UUID id) {
activeCampaigns.remove(id);
}

public void setActiveCampaigns(Collection<UUID> campaignIds) {
// TODO: evaluate if we can make this atomic somehow.
activeCampaigns.clear();
campaignIds.forEach(id -> activeCampaigns.put(id, id));
}

public boolean isCampaignActive(UUID id) {
return Objects.equals(getHost(), id) || activeCampaigns.containsKey(id);
}
Expand Down
2 changes: 1 addition & 1 deletion MekHQ/src/mekhq/gui/CampaignGUI.java
Original file line number Diff line number Diff line change
Expand Up @@ -2583,7 +2583,7 @@ private void refreshOnlineStatus() {
} else if (app.isRemote()) {
lblOnline.setText(
String.format("<html><font color='green'><b>CONNECTED</b> (%d playing)</font></html>",
getCampaignController().getActiveCampaigns().size() + 1 /*Host*/));
getCampaignController().getActiveCampaigns().size()));
} else {
lblOnline.setVisible(false);
}
Expand Down
2 changes: 2 additions & 0 deletions MekHQ/src/mekhq/online/MekHQClient.java
Original file line number Diff line number Diff line change
Expand Up @@ -234,6 +234,8 @@ protected void handlePong(UUID id, Pong pong) {
dateFormatter.parseDateTime(campaign.getDate()), campaign.getLocation(), campaign.getIsGMMode());
}

controller.setActiveCampaigns(foundCampaigns);

MekHQ.triggerEvent(new CampaignListUpdatedEvent());
}

Expand Down

0 comments on commit e15d675

Please sign in to comment.