aboutsummaryrefslogtreecommitdiff
path: root/src/models/PeerTeacher.ts
diff options
context:
space:
mode:
authorFurkan Sahin <furkan-dev@proton.me>2021-09-05 21:39:24 -0500
committerFurkan Sahin <furkan-dev@proton.me>2021-09-05 21:39:24 -0500
commitd0975a6e7ee57de4debda94e823011d813fbf4a1 (patch)
tree69d61bf6c29104434b9e3de4946e7d5dd549dec0 /src/models/PeerTeacher.ts
parentffef3a6be19d1139b6378c8119d444082dd0cbac (diff)
Initial rewrite in svelte
Diffstat (limited to 'src/models/PeerTeacher.ts')
-rw-r--r--src/models/PeerTeacher.ts58
1 files changed, 19 insertions, 39 deletions
diff --git a/src/models/PeerTeacher.ts b/src/models/PeerTeacher.ts
index f387431..6518a80 100644
--- a/src/models/PeerTeacher.ts
+++ b/src/models/PeerTeacher.ts
@@ -1,41 +1,21 @@
-import EventInfo from './EventInfo';
+import type EventInfo from "./EventInfo";
export default class PeerTeacher {
- firstname: string;
-
- lastname: string;
-
- uin: number;
-
- events: EventInfo[];
-
- assignedLabs: Set<string>;
-
- constructor(firstname = '', lastname = '', uin = 0) {
- this.firstname = firstname;
- this.lastname = lastname;
- this.uin = uin;
- this.events = [];
- this.assignedLabs = new Set();
- }
-
- conflictsWith(event: EventInfo) {
- let conflicts = false;
- this.events.every((item) => {
- if (item.conflictsWith(event)) {
- conflicts = true;
- return false;
- }
- return true;
- });
- return conflicts;
- }
-
- get name() {
- return `${this.firstname} ${this.lastname}`;
- }
-
- get id() {
- return this.uin;
- }
-}
+ id: number;
+ firstname: string;
+ lastname: string;
+ events: EventInfo[];
+ labs: Set<number>;
+
+ constructor(id: number | string, firstname: string, lastname: string) {
+ if(typeof id === "string") {
+ id = parseInt(id, 10);
+ }
+
+ this.id = id;
+ this.firstname = firstname;
+ this.lastname = lastname;
+ this.events = [];
+ this.labs = new Set();
+ }
+} \ No newline at end of file