forked from woprzech/warsawjs-workshop-26-my-photos
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathimage.js
More file actions
53 lines (46 loc) · 1.53 KB
/
image.js
File metadata and controls
53 lines (46 loc) · 1.53 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
export class Image {
constructor(id, fileName, isFavourite) {
this.id = id;
this.fileName = fileName;
this.favourite = isFavourite;
}
show() {
this.htmlElement = document.createElement('img');
this.htmlElement.setAttribute('src', this.fileName);
this.htmlElement.setAttribute('class', `images__image`);
this.htmlElement.addEventListener('click', () => this.isFavourite() ? this.unmarkAsAFavourite() : this.markAsAFavourite());
this.isFavourite() ? this.showAsAFavourite() : true;
document.getElementById('images').appendChild(this.htmlElement);
}
unmarkAsAFavourite() {
this.favourite = false;
fetch(`http://localhost:3000/photos/${this.id}`, {
method: 'PATCH',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({isFavourite: false})
});
this.showAsNotFavourite();
}
showAsNotFavourite() {
this.htmlElement.classList.remove('image--favourite');
}
markAsAFavourite() {
this.favourite = true;
fetch(`http://localhost:3000/photos/${this.id}`, {
method: 'PATCH',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({isFavourite: true})
});
this.showAsAFavourite();
}
showAsAFavourite() {
this.htmlElement.classList.add('image--favourite');
}
isFavourite() {
return this.favourite;
}
}