KursblockungDynKurs.ts 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. import { JavaObject, cast_java_lang_Object } from '../../java/lang/JavaObject';
  2. import { KursblockungInputKurs, cast_de_nrw_schule_svws_core_data_kursblockung_KursblockungInputKurs } from '../../core/data/kursblockung/KursblockungInputKurs';
  3. import { JavaInteger, cast_java_lang_Integer } from '../../java/lang/JavaInteger';
  4. import { KursblockungDynFachart, cast_de_nrw_schule_svws_core_kursblockung_KursblockungDynFachart } from '../../core/kursblockung/KursblockungDynFachart';
  5. import { KursblockungOutputKursZuSchiene, cast_de_nrw_schule_svws_core_data_kursblockung_KursblockungOutputKursZuSchiene } from '../../core/data/kursblockung/KursblockungOutputKursZuSchiene';
  6. import { LinkedCollection, cast_de_nrw_schule_svws_core_adt_collection_LinkedCollection } from '../../core/adt/collection/LinkedCollection';
  7. import { KursblockungDynSchiene, cast_de_nrw_schule_svws_core_kursblockung_KursblockungDynSchiene } from '../../core/kursblockung/KursblockungDynSchiene';
  8. import { JavaString, cast_java_lang_String } from '../../java/lang/JavaString';
  9. import { Logger, cast_de_nrw_schule_svws_logger_Logger } from '../../logger/Logger';
  10. import { Vector, cast_java_util_Vector } from '../../java/util/Vector';
  11. import { System, cast_java_lang_System } from '../../java/lang/System';
  12. import { LogLevel, cast_de_nrw_schule_svws_logger_LogLevel } from '../../logger/LogLevel';
  13. export class KursblockungDynKurs extends JavaObject {
  14. private readonly guiID : number;
  15. private readonly representation : String;
  16. private readonly fachart : KursblockungDynFachart;
  17. private readonly schienenLage : Array<KursblockungDynSchiene>;
  18. private readonly schienenLageSaveS : Array<KursblockungDynSchiene>;
  19. private readonly schienenLageSaveK : Array<KursblockungDynSchiene>;
  20. private readonly schienenLageFixiert : number;
  21. private readonly schienenFrei : Array<KursblockungDynSchiene>;
  22. private readonly schienenFreiSaveS : Array<KursblockungDynSchiene>;
  23. private readonly schienenFreiSaveK : Array<KursblockungDynSchiene>;
  24. private schuelerAnz : number = 0;
  25. private readonly logger : Logger;
  26. /**
  27. * Der Kurs wählt eine zufällige Schienenlage und fügt sich selbst den
  28. * entsprechenden Schienen hinzu.
  29. *
  30. * @param pSchienenLage Ein Array aller Schienen, in denen der Kurs
  31. * gerade liegt.
  32. * @param pSchienenLageFixiert Anzahl an Schienen in {@code pSchienenLage}, die
  33. * fixiert ist.
  34. * @param pSchienenFrei Ein Array aller Schienen, in die der Kurs
  35. * wechseln könnte.
  36. * @param iKurs Alle Informationen zu diesem Kurs. Das Objekt
  37. * stammt von der GUI.
  38. * @param pFachart Die zu diesem Kurs zugehörige Fachart.
  39. * @param pLogger Logger für Benutzerhinweise, Warnungen und
  40. * Fehler.
  41. */
  42. public constructor(pSchienenLage : Array<KursblockungDynSchiene>, pSchienenLageFixiert : number, pSchienenFrei : Array<KursblockungDynSchiene>, iKurs : KursblockungInputKurs, pFachart : KursblockungDynFachart, pLogger : Logger) {
  43. super();
  44. this.schienenLage = pSchienenLage;
  45. this.schienenLageFixiert = pSchienenLageFixiert;
  46. this.schienenFrei = pSchienenFrei;
  47. this.guiID = iKurs.id;
  48. this.representation = iKurs.representation;
  49. this.fachart = pFachart;
  50. this.schuelerAnz = 0;
  51. this.logger = pLogger;
  52. this.schienenLageSaveS = Array(this.schienenLage.length).fill(null);
  53. this.schienenLageSaveK = Array(this.schienenLage.length).fill(null);
  54. for (let i : number = 0; i < this.schienenLage.length; i++){
  55. this.schienenLageSaveS[i] = this.schienenLage[i];
  56. this.schienenLageSaveK[i] = this.schienenLage[i];
  57. }
  58. this.schienenFreiSaveS = Array(this.schienenFrei.length).fill(null);
  59. this.schienenFreiSaveK = Array(this.schienenFrei.length).fill(null);
  60. for (let i : number = 0; i < this.schienenFrei.length; i++){
  61. this.schienenFreiSaveS[i] = this.schienenFrei[i];
  62. this.schienenFreiSaveK[i] = this.schienenFrei[i];
  63. }
  64. for (let i : number = 0; i < this.schienenLage.length; i++){
  65. this.schienenLage[i].aktionKursHinzufuegen(this);
  66. }
  67. }
  68. public toString() : String {
  69. return this.representation;
  70. }
  71. /**
  72. * Die Kurs-ID der GUI.
  73. *
  74. * @return Die Kurs-ID der GUI.
  75. */
  76. public gibID() : number {
  77. return this.guiID;
  78. }
  79. /**
  80. * Eine String-Darstellung des Kurses, z.B. 'D;GK1'.
  81. *
  82. * @return Eine String-Darstellung des Kurses, z.B. 'D;GK1'.
  83. */
  84. public gibRepresentation() : String {
  85. return this.representation;
  86. }
  87. /**
  88. * Liefert die zum Kurs zugehörige Fachart.
  89. *
  90. * @return Die zum Kurs zugehörige Fachart.
  91. */
  92. public gibFachart() : KursblockungDynFachart {
  93. return this.fachart;
  94. }
  95. /**
  96. * Liefert die aktuelle Anzahl an Schülern in diesem Kurs.
  97. *
  98. * @return Die aktuelle Anzahl an Schülern in diesem Kurs.
  99. */
  100. public gibSchuelerAnzahl() : number {
  101. return this.schuelerAnz;
  102. }
  103. /**
  104. * Liefert {@code true} falls die Schienenlage des Kurses noch veränderbar ist.
  105. * Wenn der Kurs komplett fixiert ist, oder so viele Schienen gesperrt sind,
  106. * dass der Kurs keine Wahlmöglichkeit bezüglich seiner Schienen hat, dann ist
  107. * das Resultat {@code false}
  108. *
  109. * @return Liefert {@code true}, falls die Schienenlage des Kurses noch
  110. * veränderbar ist.
  111. */
  112. public gibHatFreiheitsgrade() : boolean {
  113. return (this.schienenLageFixiert < this.schienenLage.length) && (this.schienenFrei.length > 0);
  114. }
  115. /**
  116. * Liefert die aktuelle Schienenlage dieses Kurses.
  117. *
  118. * @return Ein Array, das angibt, in welchen Schienen der Kurs ist. Die Werte
  119. * sind 0-indiziert.
  120. */
  121. public gibSchienenLage() : Array<number> {
  122. let length : number = this.schienenLage.length;
  123. let lage : Array<number> = Array(length).fill(0);
  124. for (let i : number = 0; i < length; i++){
  125. lage[i] = this.schienenLage[i].gibNr();
  126. }
  127. return lage;
  128. }
  129. /**
  130. * Liefert die Anzahl an Schienen, die dieser Kurs belegt.
  131. *
  132. * @return Die Anzahl an Schienen, die dieser Kurs belegt.
  133. */
  134. public gibSchienenAnzahl() : number {
  135. return this.schienenLage.length;
  136. }
  137. /**
  138. * Speichert die aktuelle Lage der Schienen im Zustand S, um diese bei Bedarf
  139. * mit der Methode {@link #aktionZustandLadenS} zu laden.
  140. */
  141. public aktionZustandSpeichernS() : void {
  142. System.arraycopy(this.schienenLage, 0, this.schienenLageSaveS, 0, this.schienenLage.length);
  143. System.arraycopy(this.schienenFrei, 0, this.schienenFreiSaveS, 0, this.schienenFrei.length);
  144. }
  145. /**
  146. * Speichert die aktuelle Lage der Schienen im Zustand K, um diese bei Bedarf
  147. * mit der Methode {@link #aktionZustandLadenK} zu laden.
  148. */
  149. public aktionZustandSpeichernK() : void {
  150. System.arraycopy(this.schienenLage, 0, this.schienenLageSaveK, 0, this.schienenLage.length);
  151. System.arraycopy(this.schienenFrei, 0, this.schienenFreiSaveK, 0, this.schienenFrei.length);
  152. }
  153. /**
  154. * Lädt die zuvor mit der Methode {@link #aktionZustandSpeichernS} gespeicherte
  155. * Lage der Schienen.
  156. */
  157. public aktionZustandLadenS() : void {
  158. this.aktionSchienenLageEntfernen();
  159. System.arraycopy(this.schienenLageSaveS, 0, this.schienenLage, 0, this.schienenLage.length);
  160. System.arraycopy(this.schienenFreiSaveS, 0, this.schienenFrei, 0, this.schienenFrei.length);
  161. this.aktionSchienenLageHinzufuegen();
  162. }
  163. /**
  164. * Lädt die zuvor mit der Methode {@link #aktionZustandSpeichernK} gespeicherte
  165. * Lage der Schienen.
  166. */
  167. public aktionZustandLadenK() : void {
  168. this.aktionSchienenLageEntfernen();
  169. System.arraycopy(this.schienenLageSaveK, 0, this.schienenLage, 0, this.schienenLage.length);
  170. System.arraycopy(this.schienenFreiSaveK, 0, this.schienenFrei, 0, this.schienenFrei.length);
  171. this.aktionSchienenLageHinzufuegen();
  172. }
  173. /**
  174. * Verteilt den Kurs auf die Schienen zufällig.
  175. */
  176. public aktionZufaelligVerteilen() : void {
  177. if (!this.gibHatFreiheitsgrade()) {
  178. return;
  179. }
  180. if (this.schuelerAnz > 0) {
  181. this.logger.log(LogLevel.ERROR, "Kurs.aktionZufaelligVerteilen: schuelerAnz > 0 (Ein Kurs mit SuS darf nicht verteilt werden)");
  182. return;
  183. }
  184. for (let i1 : number = this.schienenLageFixiert; i1 < this.schienenLage.length; i1++){
  185. let i2 : number = (Math.random() * this.schienenFrei.length) as number;
  186. let schiene1 : KursblockungDynSchiene = this.schienenLage[i1];
  187. let schiene2 : KursblockungDynSchiene = this.schienenFrei[i2];
  188. schiene1.aktionKursEntfernen(this);
  189. schiene2.aktionKursHinzufuegen(this);
  190. this.schienenLage[i1] = schiene2;
  191. this.schienenFrei[i2] = schiene1;
  192. }
  193. }
  194. /**
  195. * Setzt die Lage des Kurses auf die in der Liste übergebenen Schienen.
  196. *
  197. * @param pSchienenWahl Die Schienen (0-indiziert), in denen der Kurs liegen
  198. * soll.
  199. */
  200. public aktionVerteileAufSchienen(pSchienenWahl : LinkedCollection<Number>) : void {
  201. for (let iLage : number = this.schienenLageFixiert; iLage < this.schienenLage.length; iLage++){
  202. let schieneL : KursblockungDynSchiene = this.schienenLage[iLage];
  203. if (pSchienenWahl.contains(schieneL.gibNr())) {
  204. continue;
  205. }
  206. for (let iFrei : number = 0; iFrei < this.schienenFrei.length; iFrei++){
  207. let schieneF : KursblockungDynSchiene = this.schienenFrei[iFrei];
  208. if (pSchienenWahl.contains(schieneF.gibNr())) {
  209. schieneL.aktionKursEntfernen(this);
  210. schieneF.aktionKursHinzufuegen(this);
  211. this.schienenFrei[iFrei] = schieneL;
  212. this.schienenLage[iLage] = schieneF;
  213. break;
  214. }
  215. }
  216. }
  217. }
  218. /**
  219. * Speichert die aktuelle Kurs-Schiene-Zuordnung im Vector
  220. * {@code vKursZuSchiene}.
  221. *
  222. * @param vKursZuSchiene Diesem Vektor wird die aktuelle Kurszuordnung
  223. * hinzugefügt.
  224. */
  225. public aktionOutputErzeugen(vKursZuSchiene : Vector<KursblockungOutputKursZuSchiene>) : void {
  226. let kursZuSchiene : KursblockungOutputKursZuSchiene = new KursblockungOutputKursZuSchiene();
  227. kursZuSchiene.kurs = this.guiID;
  228. kursZuSchiene.schienen = this.gibSchienenLage();
  229. vKursZuSchiene.add(kursZuSchiene);
  230. }
  231. /**
  232. * Entfernt einen Schüler aus diesem Kurs.
  233. */
  234. public aktionSchuelerEntfernen() : void {
  235. this.fachart.aktionKursdifferenzEntfernen();
  236. this.schuelerAnz--;
  237. this.fachart.aktionSchuelerWurdeEntfernt();
  238. this.fachart.aktionKursdifferenzHinzufuegen();
  239. }
  240. /**
  241. * Fügt einen Schüler diesem Kurs hinzu.
  242. */
  243. public aktionSchuelerHinzufügen() : void {
  244. this.fachart.aktionKursdifferenzEntfernen();
  245. this.schuelerAnz++;
  246. this.fachart.aktionSchuelerWurdeHinzugefuegt();
  247. this.fachart.aktionKursdifferenzHinzufuegen();
  248. }
  249. /**
  250. * Liefert TRUE, wenn die Schiene für den Kurs gesperrt wurde.
  251. *
  252. * @param pSchiene Die Schiene nach der gefragt wurde.
  253. *
  254. * @return TRUE, wenn die Schiene für den Kurs gesperrt wurde.
  255. */
  256. public gibIstSchieneGesperrt(pSchiene : number) : boolean {
  257. for (let s of this.schienenLage) {
  258. if (s.gibNr() === pSchiene) {
  259. return false;
  260. }
  261. }
  262. for (let s of this.schienenFrei) {
  263. if (s.gibNr() === pSchiene) {
  264. return false;
  265. }
  266. }
  267. return true;
  268. }
  269. /**
  270. * Liefert TRUE, wenn die Schiene für den Kurs fixiert wurde.
  271. *
  272. * @param pSchiene Die Schiene nach der gefragt wurde.
  273. *
  274. * @return TRUE, wenn die Schiene für den Kurs fixiert wurde.
  275. */
  276. public gibIstSchieneFixiert(pSchiene : number) : boolean {
  277. for (let iLage : number = 0; iLage < this.schienenLageFixiert; iLage++){
  278. if (this.schienenLage[iLage].gibNr() === pSchiene) {
  279. return true;
  280. }
  281. }
  282. return false;
  283. }
  284. private aktionSchienenLageHinzufuegen() : void {
  285. for (let i : number = 0; i < this.schienenLage.length; i++){
  286. this.schienenLage[i].aktionKursHinzufuegen(this);
  287. }
  288. }
  289. private aktionSchienenLageEntfernen() : void {
  290. for (let i : number = 0; i < this.schienenLage.length; i++){
  291. this.schienenLage[i].aktionKursEntfernen(this);
  292. }
  293. }
  294. isTranspiledInstanceOf(name : string): boolean {
  295. return ['de.nrw.schule.svws.core.kursblockung.KursblockungDynKurs'].includes(name);
  296. }
  297. }
  298. export function cast_de_nrw_schule_svws_core_kursblockung_KursblockungDynKurs(obj : unknown) : KursblockungDynKurs {
  299. return obj as KursblockungDynKurs;
  300. }