From 20d3058e5c2a33fbc073d38fdaae178d936e9e1c Mon Sep 17 00:00:00 2001 From: klorpa <klorpa@yahoo.com> Date: Tue, 22 Nov 2022 19:14:26 +0000 Subject: [PATCH] Spacing and Pronoun Fixes --- .../SecExp/buildings/riotControlCenter.js | 2 +- src/Mods/SecExp/events/secExpSmilingMan0.js | 2 +- src/Mods/SecExp/js/Unit.js | 2 +- src/Mods/SecExp/js/secExpObject.js | 60 ++++---- src/Mods/SpecialForce/AfterActionReport.js | 2 +- src/Mods/SpecialForce/FireBase.js | 42 +++--- src/Mods/SpecialForce/SpecialForceFS.js | 2 +- src/art/webgl/art.js | 2 +- src/art/webgl/contents.txt | 28 ++-- src/art/webgl/engine.js | 138 +++++++++--------- src/data/backwardsCompatibility/policiesBC.js | 2 +- src/endWeek/economics/neighborsDevelopment.js | 4 +- src/endWeek/economics/personalNotes.js | 2 +- src/endWeek/nextWeek/nextWeek.js | 2 +- src/endWeek/player/prDiet.js | 2 +- src/endWeek/player/prDrugs.js | 6 +- src/endWeek/player/prHormones.js | 4 +- src/endWeek/reports/penthouseReport.js | 2 +- src/endWeek/saChoosesOwnClothes.js | 2 +- src/endWeek/saSocialEffects.js | 2 +- src/endWeek/standardSlaveReport.js | 2 +- src/events/JE/jeSlaveDisputeBreedingDeal.js | 2 +- src/events/PE/foodplay.js | 8 +- src/events/intro/newGamePlusPassage.js | 2 +- src/events/nonRandom/pAbducted.js | 14 +- src/events/nonRandom/pFSAnnouncement.js | 2 +- src/events/nonRandom/pInvasion.js | 8 +- src/events/nonRandom/rival/pRivalryHostage.js | 2 +- src/events/recETS/recetsIncestTwinsMixed.js | 2 +- src/events/scheduled/assholeKnight.js | 2 +- src/events/scheduled/pitFightLethal.js | 2 +- src/facilities/salon/salonPassage.js | 2 +- src/facilities/surgery/analyzePregnancy.js | 4 +- .../encyclopediaFutureSocities.js | 2 +- src/gui/Encyclopedia/encyclopediaMods.js | 2 +- src/js/economyJS.js | 14 +- src/js/ibcJS.js | 2 +- src/js/rulesAutosurgery.js | 2 +- .../specificMarkets/householdLiquidator.js | 2 +- src/neighbor/neighborDescription.js | 2 +- src/npc/descriptions/descriptionWidgets.js | 8 +- src/npc/descriptions/ears.js | 18 +-- src/npc/generate/lawCompliance.js | 2 +- src/npc/interaction/fAnimal.js | 2 +- src/npc/startingGirls/startingGirlsPassage.js | 2 +- src/player/desc/pLongBody.js | 2 +- src/player/desc/pLongBoobs.js | 2 +- src/player/desc/pLongButt.js | 4 +- src/player/electiveSurgery.js | 2 +- src/player/pcSalon.js | 2 +- 50 files changed, 215 insertions(+), 215 deletions(-) diff --git a/src/Mods/SecExp/buildings/riotControlCenter.js b/src/Mods/SecExp/buildings/riotControlCenter.js index 428a4352280..7c649a455e8 100644 --- a/src/Mods/SecExp/buildings/riotControlCenter.js +++ b/src/Mods/SecExp/buildings/riotControlCenter.js @@ -226,7 +226,7 @@ App.Mods.SecExp.riotCenter = (function() { deploy.append("Spend: ", App.UI.DOM.generateLinksStrip(r)); return deploy; /** - * @param {string} cost + * @param {string} cost * @returns {HTMLSpanElement} */ function menu(cost) { diff --git a/src/Mods/SecExp/events/secExpSmilingMan0.js b/src/Mods/SecExp/events/secExpSmilingMan0.js index 32685d4c074..6a1253f6412 100644 --- a/src/Mods/SecExp/events/secExpSmilingMan0.js +++ b/src/Mods/SecExp/events/secExpSmilingMan0.js @@ -58,6 +58,6 @@ App.Events.secExpSmilingMan0 = class secExpSmilingMan0 extends App.Events.BaseEv App.Events.queueEvent(3, new App.Events.secExpSmilingMan1()); return `You do not consider this individual a threat.`; } - + } }; diff --git a/src/Mods/SecExp/js/Unit.js b/src/Mods/SecExp/js/Unit.js index b3d0d76aa14..c0126879643 100644 --- a/src/Mods/SecExp/js/Unit.js +++ b/src/Mods/SecExp/js/Unit.js @@ -220,7 +220,7 @@ App.Mods.SecExp.unit = (function() { if (V.peacekeepers.state === 3 && type !== "bots") { const unitAdjust = Math.ceil((unit.troops / 10) + (unit.maxTroops / 10) + (unit.training / 10) + unit.equip + unit.commissars + unit.cyber + unit.medics + unit.SF); const cost = forceNeg(25000 * (1.5 + unitAdjust)); - linkArray.push(App.UI.DOM.link(`Send this unit to improve your relationship with General ${V.peacekeepers.generalName}. Costs ${cashFormat(cost)}.`, () => { + linkArray.push(App.UI.DOM.link(`Send this unit to improve your relationship with General ${V.peacekeepers.generalName}. Costs ${cashFormat(cost)}.`, () => { V.peacekeepers.attitude += Math.ceil(unitAdjust / 5); cashX(cost, "securityExpansion"); unitFree(type).add(unit.troops); diff --git a/src/Mods/SecExp/js/secExpObject.js b/src/Mods/SecExp/js/secExpObject.js index de68ab601b0..451730fa1be 100644 --- a/src/Mods/SecExp/js/secExpObject.js +++ b/src/Mods/SecExp/js/secExpObject.js @@ -31,7 +31,7 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.settings.rebellion = V.SecExp.settings.rebellion || {}; V.SecExp.buildings = V.SecExp.buildings || {}; V.SecExp.proclamation = V.SecExp.proclamation || {}; - + V.SecExp.edicts.alternativeRents = V.SecExp.edicts.alternativeRents || V.alternativeRents || 0; V.SecExp.edicts.enslavementRights = V.SecExp.edicts.enslavementRights || V.enslavementRights || 0; V.SecExp.edicts.sellData = V.SecExp.edicts.sellData || V.sellData || 0; @@ -46,11 +46,11 @@ App.Mods.SecExp.Obj = (function() { if (typeof V.SecExp.edicts.weaponsLaw !== "number") { V.SecExp.edicts.weaponsLaw = V.weaponsLaw || 3; } - + V.SecExp.edicts.defense.soldierWages = V.SecExp.edicts.defense.soldierWages || V.soldierWages || 1; V.SecExp.edicts.defense.slavesOfficers = V.SecExp.edicts.defense.slavesOfficers || V.slavesOfficers || 0; V.SecExp.edicts.defense.discountMercenaries = V.SecExp.edicts.defense.discountMercenaries || V.discountMercenaries || 0; - + V.SecExp.edicts.defense.militia = V.SecExp.edicts.defense.militia || 0; if (V.militiaFounded) { V.SecExp.edicts.defense.militia = 1; @@ -67,13 +67,13 @@ App.Mods.SecExp.Obj = (function() { if (V.militarizedSociety) { V.SecExp.edicts.defense.militia = 5; } - + V.SecExp.edicts.defense.militaryExemption = V.SecExp.edicts.defense.militaryExemption || V.militaryExemption || 0; V.SecExp.edicts.defense.noSubhumansInArmy = V.SecExp.edicts.defense.noSubhumansInArmy || V.noSubhumansInArmy || 0; V.SecExp.edicts.defense.pregExemption = V.SecExp.edicts.defense.pregExemption || V.pregExemption || 0; V.SecExp.edicts.defense.liveTargets = V.SecExp.edicts.defense.liveTargets || V.liveTargets || 0; V.SecExp.edicts.defense.pregExemption = V.SecExp.edicts.defense.pregExemption || V.pregExemption || 0; - + // Units V.SecExp.edicts.defense.martialSchool = V.SecExp.edicts.defense.martialSchool || V.martialSchool || 0; V.SecExp.edicts.defense.eliteOfficers = V.SecExp.edicts.defense.eliteOfficers || V.eliteOfficers || 0; @@ -84,7 +84,7 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.edicts.defense.sunTzu = V.SecExp.edicts.defense.sunTzu || V.sunTzu || 0; V.SecExp.edicts.defense.mamluks = V.SecExp.edicts.defense.mamluks || V.mamluks || 0; V.SecExp.edicts.defense.pharaonTradition = V.SecExp.edicts.defense.pharaonTradition || V.pharaonTradition || 0; - + // Priv V.SecExp.edicts.defense.privilege = V.SecExp.edicts.defense.privilege || {}; V.SecExp.edicts.defense.privilege.militiaSoldier = V.SecExp.edicts.defense.privilege.militiaSoldier || V.militiaSoldier || 0; @@ -114,11 +114,11 @@ App.Mods.SecExp.Obj = (function() { u.SF = 0; } } - + if (unit !== 'bots' && u.platoonName.contains('undefined')) { u.platoonName = u.platoonName.replace('undefined', data.defaultName); } - + App.Mods.SecExp.unit.genID(u, unit); u.equip = u.equip || 0; delete u.isDeployed; @@ -132,14 +132,14 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.units.mercs.free = 30; } } - + if (V.SecExp.defaultNames) { V.SecExp.units.slaves.defaultName = V.SecExp.defaultNames.slaves; V.SecExp.units.militia.defaultName = V.SecExp.defaultNames.milita || V.SecExp.defaultNames.militia; V.SecExp.units.mercs.defaultName = V.SecExp.defaultNames.mercs; delete V.SecExp.defaultNames; } - + V.SecExp.smilingMan.progress = V.SecExp.smilingMan.progress || V.smilingManProgress || 0; if (jsDef(V.smilingManFate)) { if (V.smilingManFate === 0) { // Offer $him a new life @@ -150,7 +150,7 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.smilingMan.progress = 30; } } - + if (V.SecExp.smilingMan.progress === 4) { V.SecExp.smilingMan.progress = 10; } else if (V.SecExp.smilingMan.progress < 4) { @@ -164,11 +164,11 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.smilingMan.globalCrisisWeeks = V.globalCrisisWeeks; } } - + delete V.SecExp.core.crimeCap; V.SecExp.core.trade = V.SecExp.core.trade || V.trade || 0; initTrade(); - + V.SecExp.core.authority = V.SecExp.core.authority || V.authority || 0; V.SecExp.core.security = V.SecExp.core.security || V.security || 100; if (jsDef(V.SecExp.security)) { @@ -176,12 +176,12 @@ App.Mods.SecExp.Obj = (function() { delete V.SecExp.security; } V.SecExp.core.totalKills = +V.SecExp.core.totalKills || V.totalKills || 0; - + if (V.week === 1 || !jsDef(V.SecExp.core.crimeLow)) { V.SecExp.core.crimeLow = 30; } V.SecExp.core.crimeLow = Math.clamp(V.SecExp.core.crimeLow, 0, 100) || V.crime || 0; - + V.SecExp.battles.slaveVictories = V.SecExp.battles.slaveVictories || V.slaveVictories || []; V.SecExp.battles.major = V.SecExp.battles.major || 0; if (jsDef(V.majorBattlesCount)) { @@ -200,7 +200,7 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.battles.saved = V.SecExp.battles.saved || {}; V.SecExp.battles.saved.commander = V.SecExp.battles.saved.commander || V.SavedLeader || ""; V.SecExp.battles.saved.sfSupport = V.SecExp.battles.saved.sfSupport || V.SavedSFI || 0; - + V.SecExp.rebellions.tension = V.SecExp.rebellions.tension || V.tension || 0; V.SecExp.rebellions.slaveProgress = V.SecExp.rebellions.slaveProgress || V.slaveProgress || 0; V.SecExp.rebellions.citizenProgress = V.SecExp.rebellions.citizenProgress || V.citizenProgress || 0; @@ -211,7 +211,7 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.rebellions.sfArmor = V.SFGear; } V.SecExp.settings.difficulty = V.difficulty || V.SecExp.settings.difficulty || 1; - + if (!jsDef(V.SecExp.settings.battle.enabled)) { V.SecExp.settings.battle.enabled = 1; } @@ -219,25 +219,25 @@ App.Mods.SecExp.Obj = (function() { V.SecExp.settings.battle.enabled = V.battlesEnabled; } delete V.SecExp.battle; - + V.SecExp.settings.battle.frequency = V.battleFrequency || V.SecExp.settings.battle.frequency || 1; V.SecExp.settings.battle.force = V.forceBattle || V.SecExp.settings.battle.force || 0; - + if (V.readiness && V.readiness === 10 || V.sectionInFirebase) { V.SecExp.sectionInFirebase = 1; } - + V.SecExp.settings.unitDescriptions = V.SecExp.settings.unitDescriptions || 0; - + if (!jsDef(V.SecExp.settings.battle.allowSlavePrestige)) { V.SecExp.settings.battle.allowSlavePrestige = 1; } if (jsDef(V.allowPrestigeFromBattles)) { V.SecExp.settings.battle.allowSlavePrestige = V.allowPrestigeFromBattles; } - + V.SecExp.settings.battle.major.enabled = V.majorBattlesEnabled || V.SecExp.settings.battle.major.enabled || 0; - + if (!jsDef(V.SecExp.settings.battle.major.gameOver)) { V.SecExp.settings.battle.major.gameOver = 1; } @@ -246,14 +246,14 @@ App.Mods.SecExp.Obj = (function() { } V.SecExp.settings.battle.major.force = V.forceMajorBattle || V.SecExp.settings.battle.major.force || 0; V.SecExp.settings.battle.major.mult = V.SecExp.settings.battle.major.mult || 1; - + if (!jsDef(V.SecExp.settings.rebellion.enabled)) { V.SecExp.settings.rebellion.enabled = 1; } if (jsDef(V.rebellionsEnabled)) { V.SecExp.settings.rebellion.enabled = V.rebellionsEnabled; } - + V.SecExp.settings.rebellion.force = V.forceRebellion || V.SecExp.settings.rebellion.force || 0; if (!jsDef(V.SecExp.settings.rebellion.gameOver)) { V.SecExp.settings.rebellion.gameOver = 1; @@ -261,24 +261,24 @@ App.Mods.SecExp.Obj = (function() { if (jsDef(V.rebellionGameOver)) { V.SecExp.settings.rebellion.gameOver = V.rebellionGameOver; } - + V.SecExp.settings.rebellion.speed = V.rebellionSpeed || V.SecExp.settings.rebellion.speed || 1; V.SecExp.settings.showStats = V.showBattleStatistics || V.SecExp.settings.showStats || 0; - + App.Mods.SecExp.BC.propHub(); App.Mods.SecExp.BC.barracks(); App.Mods.SecExp.BC.secHub(); App.Mods.SecExp.BC.transportHub(); App.Mods.SecExp.BC.riotCenter(); App.Mods.SecExp.BC.weaponsManufacturing(); - + V.SecExp.proclamation.cooldown = V.SecExp.proclamation.cooldown || V.proclamationsCooldown || 0; V.SecExp.proclamation.currency = V.SecExp.proclamation.currency || V.proclamationCurrency || ""; V.SecExp.proclamation.type = V.SecExp.proclamation.type || "crime"; if (jsDef(V.proclamationType) && V.proclamationType !== "none") { V.SecExp.proclamation.type = V.proclamationType; } - + V.SecExp.rebellions.repairTime = V.SecExp.rebellions.repairTime || {}; if (jsDef(V.garrison)) { if (V.garrison.waterwayTime > 0) { @@ -294,7 +294,7 @@ App.Mods.SecExp.Obj = (function() { if (V.arcRepairTime && V.arcRepairTime > 0) { V.SecExp.rebellions.repairTime.arc = V.arcRepairTime; } - + delete V.SecExp.settings.show; }; diff --git a/src/Mods/SpecialForce/AfterActionReport.js b/src/Mods/SpecialForce/AfterActionReport.js index bc01d949040..dd65b78f79f 100644 --- a/src/Mods/SpecialForce/AfterActionReport.js +++ b/src/Mods/SpecialForce/AfterActionReport.js @@ -352,7 +352,7 @@ App.Mods.SF.AAR = function() { V.SF.MercCon.CanAttend = -1; } return [node, upkeep, profit]; - + function weeklyOptions() { const choices = document.createElement("span"); App.UI.DOM.appendNewElement("div", choices, `The Colonel looks down a list on her tablet. "There's some things we can do to help you out, boss.`); diff --git a/src/Mods/SpecialForce/FireBase.js b/src/Mods/SpecialForce/FireBase.js index 0cc6dcd35c1..05e600775b1 100644 --- a/src/Mods/SpecialForce/FireBase.js +++ b/src/Mods/SpecialForce/FireBase.js @@ -100,7 +100,7 @@ App.UI.FireBase = function() { App.UI.DOM.appendNewElement("p", node, ROE()); App.UI.DOM.appendNewElement("p", node, Accountability()); App.Events.addParagraph(node, ["Force depravity is a measure of how cruel and indifferent solders of the force are. This affects trade, how the force is viewed and or acts during some situations. Lower values lead to more ideal outcomes."]); - + if (V.SF.MercCon.CanAttend === 0 || V.SF.MercCon.History >= 1 && repeatTrigger) { r.push(`Her expression changes as something jogs her memory. "Before we begin, ${isBrazen ? `${properTitle()}` : 'boss'},`); if (V.SF.MercCon.CanAttend === 0) { @@ -176,10 +176,10 @@ App.UI.FireBase = function() { const text = new DocumentFragment(); let focus = document.createElement("span"); App.UI.DOM.appendNewElement("span", focus, mapping()); - + App.UI.DOM.appendNewElement("span", text, "Deployment focus: "); App.UI.DOM.appendNewElement("span", text, focus, "bold"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Recruiting and Training", () => { V.SF.Target = "recruit"; @@ -187,7 +187,7 @@ App.UI.FireBase = function() { }, [], "", "Increases the amount of FNGs at the cost of revenue." ), "indent"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Securing Trade Routes", () => { V.SF.Target = "secure"; @@ -195,7 +195,7 @@ App.UI.FireBase = function() { }, [], "", "Increases trade and reputation at the cost of revenue." ), "indent"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Raiding and Slaving", () => { V.SF.Target = "raiding"; @@ -203,9 +203,9 @@ App.UI.FireBase = function() { }, [], "", "Increases revenue at the cost of less FNGs and increased force depravity." ), "indent"); - + return text; - + function mapping() { switch (V.SF.Target) { case "recruit": @@ -217,15 +217,15 @@ App.UI.FireBase = function() { } } } - + function ROE() { const text = new DocumentFragment(); let focus = document.createElement("span"); App.UI.DOM.appendNewElement("span", focus, mapping()); - + App.UI.DOM.appendNewElement("span", text, "Rules of Engagements: "); App.UI.DOM.appendNewElement("span", text, focus, "bold"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Hold Fire", () => { V.SF.ROE = "hold"; @@ -233,7 +233,7 @@ App.UI.FireBase = function() { }, [], "", "Reduces force depravity." ), "indent"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("limited Fire", () => { V.SF.ROE = "limited"; @@ -241,7 +241,7 @@ App.UI.FireBase = function() { }, [], "", "Does not adjust force depravity." ), "indent"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Free Fire", () => { V.SF.ROE = "free"; @@ -249,9 +249,9 @@ App.UI.FireBase = function() { }, [], "", "Increases force depravity." ), "indent"); - + return text; - + function mapping() { switch (V.SF.ROE) { case "hold": @@ -263,15 +263,15 @@ App.UI.FireBase = function() { } } } - + function Accountability() { const text = new DocumentFragment(); let focus = document.createElement("span"); App.UI.DOM.appendNewElement("span", focus, mapping()); - + App.UI.DOM.appendNewElement("span", text, "Rules of Engagements: "); App.UI.DOM.appendNewElement("span", text, focus, "bold"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Strict Accountability", () => { V.SF.Regs = "strict"; @@ -279,7 +279,7 @@ App.UI.FireBase = function() { }, [], "", "Reduces force depravity." ), "indent"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("Some Accountability", () => { V.SF.Regs = "some"; @@ -287,7 +287,7 @@ App.UI.FireBase = function() { }, [], "", "Does not adjust force depravity." ), "indent"); - + App.UI.DOM.appendNewElement("div", text, App.UI.DOM.link("No Accountability", () => { V.SF.Regs = "none"; @@ -295,9 +295,9 @@ App.UI.FireBase = function() { }, [], "", "Increases force depravity." ), "indent"); - + return text; - + function mapping() { switch (V.SF.Regs) { case "strict": diff --git a/src/Mods/SpecialForce/SpecialForceFS.js b/src/Mods/SpecialForce/SpecialForceFS.js index ce94d1dba85..37937314e59 100644 --- a/src/Mods/SpecialForce/SpecialForceFS.js +++ b/src/Mods/SpecialForce/SpecialForceFS.js @@ -777,7 +777,7 @@ App.Mods.SF.fsIntegration = (function() { if (passage() === "Economics" && !firstExecution) { App.UI.DOM.appendNewElement("div", t, `This week your arcology lost a bit of prosperity and large amount of reputation, due to the looming threat that The Colonel and her forces may resurface.`, ["red"]); } - + let type; switch (V.SF.Colonel.Core) { case "kind": diff --git a/src/art/webgl/art.js b/src/art/webgl/art.js index d84de114fb5..be76df5f303 100644 --- a/src/art/webgl/art.js +++ b/src/art/webgl/art.js @@ -1143,7 +1143,7 @@ App.Art.applySurfaces = function(slave, scene, p) { torsoLayers.push("tattoo_breeding"); } - if (slave.birthsTat > 0 && slave.birthsTat >= 100) { + if (slave.birthsTat > 0 && slave.birthsTat >= 100) { let location = "left abdomen"; let [, center, layer] = getDecalArea(location); if (layer !== null) { diff --git a/src/art/webgl/contents.txt b/src/art/webgl/contents.txt index 0aa0767332d..0653f90fda9 100644 --- a/src/art/webgl/contents.txt +++ b/src/art/webgl/contents.txt @@ -1,7 +1,7 @@ OUTDATED!!! ///////////////// MORPHS ///////////////// -General +General physicalAgeYoung physicalAgeOld weight @@ -22,14 +22,14 @@ General dickRemove vaginaRemove - just closes the vagina -amputee +amputee leftArm rightArm leftLeg rightLeg boobShape - small + small normal perky saggy @@ -42,7 +42,7 @@ nipples huge puffy -faceShape +faceShape normal masculine androgynous @@ -50,15 +50,15 @@ faceShape sensual exotic -lips +lips thin normal pretty plush huge facepussy - -eyes + +eyes normal wide round @@ -66,16 +66,16 @@ eyes slit small open - -nose + +nose normal wide forward flat triangular small - -forehead + +forehead normal round small @@ -84,7 +84,7 @@ expressions happy fear -race +race white asian latina @@ -97,7 +97,7 @@ race indo-aryan (aryan) malay -poses +poses high mid low @@ -110,7 +110,7 @@ general makeup fingernails -skin color +skin color pure white (Ceridwen) ivory (Ceridwen) white (Ceridwen) diff --git a/src/art/webgl/engine.js b/src/art/webgl/engine.js index a89db2b1a5d..075f3198181 100644 --- a/src/art/webgl/engine.js +++ b/src/art/webgl/engine.js @@ -46,7 +46,7 @@ App.Art.Engine = class { if (map_d < 0.85) discard; - + gPosition = pos; gNormal = normalize(normal); }`; @@ -81,7 +81,7 @@ App.Art.Engine = class { if (map_d < 0.85) discard; - + gShadowDepth = gl_FragCoord.z; }`; } @@ -139,19 +139,19 @@ App.Art.Engine = class { { // get sample position vec3 samplePos = TBN * samples[i]; // from tangent to view-space - samplePos = pos + samplePos * radius; - + samplePos = pos + samplePos * radius; + // project sample position vec4 offset = vec4(samplePos, 1.0); offset = projection * offset; // from view to clip-space offset.xy /= offset.w; // perspective divide offset.xy = offset.xy * 0.5 + 0.5; // transform to range 0.0 - 1.0 - + float sampleDepth = texture(gPosition, offset.xy).z; - + // range check & accumulate float rangeCheck = smoothstep(0.0, 1.0, radius / abs(pos.z - sampleDepth)); - occlusion += (sampleDepth <= samplePos.z + bias ? 1.0 : 0.0) * rangeCheck; + occlusion += (sampleDepth <= samplePos.z + bias ? 1.0 : 0.0) * rangeCheck; } ao = 1.0 - (occlusion / scale); }`; @@ -166,14 +166,14 @@ App.Art.Engine = class { uniform sampler2D ssaoInput; uniform float blur; - - void main() + + void main() { vec2 texelSize = 1.0 / vec2(textureSize(ssaoInput, 0)); float result = 0.0; - for (float x = -blur; x <= blur; x++) + for (float x = -blur; x <= blur; x++) { - for (float y = -blur; y <= blur; y++) + for (float y = -blur; y <= blur; y++) { vec2 offset = vec2(x, y) * texelSize; result += texture(ssaoInput, textureCoord + offset).r; @@ -222,19 +222,19 @@ App.Art.Engine = class { { // get sample position vec3 samplePos = TBN * samples[i]; // from tangent to view-space - samplePos = pos + samplePos * radius; - + samplePos = pos + samplePos * radius; + // project sample position vec4 offset = vec4(samplePos, 1.0); offset = projection * offset; // from view to clip-space offset.xy /= offset.w; // perspective divide offset.xy = offset.xy * 0.5 + 0.5; // transform to range 0.0 - 1.0 - + float sampleDepth = texture(gPosition, offset.xy).z; - + // range check & accumulate float rangeCheck = smoothstep(0.0, 1.0, radius / abs(pos.z - sampleDepth)); - occlusion += (sampleDepth <= samplePos.z + bias ? 1.0 : 0.0) * rangeCheck; + occlusion += (sampleDepth <= samplePos.z + bias ? 1.0 : 0.0) * rangeCheck; } iao = 1.0 - (occlusion / scale); }`; @@ -249,14 +249,14 @@ App.Art.Engine = class { uniform sampler2D sssInput; uniform float blur; - - void main() + + void main() { vec2 texelSize = 1.0 / vec2(textureSize(sssInput, 0)); float result = 0.0; - for (float x = -blur; x <= blur; x++) + for (float x = -blur; x <= blur; x++) { - for (float y = -blur; y <= blur; y++) + for (float y = -blur; y <= blur; y++) { vec2 offset = vec2(x, y) * texelSize; result += texture(sssInput, textureCoord + offset).r; @@ -269,7 +269,7 @@ App.Art.Engine = class { getFsSourceForwardPass(dl, pl) { return `#version 300 es precision highp float; - + uniform float lightInt[${dl}]; uniform vec3 lightAmb[${dl}]; uniform vec3 lightColor[${dl}]; @@ -327,7 +327,7 @@ App.Art.Engine = class { uniform float sSSS; uniform float overlay; - + uniform vec3 cameraPos; uniform sampler2D textSampler[10]; @@ -341,23 +341,23 @@ App.Art.Engine = class { const float PI = 3.14159265359; - vec2 poissonDisk[16] = vec2[]( - vec2( -0.94201624, -0.39906216 ), - vec2( 0.94558609, -0.76890725 ), - vec2( -0.094184101, -0.92938870 ), - vec2( 0.34495938, 0.29387760 ), - vec2( -0.91588581, 0.45771432 ), - vec2( -0.81544232, -0.87912464 ), - vec2( -0.38277543, 0.27676845 ), - vec2( 0.97484398, 0.75648379 ), - vec2( 0.44323325, -0.97511554 ), - vec2( 0.53742981, -0.47373420 ), - vec2( -0.26496911, -0.41893023 ), - vec2( 0.79197514, 0.19090188 ), - vec2( -0.24188840, 0.99706507 ), - vec2( -0.81409955, 0.91437590 ), - vec2( 0.19984126, 0.78641367 ), - vec2( 0.14383161, -0.14100790 ) + vec2 poissonDisk[16] = vec2[]( + vec2( -0.94201624, -0.39906216 ), + vec2( 0.94558609, -0.76890725 ), + vec2( -0.094184101, -0.92938870 ), + vec2( 0.34495938, 0.29387760 ), + vec2( -0.91588581, 0.45771432 ), + vec2( -0.81544232, -0.87912464 ), + vec2( -0.38277543, 0.27676845 ), + vec2( 0.97484398, 0.75648379 ), + vec2( 0.44323325, -0.97511554 ), + vec2( 0.53742981, -0.47373420 ), + vec2( -0.26496911, -0.41893023 ), + vec2( 0.79197514, 0.19090188 ), + vec2( -0.24188840, 0.99706507 ), + vec2( -0.81409955, 0.91437590 ), + vec2( 0.19984126, 0.78641367 ), + vec2( 0.14383161, -0.14100790 ) ); float distributionGGX(vec3 N, vec3 H, float roughness) @@ -366,22 +366,22 @@ App.Art.Engine = class { float a2 = a*a; float NdotH = max(dot(N, H), 0.0); float NdotH2 = NdotH*NdotH; - + float num = a2; float denom = (NdotH2 * (a2 - 1.0) + 1.0); denom = PI * denom * denom; - + return num / denom; } - + float geometrySchlickGGX(float NdotV, float roughness) { float r = (roughness + 1.0); float k = (r*r) / 8.0; - + float num = NdotV; float denom = NdotV * (1.0 - k) + k; - + return num / denom; } @@ -391,7 +391,7 @@ App.Art.Engine = class { float NdotL = max(dot(N, L), 0.0); float ggx2 = geometrySchlickGGX(NdotV, roughness); float ggx1 = geometrySchlickGGX(NdotL, roughness); - + return ggx1 * ggx2; } @@ -429,15 +429,15 @@ App.Art.Engine = class { float S1 = m + a * l0; float C2 = (a * P) / (P - S1); float CP = -C2 / P; - + vec3 w0 = 1.0 - smoothstep(0.0, m, x); vec3 w2 = step(m + l0, x); vec3 w1 = 1.0 - w0 - w2; - + vec3 T = m * pow(x / m, vec3(c)) + b; vec3 S = P - (P - S1) * exp(CP * (x - S0)); vec3 L = m + a * (x - m); - + return T * w0 + L * w1 + S * w2; } @@ -466,7 +466,7 @@ App.Art.Engine = class { coord = vec2(coord.x * cos(angle) - coord.y * sin(angle), coord.x * sin(angle) + coord.y * cos(angle)); coord = coord / scale; coord = coord + vec2(0.5, 0.5); - + if (sAlpha == 1.0) map_d = d * texture(textSampler[1], coord).r; @@ -500,7 +500,7 @@ App.Art.Engine = class { if (sShadows == 1.0) { vec3 projCoords = shadowMap.xyz/shadowMap.w * 0.5 + 0.5; float currentDepth = projCoords.z; - float bias = max(shadowBiasMax * (1.0 - dot(new_normal, shadowDir)), shadowBiasMin); + float bias = max(shadowBiasMax * (1.0 - dot(new_normal, shadowDir)), shadowBiasMin); vec2 texelSize = 1.0 / vec2(textureSize(textSampler[8], 0)); for (int i=0;i<16;i++){ @@ -530,21 +530,21 @@ App.Art.Engine = class { // calculate per-light radiance vec3 L = -lightVect[i]; vec3 H = normalize(V + L); - vec3 radiance = lightColor[i] * lightInt[i]; - + vec3 radiance = lightColor[i] * lightInt[i]; + // cook-torrance brdf - float NDF = distributionGGX(N, H, roughness); - float G = geometrySmith(N, V, L, roughness); - vec3 F = fresnelSchlickRoughness(max(dot(H, V), 0.0), F0, roughness); - + float NDF = distributionGGX(N, H, roughness); + float G = geometrySmith(N, V, L, roughness); + vec3 F = fresnelSchlickRoughness(max(dot(H, V), 0.0), F0, roughness); + vec3 numerator = NDF * G * F; float denominator = 4.0 * max(dot(N, V), 0.0) * max(dot(N, L), 0.0) + 0.00001; - vec3 specular = numerator / denominator; + vec3 specular = numerator / denominator; // kS is equal to Fresnel vec3 kD = vec3(1.0) - F; - kD *= 1.0 - metallic; - + kD *= 1.0 - metallic; + // add to outgoing radiance Lo float NdotL = max(dot(N, L), 0.0); if (map_d >= 0.85 || overlay == 1.0) { @@ -579,21 +579,21 @@ App.Art.Engine = class { // calculate per-light radiance vec3 L = normalize(pointLightPos[i] - pos); vec3 H = normalize(V + L); - vec3 radiance = pointLightColor[i] * pointLightInt[i]; - + vec3 radiance = pointLightColor[i] * pointLightInt[i]; + // cook-torrance brdf - float NDF = distributionGGX(N, H, roughness); - float G = geometrySmith(N, V, L, roughness); - vec3 F = fresnelSchlickRoughness(max(dot(H, V), 0.0), F0, roughness); - + float NDF = distributionGGX(N, H, roughness); + float G = geometrySmith(N, V, L, roughness); + vec3 F = fresnelSchlickRoughness(max(dot(H, V), 0.0), F0, roughness); + vec3 numerator = NDF * G * F; float denominator = 4.0 * max(dot(N, V), 0.0) * max(dot(N, L), 0.0) + 0.00001; - vec3 specular = numerator / denominator; + vec3 specular = numerator / denominator; // kS is equal to Fresnel vec3 kD = vec3(1.0) - F; - kD *= 1.0 - metallic; - + kD *= 1.0 - metallic; + // add to outgoing radiance Lo float NdotL = max(dot(N, L), 0.0); if (map_d >= 0.85 || overlay == 1.0) { @@ -637,7 +637,7 @@ App.Art.Engine = class { if (sGamma == 1.0) c = pow(c, vec3(1.0/gammaY)); - + if (sNormals == 1.0) c = new_normal*0.5+0.5; diff --git a/src/data/backwardsCompatibility/policiesBC.js b/src/data/backwardsCompatibility/policiesBC.js index 3143dead083..b967d1a122b 100644 --- a/src/data/backwardsCompatibility/policiesBC.js +++ b/src/data/backwardsCompatibility/policiesBC.js @@ -17,7 +17,7 @@ App.Update.policies = function() { gumjobFetishism: 0, gumjobFetishismSMR: 0, idealAge: 0 - }); + }); // Spelling fixes: V.policies.sexualOpenness = V.policies.sexualOpenness || V.policies.sexualOpeness || 0; diff --git a/src/endWeek/economics/neighborsDevelopment.js b/src/endWeek/economics/neighborsDevelopment.js index bc3c6c994dd..3e97621a764 100644 --- a/src/endWeek/economics/neighborsDevelopment.js +++ b/src/endWeek/economics/neighborsDevelopment.js @@ -2083,7 +2083,7 @@ App.EndWeek.neighborsDevelopment = function() { } /* CROSS-FS ADOPTION */ - /** Map from source to an array of destination FSes. On the destination side, order matters; adoption is attempted in sequence through the array. + /** Map from source to an array of destination FSes. On the destination side, order matters; adoption is attempted in sequence through the array. * If several destination FSes should be equally likely at a particular stage, put them in a nested array. * @typedef {{fs: FC.FutureSociety, prereqs?: () => boolean, msg: string}} crossFSDest * @type {Map<FC.FutureSociety, (crossFSDest|crossFSDest[])[]>} */ @@ -2569,7 +2569,7 @@ App.EndWeek.neighborsDevelopment = function() { r.push(`${arc.name} is aligned with ${toSentence(aligned)} socially, encouraging it to consider adopting more of ${aligned.length > 1 ? 'their' : 'its'} cultural values.`); } if (opposed.length > 0) { - r.push(`${arc.name} is culturally opposed with ${toSentence(opposed)} socially, encouraging it to resist adopting ${opposed.length > 1 ? 'their' : 'its'} cultural values.`); + r.push(`${arc.name} is culturally opposed with ${toSentence(opposed)} socially, encouraging it to resist adopting ${opposed.length > 1 ? 'their' : 'its'} cultural values.`); } if (usableCandidates.length > 0) { const chosen = usableCandidates.random(); diff --git a/src/endWeek/economics/personalNotes.js b/src/endWeek/economics/personalNotes.js index de0869c2201..cfa10672ce7 100644 --- a/src/endWeek/economics/personalNotes.js +++ b/src/endWeek/economics/personalNotes.js @@ -36,7 +36,7 @@ App.EndWeek.personalNotes = function() { App.Events.addParagraph(el, r); r = []; - + if (V.useTabs === 1) { App.UI.DOM.appendNewElement("h2", el, `Diet`); } diff --git a/src/endWeek/nextWeek/nextWeek.js b/src/endWeek/nextWeek/nextWeek.js index 38fba02bc6d..9207235f9ad 100644 --- a/src/endWeek/nextWeek/nextWeek.js +++ b/src/endWeek/nextWeek/nextWeek.js @@ -330,7 +330,7 @@ App.EndWeek.nextWeek = function() { V.pSurgery.nursePreg = -3; } } - + if (V.doctor.state > 1) { V.doctor.state = 1; } diff --git a/src/endWeek/player/prDiet.js b/src/endWeek/player/prDiet.js index 178dfc59d92..f470ac257de 100644 --- a/src/endWeek/player/prDiet.js +++ b/src/endWeek/player/prDiet.js @@ -87,7 +87,7 @@ App.EndWeek.Player.diet = function(PC = V.PC) { if (PC.vagina >= 0 && PC.vaginaLube === 0 && PC.energy > 20 && random(1, 100) > (100 - (PC.energy / 4))) { r.push(`It also gets the juices flowing; <span class="change positive">your pussy is no longer so dry.</span>`); PC.vaginaLube = 1; - } else if (PC.energy > 95 && random(1, 100) > 40 + ((100 - PC.energy) * 10)) { + } else if (PC.energy > 95 && random(1, 100) > 40 + ((100 - PC.energy) * 10)) { r.push(`It also gets the juices really flowing; <span class="change positive">your pussy has become so wet</span> that you're soaked with arousal by the end of your meal.`); PC.vaginaLube = 2; } diff --git a/src/endWeek/player/prDrugs.js b/src/endWeek/player/prDrugs.js index 96bc58a56f8..2d8e40b9f22 100644 --- a/src/endWeek/player/prDrugs.js +++ b/src/endWeek/player/prDrugs.js @@ -1343,7 +1343,7 @@ App.EndWeek.Player.drugs = function(PC = V.PC) { r.push(`Your massive <span class="change positive">cock shrinks dully,</span> becoming noticeably shorter and thinner.`); shrinkage = 2; } else if ((PC.geneMods.NCS === 1) || (random(1, 100) > 40 - (V.injectionUpgrade * 10) - (PC.dick * 5) && PC.dick > 1)) { - r.push(`Your <span class="change positive">cock shrinks dully,</span> becoming shorter and thinner.`); + r.push(`Your <span class="change positive">cock shrinks dully,</span> becoming shorter and thinner.`); shrinkage = 1; } if (PC.geneMods.NCS === 1 && PC.dick > 2) { @@ -1379,7 +1379,7 @@ App.EndWeek.Player.drugs = function(PC = V.PC) { r.push(`Your enormous <span class="change positive">balls shrink dully,</span> losing mass inside your scrotum.`); shrinkage = 1; } else if ((PC.geneMods.NCS === 1) || (random(1, 100) > 40 - (V.injectionUpgrade * 10) - (PC.balls * 2) && PC.balls > 1)) { - r.push(`Your <span class="change positive">balls shrink dully,</span> becoming smaller and filling out your scrotum less.`); + r.push(`Your <span class="change positive">balls shrink dully,</span> becoming smaller and filling out your scrotum less.`); shrinkage = 1; } if (PC.geneMods.NCS === 1 && PC.balls > 2) { @@ -1623,7 +1623,7 @@ App.EndWeek.Player.drugs = function(PC = V.PC) { healthDamage(PC, 10); r.push(`Since you've passed your due date, something your body is well aware of, the drugs begin having a <span class="health dec">negative affect on your health.</span>`); } else if (WombBirthReady(PC, PC.pregData.normalBirth * .90) > 0) { - r.push(`You're getting close to your intended due date, so it may be time to stop taking the drugs and "pop the cork," so to speak.`); + r.push(`You're getting close to your intended due date, so it may be time to stop taking the drugs and "pop the cork," so to speak.`); } } } diff --git a/src/endWeek/player/prHormones.js b/src/endWeek/player/prHormones.js index 3092dc19603..f33394534f1 100644 --- a/src/endWeek/player/prHormones.js +++ b/src/endWeek/player/prHormones.js @@ -125,8 +125,8 @@ App.EndWeek.Player.hormones = function(PC, selfManufactured, hormonePower) { const slimModBreasts = (V.arcologies[0].FSSlimnessEnthusiastFoodLaw === 1 && !canEatFood(PC)) ? 0.45 : 1; // 600 average breast target, 270 target, 475 @ 350 hormone const slimModButts = (V.arcologies[0].FSSlimnessEnthusiastFoodLaw === 1 && !canEatFood(PC)) ? 0.6 : 1; // 2.5 average butt, 1.5 target /* 'Expected' breast size based on weight for feminine-bodied player. Masculine-bodied takes a small hit. */ - normBreasts = Math.trunc((100 + (PC.weight + 100) * 5 + 2 * PC.lactationAdaptation) * (0.85 + PC.hormoneBalance / 400) * gigantomastiaMod * slimModBreasts / Math.max(PC.title * 1.25, 1)); - normButt = ((PC.weight + 100) * 0.025 * (0.9 + PC.hormoneBalance / 600) * (rearLipedemaMod / 2 + 1) * slimModButts / Math.max(PC.title * 1.10, 1)); + normBreasts = Math.trunc((100 + (PC.weight + 100) * 5 + 2 * PC.lactationAdaptation) * (0.85 + PC.hormoneBalance / 400) * gigantomastiaMod * slimModBreasts / Math.max(PC.title * 1.25, 1)); + normButt = ((PC.weight + 100) * 0.025 * (0.9 + PC.hormoneBalance / 600) * (rearLipedemaMod / 2 + 1) * slimModButts / Math.max(PC.title * 1.10, 1)); } if (PC.hormoneBalance >= 350) { diff --git a/src/endWeek/reports/penthouseReport.js b/src/endWeek/reports/penthouseReport.js index 053be20e10e..e2b8133c83a 100644 --- a/src/endWeek/reports/penthouseReport.js +++ b/src/endWeek/reports/penthouseReport.js @@ -61,7 +61,7 @@ App.EndWeek.penthouseReport = function() { } = getPronouns(slave); let r = []; let milkResults; - + r.push(App.SlaveAssignment.saSlaveIntro(slave, '')); if (slave.choosesOwnAssignment) { r.push(He); // starts new sentence diff --git a/src/endWeek/saChoosesOwnClothes.js b/src/endWeek/saChoosesOwnClothes.js index c2794b7b947..d82d7051888 100644 --- a/src/endWeek/saChoosesOwnClothes.js +++ b/src/endWeek/saChoosesOwnClothes.js @@ -997,7 +997,7 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { } } if (V.arcologies[0].FSChattelReligionist > 0) { - // Chattel religionism is currently the only FS with a hard advancement link to clothing. Accepting slaves should never voluntarily select an outfit that won't help. + // Chattel religionism is currently the only FS with a hard advancement link to clothing. Accepting slaves should never voluntarily select an outfit that won't help. clothing.deleteWith(c => !ChattelReligionistClothingPass(c.clothes)); if (clothing.length < 1) { if (V.arcologies[0].FSChattelReligionistLaw2 === 1) { diff --git a/src/endWeek/saSocialEffects.js b/src/endWeek/saSocialEffects.js index f44a50ee253..7001dd37118 100644 --- a/src/endWeek/saSocialEffects.js +++ b/src/endWeek/saSocialEffects.js @@ -1070,7 +1070,7 @@ App.SlaveAssignment.saSocialEffects = function(slave) { // temporarily enact the FS at full strength V.arcologies[0][proposedFS] = 100; // see what the slave's social effects would be under the proposed FS - const newSocialEffects = [...makeSocialEffects(), ...makeShelterGirlEffects()]; + const newSocialEffects = [...makeSocialEffects(), ...makeShelterGirlEffects()]; // undo the temporary FS enactment V.arcologies[0][proposedFS] = "unset"; // return the differences between the current and new states diff --git a/src/endWeek/standardSlaveReport.js b/src/endWeek/standardSlaveReport.js index 9890556c281..b4962282ac7 100644 --- a/src/endWeek/standardSlaveReport.js +++ b/src/endWeek/standardSlaveReport.js @@ -65,7 +65,7 @@ App.SlaveAssignment.saSlaveName = function(slave) { /** * Render linkified slave name with job assignment statement. * @param {App.Entity.SlaveState} slave - * @param {string} def - this statement will be used if the slave ISN'T choosing her own job. Generally, something like "is <verb>ing in <facility>." Note that penthouse jobs do not have a default job statement, instead leading directly into the job text if the slave is not choosing her own job. + * @param {string} def - this statement will be used if the slave ISN'T choosing her own job. Generally, something like "is <verb>ing in <facility>." Note that penthouse jobs do not have a default job statement, instead leading directly into the job text if the slave is not choosing her own job. */ App.SlaveAssignment.saSlaveIntro = function(slave, def) { const frag = this.saSlaveName(slave); diff --git a/src/events/JE/jeSlaveDisputeBreedingDeal.js b/src/events/JE/jeSlaveDisputeBreedingDeal.js index c59d2d39e02..521f0125e32 100644 --- a/src/events/JE/jeSlaveDisputeBreedingDeal.js +++ b/src/events/JE/jeSlaveDisputeBreedingDeal.js @@ -99,7 +99,7 @@ App.Events.JESlaveDisputeBreedingDeal = class JESlaveDisputeBreedingDeal extends const frag = new DocumentFragment(); let r = []; cashX(forceNeg(contractCost), "slaveTransfer"); - r.push(`You offer to buy out the deal, paying the breeder and taking the slave yourself, and passing the child off to the buyer. The citizen gets what he wants and speaks <span class="green">kindly</span> in public about how you helped smooth over a rather rough dispute. The breeder sends a <span class="green">positive note</span> around the industry to the effect that slavers trading with your arcology can expect to be aided in times of need; though the loss of a star mother always stings.`); + r.push(`You offer to buy out the deal, paying the breeder and taking the slave yourself, and passing the child off to the buyer. The citizen gets what he wants and speaks <span class="green">kindly</span> in public about how you helped smooth over a rather rough dispute. The breeder sends a <span class="green">positive note</span> around the industry to the effect that slavers trading with your arcology can expect to be aided in times of need, though the loss of a star mother always stings.`); V.arcologies[0].prosperity += 3; repX(300, "event"); App.Events.addParagraph(frag, r); diff --git a/src/events/PE/foodplay.js b/src/events/PE/foodplay.js index 512371f58de..fbd1d709c3c 100644 --- a/src/events/PE/foodplay.js +++ b/src/events/PE/foodplay.js @@ -42,7 +42,7 @@ App.Events.PEFoodplay = class PEFoodplay extends App.Events.BaseEvent { r.push(`You summon`); r.push(contextualIntro(V.PC, eventSlave, true)); - r.push(`to your office and order her to lie down on your desk.`); + r.push(`to your office and order ${him} to lie down on your desk.`); if (hasAnyLegs(eventSlave)){ if (eventSlave.devotion > 50){ r.push(`${He} complies with a smile, excited to see what you have in store for ${him}.`); @@ -84,7 +84,7 @@ App.Events.PEFoodplay = class PEFoodplay extends App.Events.BaseEvent { r.toParagraph(); - r.push(`Two pieces are laid onto her`); + r.push(`Two pieces are laid onto ${his}`); if (eventSlave.boobs > 40000) { r.push(`gargantuan`); } else if (eventSlave.boobs > 25000) { @@ -111,7 +111,7 @@ App.Events.PEFoodplay = class PEFoodplay extends App.Events.BaseEvent { } if (eventSlave.areolae > 2){ - r.push(`, barely covering her huge areolas`); + r.push(`, barely covering ${his} huge areolas`); } r.push(`and ${eventSlave.nipples} nipples.`); @@ -270,7 +270,7 @@ App.Events.PEFoodplay = class PEFoodplay extends App.Events.BaseEvent { r.toParagraph(); - r.push(`Under your eager attention, ${eventSlave.slaveName} collapses in a moaning, writhing puddle on your desk. You clean your mouth with a handkerchief and tell her to get back to her assignment before calling in another slave to clean up the mess.`); + r.push(`Under your eager attention, ${eventSlave.slaveName} collapses in a moaning, writhing puddle on your desk. You clean your mouth with a handkerchief and tell ${him} to get back to ${his} assignment before calling in another slave to clean up the mess.`); r.toParagraph(); diff --git a/src/events/intro/newGamePlusPassage.js b/src/events/intro/newGamePlusPassage.js index d787e281407..f2b27c4f23d 100644 --- a/src/events/intro/newGamePlusPassage.js +++ b/src/events/intro/newGamePlusPassage.js @@ -12,7 +12,7 @@ App.Intro.newGamePlus = function() { if (V.cash >= fee) { App.Events.addNode(node, [`You have allocated funds to bring up to ${V.slavesToImportMax} slaves with you (or your equivalent) to a new arcology. It will cost <span class="yellowgreen">${cashFormat(fee)}</span> to ensure another slave's safe transfer. You have <span class="yellowgreen">${cashFormat(V.cash)}</span> to spend.`], "div"); App.UI.DOM.appendNewElement("div", node, makePurchase( - "Increase slave import capacity by 1.", fee, "capEx", + "Increase slave import capacity by 1.", fee, "capEx", {handler: () => { V.slavesToImportMax++; }} )); } else { diff --git a/src/events/nonRandom/pAbducted.js b/src/events/nonRandom/pAbducted.js index ffce82a2caa..58314473eb0 100644 --- a/src/events/nonRandom/pAbducted.js +++ b/src/events/nonRandom/pAbducted.js @@ -29,7 +29,7 @@ App.Events.pAbducted = class pAbducted extends App.Events.BaseEvent { abductor.skill.oral = 0; abductor.skill.anal = 0; abductor.muscles = Math.max(abductor.muscles, 40); - abductor.origin = `You sentenced $him to enslavement for the attempted abduction of a child.`; + abductor.origin = `You sentenced $him to enslavement for the attempted abduction of a child - you, to be exact.`; abductor.devotion = -100; abductor.trust = -100; setHealth(abductor, jsRandom(-40, -20), normalRandInt(15, 3), undefined, 1, random(30, 80)); @@ -39,10 +39,10 @@ App.Events.pAbducted = class pAbducted extends App.Events.BaseEvent { const { He, - his, he, him + his, he, him, himself, woman } = getPronouns(abductor); - r.push(`While returning from a meeting with a prospective investor, an unfortunate wrong turn has led you into a rather seedy area of your arcology. You feel distinctly uncomfortable for some reason. You suspicions are quickly confirmed as a bag is swung over your head. Your grab your assailant's wrists and struggle to keep them from completely engulfing you,`); + r.push(`While returning from a meeting with a prospective investor, an unfortunate wrong turn has led you into a rather seedy area of your arcology. You feel distinctly uncomfortable for some reason. Your suspicions are quickly confirmed as a bag is swung over your head. Your grab your assailant's wrists and struggle to keep them from completely engulfing you,`); if (overpowerCheck(abductor, V.PC) >= random(1, 100)) { r.push(`only to find that you're quite capable of keeping them at bay.`); @@ -60,7 +60,7 @@ App.Events.pAbducted = class pAbducted extends App.Events.BaseEvent { r.push(`You cry out as you yank the weapon from your body, and clutching the gushing wound, hobble back the way you came — the way back to safety. The world spins as you lose consciousnesses.`); App.Events.addParagraph(node, r); r = []; - r.push(`You awaken on a hard cot, staring face to face with a rather haggard looking man. You leap in shock, sending the man swearing and tearing your stitches open. As you regain composure, and get restitched, you realize that you are in a particularly shitty clinic known for their outrageous treatment fees. The wound was minor and should heal readily, but it will keep you out of commission for a little. `); + r.push(`You awaken on a hard cot, staring face to face with a rather haggard looking man. You leap in shock, sending the man swearing and tearing your stitches open. As you regain your composure, and get restitched, you realize that you are in a particularly shitty clinic known for their outrageous treatment fees. The wound was minor and should heal readily, but it will keep you out of commission for a little. `); if (V.PC.preg > 2 && V.PC.pregKnown) { r.push(`You're just glad it didn't harm your womb. This could have been a lot worse.`); } @@ -79,7 +79,7 @@ App.Events.pAbducted = class pAbducted extends App.Events.BaseEvent { } App.Events.addParagraph(node, r); r = []; - r.push(`It would be prudent to up security in your arcology. That or take a guard along when you leave the penthouse. You are undeniably a high-value target for wealthy collectors and would rather avoid any future attempts and or stabbings. Even with a full description of them, your assailant got away; there was just nobody interested in tracking him down.`); + r.push(`It would be prudent to up security in your arcology. That or take a guard along when you leave the penthouse. You are undeniably a high-value target for wealthy collectors and would rather avoid any future attempts and or stabbings. Even with a full description of him, your assailant got away; there was just nobody interested in tracking him down.`); App.Events.addParagraph(node, r); cashX(-1000, "event"); } @@ -124,7 +124,7 @@ App.Events.pAbducted = class pAbducted extends App.Events.BaseEvent { const node = new DocumentFragment(); const bounty = 500 * random(3, 6); let r = []; - r.push(`Calling for help when it's just you and your abductor is nothing short of an invitation for trouble, so you keep your mouth shut and wait for an opportunity. There's only so many ways in and out of the arcology, and there's bound to be people going about their business through them at this hour. After an uncomfortably cramped ride and having to put up with your captive merrily humming to himself and arriving at a suitably populated loading dock, the thought occurs to you; what if they don't believe you are anything more than an unbroken slave?`); + r.push(`Calling for help when it's just you and your abductor is nothing short of an invitation for trouble, so you keep your mouth shut and wait for an opportunity. There's only so many ways in and out of the arcology, and there's bound to be people going about their business through them at this hour. After an uncomfortably cramped ride and having to put up with your captive merrily humming to himself and arriving at a suitably populated loading dock, the thought occurs to you: what if they don't believe you are anything more than an unbroken slave?`); if (V.PC.actualAge < V.minimumSlaveAge) { r.push(`Fortunately, you are actually underage, so your screams for help quickly attract concerned workers. They corner the man and pry the lid off your box, allowing you to clamber back onto solid ground. Your would-be captor makes a short lived escape attempt straight into a fist once he realizes his plans are ruined. He's quickly tied up and presented to you for revenge.`); abductor.minorInjury = "black eye"; @@ -140,7 +140,7 @@ App.Events.pAbducted = class pAbducted extends App.Events.BaseEvent { App.Utils.scheduleSidebarRefresh(); V.fcnn.push("...plans for increased security measures following the unsuccessful abduction of..."); - App.UI.DOM.appendNewElement("div", node, `Now the only remaining question is what to do with the would-be kidnapper. You could toss them out of the arcology, but it might be more fun to turn the tables on ${him}.`); + App.UI.DOM.appendNewElement("div", node, `Now the only remaining question is what to do with the would-be kidnapper. You could toss ${him} out of the arcology, but it might be more fun to turn the tables on ${him}.`); App.UI.DOM.appendNewElement("div", node, `Applying enslavement as punishment will cost ${cashFormat(contractCost)}. Doing so and then selling ${him} immediately will bring in approximately ${cashFormat(slaveCost(abductor) - contractCost)}.`, ["note"]); node.append(App.Desc.longSlave(abductor, {market: "generic"})); diff --git a/src/events/nonRandom/pFSAnnouncement.js b/src/events/nonRandom/pFSAnnouncement.js index 10b47e27cc9..36bca5e37c0 100644 --- a/src/events/nonRandom/pFSAnnouncement.js +++ b/src/events/nonRandom/pFSAnnouncement.js @@ -15,7 +15,7 @@ App.Events.PFSAnnouncement = class PFSAnnouncement extends App.Events.BaseEvent App.Events.drawEventArt(node, "assistant"); - const {heA} = getPronouns(assistant.pronouns().main).appendSuffix("A"); // Assistant Awakens doesn't have a rep requirement, but this event does. It's possible for them to trigger in either order. + const {heA} = getPronouns(assistant.pronouns().main).appendSuffix("A"); // Assistant Awakens doesn't have a rep requirement, but this event does. It's possible for them to trigger in either order. App.Events.addParagraph(node, [`The simple pleasure of power has to be experienced to be understood. You often take a moment to stand on a balcony overlooking an interior atrium, watching the living, breathing, flowing current of your demesne. ${capFirstChar(V.assistant.name)} knows to allow you these moments of peace.`]); App.Events.addParagraph(node, [`You immediately pay attention, therefore, when ${heA} interrupts. "${properTitle()}," ${heA} says, "this is an appropriate moment to bring a serious matter to your attention. I monitor conversations, social media, and general opinion within the arcology where I can. You are respected, and the inhabitants of this arcology are starting to look to you to give direction to society."`]); diff --git a/src/events/nonRandom/pInvasion.js b/src/events/nonRandom/pInvasion.js index 79786343ba7..e97fc9a0deb 100644 --- a/src/events/nonRandom/pInvasion.js +++ b/src/events/nonRandom/pInvasion.js @@ -83,11 +83,11 @@ 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.`); @@ -97,7 +97,7 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent { 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.`); @@ -108,7 +108,7 @@ App.Events.PInvasion = class PInvasion extends App.Events.BaseEvent { } } 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`); diff --git a/src/events/nonRandom/rival/pRivalryHostage.js b/src/events/nonRandom/rival/pRivalryHostage.js index 6953beab2b1..a28f33a52f8 100644 --- a/src/events/nonRandom/rival/pRivalryHostage.js +++ b/src/events/nonRandom/rival/pRivalryHostage.js @@ -429,7 +429,7 @@ App.Events.pRivalryHostage = function() { params.race = "nonslave"; params.disableDisability = 1; - /** The hostage is always a peer of a young PC, but younger than an adult PC. Find the appropriate age range for slave generation. + /** The hostage is always a peer of a young PC, but younger than an adult PC. Find the appropriate age range for slave generation. * @param {number} adultMin * @param {number} adultMax */ diff --git a/src/events/recETS/recetsIncestTwinsMixed.js b/src/events/recETS/recetsIncestTwinsMixed.js index da82a05d02f..b8f46f391e7 100644 --- a/src/events/recETS/recetsIncestTwinsMixed.js +++ b/src/events/recETS/recetsIncestTwinsMixed.js @@ -62,7 +62,7 @@ App.Events.recetsIncestTwinsMixed = class recetsIncestTwinsMixed extends App.Eve bro.clothes = "conservative clothing"; bro.relationship = 3; bro.relationshipTarget = sis.ID; - + sis.relationshipTarget = bro.ID; if (V.seePreg) { diff --git a/src/events/scheduled/assholeKnight.js b/src/events/scheduled/assholeKnight.js index 8375dbf0a44..2e4953c0e69 100644 --- a/src/events/scheduled/assholeKnight.js +++ b/src/events/scheduled/assholeKnight.js @@ -39,7 +39,7 @@ App.Events.SEAssholeKnight = class SEAssholeKnight extends App.Events.BaseEvent assholeKnight.boobs = Math.min(assholeKnight.boobs, 450); } assholeKnight.accent = random(0, 1); - + const {he, his, him, woman} = getPronouns(assholeKnight); App.Events.drawEventArt(node, assholeKnight, "Imperial Plate"); diff --git a/src/events/scheduled/pitFightLethal.js b/src/events/scheduled/pitFightLethal.js index a3d2f056ab1..fd05d6e975d 100644 --- a/src/events/scheduled/pitFightLethal.js +++ b/src/events/scheduled/pitFightLethal.js @@ -16,7 +16,7 @@ App.Facilities.Pit.lethalFight = function(fighters) { animals.push(V.active.feline); } - if (V.pit.fighters === 2 || V.pit.slaveFightingAnimal) { + if (V.pit.fighters === 2 || V.pit.slaveFightingAnimal) { animal = V.pit.animal === 'random' ? getAnimal(animals.random()) : getAnimal(V.pit.animal); diff --git a/src/facilities/salon/salonPassage.js b/src/facilities/salon/salonPassage.js index 70974df9f6d..0e73768577e 100644 --- a/src/facilities/salon/salonPassage.js +++ b/src/facilities/salon/salonPassage.js @@ -673,7 +673,7 @@ App.UI.salon = function(slave, cheat = false, startingGirls = false) { option = options.addOption("Effect color", "tailEffectColor", slave); for (const color of filtered) { - option.addValue(capFirstChar(color.value), color.value, billMod); + option.addValue(capFirstChar(color.value), color.value, billMod); } option.pulldown(); diff --git a/src/facilities/surgery/analyzePregnancy.js b/src/facilities/surgery/analyzePregnancy.js index 7ed19d59c5e..2beb1a23541 100644 --- a/src/facilities/surgery/analyzePregnancy.js +++ b/src/facilities/surgery/analyzePregnancy.js @@ -109,12 +109,12 @@ globalThis.analyzePregnancies = function(mother, cheat) { el.append(fetusAbnormalities()); } if(V.inbreeding && genes.inbreedingCoeff!==undefined) - { + { option = options.addOption(`Inbreeding coefficient: ${genes.inbreedingCoeff}`, "inbreedingCoeff", genes); if (cheat) { option.showTextBox(); } - } + } } else { if (fetus.age > 13) { App.UI.DOM.appendNewElement("div", el, `Gender: ${genes.gender}`); diff --git a/src/gui/Encyclopedia/encyclopediaFutureSocities.js b/src/gui/Encyclopedia/encyclopediaFutureSocities.js index 492d280f022..dc082f4b248 100644 --- a/src/gui/Encyclopedia/encyclopediaFutureSocities.js +++ b/src/gui/Encyclopedia/encyclopediaFutureSocities.js @@ -56,7 +56,7 @@ App.Encyclopedia.addArticle("Gender Radicalism", function() { r.toNode("div"); App.Events.addNode(t, ["Improves the value of slaves with dicks and slaves with balls."], "div", ["indent"]); App.Events.addNode(t, ["Can be developed to affect the biology seen in the slave market, and subtly influence arcology society."], "div", ["indent"]); - App.Events.addNode(t, [`Provides demand for; slaves with dicks, hormonally treated slaves and futanari${V.seeDicks !== 0 ? ' and ballsless bitches' : ''} from`, App.Encyclopedia.Dialog.linkDOM("The Corporation.", "The Corporation")]); + App.Events.addNode(t, [`Provides demand for; slaves with dicks, hormonally treated slaves and futanari${V.seeDicks !== 0 ? ' and ballsless bitches' : ''} from`, App.Encyclopedia.Dialog.linkDOM("The Corporation.", "The Corporation")]); App.Events.addNode(t, ["Mutually exclusive with", App.Encyclopedia.Dialog.linkDOM("Gender Fundamentalism.", "Gender Fundamentalism")]); return t; }, "FutureSocities"); diff --git a/src/gui/Encyclopedia/encyclopediaMods.js b/src/gui/Encyclopedia/encyclopediaMods.js index ca3076dd6a4..d5c875dab6b 100644 --- a/src/gui/Encyclopedia/encyclopediaMods.js +++ b/src/gui/Encyclopedia/encyclopediaMods.js @@ -283,7 +283,7 @@ App.Encyclopedia.addArticle("The Incubation Facility", function() { const r = new SpacedTextAccumulator(f); r.push("A facility used to rapidly age children kept within its aging tanks using a combination of growth hormones, accelerants, stem cells and other chemicals; slaves that come out of it are rarely healthy. The Incubator requires a massive amount of electricity to run, though once powered contains a battery backup that can last at least a day. It can be upgraded to combat malnutrition and thinness caused by a body growing far beyond any natural rate. Hormones can also be added to encourage puberty and even sex organ development. Growth control systems include cost saving overrides, though enabling them may result in bloated, sex crazed slaves barely capable of moving."); r.toNode("div"); - + App.Events.addNode(f, ["Please click", App.Encyclopedia.Dialog.linkDOM("here", "Facilities Overview"), "for an overview of other facilities."], "p"); return f; }, "Mods"); diff --git a/src/js/economyJS.js b/src/js/economyJS.js index cb4149763c0..763fca17271 100644 --- a/src/js/economyJS.js +++ b/src/js/economyJS.js @@ -841,22 +841,22 @@ globalThis.calculateCosts = (function() { break; } if (V.PC.geneticQuirks.fertility === 2 && V.PC.geneticQuirks.hyperFertility === 2 && V.PC.preg === 0 && (V.PC.ovaries === 1 || V.PC.mpreg === 1)) { - costs += Math.trunc(foodCost * 0.5); + costs += Math.trunc(foodCost * 0.5); } if (V.PC.geneticQuirks.rearLipedema === 2) { - costs += Math.trunc(foodCost * 0.2); + costs += Math.trunc(foodCost * 0.2); } if (V.PC.geneticQuirks.macromastia === 2) { - costs += Math.trunc(foodCost * 0.2); + costs += Math.trunc(foodCost * 0.2); } if (V.PC.geneticQuirks.gigantomastia === 2) { - costs += Math.trunc(foodCost * 0.2); + costs += Math.trunc(foodCost * 0.2); } if (V.PC.geneticQuirks.mGain === 2 && V.PC.geneticQuirks.mLoss !== 2) { - costs += Math.trunc(foodCost * 0.2); + costs += Math.trunc(foodCost * 0.2); } if (V.PC.geneticQuirks.wGain === 2 && V.PC.geneticQuirks.wLoss !== 2) { - costs += Math.trunc(foodCost * 0.2); + costs += Math.trunc(foodCost * 0.2); } if (V.PC.drugs === 'appetite suppressors') { costs -= foodCost; @@ -944,7 +944,7 @@ globalThis.calculateCosts = (function() { costs += Math.trunc(drugsCost * Math.abs(V.PC.hormones) * (V.consumerDrugs ? 0.5 : 1)); } if (V.PC.bodySwap > 0) { - costs += Math.trunc(drugsCost * V.PC.bodySwap * 10); + costs += Math.trunc(drugsCost * V.PC.bodySwap * 10); } if (V.PC.preg === -1) { costs += Math.trunc(drugsCost * 0.5); diff --git a/src/js/ibcJS.js b/src/js/ibcJS.js index e7dde696f72..3573a465ba6 100644 --- a/src/js/ibcJS.js +++ b/src/js/ibcJS.js @@ -112,7 +112,7 @@ globalThis.ibc = (() => { if (vs1 === undefined) vs1 = vs[id1] = []; - // cache format, conceptually: a set of arrays of numbers. the top-level set is indexed by id1. a lower-level array has the format + // cache format, conceptually: a set of arrays of numbers. the top-level set is indexed by id1. a lower-level array has the format // [id, kinship value, id, kinship value, ...] with the id in an entry corresponding to id2 here and with the pairs in the array being kept invariably sorted by id. return this.kinship_cache(vs1, id2, calculateValue); } diff --git a/src/js/rulesAutosurgery.js b/src/js/rulesAutosurgery.js index cbda4cf5bbb..06eaddbf73f 100644 --- a/src/js/rulesAutosurgery.js +++ b/src/js/rulesAutosurgery.js @@ -138,7 +138,7 @@ globalThis.rulesAutosurgery = (function() { } const [diff, reaction] = surgeryResult; - const result1 = reaction.reaction(slave, diff); + const result1 = reaction.reaction(slave, diff); const result2 = reaction.outro(slave, diff, result1); App.Utils.Diff.applyDiff(slave, diff); diff --git a/src/markets/specificMarkets/householdLiquidator.js b/src/markets/specificMarkets/householdLiquidator.js index 4892ac3ee2e..4d2ad2477d4 100644 --- a/src/markets/specificMarkets/householdLiquidator.js +++ b/src/markets/specificMarkets/householdLiquidator.js @@ -18,7 +18,7 @@ App.Markets["Household Liquidator"] = function() { App.UI.DOM.appendNewElement("p", el, `The household liquidator is offering a set of siblings for sale. You are permitted to inspect both slaves.`); const relativeSlave = generateRelatedSlave(slave, "younger sibling", oppositeSex); - + newSlaves = prepSlaveSale(3.0, slave, relativeSlave); } else if (jsRandom(1, 100) > 20) { // Old enough to have a child who can be a slave. diff --git a/src/neighbor/neighborDescription.js b/src/neighbor/neighborDescription.js index dcf02215769..cc97a4a1c3f 100644 --- a/src/neighbor/neighborDescription.js +++ b/src/neighbor/neighborDescription.js @@ -161,7 +161,7 @@ App.UI.neighborDescription = function(i) { 40: `quite a sight, since its citizens and slaves all lift constantly`, 0: `the site of a musclegirl fetish community`, }, - FSHedonisticDecadence: { + FSHedonisticDecadence: { 95: `very well known as a place where every imaginable desire and fantasy can be fulfilled`, 40: `importing huge amounts of food and alcohol`, 0: `the site of a large number of lazy individuals`, diff --git a/src/npc/descriptions/descriptionWidgets.js b/src/npc/descriptions/descriptionWidgets.js index 16701381534..047dcd6391a 100644 --- a/src/npc/descriptions/descriptionWidgets.js +++ b/src/npc/descriptions/descriptionWidgets.js @@ -1253,16 +1253,16 @@ App.Desc.longLimbs = function(slave) { r += "cyber "; break; case 7: - r += "quadruped feline "; + r += "quadruped feline "; break; case 8: - r += "quadruped canine "; + r += "quadruped canine "; break; case 9: - r += "feline combat "; + r += "feline combat "; break; case 10: - r += "canine combat "; + r += "canine combat "; break; } if (count > 1) { diff --git a/src/npc/descriptions/ears.js b/src/npc/descriptions/ears.js index 29f4fadf1fa..c009f8e22d6 100644 --- a/src/npc/descriptions/ears.js +++ b/src/npc/descriptions/ears.js @@ -76,9 +76,9 @@ App.Desc.ears = function(slave) { r.push(`hairless.`); } else { r.push(`covered in soft, ${slave.earTColor} colored fur that has`); - if (slave.earTEffect !== "none") { + if (slave.earTEffect !== "none") { r.push(`${slave.earTEffect} and`); - } + } r.push(`${slave.patternColor} leopard spots; they`); } if (slave.earImplant === 1) { @@ -96,9 +96,9 @@ App.Desc.ears = function(slave) { r.push(`hairless but`); } else { r.push(`covered in dense, ${slave.earTColor} colored fur that has`); - if (slave.earTEffect !== "none") { + if (slave.earTEffect !== "none") { r.push(`${slave.earTEffect} and`); - } + } r.push(`distinct ${slave.patternColor} vertical stripes. They`); } if (slave.earImplant === 1) { @@ -116,9 +116,9 @@ App.Desc.ears = function(slave) { r.push(`hairless`); } else { r.push(`covered in ${slave.earTColor} colored fur that`); - if (slave.earTEffect !== "none") { + if (slave.earTEffect !== "none") { r.push(`has ${slave.earTEffect} and`); - } + } r.push(`is packed with ${slave.patternColor} rosettes that have dots in their center. They`); } if (slave.earImplant === 1) { @@ -136,10 +136,10 @@ App.Desc.ears = function(slave) { r.push(`hairless.`); } else { r.push(`covered in ${slave.earTColor} colored fur.`); - if (slave.earTEffect !== "none") { + if (slave.earTEffect !== "none") { r.push(`that has ${slave.earTEffect}.`); - } - r.push(`The ears have tufts of ${slave.hColor} hair sprouting from their base and`); + } + r.push(`The ears have tufts of ${slave.hColor} hair sprouting from their base and`); } if (slave.earImplant === 1) { r.push(`perk up at`); diff --git a/src/npc/generate/lawCompliance.js b/src/npc/generate/lawCompliance.js index eea740cead5..d67ff08d971 100644 --- a/src/npc/generate/lawCompliance.js +++ b/src/npc/generate/lawCompliance.js @@ -146,7 +146,7 @@ App.Desc.lawCompliance = function(slave, market = 0) { if (market !== "Elite Slave" && policies.countEugenicsSMRs() > 0) { r.push(eugenicsSMRsCount()); } - + SlaveStatClamp(slave); return r.join(" "); diff --git a/src/npc/interaction/fAnimal.js b/src/npc/interaction/fAnimal.js index e641a278ab0..b19e5cc1572 100644 --- a/src/npc/interaction/fAnimal.js +++ b/src/npc/interaction/fAnimal.js @@ -505,7 +505,7 @@ App.Interact.fAnimal = function(slave, type, act) { break; case V.active.feline: if (act === Acts.ORAL) { - text.push(`${slave.slaveName} gets to work, ${his} head bobbing back and forth rhythmically as ${he} works on bringing the ${animal.name} to orgasm. ${His} efforts pay off after a few minutes when the ${animal.name} begins to pant as its orgasm approaches. After a few minutes of painful coupling, the ${animal.species}'s thrusts finally slow, then stop completely as its ${animal.species !== "cat" ? `large` : ``} cock erupts down ${slave.slaveName}'s throat. With a ${animal.species !== "cat" ? `deep bellow` : `loud meow`}, he finally dismounts, gives you a long look, then stalks off.`); + text.push(`${slave.slaveName} gets to work, ${his} head bobbing back and forth rhythmically as ${he} works on bringing the ${animal.name} to orgasm. ${His} efforts pay off after a few minutes when the ${animal.name} begins to pant as its orgasm approaches. After a few minutes of painful coupling, the ${animal.species}'s thrusts finally slow, then stop completely as its ${animal.species !== "cat" ? `large` : ``} cock erupts down ${slave.slaveName}'s throat. With a ${animal.species !== "cat" ? `deep bellow` : `loud meow`}, he finally dismounts, gives you a long look, then stalks off.`); } else { text.push(`The ${animal.name} begins to move, thrusting faster and faster. The ${girl} underneath it can't stop a groan of pain from escaping ${his} lips as the ${animal.species}'s barbed dick rubs the inside of ${his} ${orifice()} raw. After a few minutes of painful coupling, the ${animal.species}'s thrusts finally slow, then stop completely as its ${animal.species !== "cat" ? `large` : ``} cock erupts, filling ${slave.slaveName} with its sperm. With a ${animal.species !== "cat" ? `deep bellow` : `loud meow`}, he finally dismounts, gives you a long look, then stalks off.`); } diff --git a/src/npc/startingGirls/startingGirlsPassage.js b/src/npc/startingGirls/startingGirlsPassage.js index 96255d073c2..fce85cf5363 100644 --- a/src/npc/startingGirls/startingGirlsPassage.js +++ b/src/npc/startingGirls/startingGirlsPassage.js @@ -32,7 +32,7 @@ App.StartingGirls.passage = function() { for (const slave of V.slaves) { const cost = slave.slaveCost; App.Events.addNode(el, [ - App.UI.DOM.slaveDescriptionDialog(slave), + App.UI.DOM.slaveDescriptionDialog(slave), `costing: ${cashFormatColor(cost)}`, App.UI.DOM.generateLinksStrip([ App.UI.DOM.link("Delete", () => { diff --git a/src/player/desc/pLongBody.js b/src/player/desc/pLongBody.js index e30a5aa5736..1643a76f78a 100644 --- a/src/player/desc/pLongBody.js +++ b/src/player/desc/pLongBody.js @@ -203,7 +203,7 @@ App.Desc.Player.body = function(PC = V.PC) { r.push(`However, you're so powerfully built that you can do it with effort, though you're out of breath just standing here.`); } else if (PC.muscles > 30) { r.push(`You're strong enough to get to your feet, but given you're currently leaning against a chair to take some of the load off, that may not be for much longer.`); - } else { + } else { r.push(`It takes a lot to get on your feet, so you try to avoid that if possible.`); } } diff --git a/src/player/desc/pLongBoobs.js b/src/player/desc/pLongBoobs.js index 158b94d1260..74281dcbd63 100644 --- a/src/player/desc/pLongBoobs.js +++ b/src/player/desc/pLongBoobs.js @@ -408,7 +408,7 @@ App.Desc.Player.boobs = function(PC = V.PC) { r.push(`However, you're so powerfully built that you can comfortably stand up straight, though you definitely feel it in the morning.`); } else if (PC.muscles > 30) { r.push(`Your back is strong enough to support their weight, but you frequently catch yourself slouching under their weight, so you may be nearing your limit.`); - } else { + } else { r.push(`It takes a lot of effort to keep upright with them, so you're most comfortable letting them rest on something when you have the chance.`); } } else if (PC.boobs >= dwarfSize) { diff --git a/src/player/desc/pLongButt.js b/src/player/desc/pLongButt.js index 3e97350ec32..70caba5619d 100644 --- a/src/player/desc/pLongButt.js +++ b/src/player/desc/pLongButt.js @@ -1,7 +1,7 @@ App.Desc.Player.butt = function(PC = V.PC) { const r = []; const implantRatio = PC.buttImplant / PC.butt; - const implantType = PC.buttImplantType !== "normal" ? PC.buttImplantType : ""; + const implantType = PC.buttImplantType !== "normal" ? PC.buttImplantType : ""; const {girlP} = getPronouns(PC).appendSuffix("P"); function hips() { @@ -238,7 +238,7 @@ App.Desc.Player.butt = function(PC = V.PC) { } } else if (PC.muscles > 30) { r.push(`Your legs are strong enough to support its weight, but it's still much more comfortable to remain seated; it's either time to work your quads harder or consider a reduction.`); - } else { + } else { r.push(`It takes a lot of effort to not be forced into a sitting position with it, so you're most comfortable just letting it rest on something when you have the chance.`); } r.push(buttAccessibility()); diff --git a/src/player/electiveSurgery.js b/src/player/electiveSurgery.js index cf8db44f21b..649debccc9a 100644 --- a/src/player/electiveSurgery.js +++ b/src/player/electiveSurgery.js @@ -15,7 +15,7 @@ App.UI.electiveSurgery = function() { nurse.race = arcology.FSSupremacistRace; nurse.devotion = 100; nurse.trust = 100; - if (["white", "asian", "semitic", "southern european"].includes(nurse.race)) { + if (["asian", "semitic", "southern european", "white"].includes(nurse.race)) { nurse.skin = "light"; } else { nurse.skin = "brown"; diff --git a/src/player/pcSalon.js b/src/player/pcSalon.js index 4b9d02da9c5..2f2404674fc 100644 --- a/src/player/pcSalon.js +++ b/src/player/pcSalon.js @@ -508,7 +508,7 @@ App.UI.playerSalon = function(PC) { option = options.addOption("Effect color", "tailEffectColor", PC); for (const color of filtered) { - option.addValue(capFirstChar(color.value), color.value); + option.addValue(capFirstChar(color.value), color.value); } option.pulldown(); -- GitLab