HummingBirdAnimeClient/public/js/anime_edit.js

61 lines
1.6 KiB
JavaScript
Raw Normal View History

/**
* Javascript for editing anime, if logged in
*/
2016-02-08 20:21:41 -05:00
((_) => {
2015-11-13 11:33:27 -05:00
2016-02-01 09:49:18 -05:00
'use strict';
// Action to increment episode count
2017-02-16 11:47:54 -05:00
_.on('body.anime.list', 'click', '.plus_one', (e) => {
2017-02-15 14:08:15 -05:00
let parentSel = _.closestParent(e.target, 'article');
2017-04-10 15:31:35 -04:00
let watchedCount = parseInt(_.$('.completed_number', parentSel)[0].textContent, 10) || 0;
2017-02-15 14:08:15 -05:00
let totalCount = parseInt(_.$('.total_number', parentSel)[0].textContent, 10);
let title = _.$('.name a', parentSel)[0].textContent;
// Setup the update data
2016-02-01 09:49:18 -05:00
let data = {
2017-02-15 14:08:15 -05:00
id: parentSel.dataset.kitsuId,
mal_id: parentSel.dataset.malId,
data: {
2017-02-15 14:08:15 -05:00
progress: watchedCount + 1
}
};
// If the episode count is 0, and incremented,
// change status to currently watching
2017-02-15 14:08:15 -05:00
if (isNaN(watchedCount) || watchedCount === 0) {
data.data.status = 'current';
}
// If you increment at the last episode, mark as completed
2017-02-16 11:47:54 -05:00
if (( ! isNaN(watchedCount)) && (watchedCount + 1) === totalCount) {
data.data.status = 'completed';
}
_.show(_.$('#loading-shadow')[0]);
// okay, lets actually make some changes!
2016-02-08 20:21:41 -05:00
_.ajax(_.url('/anime/update'), {
2017-02-16 11:47:54 -05:00
data,
2015-11-13 11:33:27 -05:00
dataType: 'json',
2016-02-02 11:34:03 -05:00
type: 'POST',
2017-01-09 21:38:42 -05:00
success: () => {
2017-02-16 11:47:54 -05:00
if (data.data.status === 'completed') {
2017-02-15 14:08:15 -05:00
_.hide(parentSel);
2016-02-02 11:34:03 -05:00
}
_.hide(_.$('#loading-shadow')[0]);
_.showMessage('success', `Successfully updated ${title}`);
2017-02-15 14:08:15 -05:00
_.$('.completed_number', parentSel)[0].textContent = ++watchedCount;
2016-02-08 20:21:41 -05:00
_.scrollToTop();
2016-02-02 11:34:03 -05:00
},
error: (xhr, errorType, error) => {
_.hide(_.$('#loading-shadow')[0]);
_.showMessage('error', `Failed to update ${title}. `);
2016-02-08 20:21:41 -05:00
_.scrollToTop();
}
});
});
2016-02-08 20:21:41 -05:00
})(AnimeClient);