From 33ef1f16b746183e346c1ac25433f2179dc773cb Mon Sep 17 00:00:00 2001
From: Blank_Alt <Blank_Alt>
Date: Fri, 14 Oct 2022 00:01:12 +1300
Subject: [PATCH] tweak_pInvasion

---
 src/events/nonRandom/pInvasion.js | 59 +++++++++++--------------------
 1 file changed, 20 insertions(+), 39 deletions(-)

diff --git a/src/events/nonRandom/pInvasion.js b/src/events/nonRandom/pInvasion.js
index 0aa592ac02b..79786343ba7 100644
--- a/src/events/nonRandom/pInvasion.js
+++ b/src/events/nonRandom/pInvasion.js
@@ -2,18 +2,18 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent {
 	execute(node) {
 		let r = [];
 		V.nextButton = "Continue";
-		const newSlaves = [];
 		V.invasionVictory = 1;
 		const {
 			HeA, HisA,
 			heA, hisA, womanA
 		} = getPronouns(assistant.pronouns().main).appendSuffix("A");
+		const newSlaves = [];
+		const ravineArc = V.terrain === "ravine";
 
 		r.push(`The day that wasn't supposed to come is here. The troubled little country next door is falling apart. Last month, its stock market collapsed. Last week, its government fell. Yesterday, there was open looting in its cities. And today, a faction of disaffected citizens that blames the Free Cities for siphoning off business and causing the collapse seized weapons from unguarded army depots${(V.terrain === "marine" || V.terrain === "oceanic") ? ", armed merchant ships and private vessels, and are approaching the Free City over the water." : " and advanced towards your home."}`);
-
 		App.Events.addParagraph(node, r);
-		r = [];
 
+		r = [];
 		r.push(`Sirens are blaring; there is a crump far above as ${V.arcologies[0].name}'s defensive systems knock down one of the first mortar rounds fired into the Free City. The lights in your office changed to a harsh emergency scheme as soon as the attack became a certainty.`);
 		if (V.assistant.personality <= 0) {
 			r.push(`Your personal assistant offers terse reports on the efficiency of the point defense fire.`);
@@ -82,15 +82,13 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent {
 			}
 		}
 		r.push(`It's going well. Whoever's in command of the attackers sees that their fire is having no effect, and orders an advance. The mortars and other artillery systems maintain their fire, trying to occupy as many guns as possible.`);
-
 		App.Events.addParagraph(node, r);
+		
 		r = [];
-
 		r.push(`The loose militia lately organized by the arcology owners has been called out to defend the city. Its commander, seeing that the attackers have more passion than tactical skill, orders an immediate counterattack by anyone able${(V.terrain === "marine" || V.terrain === "oceanic") ? " to push the invaders landing in the dock areas back into the sea" : ""}. Technology has advanced to the point that rich militiamen who buy their own gear can form a powerful fighting force. With luck, the counterattack should shatter the enemy.`);
-
 		App.Events.addParagraph(node, r);
+		
 		r = [];
-
 		if (V.personalArms === 0) {
 			r.push(`Since you are not well armed or armored, you stay back and oversee the defense of your own arcology.`);
 		} else if (V.personalArms === 1) {
@@ -98,44 +96,36 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent {
 		} else {
 			r.push(`Since you are well armed and armored and your drones are combat ready, you take part in the counterattack. You are preceded into combat by a wedge of your drones, which lack the intelligence to take good cover but are remorseless and highly accurate. Your exoskeleton mounts a smart mortar system that independently targets and eliminates enemy groups even as you lay down fire from the guns mounted on your forearms.`);
 		}
-
 		App.Events.addParagraph(node, r);
+		
 		r = [];
-
 		if (V.mercenaries === 0) {
 			r.push(`You are alone in contributing to the defense of your home.`);
-		} else if (V.mercenaries === 1) {
+		} else if (V.mercenaries >= 1) {
 			r.push(`Your mercenaries see to the defense of ${V.arcologies[0].name}, ensuring that nothing that gets through will do truly serious damage.`);
-		} else {
-			r.push(`Your mercenaries see to the defense of ${V.arcologies[0].name}, ensuring that nothing that gets through will do truly serious damage. There are enough of them that they can even spare a squad to accompany the counterattack. They're mostly old veterans of many bitter brush wars, and they go about the bloody business with the air of men and women who saw their first battlefield long before their hair was shot with grey.`);
+			if (V.mercenaries > 1) {
+				r.push(`There are enough of them that they can even spare a squad to accompany the counterattack. They're mostly old veterans of many bitter brush wars, and they go about the bloody business with the air of men and women who saw their first battlefield long before their hair was shot with grey.`);
+			}
 		}
-
 		App.Events.addParagraph(node, r);
+		
 		r = [];
-
 		if (V.mercenaries + V.personalArms < 2) {
 			r.push(`<span class="red">The counterattack fails.</span> The enemy is eventually defeated, but only after they get mired in urban combat in the streets of the Free City. <span class="red">${V.arcologies[0].name} takes considerable damage from`);
-			if (V.terrain === "ravine") {
-				r.push(`cliffside fire,`);
-			} else {
-				r.push(`stray fire,`);
-			}
-			r.push(`and many supplies have been lost or stolen.</span> The repairs will be extremely costly.`);
-			if (V.terrain === "ravine") {
-				cashX(forceNeg(Math.trunc(V.cash * 0.8)), "war");
-				cashX(-50000, "war");
-			} else {
-				cashX(forceNeg(Math.trunc(V.cash * 0.9)), "war");
-				cashX(-10000, "war");
-			}
+			r.push(`${ravineArc ? 'cliffside' : 'stray'} fire, and many supplies have been lost or stolen.</span> The repairs will be extremely costly.`);
+			App.Events.addParagraph(node, r);
+			cashX(forceNeg(Math.trunc(V.cash * (ravineArc ? 0.8 : 0.9))), "war");
+			cashX(ravineArc ? -50000 : -10000, "war");
 		} else if (V.mercenaries + V.personalArms < 6) {
 			r.push(`<span class="yellow">The counterattack succeeds.</span> <span class="red">${V.arcologies[0].name} takes minor damage from stray fire,</span> but the repairs are not too costly. Your participation in the counterattack that saved the Free City was noted, and <span class="green">you are acclaimed as a protector of its people.</span>`);
+			App.Events.addParagraph(node, r);
 			V.invasionVictory = 2;
 			cashX(forceNeg(Math.trunc(V.cash * 0.2)), "war");
 			cashX(-5000, "war");
 			repX(5000, "event");
 		} else {
 			r.push(`<span class="green">The counterattack is a crushing success.</span> Your mercenary squad and your drones form an irresistible phalanx around you that smashes everything it touches. The enemy is put to flight, and you send your drones racing ahead to take captives. By law these are shared among the militia. There is talk that your contributions deserve more than a few wretched slaves in reward. A public subscription pays for the damage ${V.arcologies[0].name} took from stray fire, and <span class="green">you are acclaimed a hero.</span>`);
+			App.Events.addParagraph(node, r);
 			V.invasionVictory = 3;
 			repX(10000, "event");
 
@@ -144,12 +134,9 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent {
 				slave.origin = "$He is an enslaved prisoner of war.";
 				newSlaves.push(slave);
 			}
-
 			V.menials += 5;
 			addTrinket("a shot-torn flag of the failed nation whose militants attacked the Free City");
 
-			App.Events.addParagraph(node, r);
-
 			App.Events.addResponses(node, [
 				new App.Events.Result(`Sell your prisoners immediately`, sell),
 				new App.Events.Result(`Give your prisoners to citizens who displayed bravery during the counterattack`, give),
@@ -157,23 +144,17 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent {
 			]);
 		}
 		function sell() {
-			for (const s of newSlaves) {
-				cashX(slaveCost(s), "slaveTransfer");
-			}
+			newSlaves.forEach(s => cashX(slaveCost(s), "slaveTransfer"));
 			return `Prisoners sold.`;
 		}
 
 		function give() {
-			for (const s of newSlaves) {
-				repX(Math.trunc(slaveCost(s) / 2), "event");
-			}
+			newSlaves.forEach(s => repX(Math.trunc(slaveCost(s) / 2), "event"));
 			return `Prisoners <span class="green">given away.</span>`;
 		}
 
 		function enslave() {
-			for (const s of newSlaves) {
-				newSlave(s); /* skip New Slave Intro */
-			}
+			newSlaves.forEach(s => newSlave(s)); // skip New Slave Intro
 			return `You simply enslave all of your prisoners yourself. These slaves will regret attacking your arcology.`;
 		}
 	}
-- 
GitLab