mirror of
https://github.com/yairm210/Unciv.git
synced 2025-01-05 21:11:35 +07:00
Defensive pact notification fix (#10025)
* Fixed Civ getting two notifications of canceling their defensive pact when attacking. * Added Defensive Pact related warnings to the Declare War popup * Improved the warning to not include Civs that are already at war with the aggressor * Improved the warning to not include Civs that are already at war with the aggressor * Added defensive pact related warning translations * Refactored removeDefensivePacts * DeclareWarButton text now uses arrayListOf<String> and changed the for loop to a while loop * Extracted the DeclareWarButton text to a new method.
This commit is contained in:
parent
a4cc566a8a
commit
eec3732c96
@ -119,6 +119,9 @@ Peace =
|
|||||||
Research Agreement =
|
Research Agreement =
|
||||||
Declare war =
|
Declare war =
|
||||||
Declare war on [civName]? =
|
Declare war on [civName]? =
|
||||||
|
[civName] will also join them in the war =
|
||||||
|
An unknown civilization will also join them in the war =
|
||||||
|
This will cancel your defensive pact with [civName] =
|
||||||
Go to on map =
|
Go to on map =
|
||||||
Let's begin! =
|
Let's begin! =
|
||||||
[civName] has declared war on us! =
|
[civName] has declared war on us! =
|
||||||
|
@ -765,27 +765,29 @@ class DiplomacyManager() : IsPartOfGameInfoSerialization {
|
|||||||
*/
|
*/
|
||||||
private fun removeDefensivePacts() {
|
private fun removeDefensivePacts() {
|
||||||
val civAtWarWith = otherCiv()
|
val civAtWarWith = otherCiv()
|
||||||
civInfo.diplomacy.values.filter { it.diplomaticStatus == DiplomaticStatus.DefensivePact }.forEach {
|
for (diploManager in civInfo.diplomacy.values) {
|
||||||
|
if (diploManager.diplomaticStatus != DiplomaticStatus.DefensivePact) continue
|
||||||
|
|
||||||
// We already removed the trades and we don't want to remove the flags yet.
|
// We already removed the trades and we don't want to remove the flags yet.
|
||||||
if (it.otherCiv() != civAtWarWith) {
|
if (diploManager.otherCiv() != civAtWarWith) {
|
||||||
// Trades with defensive pact are now invalid
|
// Trades with defensive pact are now invalid
|
||||||
val defensivePactOffer = it.trades.firstOrNull { trade -> trade.ourOffers.any { offer -> offer.name == Constants.defensivePact } }
|
val defensivePactOffer = diploManager.trades
|
||||||
it.trades.remove(defensivePactOffer)
|
.firstOrNull { trade -> trade.ourOffers.any { offer -> offer.name == Constants.defensivePact } }
|
||||||
val theirDefensivePactOffer = it.otherCivDiplomacy().trades.firstOrNull { trade -> trade.ourOffers.any { offer -> offer.name == Constants.defensivePact } }
|
diploManager.trades.remove(defensivePactOffer)
|
||||||
it.otherCivDiplomacy().trades.remove(theirDefensivePactOffer)
|
val theirDefensivePactOffer = diploManager.otherCivDiplomacy().trades
|
||||||
it.removeFlag(DiplomacyFlags.DefensivePact)
|
.firstOrNull { trade -> trade.ourOffers.any { offer -> offer.name == Constants.defensivePact } }
|
||||||
it.otherCivDiplomacy().removeFlag(DiplomacyFlags.DefensivePact)
|
diploManager.otherCivDiplomacy().trades.remove(theirDefensivePactOffer)
|
||||||
it.diplomaticStatus = DiplomaticStatus.Peace
|
diploManager.removeFlag(DiplomacyFlags.DefensivePact)
|
||||||
it.otherCivDiplomacy().diplomaticStatus = DiplomaticStatus.Peace
|
diploManager.otherCivDiplomacy().removeFlag(DiplomacyFlags.DefensivePact)
|
||||||
|
diploManager.diplomaticStatus = DiplomaticStatus.Peace
|
||||||
|
diploManager.otherCivDiplomacy().diplomaticStatus = DiplomaticStatus.Peace
|
||||||
}
|
}
|
||||||
for (civ in getCommonKnownCivs().filter { civ -> civ.isMajorCiv() }) {
|
for (civ in getCommonKnownCivs().filter { civ -> civ.isMajorCiv() }) {
|
||||||
civ.addNotification("[${civInfo.civName}] canceled their Defensive Pact with [${it.otherCivName}]!",
|
civ.addNotification("[${civInfo.civName}] canceled their Defensive Pact with [${diploManager.otherCivName}]!",
|
||||||
NotificationCategory.Diplomacy, civInfo.civName, NotificationIcon.Diplomacy, it.otherCivName)
|
NotificationCategory.Diplomacy, civInfo.civName, NotificationIcon.Diplomacy, diploManager.otherCivName)
|
||||||
}
|
}
|
||||||
civInfo.addNotification("We have canceled our Defensive Pact with [${it.otherCivName}]!",
|
civInfo.addNotification("We have canceled our Defensive Pact with [${diploManager.otherCivName}]!",
|
||||||
NotificationCategory.Diplomacy, NotificationIcon.Diplomacy, it.otherCivName)
|
NotificationCategory.Diplomacy, NotificationIcon.Diplomacy, diploManager.otherCivName)
|
||||||
it.otherCiv().addNotification("[${civInfo.civName}] has canceled our Defensive Pact with us!",
|
|
||||||
NotificationCategory.Diplomacy, civInfo.civName, NotificationIcon.Diplomacy)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -873,7 +873,7 @@ class DiplomacyScreen(
|
|||||||
declareWarButton.setText(declareWarButton.text.toString() + " ($turnsToPeaceTreaty${Fonts.turn})")
|
declareWarButton.setText(declareWarButton.text.toString() + " ($turnsToPeaceTreaty${Fonts.turn})")
|
||||||
}
|
}
|
||||||
declareWarButton.onClick {
|
declareWarButton.onClick {
|
||||||
ConfirmPopup(this, "Declare war on [${otherCiv.civName}]?", "Declare war") {
|
ConfirmPopup(this, getDeclareWarButtonText(otherCiv), "Declare war") {
|
||||||
diplomacyManager.declareWar()
|
diplomacyManager.declareWar()
|
||||||
setRightSideFlavorText(otherCiv, otherCiv.nation.attacked, "Very well.")
|
setRightSideFlavorText(otherCiv, otherCiv.nation.attacked, "Very well.")
|
||||||
updateLeftSideTable(otherCiv)
|
updateLeftSideTable(otherCiv)
|
||||||
@ -883,6 +883,43 @@ class DiplomacyScreen(
|
|||||||
if (isNotPlayersTurn()) declareWarButton.disable()
|
if (isNotPlayersTurn()) declareWarButton.disable()
|
||||||
return declareWarButton
|
return declareWarButton
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun getDeclareWarButtonText(otherCiv: Civilization): String {
|
||||||
|
val messageLines = arrayListOf<String>()
|
||||||
|
messageLines += "Declare war on [${otherCiv.civName}]?"
|
||||||
|
// Tell the player who all will join the other side from defensive pacts
|
||||||
|
val otherCivDefensivePactList = otherCiv.diplomacy.values.filter {
|
||||||
|
otherCivDiploManager -> otherCivDiploManager.otherCiv() != viewingCiv
|
||||||
|
&& otherCivDiploManager.diplomaticStatus == DiplomaticStatus.DefensivePact
|
||||||
|
&& !otherCivDiploManager.otherCiv().isAtWarWith(viewingCiv) }
|
||||||
|
.map { it.otherCiv() }.toMutableList()
|
||||||
|
// Go through and find all of the defensive pact chains and add them to the list
|
||||||
|
var listIndex = 0
|
||||||
|
while (listIndex < otherCivDefensivePactList.size) {
|
||||||
|
messageLines += if (viewingCiv.knows(otherCivDefensivePactList[listIndex]))
|
||||||
|
"[${otherCivDefensivePactList[listIndex].civName}] will also join them in the war"
|
||||||
|
else "An unknown civilization will also join them in the war"
|
||||||
|
|
||||||
|
// Add their defensive pact allies
|
||||||
|
otherCivDefensivePactList.addAll(otherCivDefensivePactList[listIndex].diplomacy.values
|
||||||
|
.filter { diploChain -> diploChain.diplomaticStatus == DiplomaticStatus.DefensivePact
|
||||||
|
&& !otherCivDefensivePactList.contains(diploChain.otherCiv())
|
||||||
|
&& diploChain.otherCiv() != viewingCiv && diploChain.otherCiv() != otherCiv
|
||||||
|
&& !diploChain.otherCiv().isAtWarWith(viewingCiv) }
|
||||||
|
.map { it.otherCiv() })
|
||||||
|
listIndex++
|
||||||
|
}
|
||||||
|
|
||||||
|
// Tell the player that their defensive pacts will be canceled.
|
||||||
|
for (civDiploManager in viewingCiv.diplomacy.values) {
|
||||||
|
if (civDiploManager.otherCiv() != otherCiv
|
||||||
|
&& civDiploManager.diplomaticStatus == DiplomaticStatus.DefensivePact
|
||||||
|
&& !otherCivDefensivePactList.contains(civDiploManager.otherCiv())) {
|
||||||
|
messageLines += "This will cancel your defensive pact with [${civDiploManager.otherCivName}]"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return messageLines.joinToString("\n") { "{$it}" }
|
||||||
|
}
|
||||||
|
|
||||||
//endregion
|
//endregion
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user