diff --git a/android/assets/jsons/Civ V - Gods & Kings/Buildings.json b/android/assets/jsons/Civ V - Gods & Kings/Buildings.json index bb11aded488d4..f36d2b94a110f 100644 --- a/android/assets/jsons/Civ V - Gods & Kings/Buildings.json +++ b/android/assets/jsons/Civ V - Gods & Kings/Buildings.json @@ -791,7 +791,7 @@ "happiness": 4, "greatPersonPoints": {"Great Artist": 2}, "isWonder": true, - "uniques": ["Empire enters golden age"], + "uniques": ["Empire enters [Golden Age]"], "requiredTech": "Architecture", "quote": "'The Taj Mahal rises above the banks of the river like a solitary tear suspended on the cheek of time.' - Rabindranath Tagore" }, diff --git a/android/assets/jsons/Civ V - Gods & Kings/Policies.json b/android/assets/jsons/Civ V - Gods & Kings/Policies.json index 2a1e83eab2c8b..919a80eca3edb 100644 --- a/android/assets/jsons/Civ V - Gods & Kings/Policies.json +++ b/android/assets/jsons/Civ V - Gods & Kings/Policies.json @@ -114,7 +114,7 @@ "name": "Representation", "uniques": [ "Each city founded increases culture cost of policies [33]% less than normal", - "Empire enters golden age" + "Empire enters [Golden Age]" ], "requires": ["Citizenship"], "row": 2, @@ -252,7 +252,7 @@ "name": "Reformation", "uniques": [ "[+33]% [Culture] [in all cities with a world wonder]", - "Empire enters golden age" + "Empire enters [Golden Age]" ], "requires": ["Organized Religion"], "row": 2, diff --git a/android/assets/jsons/Civ V - Gods & Kings/Units.json b/android/assets/jsons/Civ V - Gods & Kings/Units.json index 5d301e40421a2..19bdc6da7f0b6 100644 --- a/android/assets/jsons/Civ V - Gods & Kings/Units.json +++ b/android/assets/jsons/Civ V - Gods & Kings/Units.json @@ -1583,7 +1583,7 @@ "name": "Great Artist", "unitType": "Civilian", "uniques": [ - "Empire enters a [8]-turn Golden Age ", + "Empire enters a [8]-turn [Golden Age] ", "Can instantly construct a [Landmark] improvement ", "Great Person - [Culture]", "Unbuildable", "Uncapturable"], "movement": 2 @@ -1632,7 +1632,7 @@ "name": "Great General", "unitType": "Civilian", "uniques": [ - "Empire enters a [8]-turn Golden Age ", + "Empire enters a [8]-turn [Golden Age] ", "[+15]% Strength bonus for [Military] units within [2] tiles", "Can instantly construct a [Citadel] improvement ", "Can be earned through combat", @@ -1645,7 +1645,7 @@ "uniqueTo": "Mongolia", "replaces": "Great General", "uniques": [ - "Empire enters a [8]-turn Golden Age ", + "Empire enters a [8]-turn [Golden Age] ", "[+15]% Strength bonus for [Military] units within [2] tiles", "All adjacent units heal [+15] HP when healing", "[+15] HP when healing", "Can instantly construct a [Citadel] improvement ", diff --git a/android/assets/jsons/Civ V - Vanilla/Buildings.json b/android/assets/jsons/Civ V - Vanilla/Buildings.json index d8247a77ec742..8e2cd1b0fec22 100644 --- a/android/assets/jsons/Civ V - Vanilla/Buildings.json +++ b/android/assets/jsons/Civ V - Vanilla/Buildings.json @@ -665,7 +665,7 @@ "happiness": 4, "greatPersonPoints": {"Great Artist": 2}, "isWonder": true, - "uniques": ["Empire enters golden age"], + "uniques": ["Empire enters [Golden Age]"], "requiredTech": "Printing Press", "quote": "'The Taj Mahal rises above the banks of the river like a solitary tear suspended on the cheek of time.' - Rabindranath Tagore" }, diff --git a/android/assets/jsons/Civ V - Vanilla/Policies.json b/android/assets/jsons/Civ V - Vanilla/Policies.json index 5aa499714a3ce..11f5c1e5b2661 100644 --- a/android/assets/jsons/Civ V - Vanilla/Policies.json +++ b/android/assets/jsons/Civ V - Vanilla/Policies.json @@ -113,7 +113,7 @@ "name": "Representation", "uniques": [ "Each city founded increases culture cost of policies [33]% less than normal", - "Empire enters golden age" + "Empire enters [Golden Age]" ], "requires": ["Citizenship"], "row": 2, @@ -249,7 +249,7 @@ "name": "Reformation", "uniques": [ "[+33]% [Culture] [in all cities with a world wonder]", - "Empire enters golden age" + "Empire enters [Golden Age]" ], "requires": ["Organized Religion"], "row": 2, diff --git a/android/assets/jsons/Civ V - Vanilla/Units.json b/android/assets/jsons/Civ V - Vanilla/Units.json index 6ae5f4ca71da3..36bdbb2d9b2ca 100644 --- a/android/assets/jsons/Civ V - Vanilla/Units.json +++ b/android/assets/jsons/Civ V - Vanilla/Units.json @@ -1260,7 +1260,7 @@ "name": "Great Artist", "unitType": "Civilian", "uniques": [ - "Empire enters a [8]-turn Golden Age ", + "Empire enters a [8]-turn [Golden Age] ", "Can instantly construct a [Landmark] improvement ", "Great Person - [Culture]", "Unbuildable", "Uncapturable"], "movement": 2 @@ -1293,7 +1293,7 @@ "name": "Great General", "unitType": "Civilian", "uniques": [ - "Empire enters a [8]-turn Golden Age ", + "Empire enters a [8]-turn [Golden Age] ", "[+15]% Strength bonus for [Military] units within [2] tiles", "Can instantly construct a [Citadel] improvement ", "Can be earned through combat", @@ -1306,7 +1306,7 @@ "uniqueTo": "Mongolia", "replaces": "Great General", "uniques": [ - "Empire enters a [8]-turn Golden Age ", + "Empire enters a [8]-turn [Golden Age] ", "[+15]% Strength bonus for [Military] units within [2] tiles", "All adjacent units heal [+15] HP when healing", "[+15] HP when healing", "Can instantly construct a [Citadel] improvement ", diff --git a/core/src/com/unciv/logic/city/CityStats.kt b/core/src/com/unciv/logic/city/CityStats.kt index 9849020d1cdbf..cb1a99dd6cd32 100644 --- a/core/src/com/unciv/logic/city/CityStats.kt +++ b/core/src/com/unciv/logic/city/CityStats.kt @@ -458,7 +458,7 @@ class CityStats(val city: City) { private fun updateStatPercentBonusList(currentConstruction: IConstruction) { val newStatsBonusTree = StatTreeNode() - newStatsBonusTree.addStats(getStatPercentBonusesFromGoldenAge(city.civ.goldenAges.isGoldenAge()),"Golden Age") + newStatsBonusTree.addStats(getStatPercentBonusesFromGoldenAge(city.civ.goldenAges.isGoldenAge()),city.civ.nation.goldenAgeName) addStatPercentBonusesFromBuildings(newStatsBonusTree) newStatsBonusTree.addStats(getStatPercentBonusesFromRailroad(), "Railroad") newStatsBonusTree.addStats(getStatPercentBonusesFromPuppetCity(), "Puppet City") diff --git a/core/src/com/unciv/logic/civilization/managers/GoldenAgeManager.kt b/core/src/com/unciv/logic/civilization/managers/GoldenAgeManager.kt index 54bd6e94d6022..2b22f66b70596 100644 --- a/core/src/com/unciv/logic/civilization/managers/GoldenAgeManager.kt +++ b/core/src/com/unciv/logic/civilization/managers/GoldenAgeManager.kt @@ -49,7 +49,7 @@ class GoldenAgeManager : IsPartOfGameInfoSerialization { fun enterGoldenAge(unmodifiedNumberOfTurns: Int = 10) { turnsLeftForCurrentGoldenAge += calculateGoldenAgeLength(unmodifiedNumberOfTurns) - civInfo.addNotification("You have entered a Golden Age!", + civInfo.addNotification("[${civInfo.nation.enteredGoldenAge}]!", CivilopediaAction("Tutorial/Golden Age"), NotificationCategory.General, "StatIcons/Happiness") civInfo.popupAlerts.add(PopupAlert(AlertType.GoldenAge, "")) diff --git a/core/src/com/unciv/logic/map/tile/TileStatFunctions.kt b/core/src/com/unciv/logic/map/tile/TileStatFunctions.kt index a74fce64dd34b..9e6f727bde28c 100644 --- a/core/src/com/unciv/logic/map/tile/TileStatFunctions.kt +++ b/core/src/com/unciv/logic/map/tile/TileStatFunctions.kt @@ -124,7 +124,7 @@ class TileStatFunctions(val tile: Tile) { if (observingCiv != null && listOfStats.toStats().gold != 0f && observingCiv.goldenAges.isGoldenAge()) - listOfStats.add("Golden Age" to Stats(gold = 1f)) + listOfStats.add(observingCiv.nation.goldenAgeName to Stats(gold = 1f)) // To ensure that the original stats (in uniques, terrains, etc) are not modified in getTileStats, we clone them all return listOfStats.filter { !it.second.isEmpty() }.map { it.first to it.second.clone() } diff --git a/core/src/com/unciv/models/ruleset/nation/Nation.kt b/core/src/com/unciv/models/ruleset/nation/Nation.kt index 1bbde69ad40d2..ca3638030e6e2 100644 --- a/core/src/com/unciv/models/ruleset/nation/Nation.kt +++ b/core/src/com/unciv/models/ruleset/nation/Nation.kt @@ -57,6 +57,8 @@ class Nation : RulesetObject() { var startIntroPart1 = "" var startIntroPart2 = "" + var goldenAgeName = "Golden Age" + var enteredGoldenAge = "You have entered a Golden Age" /* Properties present in json but not yet implemented: var adjective = ArrayList() diff --git a/core/src/com/unciv/models/ruleset/unique/UniqueParameterType.kt b/core/src/com/unciv/models/ruleset/unique/UniqueParameterType.kt index 44de0095647dc..34c9a87867872 100644 --- a/core/src/com/unciv/models/ruleset/unique/UniqueParameterType.kt +++ b/core/src/com/unciv/models/ruleset/unique/UniqueParameterType.kt @@ -598,6 +598,10 @@ enum class UniqueParameterType( UnitTriggerTarget("unitTriggerTarget", Constants.thisUnit, "`${Constants.thisUnit}` or `${Constants.targetUnit}`") { override val staticKnownValues = setOf(Constants.thisUnit, Constants.targetUnit) }, + + GoldenAgeName("Golden Age", "Golden Age", "Affects only the visuals. Does not impact gameplay.") { + override fun getErrorSeverity(parameterText: String, ruleset: Ruleset) = null + }, /** Mod declarative compatibility: Define Mod relations by their name. */ ModName("modFilter", diff --git a/core/src/com/unciv/models/ruleset/unique/UniqueTriggerActivation.kt b/core/src/com/unciv/models/ruleset/unique/UniqueTriggerActivation.kt index c23dec7807457..a10802fe5520b 100644 --- a/core/src/com/unciv/models/ruleset/unique/UniqueTriggerActivation.kt +++ b/core/src/com/unciv/models/ruleset/unique/UniqueTriggerActivation.kt @@ -378,7 +378,7 @@ object UniqueTriggerActivation { val notificationText = getNotificationText( notification, triggerNotificationText, - "You enter a Golden Age" + "[${civInfo.nation.enteredGoldenAge}]" ) if (notificationText != null) civInfo.addNotification(notificationText, NotificationCategory.General, NotificationIcon.Happiness) diff --git a/core/src/com/unciv/models/ruleset/unique/UniqueType.kt b/core/src/com/unciv/models/ruleset/unique/UniqueType.kt index 5da38f6c1b48c..dfe43fe73a36c 100644 --- a/core/src/com/unciv/models/ruleset/unique/UniqueType.kt +++ b/core/src/com/unciv/models/ruleset/unique/UniqueType.kt @@ -811,8 +811,8 @@ enum class UniqueType( OneTimeFreeUnitRuins("Free [unit] found in the ruins", UniqueTarget.Ruins), // Differs from "Free [] appears" in that it spawns near the ruins instead of in a city OneTimeFreePolicy("Free Social Policy", UniqueTarget.Triggerable), // used in Buildings OneTimeAmountFreePolicies("[positiveAmount] Free Social Policies", UniqueTarget.Triggerable), // Not used in Vanilla - OneTimeEnterGoldenAge("Empire enters golden age", UniqueTarget.Triggerable), // used in Policies, Buildings - OneTimeEnterGoldenAgeTurns("Empire enters a [positiveAmount]-turn Golden Age", UniqueTarget.Triggerable), + OneTimeEnterGoldenAge("Empire enters [Golden Age]", UniqueTarget.Triggerable), // used in Policies, Buildings + OneTimeEnterGoldenAgeTurns("Empire enters a [positiveAmount]-turn [Golden Age]", UniqueTarget.Triggerable), OneTimeFreeGreatPerson("Free Great Person", UniqueTarget.Triggerable), // used in Policies, Buildings OneTimeGainPopulation("[amount] population [cityFilter]", UniqueTarget.Triggerable), // used in CN tower OneTimeGainPopulationRandomCity("[amount] population in a random city", UniqueTarget.Triggerable), @@ -985,6 +985,10 @@ enum class UniqueType( ///////////////////////////////////////////// region 99 DEPRECATED AND REMOVED ///////////////////////////////////////////// + @Deprecated("As of 4.15.20", ReplaceWith("Empire enters [Golden Age]"), DeprecationLevel.ERROR) + OneTimeEnterGoldenAgeOld("Empire enters golden age", UniqueTarget.Triggerable), + @Deprecated("As of 4.15.20", ReplaceWith("Empire enters a [positiveAmount]-turn [Golden Age]"), DeprecationLevel.ERROR) + OneTimeEnterGoldenAgeTurnsOld("Empire enters a [positiveAmount]-turn Golden Age", UniqueTarget.Triggerable), @Deprecated("As of 4.14.6", ReplaceWith("[+100]% Strength "), DeprecationLevel.ERROR) DefenceBonusWhenEmbarked("Defense bonus when embarked", UniqueTarget.Unit, UniqueTarget.Global), @Deprecated("As of 4.13.18", ReplaceWith("Only available "), DeprecationLevel.ERROR) diff --git a/core/src/com/unciv/ui/screens/worldscreen/AlertPopup.kt b/core/src/com/unciv/ui/screens/worldscreen/AlertPopup.kt index ae8f7acb5512d..fdc03ebc563dd 100644 --- a/core/src/com/unciv/ui/screens/worldscreen/AlertPopup.kt +++ b/core/src/com/unciv/ui/screens/worldscreen/AlertPopup.kt @@ -318,9 +318,10 @@ class AlertPopup( } private fun addGoldenAge() { - addGoodSizedLabel("GOLDEN AGE") + val nation = viewingCiv.nation + addGoodSizedLabel(viewingCiv.nation.goldenAgeName.tr().uppercase()) addSeparator() - addGoodSizedLabel("Your citizens have been happy with your rule for so long that the empire enters a Golden Age!").row() + addGoodSizedLabel("Your citizens have been happy with your rule for so long that the empire enters a [${viewingCiv.nation.goldenAgeName}]!").row() addCloseButton() music.chooseTrack(viewingCiv.civName, MusicMood.Golden, MusicTrackChooserFlags.setSpecific) } diff --git a/core/src/com/unciv/ui/screens/worldscreen/topbar/WorldScreenTopBarStats.kt b/core/src/com/unciv/ui/screens/worldscreen/topbar/WorldScreenTopBarStats.kt index db455a4936a98..1087efa3cb2d4 100644 --- a/core/src/com/unciv/ui/screens/worldscreen/topbar/WorldScreenTopBarStats.kt +++ b/core/src/com/unciv/ui/screens/worldscreen/topbar/WorldScreenTopBarStats.kt @@ -167,7 +167,7 @@ internal class WorldScreenTopBarStats(topbar: WorldScreenTopBar) : ScalingTableW val goldenAges = civInfo.goldenAges happinessText += if (goldenAges.isGoldenAge()) - " {GOLDEN AGE}(${goldenAges.turnsLeftForCurrentGoldenAge})".tr() + " ${civInfo.nation.goldenAgeName.tr().uppercase()}(${goldenAges.turnsLeftForCurrentGoldenAge})".tr() else " (${goldenAges.storedHappiness.tr()}/${goldenAges.happinessRequiredForNextGoldenAge().tr()})" return happinessText diff --git a/core/src/com/unciv/ui/screens/worldscreen/unit/actions/UnitActionsFromUniques.kt b/core/src/com/unciv/ui/screens/worldscreen/unit/actions/UnitActionsFromUniques.kt index 1129eb988ce63..351ea019cafda 100644 --- a/core/src/com/unciv/ui/screens/worldscreen/unit/actions/UnitActionsFromUniques.kt +++ b/core/src/com/unciv/ui/screens/worldscreen/unit/actions/UnitActionsFromUniques.kt @@ -211,11 +211,18 @@ object UnitActionsFromUniques { if (!UnitActionModifiers.canUse(unit, unique)) continue val baseTitle = when (unique.type) { + UniqueType.OneTimeEnterGoldenAge -> { + unique.placeholderText.fillPlaceholders( + unit.civ.nation.goldenAgeName.tr() + ) + } UniqueType.OneTimeEnterGoldenAgeTurns -> { unique.placeholderText.fillPlaceholders( unit.civ.goldenAges.calculateGoldenAgeLength( - unique.params[0].toInt()).tr()) - } + unique.params[0].toInt()).tr(), + unit.civ.nation.goldenAgeName.tr() + ) + } UniqueType.OneTimeGainStat -> { if (unique.hasModifier(UniqueType.ModifiedByGameSpeed)) { val stat = unique.params[1] diff --git a/docs/Modders/schemas/nations.json b/docs/Modders/schemas/nations.json index 47da81e8e26f9..0845b65cd158f 100644 --- a/docs/Modders/schemas/nations.json +++ b/docs/Modders/schemas/nations.json @@ -39,6 +39,8 @@ "defeated": { "type": "string" }, "startIntroPart1": { "type": "string" }, "startIntroPart2": { "type": "string" }, + "goldenAgeName": { "type": "string" }, + "enteredGoldenAge": { "type": "string" }, "cities": { "type": "array", "items": { "type": "string" },