-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathapp.js
79 lines (71 loc) · 2.97 KB
/
app.js
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
$(function() {
$.ajax('http://localhost:1323/books')
.done(function(books) {
books.forEach(appendBook)
$('.js-toggle-review').on('click', function(event) {
var bookId = $(this).data('bookId')
$('.js-review[data-book-id="' + bookId + '"]').toggle('fast')
return false
})
$(document).on('click', '.js-like', function(event) {
var likeCountElement = $(this).find('.js-like-count')
likeCountElement.text(likeCountElement.text() + 1)
return false
})
$(document).on('submit', '.js-form', function(event) {
var bookId = $(this).data('bookId')
$.ajax({
url: 'http://localhost:1323/reviews',
type: 'post',
dataType: 'json',
data: {
comment: $(event.currentTarget).find('textarea').val()
}
}).done(function(review) {
$('.js-review[data-book-id="' + bookId + '"] > ul').append($(createBookReview(review)))
})
return false
})
})
})
function appendBook(book) {
$('#js-book-list').append($(
'<li class="book-list__item">' +
'<div class="book-list__item__inner">' +
'<img class="book-list__item__inner__image" src="' + book.image + '" alt="' + book.title + '">' +
'<div class="book-list__item__inner__info">' +
'<h3 class="book-list__item__inner__info__title">' +
book.title +
'<span class="book-list__item__inner__info__title__author">(' + book.author + ')</span>' +
'</h3>' +
'<p class="book-list__item__inner__info__overview">' + book.overview + '</p>' +
'<p class="book-list__item__inner__info__comment">' +
'<a href="#" class="book-list__item__inner__info__comment__link js-toggle-review" data-book-id="' + book.id + '">' +
book.reviews.length + '件の感想・評価' +
'</a>' +
'</p>' +
'</div>' +
'</div>' +
'<div class="review js-review" data-book-id="' + book.id + '">' +
'<ul class="review__list">' + book.reviews.map(createBookReview).join('') + '</ul>' +
'<form class="review__form js-form" data-book-id="' + book.id + '">' +
'<textarea class="review__form__input" rows="5" placeholder="「' + book.title + '」を読んだ感想・評価を教えてください"></textarea>' +
'<button class="review__form__submit" type="submit">投稿</button>' +
'</form>' +
'</div>' +
'</li>'
))
}
function createBookReview(review) {
return (
'<li class="review__list__item">' +
'<p class="review__list__item__name">' + review.username + 'さんの感想・評価</p>' +
'<p class="review__list__item__comment">' + review.comment + '</p>' +
'<p class="review__list__item__like">' +
'<a href="#" class="review__list__item__like__button js-like">' +
'❤️ <span class="js-like-count">' + review.like + '</span>件' +
'</a>' +
'</p>' +
'</li>'
)
}