diff --git a/src/endWeek/schoolroomReport.js b/src/endWeek/schoolroomReport.js new file mode 100644 index 0000000000000000000000000000000000000000..e79adb72016255ae16ee60ed671136fcb26f55ea --- /dev/null +++ b/src/endWeek/schoolroomReport.js @@ -0,0 +1,245 @@ +App.EndWeek.schoolroomReport = function() { + let frag = document.createDocumentFragment(); + + const slaves = App.Utils.sortedEmployees(App.Entity.facilities.schoolroom); + const devBonus = (V.schoolroomDecoration !== "standard") ? 1 : 0; + + function schoolteacherText() { + let r = []; + let FLsFetish = 0; + let idleBonus = 0; + + if (S.Schoolteacher) { + if (S.Schoolteacher.health.condition < -80) { + improveCondition(S.Schoolteacher, 20); + } else if (S.Schoolteacher.health.condition < -40) { + improveCondition(S.Schoolteacher, 15); + } else if (S.Schoolteacher.health.condition < 0) { + improveCondition(S.Schoolteacher, 10); + } else if (S.Schoolteacher.health.condition < 90) { + improveCondition(S.Schoolteacher, 7); + } + if (S.Schoolteacher.devotion <= 60) { + S.Schoolteacher.devotion++; + } + if (S.Schoolteacher.trust < -30) { + S.Schoolteacher.trust++; + } + S.Schoolteacher.devotion += devBonus; + if (S.Schoolteacher.rules.living !== "luxurious") { + S.Schoolteacher.rules.living = "luxurious"; + } + if (S.Schoolteacher.fetishStrength <= 95) { + if (S.Schoolteacher.fetish !== "dom") { + if (fetishChangeChance(S.Schoolteacher) > jsRandom(0, 100)) { + FLsFetish = 1; + S.Schoolteacher.fetishKnown = 1; + S.Schoolteacher.fetish = "dom"; + } + } else if (S.Schoolteacher.fetishKnown === 0) { + FLsFetish = 1; + S.Schoolteacher.fetishKnown = 1; + } else { + FLsFetish = 2; + S.Schoolteacher.fetishStrength += 4; + } + } + + const {He, he, His, his, him, wife} = getPronouns(S.Schoolteacher); + r.push(`${S.Schoolteacher.slaveName} is serving as your Schoolteacher.`); + if (S.Schoolteacher.relationship === -3 && S.Schoolteacher.devotion > 50) { + r.push(`As your loving ${wife}, ${he} tries ${his} best to teach ${his} pupils how to please you.`); + } + if (FLsFetish === 1) { + r.push(`${He}'s allowed and even expected to use ${his} students for ${his} own sexual gratification, and in their own way ${his} students are complicit, offering sexual favors for an easier time in the classroom. Before long, ${he}'s running a hungry eye over the tits and asses of new trainees; ${he} is now <span class="lightcoral">more dominant.</span>`); + } else if (FLsFetish === 2) { + r.push(`Every new student in class is a new target for ${his} personal educational attention. <span class="lightsalmon">${He} becomes more dominant.</span>`); + } + if (setup.schoolteacherCareers.includes(S.Schoolteacher.career)) { + r.push(`${He} has experience with students and learning from ${his} life before ${he} was a slave, making ${him} more effective.`); + idleBonus++; + } else if (S.Schoolteacher.skill.teacher >= V.masteredXP) { + r.push(`${He} has experience with students and learning from working for you, making ${him} more effective.`); + idleBonus++; + } else { + S.Schoolteacher.skill.teacher += jsRandom(1, Math.ceil((S.Schoolteacher.intelligence + S.Schoolteacher.intelligenceImplant) / 15) + 8); + } + if (S.Schoolteacher.visualAge > 35) { + r.push(`${His} age earns ${him} the respect of ${his} students.`); + idleBonus++; + } + if (S.Schoolteacher.intelligence > 15) { + r.push(`${He}'s intelligent enough to be a good teacher.`); + idleBonus++; + } + if (S.Schoolteacher.intelligenceImplant >= 15) { + r.push(`Since ${he}'s educated ${him}self, ${he} understands `); + if (V.schoolroomRemodelBimbo !== 0) { + r.push(`how best to apply the new lesson plan.`); + } else { + r.push(`${his} students.`); + } + idleBonus++; + } + if (S.Schoolteacher.face > 40) { + r.push(`${His} students want to be just like their beautiful teacher.`); + idleBonus++; + } + + for (const slave of slaves) { + const {he2} = getPronouns(slave).appendSuffix('2'); + if (S.Schoolteacher.rivalryTarget === slave.ID) { + r.push(`Ever since ${his} ${rivalryTerm(S.Schoolteacher)} was enrolled, ${he} began stalking the classroom carrying a large paddle, much to ${slave.slaveName}'s terror.`); + slave.devotion -= 4; + slave.trust -= 4; + if (jsRandom(1, 100) > 35) { + S.Schoolteacher.rivalry++; + slave.rivalry++; + } + } else if (S.Schoolteacher.relationshipTarget === slave.ID) { + r.push(`${He} dedicates most of ${his} attention to ${his} ${relationshipTerm(S.Schoolteacher)}, ${slave.slaveName}, making sure ${he2} understands that day's lesson.`); + slave.devotion += 2; + slave.trust += 2; + } else if (areRelated(S.Schoolteacher, slave)) { + r.push(`${He} makes sure to spend extra time teaching ${his} ${relativeTerm(S.Schoolteacher, slave)}, ${slave.slaveName}.`); + slave.trust++; + } + } + + if (slaves.length < V.schoolroom) { + const _idlePay = jsRandom(1, 10) + ((V.schoolroom - slaves.length) * (jsRandom(150, 170) + (idleBonus * 10))); + cashX(_idlePay, "school", V.Schoolteacher); + r.push(`<div class="indent">Since ${he} doesn't have enough students to occupy all of ${his} time, ${V.schoolroomName} takes in citizens' slaves on a contract basis and ${he} teaches them too, earning <span class="yellowgreen">${cashFormat(_idlePay)}.</span></div>`); + } + + return r.join(" "); + } + } + + const schoolteacherEffects = App.UI.DOM.appendNewElement("p", frag, '', "indent"); + $(schoolteacherEffects).append(schoolteacherText()); + + if (slaves.length > 0) { + const intro = App.UI.DOM.appendNewElement("p", frag, '', "indent"); + if (slaves.length > 1) { + $(intro).append(`<strong>There are ${slaves.length} slaves studying in ${V.schoolroomName}.</strong>`); + } else { + $(intro).append(`<strong>There is one slave studying in ${V.schoolroomName}.</strong>`); + } + } + + if (S.Schoolteacher) { + const slave = S.Schoolteacher; + V.i = V.slaveIndices[slave.ID]; + App.Utils.setLocalPronouns(slave); // need this for the includes + /* apply following SA passages to facility leader */ + if (V.showEWD !== 0) { + const schoolteacherEntry = App.UI.DOM.appendNewElement("div", frag, '', "slave-report"); + if (V.seeImages && V.seeReportImages) { + App.UI.DOM.appendNewElement("div", schoolteacherEntry, App.Art.SlaveArtElement(slave, 0, 0), ["imageRef", "tinyImg"]); + } + $(schoolteacherEntry).append(`<span class='slave-name'>${slave.slaveName}</span> is serving as your Schoolteacher.`); + $(schoolteacherEntry).append(App.SlaveAssignment.standardSlaveReport(slave, false)); + } else { + App.SlaveAssignment.standardSlaveReport(slave, true); + } + } + + let restedSlaves = 0; + for (const slave of slaves) { + V.i = V.slaveIndices[slave.ID]; + slave.devotion += devBonus; + if (slave.health.condition < -80) { + improveCondition(slave, 20); + } else if (slave.health.condition < -40) { + improveCondition(slave, 10); + } else if (slave.health.condition < 0) { + improveCondition(slave, 7); + } else if (slave.health.condition < 90) { + improveCondition(slave, 3); + } + if (slave.rules.living !== "normal") { + slave.rules.living = "normal"; + } + /* Education done? Has to be here before we run the standard slave report or there will be double entries for slave */ + if (slave.fetish === "mindbroken") { + if (V.assignmentRecords[slave.ID]) { + assignJobSafely(slave, V.assignmentRecords[slave.ID]); + } else { + removeJob(slave, "learn in the schoolroom"); + } + restedSlaves++; + continue; + } else if ( ((slave.intelligenceImplant >= 30 && V.schoolroomRemodelBimbo !== 1) || (slave.intelligenceImplant <= -15 && V.schoolroomRemodelBimbo === 1)) && + ((slave.voice === 0) || (slave.accent <= 1) || ((V.schoolroomUpgradeLanguage === 0) && (slave.accent <= 2))) && + ((slave.skill.oral > 30) || ((V.schoolroomUpgradeSkills === 0) && (slave.skill.oral > 10))) && + ((slave.skill.whoring > 30) || ((V.schoolroomUpgradeSkills === 0) && (slave.skill.whoring > 10))) && + ((slave.skill.entertainment > 30) || ((V.schoolroomUpgradeSkills === 0) && (slave.skill.entertainment > 10))) && + ((slave.skill.anal > 30) || ((V.schoolroomUpgradeSkills === 0) && (slave.skill.anal > 10))) && + ((slave.skill.vaginal > 30) || ((V.schoolroomUpgradeSkills === 0) && (slave.skill.vaginal > 10)) || (slave.vagina < 0)) ) { + const reassignment = App.UI.DOM.appendNewElement("p", frag, ''); + const {he, his} = getPronouns(slave); + let r = []; + r.push(`<span class="slave-name">_slave.slaveName</span> can learn little from further classes,`); + r.push(`<span class="noteworthy">`); + if (V.assignmentRecords[slave.ID]) { + const oldJob = V.assignmentRecords[slave.ID]; + assignJobSafely(slave, oldJob); + if (slave.choosesOwnAssignment === 1) { + r.push(`and ${he} is resting before choosing another task.`); + } else if (slave.assignment === "rest") { + if (oldJob !== "rest") { + r.push(`and since ${he} was unable to return to ${his} old task to ${oldJob}, ${his} assignment has defaulted to rest.`); + } else { + r.push(`so ${he} has returned to rest.`); + } + } else { + r.push(`so ${he} goes back to ${slave.assignment}.`); + } + } else { + r.push(`so ${his} assignment has defaulted to rest.`); + removeJob(slave, "learn in the schoolroom"); + } + r.push(`</span>`); + restedSlaves++; + $(reassignment).append(r.join(" ")); + continue; + } + + App.Utils.setLocalPronouns(slave); // need this for the includes + if (V.showEWD !== 0) { + const {He} = getPronouns(slave); + const slaveEntry = App.UI.DOM.appendNewElement("div", frag, '', "slave-report"); + if (V.seeImages && V.seeReportImages) { + App.UI.DOM.appendNewElement("div", slaveEntry, App.Art.SlaveArtElement(slave, 0, 0), ["imageRef", "tinyImg"]); + } + $(slaveEntry).append(`<span class='slave-name'>${slave.slaveName}</span> `); + if (slave.choosesOwnAssignment === 2) { + $(slaveEntry).append(App.UI.DOM.renderPassage("SA chooses own job")); + } else { + $(slaveEntry).append(`is studying in ${V.schoolroomName}.`); + } + const studentContent = App.UI.DOM.appendNewElement("div", slaveEntry, '', "indent"); + $(studentContent).append(`${He} ${App.SlaveAssignment.takeClasses(slave)}`); + $(slaveEntry).append(App.SlaveAssignment.standardSlaveReport(slave, false)); + } else { + // discard return values silently + App.SlaveAssignment.takeClasses(slave); + App.SlaveAssignment.standardSlaveReport(slave, true); + } + } + + if (restedSlaves > 0) { + const rested = App.UI.DOM.appendNewElement("p", frag, '', "indent"); + rested.append((restedSlaves === 1) ? `One slave has ` : `${restedSlaves} slaves have `); + App.UI.DOM.appendNewElement("span", rested, "learned", "green"); + rested.append(` all they can, and will be released from the schoolroom before the end of the week.`); + } + + if (V.schoolroomDecoration !== "standard") { + const decorationEffects = App.UI.DOM.appendNewElement("p", frag, '', "indent"); + $(decorationEffects).append(`${V.schoolroomNameCaps}'s ${V.schoolroomDecoration} atmosphere <span class="hotpink">has a minor impact on the students.</span>`); + } + + return frag; +}; diff --git a/src/uncategorized/schoolroomReport.tw b/src/uncategorized/schoolroomReport.tw index 329c301d27b25866e673b90a6b412689add547a9..2d651a8e6642991fa209ba41e731453c85bff245 100644 --- a/src/uncategorized/schoolroomReport.tw +++ b/src/uncategorized/schoolroomReport.tw @@ -1,267 +1,5 @@ :: Schoolroom Report [nobr] -<<set _slaves = App.Utils.sortedEmployees(App.Entity.facilities.schoolroom)>> -<<set _DL = _slaves.length, _SL = $slaves.length, _idleBonus = 0, _FLsFetish = 0>> - -<<if $schoolroomDecoration != "standard">> - <<set _devBonus = 1>> -<<else>> - <<set _devBonus = 0>> -<</if>> - -<<if $Schoolteacher != 0>> - <<set _FLs = $slaveIndices[$Schoolteacher.ID]>> - - <<if ($slaves[_FLs].health.condition < -80)>> - <<run improveCondition($slaves[_FLs], 20)>> - <<elseif ($slaves[_FLs].health.condition < -40)>> - <<run improveCondition($slaves[_FLs], 15)>> - <<elseif ($slaves[_FLs].health.condition < 0)>> - <<run improveCondition($slaves[_FLs], 10)>> - <<elseif ($slaves[_FLs].health.condition < 90)>> - <<run improveCondition($slaves[_FLs], 7)>> - <</if>> - <<if ($slaves[_FLs].devotion <= 60)>> - <<set $slaves[_FLs].devotion++>> - <</if>> - <<if ($slaves[_FLs].trust < -30)>> - <<set $slaves[_FLs].trust++>> - <</if>> - <<set $slaves[_FLs].devotion += _devBonus>> - <<if $slaves[_FLs].rules.living != "luxurious">> - <<set $slaves[_FLs].rules.living = "luxurious">> - <</if>> - <<if $slaves[_FLs].fetishStrength <= 95>> - <<if $slaves[_FLs].fetish != "dom">> - <<if fetishChangeChance($slaves[_FLs]) > random(0,100)>> - <<set _FLsFetish = 1, $slaves[_FLs].fetishKnown = 1, $slaves[_FLs].fetish = "dom">> - <</if>> - <<elseif $slaves[_FLs].fetishKnown == 0>> - <<set _FLsFetish = 1, $slaves[_FLs].fetishKnown = 1>> - <<else>> - <<set _FLsFetish = 2, $slaves[_FLs].fetishStrength += 4>> - <</if>> - <</if>> - <<set $Schoolteacher = $slaves[_FLs]>> - <<setLocalPronouns $Schoolteacher>> - $Schoolteacher.slaveName is serving as your Schoolteacher.<<if $Schoolteacher.relationship == -3 && $Schoolteacher.devotion > 50>> As your loving $wife, $he tries $his best to teach $his pupils how to please you.<</if>> - <<if (_FLsFetish == 1)>> - $He's allowed and even expected to use $his students for $his own sexual gratification, and in their own way $his students are complicit, offering sexual favors for an easier time in the classroom. Before long, $he's running a hungry eye over the tits and asses of new trainees; $he is now @@.lightcoral;more dominant.@@ - <<elseif (_FLsFetish == 2)>> - Every new student in class is a new target for $his personal educational attention. @@.lightsalmon;$He becomes more dominant.@@ - <</if>> - <<if setup.schoolteacherCareers.includes($Schoolteacher.career)>> - $He has experience with students and learning from $his life before $he was a slave, making $him more effective. - <<set _idleBonus++>> - <<elseif $Schoolteacher.skill.teacher >= $masteredXP>> - $He has experience with students and learning from working for you, making $him more effective. - <<set _idleBonus++>> - <<else>> - <<set $slaves[_FLs].skill.teacher += random(1,Math.ceil(($Schoolteacher.intelligence+$Schoolteacher.intelligenceImplant)/15) + 8)>> - <</if>> - <<if ($Schoolteacher.visualAge > 35)>> - $His age earns $him the respect of $his students. - <<set _idleBonus++>> - <</if>> - <<if ($Schoolteacher.intelligence > 15)>> - $He's intelligent enough to be a good teacher. - <<set _idleBonus++>> - <</if>> - <<if ($Schoolteacher.intelligenceImplant >= 15)>> - Since $he's educated $himself, $he understands <<if $schoolroomRemodelBimbo != 0>>how best to apply the new lesson plan<<else>>$his students<</if>>. - <<set _idleBonus++>> - <</if>> - <<if ($Schoolteacher.face > 40)>> - $His students want to be just like their beautiful teacher. - <<set _idleBonus++>> - <</if>> - <<for _slave range _slaves>> - <<set $i = $slaveIndices[_slave.ID]>> - <<setLocalPronouns _slave 2>> - <<if $Schoolteacher.rivalryTarget == _slave.ID>> - Ever since $his <<print rivalryTerm($Schoolteacher)>> was enrolled, $he began stalking the classroom carrying a large paddle, much to _slave.slaveName's terror. - <<set _slave.devotion -= 4, _slave.trust -= 4>> - <<if random(1,100) > 35>> - <<set $Schoolteacher.rivalry++, $slaves[_FLs].rivalry++, _slave.rivalry++>> - <</if>> - <<elseif $Schoolteacher.relationshipTarget == _slave.ID>> - $He dedicates most of $his attention to $his <<print relationshipTerm($Schoolteacher)>>, _slave.slaveName, making sure _he2 understands that day's lesson. - <<set _slave.devotion += 2, _slave.trust += 2>> - <<elseif areRelated($Schoolteacher, _slave)>> - $He makes sure to spend extra time teaching $his <<print relativeTerm($Schoolteacher,_slave)>>, _slave.slaveName. - <<set _slave.trust++>> - <</if>> - <</for>> - <<if (_DL < $schoolroom)>> - <<set _seed = random(1,10)+(($schoolroom-_DL)*(random(150,170)+(_idleBonus*10)))>> - <<run cashX(_seed, "school", $Schoolteacher)>> - <br> Since $he doesn't have enough students to occupy all of $his time, $schoolroomName takes in citizens' slaves on a contract basis and $he teaches them too, earning @@.yellowgreen;<<print cashFormat(_seed)>>.@@ - <</if>> - <<if (_DL > 0)>><br><br><</if>> -<</if>> - -<<if (_DL > 0)>> - <<if (_DL == 1)>>''There is one slave studying in $schoolroomName.''<<else>>''There are _DL slaves studying in $schoolroomName.''<</if>> -<</if>> - -<<if ($Schoolteacher != 0)>> - <<set $i = _FLs>> /* apply following SA passages to facility leader */ - <<if $showEWD != 0>> - <br><br> - /* 000-250-006 */ - <<if $seeImages && $seeReportImages>> - <div class="imageRef tinyImg"> - <<= SlaveArt($slaves[_FLs], 0, 0)>> - </div> - <</if>> - /* 000-250-006 */ - <span class='slave-name'>$slaves[_FLs].slaveName</span> is serving as your Schoolteacher. - <br> - <<= App.SlaveAssignment.choosesOwnClothes($slaves[$i])>> - <<run tired($slaves[$i])>> - <<include "SA rules">> - <<include "SA diet">> - <<include "SA long term effects">> - <<= App.SlaveAssignment.drugs($slaves[$i])>> - <<include "SA relationships">> - <<include "SA rivalries">> - <br><<include "SA devotion">> - <<else>> - <<silently>> - <<run App.SlaveAssignment.choosesOwnClothes($slaves[$i])>> - <<run tired($slaves[$i])>> - <<include "SA rules">> - <<include "SA diet">> - <<include "SA long term effects">> - <<run App.SlaveAssignment.drugs($slaves[$i])>> - <<include "SA relationships">> - <<include "SA rivalries">> - <<include "SA devotion">> - <</silently>> - <</if>> - <<set $Schoolteacher = $slaves[_FLs]>> -<</if>> - -<<set _restedSlaves = 0>> -<<for _slave range _slaves>> - <<set $i = $slaveIndices[_slave.ID]>> - <<setLocalPronouns _slave 2>> - <<set _slave.devotion += _devBonus>> - <<if (_slave.health.condition < -80)>> - <<run improveCondition(_slave, 20)>> - <<elseif (_slave.health.condition < -40)>> - <<run improveCondition(_slave, 10)>> - <<elseif (_slave.health.condition < 0)>> - <<run improveCondition(_slave, 7)>> - <<elseif (_slave.health.condition < 90)>> - <<run improveCondition(_slave, 3)>> - <</if>> - <<if _slave.rules.living != "normal">> - <<set _slave.rules.living = "normal">> - <</if>> - /% Education done? Has to be here before we run the SA's or there will be double entries for slave %/ - <<if _slave.fetish == "mindbroken">> - <<if $assignmentRecords[_slave.ID]>> - <<= assignJobSafely(_slave, $assignmentRecords[_slave.ID])>> - <<else>> - <<= removeJob(_slave, "learn in the schoolroom")>> - <</if>> - <<set _restedSlaves++, _dI--, _DL-->> - <<continue>> - <<else>> - <<if (_slave.intelligenceImplant >= 30 && $schoolroomRemodelBimbo != 1) || (_slave.intelligenceImplant <= -15 && $schoolroomRemodelBimbo == 1)>> - <<if (_slave.voice == 0) || (_slave.accent <= 1) || (($schoolroomUpgradeLanguage == 0) && (_slave.accent <= 2))>> - <<if (_slave.skill.oral > 30) || (($schoolroomUpgradeSkills == 0) && (_slave.skill.oral > 10))>> - <<if (_slave.skill.whoring > 30) || (($schoolroomUpgradeSkills == 0) && (_slave.skill.whoring > 10))>> - <<if (_slave.skill.entertainment > 30) || (($schoolroomUpgradeSkills == 0) && (_slave.skill.entertainment > 10))>> - <<if (_slave.skill.anal > 30) || (($schoolroomUpgradeSkills == 0) && (_slave.skill.anal > 10))>> - <<if (_slave.skill.vaginal > 30) || (($schoolroomUpgradeSkills == 0) && (_slave.skill.vaginal > 10)) || (_slave.vagina < 0)>> - <p> - <span class="slave-name">_slave.slaveName</span> can learn little from further classes, - <span class="noteworthy"> - <<if $assignmentRecords[_slave.ID]>> - <<set _oldJob = $assignmentRecords[_slave.ID]>> - <<= assignJobSafely(_slave, _oldJob)>> - <<if _slave.choosesOwnAssignment === 1>> - and $he is resting before choosing another task. - <<elseif _slave.assignment === "rest">> - <<if _oldJob != "rest">> - and since $he was unable to return to $his old task to <<print _oldJob>>, $his assignment has defaulted to rest. - <<else>> - so $he has returned to rest. - <</if>> - <<else>> - so $he goes back to <<print _slave.assignment>>. - <</if>> - <<else>> - so _his2 assignment has defaulted to rest. - <<= removeJob(_slave, "learn in the schoolroom")>> - <</if>> - </span> - </p> - <<set _restedSlaves++, _dI--, _DL-->> - <<continue>> - <</if>> - <</if>> - <</if>> - <</if>> - <</if>> - <</if>> - <</if>> - <</if>> - <<if $showEWD != 0>> - <br><br> - /* 000-250-006 */ - <<if $seeImages && $seeReportImages>> - <div class="imageRef tinyImg"> - <<= SlaveArt(_slave, 0, 0)>> - </div> - <</if>> - /* 000-250-006 */ - <<setLocalPronouns _slave>> - <span class='slave-name'>_slave.slaveName</span> - <<if _slave.choosesOwnAssignment == 2>> - <<include "SA chooses own job">> - <<else>> - is studying in $schoolroomName. - <</if>> - <br> $He <<= App.SlaveAssignment.takeClasses(_slave)>> - <br> - <<= App.SlaveAssignment.choosesOwnClothes(_slave)>> - <<include "SA rules">> - <<include "SA diet">> - <<include "SA long term effects">> - <<= App.SlaveAssignment.drugs(_slave)>> - <<include "SA relationships">> - <<include "SA rivalries">> - <br><<include "SA devotion">> - <<else>> - <<silently>> - <<include "SA chooses own job">> - <<run App.SlaveAssignment.takeClasses(_slave)>> - <<run App.SlaveAssignment.choosesOwnClothes(_slave)>> - <<include "SA rules">> - <<include "SA diet">> - <<include "SA long term effects">> - <<run App.SlaveAssignment.drugs(_slave)>> - <<include "SA relationships">> - <<include "SA rivalries">> - <<include "SA devotion">> - <</silently>> - <</if>> -<</for>> -<<if (_restedSlaves > 0)>> - <br><br> - <<if (_restedSlaves == 1)>> - One slave has - <<else>> - _restedSlaves slaves have - <</if>> - @@.green;learned@@ all they can, and will be released from the schoolroom before the end of the week. -<</if>> -<<if $schoolroomDecoration != "standard">> - <br><br> $schoolroomNameCaps's $schoolroomDecoration atmosphere @@.hotpink;has a minor impact on the students.@@ -<</if>> -<<if _DL > 0 || $Schoolteacher != 0>> - <br><br> -<</if>> +/* This passage probably isn't really necessary but it helps organize the profiler output. + * TODO: Once all the facility reports look like this, we should probably get rid of these intermediate passages. */ +<<includeDOM App.EndWeek.schoolroomReport()>>