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>>
-	&nbsp;&nbsp;&nbsp;&nbsp;$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>&nbsp;&nbsp;&nbsp;&nbsp;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)>>
-	&nbsp;&nbsp;&nbsp;&nbsp;<<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>&nbsp;&nbsp;&nbsp;
-		<<= 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>&nbsp;&nbsp;&nbsp;&nbsp;$He <<= App.SlaveAssignment.takeClasses(_slave)>>
-		<br>&nbsp;&nbsp;&nbsp;
-		<<= 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>&nbsp;&nbsp;&nbsp;
-	<<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>&nbsp;&nbsp;&nbsp;&nbsp;$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()>>