[DP] PlanetDP MAL İzleme Durumu

PlanetDP portalında anime sayfalarındaki MAL ID'leri kullanarak listenizdeki animelerdeki izleme durumunuzu gösteririr.

// ==UserScript==
// @name         [DP] PlanetDP MAL İzleme Durumu
// @version      1.1
// @description  PlanetDP portalında anime sayfalarındaki MAL ID'leri kullanarak listenizdeki animelerdeki izleme durumunuzu gösteririr.
// @author       nht.ctn
// @namespace    https://github.com/nhtctn
// @icon         

// @include      *://*planetdp.org/title/*
// @include      *://*planetdp.org/subtitle/*

// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_xmlhttpRequest
// @grant        GM_addStyle
// ==/UserScript==

(function() {
    'use strict';
    var listCacheTime = 1200000; // 86400000 - 1 gün // 600000 - 10 dk
    var malIcon = ""
    var enter = `
`
    var title = document.querySelector( 'h1[itemprop="name"]' ).textContent;
    var seriesCheck = document.querySelector( '[id="listnum"]' ) != null;
    var animeLink = document.querySelector( 'h1 span > a[href*="myanimelist.net/anime"]');
    if (animeLink != null) {
        var firstTimeCheck;
        var userAnimeList = [];
        var updateAnimeList = [];
        var userNameGlo = malUserNameFunc();
        malListFunc(userNameGlo);

        // Eksikse altyazı üstü barını yerleştir
        var fisrtSeason = document.querySelector( '.season_1 th[colspan="12"]' );
        if (!fisrtSeason) {
            var text = (seriesCheck) ? '1. Sezon ' + title : title + ' Altyazıları';
            var barHTML = '<tbody></tbody><thead style="background-color:#ffd564;"><tr class="season_1"><th colspan="12" style="color:#fff;padding-left:15px">' + text + '</th></tr></thead>'
            document.querySelector('tr.rowhead').parentElement.insertAdjacentHTML("afterend",barHTML);
        }

        var malID = animeLink.href.toString().replace( /.+\/anime\/(\d+)/, "$1");
        document.querySelector( '.season_1 th[colspan="12"]' ).insertAdjacentHTML( "beforeend", html( malID ) );

        var css =
`
.malBox        {position: relative; float: right; margin: 3px 5px 0 0; min-width: 25px;}
.malBorder     {height: 25px; border-radius: 15px; border: 2.5px solid #fff;}
.malEpisode    {white-space: nowrap; line-height: 14.5px; font-size: 16px; width: 0; padding: 2px 0; color: transparent; overflow:hidden; transition: .3s ease-out}
.malButton     {position: absolute; top: 0; right: 0; height: 25px; width: 25px; border-radius: 15px; background-color: #fff;}
.malImg        {position: absolute; width: 20px; height: 20px; top: 2.5px; left: 2.5px;}

.completed     {background-color: #404B9E;}
.watching      {background-color: #0fc420;}
.on_hold       {background-color: #f1c83e;}
.dropped       {background-color: #ff0004;}
.plan_to_watch {background-color: #c3c3c3;}

.malBox:hover .malEpisode {padding: 2px 28px 2px 10px; width:auto; color: #fff}
`
        GM_addStyle( css );
    }


    function malUserNameFunc() {
        var userName = GM_getValue( "userName" );
        if (userName == null) {
            userName = prompt("İzleme durumunuzu site üstünde görmek için MyanimeList kullanıcı adınızı giriniz.")
            GM_setValue( "userName", userName );
            GM_setValue( "lastUpdateTime", 0 );
            firstTimeCheck = true;
        }
        return userName;
    }

    function malListFunc( userName ) {
        userAnimeList = GM_getValue( "cachedUserList" )
        var d = new Date();
        var currentTime = d.getTime();

        var lastUpdateTime = GM_getValue( "lastUpdateTime" );
        if (currentTime - lastUpdateTime > listCacheTime && GM_getValue( "userName" ) != null) {
            updateList( userName );
        }
    }

    function updateList ( userName, repeat ) {
        repeat = (repeat != null) ? repeat : 0;
        var offset = repeat*300;
        GM_xmlhttpRequest({
                method: "GET",
                url: "https://myanimelist.net/animelist/" + userName + "/load.json?status=7&offset=" + offset,
                onload: function(response) {
                    var json = response.responseText;
                    var newAnimeList = JSON.parse( json );

                    if (newAnimeList.errors == null) {
                        var anime;
                        for (var x = 0; x < newAnimeList.length; x++ )
                        {
                            anime = newAnimeList[x];
                            updateAnimeList[ anime.anime_id ] = anime;
                        }

                        var d = new Date();
                        var currentTime = d.getTime();

                        var pageLength = newAnimeList.length;
                        if (pageLength == 300) {
                            updateList( userName, repeat + 1 )
                        }
                        else {
                            GM_setValue( "cachedUserList", updateAnimeList);
                            GM_setValue( "lastUpdateTime", currentTime );
                            if (firstTimeCheck == true) {location.reload();}
                        }
                    }
                    else {
                        var newUserName = prompt("Girmiş olduğunuz \"" + userName + "\" kullanıcı adı bulunamadı." + enter + "İzleme durumunuzu site üstünde görmek için MyanimeList kullanıcı adınızı giriniz.")
                        GM_setValue( "userName", newUserName );
                        updateList ( newUserName );
                    }
                }
        });
    }

    function html( ID ) {
        var anime = userAnimeList[ID];
        var isInList = anime != null;

        var episodeCheck, episodes, status, animeName;
        if (isInList) {
            episodeCheck = "malEpisode"
            episodes = anime.num_watched_episodes + `/` + anime.anime_num_episodes.toString().replace( /^0$/, "?" );
            status = watchStatus(anime.status).toLowerCase().replace( / /g, "_" );
            animeName = anime.anime_title + ` (` + watchStatusTR(anime.status) + `)`
        }
        else {
            episodeCheck = "";
            episodes = "";
            status = '';
            animeName = "";
        }

        return `
<div class="malBox">
  <a href="https://myanimelist.net/anime/` + ID + `" target="_blank" style="text-decoration: none;">
    <div class="malBorder">
      <div class="` + episodeCheck + `">
          ` + episodes + `
      </div>
    </div>
    <div class="malButton ` + status + `" title="` + animeName + `">
      <img class="malImg" src="` + malIcon + `">
    </div>
  </a>
</div>
`
    }

    function watchStatus( ID ) {
        if (ID == 1) {return "Watching";}
        else if (ID == 2) {return "Completed";}
        else if (ID == 3) {return "On Hold";}
        else if (ID == 4) {return "Dropped";}
        else if (ID == 6) {return "Plan to Watch";}
    }

    function watchStatusTR( ID ) {
        if (ID == 1) {return "İzleniyor";}
        else if (ID == 2) {return "Tamamlandı";}
        else if (ID == 3) {return "Beklemede";}
        else if (ID == 4) {return "Bırakıldı";}
        else if (ID == 6) {return "İzlenecek";}
    }

})();