您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Planetdp portalında kendinize özel listeler oluşturmasına olanak sağlar.
- // ==UserScript==
- // @name [DP] PlanetDP Listeler
- // @description Planetdp portalında kendinize özel listeler oluşturmasına olanak sağlar.
- // @version 1.2
- // @author nht.ctn
- // @namespace https://github.com/nhtctn
- // @icon 
- // @run-at document-end
- // @include *://*planetdp.org*
- // @include *://*forum.planetdp.org*
- // @grant GM_addStyle
- // @grant GM_getValue
- // @grant GM_setValue
- // @grant GM_addValueChangeListener
- // @grant GM_xmlhttpRequest
- /* global $ */
- // ==/UserScript==
- /*jshint esversion: 6 */
- (function() {
- 'use strict';
- var defaultQueueForm = {name: "", description: "", counter: 1, delay: 0, note: 1, sortBy: "created", color: "olive"};
- var version = 1.1;
- // var defaultContentForm = {};
- // var oldContentDeleteTime = millisecondConverter(2, "year", "ms"); // 2 Year
- var checkWaitingTime = millisecondConverter(10, "minute", "ms"); // 10 minutes
- var pageUrl = window.location.href;
- var x;
- var enter = `
- `;
- if (pageUrl.search(/forum\.planetdp\.org\/.+/) > 0) {
- waitForKeyElements('.cke_toolbar.cke_toolbar_last > .cke_toolbar_end', function() {addForumExport();}, false);
- }
- else {
- if (pageUrl.search( /planetdp\.org\/title\// ) >= 0) {
- var babaMain = document.querySelector('div.baba_main');
- var cardId = pageUrl.replace(/.+planetdp\.org\/title\/.+-dp(\d+)(.+)?/,"$1");
- var cardInfos = getCardInfos(babaMain, cardId);
- }
- if (document.querySelector( '[href="/logout"]' ) != null)
- {
- // Üye menüsüne Kuyruk ikonu ve içine kuyruk oluştur seçeneğini yerleştir.
- var queueHtmlZero = `
- <li class="dropdown">
- <a data-toggle="dropdown" data-placement="bottom" class="lists-menu648" title="Listeler" class="dropdown-toggle" data-secondary-toggle="tooltip">
- <span class="badge"></span>
- <i class="fa fa-tasks"></i>
- </a>
- <ul class="dropdown-menu user-dropdown"><li id="queue648"><a href="#">Liste Oluştur</a></li></ul>
- </li>
- `;
- $('.user-buttons > .seperator:first').after(queueHtmlZero);
- document.getElementById("queue648").onclick = function() {insertQueueForm("new");};
- // Varsa mevcut kuyrukları da ekle.
- isertQueues();
- // Kuyruklar güncellendiğinde eski seçenek ve butonları temizle, baştan oluşturan fonksiyonu çlıştır.
- GM_addValueChangeListener("queueArray", function(name, old_value, new_value, remote) {
- var oldOptions = document.querySelectorAll('[id^="queue648_"]');
- for (x = 0; x < oldOptions.length; x++) {
- oldOptions[x].remove();
- }
- isertQueues();
- });
- }
- // CSS eklemeleri (Her sayfada gerekli css'ler yok.)
- GM_addStyle(`
- .window-header {
- padding-bottom: 15px;
- border-bottom: 1px solid #000;
- display: contents;
- }
- .mfp-close-btn-in .mfp-close {
- color: #333;
- }
- button.mfp-close, button.mfp-arrow {
- overflow: visible;
- cursor: pointer;
- background: transparent;
- border: 0;
- -webkit-appearance: none;
- display: block;
- outline: none;
- padding: 0;
- z-index: 1046;
- -webkit-box-shadow: none;
- box-shadow: none;
- }
- .mfp-close {
- width: 44px;
- height: 44px;
- line-height: 44px;
- position: absolute;
- right: 0;
- top: 0;
- text-decoration: none;
- text-align: center;
- opacity: .65;
- filter: alpha(opacity=65);
- padding: 0 0 18px 10px;
- color: #fff;
- font-style: normal;
- font-size: 28px;
- font-family: Arial,Baskerville,monospace;
- }
- .mfp-close, .mfp-arrow, .mfp-preloader, .mfp-counter {
- -webkit-user-select: none;
- -moz-user-select: none;
- user-select: none;
- }
- .mfp-bg {
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- z-index: 1042;
- overflow: hidden;
- position: fixed;
- background: #0b0b0b;
- opacity: .8;
- filter: alpha(opacity=80);
- }
- .mfp-wrap {
- top: 0;
- left: 0;
- width: 100%;
- height: 100%;
- z-index: 1043;
- position: fixed;
- outline: none!important;
- -webkit-backface-visibility: hidden;
- }
- .mfp-container {
- text-align: center;
- position: absolute;
- width: 100%;
- height: 100%;
- left: 0;
- top: 0;
- padding: 0 8px;
- -webkit-box-sizing: border-box;
- -moz-box-sizing: border-box;
- box-sizing: border-box;
- }
- .mfp-container:before {
- content: '';
- display: inline-block;
- height: 100%;
- vertical-align: middle;
- }
- .mfp-auto-cursor .mfp-content {
- cursor: auto;
- }
- .mfp-inline-holder .mfp-content, .mfp-ajax-holder .mfp-content {
- width: 100%;
- cursor: auto;
- }
- .mfp-content {
- position: relative;
- display: inline-block;
- vertical-align: middle;
- margin: 0 auto;
- text-align: left;
- z-index: 1045;
- }
- .window-content .btn {
- margin-right: 15px;
- }
- .btn {
- display: inline-block;
- padding: 6px 12px;
- margin-bottom: 0;
- font-size: 14px;
- font-weight: 400;
- line-height: 1.42857143;
- text-align: center;
- white-space: nowrap;
- vertical-align: middle;
- -ms-touch-action: manipulation;
- touch-action: manipulation;
- cursor: pointer;
- -webkit-user-select: none;
- -moz-user-select: none;
- -ms-user-select: none;
- user-select: none;
- background-image: none;
- border: 1px solid transparent;
- border-radius: 4px;
- }
- .btn-default {
- color: #333;
- background-color: #fff;
- border-color: #ccc;
- }` +
- // Ekstra CSS'ler
- `
- ul[id^="queueWindow_list"] {
- height: 450px;
- overflow-y: auto;
- }
- ul[id^="queueWindow_list"] > li {
- padding: 7px 5px;
- border-bottom: 1px dotted #000;
- list-style: none;
- display: flex;
- }
- .div-left {
- display: inline-block;
- width: 70%;
- padding-right: 15px;
- }
- .div-right {
- display: inline-block;
- width: 30%;
- }
- .div-left > *, .div-right > * {
- display: block;
- width: 100%;
- word-break: break-word;
- }
- .queue_list_hide {
- display: none;
- }
- .queButtons {
- display: flex;
- flex-direction: row-reverse;
- align-items: center;
- }
- .waitingButtons {
- flex: 1;
- }
- .editButtons > i {
- font-size: 15px;
- border-radius: 15px;
- margin-left: 10px;
- user-select: none;
- }
- #deleteQueue:hover, #editQueue:hover, #exportQueue:hover {
- color: #f00;
- }
- .badge.no-counter {
- opacity: 0.6;
- }
- /* MOBİL GÖRÜNÜM */
- @media only screen and (max-width: 767px) and (min-width: 320px){
- #queueWindow-form {margin: 0;}
- .queButtons { flex-direction: column; }
- .queButtons > * { width: 100%; text-align: left; }
- .editButtons > i { margin: 0 15px 0 0; }
- .waitingButtons { margin-top: 10px; }
- ul[id^="queueWindow_list"] > li { flex-direction: column; }
- .div-right, .div-left { width: 100%; }
- }
- `);
- $('#dpDarkCss').after('<style id="queueCss_dark">queueWindow-form li, [id*="-form"] .window-header { border-color: #4c4c4c!important; }</style>');
- darkToggle();
- $('#darkSwitchButton').on("click", function() {darkToggle();} );
- }
- function darkToggle() {
- if ($('#dpDarkCss').attr("disabled")) { $('#queueCss_dark').prop("disabled", "disabled"); }
- else { $('#queueCss_dark').prop("disabled", ""); }
- }
- function getCardInfos(page, c_ID) {
- var cardTitle = page.querySelector( 'h1[itemprop="name"]' ).textContent.trim();
- var year = page.querySelector('span[itemprop="copyrightYear"]');
- year = (year) ? year.textContent.trim().replace(/\n/gi,"").replace(/(\d{4})\s?-?\s?(\d{4})?/,"$1") : "?";
- var dpRaiting = page.querySelector('span[itemprop="ratingValue"]');
- dpRaiting = (dpRaiting) ? dpRaiting.textContent.trim() : "-";
- var imdbBoxLink = page.querySelector('ul.pd [href*="imdb.com/title/tt"]');
- var imdbID = (imdbBoxLink) ? imdbBoxLink.href.replace(/.+imdb\.com\/title\/tt(\d+)/,"$1") : "-";
- var imdbRating = (imdbBoxLink) ? imdbBoxLink.closest("ul").querySelector('li.active').textContent.trim().replace(/\/10/,"") : "-";
- imdbRating = (imdbRating == "") ? "-" : imdbRating;
- return {cardId: c_ID, cardTitle: cardTitle, year: year, dpRaiting: dpRaiting, imdbID: imdbID, imdbRating: imdbRating};
- }
- function activateElements() {
- var db = GM_getValue("queueArray");
- var lastActivate = GM_getValue("lastActivateTime");
- var currentTime = new Date().getTime();
- if (currentTime - lastActivate >= checkWaitingTime || lastActivate == null) {
- for (let y = 0; y < db.length; y++) {
- var activeWitingArray = db[y][1];
- for (let z = 0; z < activeWitingArray.length; z++) {
- var w = activeWitingArray[z];
- if (w != null) {
- if (w.active == 0) {
- if (currentTime >= w.activateTime) {
- w.active = 1;
- }
- }
- }
- }
- }
- GM_setValue("queueArray", db);
- GM_setValue("lastActivateTime", currentTime);
- }
- }
- function downloadQueue(no) {
- var queue = GM_getValue("queueArray")[no];
- var infos = queue[0];
- var s = ` `;
- var d = new Date();
- var date = d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate();
- var filename = infos.name + "_" + date;
- var array = [];
- arrayFilter(queue[1], array);
- arraySorter(array, "object", infos.sortBy);
- var data = `Yapım Adı` + s + `Yıl` + s + `IMDb ID` + s + `DP ID` + s + `Aktif mi?` + s + `Not` + s + `Gecikme` + s + `Oluşturma Zamanı` + s + `Aktifleşme Zamanı` + enter;
- for (let x = 0; x < array.length; x++) {
- var q = array[x];
- if (q != null) {
- data += q.cardTitle + s + q.year + s + q.imdbID + s + q.cardId + s + q.active + s + q.note + s + q.delay + s + q.created + s + q.activateTime + enter;
- }
- }
- var element = document.createElement('a');
- element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(data));
- element.setAttribute('download', filename);
- element.style.display = 'none';
- document.body.appendChild(element);
- element.click();
- document.body.removeChild(element);
- }
- function isUpToDate(no) {
- var infos = GM_getValue("queueArray")[no][0];
- if (infos.version == version) {
- return true;
- }
- else {
- upDateQueue(no);
- }
- }
- function upDateQueue(no) {
- var queueArray = GM_getValue("queueArray");
- var infos = queueArray[no][0];
- var array = queueArray[no][1];
- var filtredArray = [];
- arrayFilter(queueArray[no][1], filtredArray);
- if(confirm("Bu listenin yeni versiyona göre güncellenmesi gerekmektedir." + enter +"Sürüm " + infos.version + " => Sürüm " + version + enter + enter + "Bu işlem birkaç dakika sürebilir. Lütfen sekmeyi kapatmayın.")) {
- try {
- // İlk verisonlu sürüme geçiş. ========
- if (infos.version == null) {
- var change1 = (function(t) { // Version no ekle. Sıralama türü ekle[addedtime].
- return function (e) {
- var n_que = GM_getValue("queueArray");
- infos.version = version;
- infos.sortBy = "created";
- n_que[no][0] = infos;
- GM_setValue("queueArray", n_que);
- };
- })(no);
- upDateQueueContent(no, filtredArray, 0, change1); // Öğe bilgilerini güncellemek için request at. [yıl,imdb ID,imdb puan,dp puan]
- alert("Güncelleme işlemi tamamlandı.");
- }
- // 1.1'e geçiş. ======================= (Henüz yayınlanmadı.)
- else if (infos.version == 1.0) {
- for (let x = 0; x < filtredArray.length; x++) {
- array[filtredArray[x].cardId].year = array[filtredArray[x].cardId].year.replace(/(\d{4})\s?-?\s?(\d{4})?/,"$1");
- }
- queueArray[no][0].version = version;
- queueArray[no][1] = array;
- GM_setValue("queueArray", queueArray);
- alert("Güncelleme işlemi tamamlandı.");
- }
- }
- catch(err) {
- alert("Güncelleme işlemi sırasında bir sorun oluştu." + enter +"Sürüm " + infos.version + " => Sürüm " + version + enter + enter + "Lütfen aşağıdaki hata mesajı ile birlikte uygulama yazarına haber verin." + enter + enter + err.message);
- }
- }
- }
- function upDateQueueContent(no, array, index, myFunction) {
- if (index < array.length) {
- var ax = array[index];
- var id = ax.cardId;
- GM_xmlhttpRequest({
- method: "GET",
- url: "https://www.planetdp.org/title/-" + id,
- onload: function(response) {
- var json = response.responseText;
- var htmlObj = $(json);
- var page = htmlObj.find( 'div.baba_main' )[0];
- var cardInfos2 = getCardInfos(page, id);
- createContentLog(id, no, ax.delay, ax.note, cardInfos2, ax.created);
- setTimeout(function() {upDateQueueContent(no, array, index+1, myFunction);}, 500);
- }
- });
- }
- else if (index == array.length) {
- myFunction();
- }
- }
- function createQueueWindow(queueNo) {
- if (isUpToDate(queueNo) == true) {
- var infos = GM_getValue("queueArray")[queueNo][0];
- insertWindow("queueWindow", "tasks", infos.name, false, infos.color);
- var buttons = `
- <div class="queButtons">
- <div class="editButtons">
- <i id="exportQueue" class="fa fa-file-excel-o" aria-hidden="true" title="Bu Listenin Çıktısını Al"> Çıktı Al</i>
- <i id="editQueue" class="fa fa-pencil" aria-hidden="true" title="Bu Listeyi Düzenle"> Düzenle</i>
- <i id="deleteQueue" class="fa fa-trash" aria-hidden="true" title="Bu Listeyi Sil"> Sil</i>
- </div>
- <div class="waitingButtons">
- <a id="queueWindow_button_active" href="#" class="btn btn-info">Aktif</a>
- <a id="queueWindow_button_waiting" href="#" class="btn btn-default">Beklemede</a>
- <a id="queueWindow_button_done" href="#" class="btn btn-default" style="display: none;">Tamamlanmış</a>
- </div>
- </div>
- `;
- var listCovers = `
- <fieldset class="window-content margintop10">
- <ul id="queueWindow_list_active" class="queue_list_show">
- </ul>
- <ul id="queueWindow_list_waiting" class="queue_list_hide">
- </ul>
- <ul id="queueWindow_list_done" class="queue_list_hide">
- </ul>
- </fieldset>
- `;
- var listFieldset = document.querySelector('#queueWindow-form > .window-content');
- listFieldset.insertAdjacentHTML("beforeend", buttons + listCovers);
- // Sil, düzenle, çıktı al butonlarına fonksiyonları bağla.
- document.querySelector('#queueWindow-form #exportQueue').onclick = function() {
- if (confirm("İnecek olan Txt dosyasının içindekileri kopyalayıp bir Excel dosyasına yapıştırabilirsiniz.")) {
- downloadQueue(queueNo);
- }
- };
- document.querySelector('#queueWindow-form #editQueue').onclick = function() {removeForm("queueWindow"); insertQueueForm("edit", queueNo);};
- document.querySelector('#queueWindow-form #deleteQueue').onclick = (function(t, inf) {
- return function (e) {
- if (confirm("Bu listeyi silmek istediğinize emin misiniz? Bu işlem geri alınamaz.")) {
- var library = GM_getValue("queueArray");
- library.splice(t, 1);
- GM_setValue("queueArray", library);
- removeForm("queueWindow");
- alert("\"" + infos.name + "\" adlı kuruk silindi.");
- }
- };
- })(queueNo, infos);
- // Listelerin içini doldur ve güncelle
- insertLists(queueNo);
- GM_addValueChangeListener("queueArray", function(name, old_value, new_value, remote) {
- var oldLists = document.querySelectorAll('[id^="queueWindow_list"]');
- for (x = 0; x < oldLists.length; x++) {
- oldLists[x].innerHTML = "";
- }
- insertLists(queueNo);
- });
- // Listelerin ve butonların toggle'larını ayarla
- var listButtons = listFieldset.querySelectorAll('[id^="queueWindow_button"]');
- for (let x = 0; x < listButtons.length; x++) {
- listButtons[x].onclick = (function(t) {
- return function (e) {
- // Butonlar
- var oldButton = listFieldset.querySelector('a.btn-info');
- classToogle( oldButton, ["btn-info", "btn-default"] );
- classToogle( listButtons[x], ["btn-info", "btn-default"] );
- // Listeler
- var oldListElement = listFieldset.querySelector( 'ul.queue_list_show' );
- classToogle( oldListElement, ["queue_list_show", "queue_list_hide"] );
- var listElement = listFieldset.querySelector( '#' + listButtons[x].id.replace('button','list') );
- classToogle( listElement, ["queue_list_show", "queue_list_hide"] );
- };
- })(x);
- }
- }
- }
- function insertLists(queueNo) {
- var library = GM_getValue("queueArray");
- var sortBy = library[queueNo][0].sortBy;
- sortBy = sortBy ? sortBy : "cardTitle";
- // Aktif
- var activeArray = [];
- arrayFilter(library[queueNo][1], activeArray, "active");
- arraySorter(activeArray, "object", sortBy);
- var activeList = document.querySelector('#queueWindow_list_active');
- activeList.innerHTML = listHTML(activeArray);
- // Beklemede
- var waitingArray = [];
- arrayFilter(library[queueNo][1], waitingArray, "waiting");
- arraySorter(activeArray, "object", sortBy);
- var waitingList = document.querySelector('#queueWindow_list_waiting');
- waitingList.innerHTML = listHTML(waitingArray);
- // Tamamlanmış (Sonra)
- }
- function listHTML(array) {
- var result = '';
- for (let x = 0; x < array.length; x++) {
- var a = array[x];
- var d = new Date(a.created);
- var date = d.getDate() + "/" + (d.getMonth() + 1) + "/" + d.getFullYear();
- result += `
- <li>
- <div class="div-left">
- <a href="/title/-` + a.cardId + `"><strong>` + a.cardTitle + ` (` + a.year + `)</strong></a>
- <span>` + (a.note == "" ? "" : "<strong>Not:</strong> " + a.note) + `</span>
- </div>
- <div class="div-right">
- <span><strong>Eklenme:</strong> ` + date + `</span>
- <span><strong>Gecikme:</strong> ` + (a.delay == 0 ? "Yok" : a.delay + " gün") + `</span>
- </div>
- </li>
- `;
- }
- result = (result == '') ? "Bu listede hiçbir öğe yok." : result;
- return result;
- }
- function isertQueues() {
- var queues = GM_getValue("queueArray");
- if (queues != null && Array.isArray(queues) && queues.length >= 1) {
- // Aktifleşecek varsa aktifleştir.
- activateElements();
- // Üst menüye eklemeleri yap.
- for (x = 0; x < queues.length; x++) {
- var infos = queues[x][0];
- var activeArray = [];
- arrayFilter(queues[x][1], activeArray, "active");
- var queueOption = '<li id="queue648_' + infos.id + '_menu"><a href="#">' + infos.name + (infos.counter == 0 ? ' <span class="badge">' + activeArray.length + '</span>' : ' <span class="badge no-counter">' + activeArray.length + '</span>') + '</a></li>';
- $('#queue648').parent().append(queueOption);
- // Aktif öğe penceresi için fonksiyonu bağla.
- document.querySelector('#queue648_' + infos.id + '_menu').onclick = (function(t) {
- return function (e) {
- createQueueWindow(t);
- };
- })(x);
- }
- // Üst menü için tooltip ve bildirimi çalıştır.
- // $('script[src^="/js/jquery.min.12.4.js"]').remove();
- $('.lists-menu648').tooltip();
- $('.user-buttons > li.dropdown').each(function() {
- var counter = countCalculator(this);
- $(this).find('a[data-toggle="dropdown"] > .badge').html( (counter > 0 ? counter : "") );
- });
- // Yapım sayfasındaysa karta eklemeleri yap.
- if (pageUrl.search( /planetdp\.org\/title\// ) >= 0) {
- var readMore = document.querySelector('div[itemprop="description"] + a[data-readmore-moretext="Devamını gör"]');
- if (readMore) {
- readMore.style.position = "relative";
- readMore.style.marginRight = "15px";
- }
- for (x = 0; x < queues.length; x++) {
- var queueNo = queues.length - (x + 1);
- var infos2 = queues[queueNo][0];
- var isInQueue = queues[queueNo][1][cardId] != null;
- var buttonTitle = (isInQueue ? 'Listeden çıkar: ' : 'Listeye ekle: ') + infos2.name;
- if (isInQueue) {
- var q = queues[queueNo][1][cardId];
- var currentTime = new Date().getTime();
- buttonTitle += (q.active == 1 ? '' : enter + 'Aktifleşme: ' + millisecondConverter( (q.activateTime - currentTime) , "ms", "day") + ' gün sonra') + enter + (q.note == '' ? '' : 'Not: ' + q.note);
- }
- var queuButton = '<a href="#" id="queue648_' + infos2.id + '" title="' + buttonTitle + '" onclick="this.classList.toggle(`inQueue`)" class="' + (isInQueue ? 'inQueue': '') + '" style="margin-right: 10px; float: left;"><i class="fa fa-tasks" aria-hidden="true"></i></a>';
- document.querySelector('div.baba_main_right > div.text-right.marginver10').insertAdjacentHTML('afterbegin', queuButton);
- GM_addStyle('#queue648_' + infos2.id + ':hover, #queue648_' + infos2.id + '.inQueue {color: ' + infos2.color + '!important;}');
- // Kuyruğa yapım ekleme/çıkarma fonksiyonunu bağla.
- if (isInQueue) {
- document.querySelector('div.baba_main_right #queue648_' + infos2.id).onclick = (function(t, id) {
- return function (e) {
- removeQueueContent(t, id);
- };
- })(x, cardId);
- }
- else {
- document.querySelector('div.baba_main_right #queue648_' + infos2.id).onclick = (function(t) {
- return function (e) {
- createQueueContent(t);
- };
- })(x);
- }
- }
- }
- }
- }
- function countCalculator(dropdownLi) {
- var number = 0;
- $(dropdownLi).find('a:not([data-toggle="dropdown"]) > .badge:not(.no-counter)').each(function() {
- number += parseInt( this.textContent.trim().replace( /(\d+) - \d+/, "$1" ) );
- });
- return number;
- }
- function createQueueContent(queueNo) {
- var queues = GM_getValue("queueArray");
- var r_queueNo = queues.length - (queueNo + 1);
- var infos = queues[r_queueNo][0];
- var c_delay = infos.delay;
- var c_note = infos.note;
- var note = '';
- var delay = c_delay;
- // Lazımsa notu ve/veya gecikme süresini al.
- if (c_note == 0 || c_delay == "?") {
- insertWindow("content", "tasks", "Listeye ekle: " + infos.name, true, infos.color);
- var formContent = [];
- if (c_note == 0) {formContent.push( {name: 'Açıklama', element: 'textarea', elementProperties: 'id="queue_content_note" placeholder="Yapılacak iş ile ilgili bir not bırakabilirsiniz. Bu alan zorunlu değildir." style="resize: vertical;"'} );}
- if (c_delay == "?") {formContent.push( {name: 'Öğe Aktifleşme Gecikmesi', element: 'select', elementProperties: 'id="queue_content_delay"', inside: function() {return optionsHTML(this.options);}, options: [
- {value: '0', text: 'Yok'},
- {value: '1', text: '1 gün sonra'},
- {value: '2', text: '2 gün sonra'},
- {value: '3', text: '3 gün sonra'},
- {value: '7', text: '7 gün sonra'},
- {value: '15', text: '15 gün sonra'},
- {value: '30', text: '30 gün sonra'},
- {value: '*', text: 'Gün sayısını elle gir'}] }
- );}
- document.querySelector('#content-form > .window-content').insertAdjacentHTML("afterbegin", createformHTML(formContent) );
- if (c_delay == "?") {askToPerson( document.querySelector('select#queue_content_delay'), 7 );} // Gün sayısını elle girme fonksiyonu
- document.querySelector('button#save_content').onclick = function() {
- note = (c_note == 0 ? document.querySelector("#queue_content_note").value : '');
- delay = (c_delay == "?" ? getSelected("queue_content_delay") : c_delay);
- // Öğeyi oluştur.
- createContentLog(cardId, r_queueNo, delay, note, cardInfos, new Date().getTime());
- removeForm("content");
- };
- }
- else {
- // Öğeyi oluştur.
- createContentLog(cardId, r_queueNo, delay, note, cardInfos, new Date().getTime());
- }
- }
- function createContentLog(c_id, c_no, delay, note, c_Infos, added) {
- let que = GM_getValue("queueArray");
- var created = added;
- var activateTime = created + (delay*86400000);
- var active = (delay == 0 ? 1 : 0);
- var contentInfos = {cardId: c_id, cardTitle: c_Infos.cardTitle, active: active, note: note, created: created, activateTime: activateTime, delay: delay, year: c_Infos.year, dpRaiting: c_Infos.dpRaiting, imdbID: c_Infos.imdbID, imdbRating: c_Infos.imdbRating};
- que[c_no][1][c_id] = contentInfos;
- console.log(contentInfos);
- GM_setValue("queueArray", que);
- activateElements(); // Bekleyenleri kontrol ederek kaydet.
- }
- function removeQueueContent(queueNo, c_cardId) {
- var validation = confirm("Bu yapımı listeden çıkarmak istediğinize emin misiniz?");
- if (validation) {
- var queues = GM_getValue("queueArray");
- var r_queueNo = queues.length - (queueNo + 1);
- queues[r_queueNo][1][c_cardId] = null;
- GM_setValue("queueArray",queues);
- console.log("removed");
- }
- }
- function insertQueueForm(newOrEdit, queueNo) {
- var windowTitle, queueColor, oldInfos;
- if (newOrEdit == "new") {
- windowTitle = "Liste Oluştur";
- }
- else if (newOrEdit == "edit") {
- var library = GM_getValue("queueArray");
- oldInfos = library[queueNo][0];
- queueColor = oldInfos.color;
- windowTitle = "Listeyi Düzenle";
- }
- insertWindow("queue", "tasks", windowTitle, true, queueColor);
- var formContent = [
- {
- name: 'Liste Adı',
- element: 'input',
- elementProperties: 'id ="queue_name" type="text"'
- },
- {
- name: 'Açıklama',
- element: 'textarea',
- elementProperties: 'id="queue_description" placeholder="Listenin amacı, kullanışı vs. Bu alan zorunlu değildir." style="resize: vertical;"'
- },
- {
- name: 'Bildirim Olarak Göster',
- element: 'select',
- elementProperties: 'id="queue_counter"',
- inside: function() {return optionsHTML(this.options);},
- options: [
- {value:'0', text:'Evet'},
- {value:'1', text:'Hayır'}
- ]
- },
- {
- name: 'Öğe Notu',
- element: 'select',
- elementProperties: 'id="queue_note"',
- inside: function() {return optionsHTML(this.options);},
- options: [
- {value:'0', text:'Evet'},
- {value:'1', text:'Hayır'}] },
- {
- name: 'Öğe Aktifleşme Gecikmesi',
- element: 'select',
- elementProperties: 'id="queue_delay"',
- inside: function() {return optionsHTML(this.options);},
- options: [
- {value: '?', text: 'Ekleyişte sor'},
- {value: '0', text: 'Yok'},
- {value: '1', text: '1 gün sonra'},
- {value: '2', text: '2 gün sonra'},
- {value: '3', text: '3 gün sonra'},
- {value: '7', text: '7 gün sonra'},
- {value: '15', text: '15 gün sonra'},
- {value: '30', text: '30 gün sonra'},
- {value: '*', text: 'Gün sayısını elle gir'},
- ]
- },
- {
- name: 'Sıralama',
- element: 'select',
- elementProperties: 'id="queue_sortBy"',
- inside: function() {return optionsHTML(this.options);},
- options: [
- {value: 'created', text: 'Ekleme Tarihine Göre'},
- {value: 'activateTime', text: 'Aktifleşme Tarihine Göre'},
- {value: 'cardTitle', text: 'Alfabetik'},
- {value: 'year', text: 'Yıla Göre'},
- {value: 'imdbRating', text: 'IMDb Puanına Göre'},
- {value: 'dpRaiting', text: 'PlanetDP Puanına Göre'},
- ]
- },
- {
- name: 'Liste Rengi',
- element: 'select',
- elementProperties: 'id="queue_color" onchange="this.className = `form-control ` + this.options[this.selectedIndex].value"',
- inside: function() {return colorOptionsHTML();}
- }
- ];
- document.querySelector('#queue-form > .window-content').insertAdjacentHTML("afterbegin", createformHTML(formContent) );
- askToPerson( document.querySelector('select#queue_delay'), 8 ); // Gün sayısını elle girme fonksiyonu
- if (newOrEdit == "new") {
- document.querySelector('button#save_queue').onclick = function() { createEditQueue(); };
- fillNewEditQueueForm(defaultQueueForm);
- }
- else if (newOrEdit == "edit") {
- fillNewEditQueueForm(oldInfos);
- document.querySelector('button#save_queue').onclick = function() { createEditQueue(queueNo); createQueueWindow(queueNo); };
- document.querySelector('#queue-form button#close').onclick = function() { removeForm("queue"); createQueueWindow(queueNo); };
- }
- }
- function fillNewEditQueueForm(i_infos) {
- document.querySelector('input#queue_name').value = i_infos.name;
- document.querySelector('textarea#queue_description').value = i_infos.description;
- setSelected("queue_counter", i_infos.counter);
- setSelected("queue_note", i_infos.note);
- setSelected("queue_delay", i_infos.delay);
- setSelected("queue_sortBy", i_infos.sortBy);
- setSelected("queue_color", i_infos.color);
- }
- function setSelected(selectId, option) {
- $('select#' + selectId + ' option[value="' + option + '"]').prop('selected', true);
- }
- function askToPerson(delaySelection, askIndex) {
- delaySelection.onchange = function() {
- if(delaySelection.selectedIndex === askIndex) {
- var manualDelay;
- for (x = 0; !Number.isInteger( parseInt(manualDelay) ); x++) {
- manualDelay = prompt("Listeye eklenen öğeler kaç gün sonra aktifleşsin?");
- if (manualDelay == null) { break; }
- }
- if (manualDelay != null) {
- delaySelection.insertAdjacentHTML("beforeend", '<option value="' + manualDelay + '">' + manualDelay + ' gün sonra</option>');
- delaySelection.querySelector('option[value="' + manualDelay + '"]').selected = true;
- }
- else {
- delaySelection.firstElementChild.selected = true;
- }
- }
- };
- }
- function createformHTML(object) {
- var formContentHTML = '';
- for (x = 0; x < object.length; x++) {
- var f = object[x];
- formContentHTML += `
- <div class="row margintop10">
- <div class="col-md-4">` + f.name + `</div>
- <div class="col-md-8">
- <` + f.element + ` ` + f.elementProperties + ` class="form-control">` + (f.inside ? f.inside(): '') + `</` + f.element + `>
- </div>
- </div>`;
- }
- return formContentHTML;
- }
- function optionsHTML(object) {
- var html = '';
- for (var y = 0; y < object.length; y++ ) {
- html += '<option value="' + object[y].value + '">' + object[y].text + '</option>';
- }
- return html;
- }
- function colorOptionsHTML() {
- var queueColorsHTML = "";
- var queueColors = ["blueviolet", "brown", "cadetblue", "chocolate", "crimson", "darkgoldenrod", "dodgerblue", "forestgreen", "lightseagreen", "mediumvioletred", "olive", "orangered", "orchid", "palevioletred", "peru", "rebeccapurple", "royalblue", "teal", "tomato"];
- for (x = 0; x < queueColors.length; x++) {
- queueColorsHTML += '<option value="' + queueColors[x] + '" style="background-color: ' + queueColors[x] + '"' + (x==0 ? 'selected': '') + '>' + queueColors[x] + '</option>';
- GM_addStyle('.' + queueColors[x] + ' {background-color: ' + queueColors[x] + '}');
- }
- return queueColorsHTML;
- }
- function createEditQueue(c_queueNo) {
- var name = document.querySelector('input#queue_name').value;
- var description = document.querySelector('textarea#queue_description').value;
- var counter = getSelected("queue_counter");
- var note = getSelected("queue_note");
- var delay = getSelected("queue_delay");
- var sortBy = getSelected("queue_sortBy");
- var color = getSelected("queue_color");
- if (name == "") {
- alert("Bir liste adı girmeniz gerekiyor.");
- }
- else {
- var id = name.replace(/[\[\]\(\)\"\!\'\^\#\+\%\&\/\\\{\}\=\*\|\-\_\@\,\;\`\:\.<>\¨\~]/gi,"").replace(/\s+/g,"_").toLowerCase();
- var currentTime = new Date().getTime();
- var queueArray = GM_getValue("queueArray");
- if (queueArray == null) {
- queueArray = [];
- }
- if (c_queueNo == null) {
- var infos = {id: id, created: currentTime, name: name, description: description, counter: counter, note: note, delay: delay, sortBy: sortBy, color: color, version: version};
- var newQueue = [ infos, [], [] ]; // infos, active/waiting, completed
- queueArray.push(newQueue);
- }
- else {
- var oldInfos = queueArray[c_queueNo][0];
- var editedInfos = {id: id, created: oldInfos.created, name: name, description: description, counter: counter, note: note, delay: delay, sortBy: sortBy, color: color, version: version};
- queueArray[c_queueNo][0] = editedInfos;
- }
- // Kaydet ve pencereyi kapat.
- GM_setValue("queueArray", queueArray);
- removeForm("queue");
- }
- }
- function getSelected(selectId) {
- var selected = document.querySelector('select#' + selectId);
- if (selected != null) {
- selected = selected.options[selected.selectedIndex].value;
- return selected;
- }
- else {
- return null;
- }
- }
- function insertWindow(formName, faIcon, title, saveButton, iconColor) {
- // Formu ekle
- var formContainerHTML = `
- <div class="mfp-bg mfp-ready"></div>
- <div class="mfp-wrap mfp-close-btn-in mfp-auto-cursor mfp-ready" tabindex="-1" style="overflow: hidden auto;"><div class="mfp-container mfp-inline-holder"><div class="mfp-content">
- <form id="` + formName + `-form" class="white-popup-block" style="padding-top: 30px">
- <fieldset class="window-header">
- <h1 style="font-size: 25px;">
- <i class="fa fa-` + faIcon + `" aria-hidden="true" style="margin-right: 10px; color:` + (iconColor =! null ? iconColor : 'inherit') + `"></i>` + title + `
- </h1>
- </fieldset>
- <fieldset class="window-content margintop10">` + (saveButton ? `<div class="row margintop10 text-center"><button id="save_` + formName + `" type="button" class="btn btn-info" style="margin-top: 10px;">KAYDET</button></div>` : '') + `
- </fieldset>
- <button id="close" title="Kapat (Esc)" type="button" class="mfp-close">×</button>
- </form></div></div></div>
- `;
- document.querySelector('body').insertAdjacentHTML("afterbegin", formContainerHTML);
- // Kapat tuşuyla formu kapat
- document.querySelector('#' + formName + '-form > button#close').onclick = function() { removeForm(formName); };
- // Esc ile formu kapat
- function doc_keyUp(e) {
- if (e.key === "Escape") {
- removeForm(formName);
- }
- }
- document.addEventListener('keyup', doc_keyUp, false);
- /* Bu kod firefox'da her daim çalıştığı için sorun çıkardı.
- // Form dışı bir yere tıklama ile formu kapat
- window.onclick = function(event) {
- if (event.target.closest('#' + formName + '-form') == null) {
- removeForm(formName);
- }
- };
- */
- }
- function removeForm(formName) {
- if ( document.querySelector('#' + formName + '-form') ) {
- var formDiv = document.querySelector('#' + formName + '-form').parentElement.parentElement.parentElement;
- formDiv.previousElementSibling.remove();
- formDiv.remove();
- }
- }
- function classToogle(element, classes) {
- for (let x = 0; x < classes.length; x++) {
- element.classList.toggle( classes[x] );
- }
- }
- function arrayFilter(sourceArray, targetArray, type) {
- for (let x = 0; x < sourceArray.length; x++) {
- if (sourceArray[x] != null) {
- if (type == "active") {
- if (sourceArray[x].active == 1) targetArray.push(sourceArray[x]);
- }
- else if (type == "waiting") {
- if (sourceArray[x].active == 0) targetArray.push(sourceArray[x]);
- }
- else {
- targetArray.push(sourceArray[x]);
- }
- }
- }
- }
- function arraySorter(array, objectOrNot, objectType) {
- if (objectOrNot == "object") {
- array.sort(function(a, b) {
- var x = ( isFinite(a[objectType]) ) ? Number(a[objectType]) : a[objectType].toString().toLowerCase();
- var y = ( isFinite(b[objectType]) ) ? Number(b[objectType]) : b[objectType].toString().toLowerCase();
- if (x < y) {return -1;}
- if (x > y) {return 1;}
- return 0;
- });
- if (objectType == "imdbRating" || objectType == "dpRaiting") array.reverse();
- }
- else if (objectOrNot == "nonObject") {
- array.sort();
- }
- }
- function millisecondConverter( unit, from, to ) {
- var result;
- switch (from) {
- case "ms" :
- switch (to) {
- case "year": result = Math.round(unit / 31556952000); break;
- case "month" : result = Math.round(unit / 2592000000); break;
- case "week" : result = Math.round(unit / 604800000); break;
- case "day" : result = Math.round(unit / 86400000); break;
- case "hour" : result = Math.round(unit / 3600000); break;
- case "minute" : result = Math.round(unit / 60000); break;
- case "second" : result = Math.round(unit / 1000); break;
- }
- break;
- case "year":
- switch (to) {case "ms": result = unit * 31556952000; break;} break;
- case "month":
- switch (to) {case "ms": result = unit * 2592000000; break;} break;
- case "week":
- switch (to) {case "ms": result = unit * 604800000; break;} break;
- case "day":
- switch (to) {case "ms": result = unit * 86400000; break;} break;
- case "hour":
- switch (to) {case "ms": result = unit * 3600000; break;} break;
- case "minute":
- switch (to) {case "ms": result = unit * 60000; break;} break;
- case "second":
- switch (to) {case "ms": result = unit * 1000; break;} break;
- }
- return result;
- }
- function addForumExport() {
- var appsArea = document.querySelector('.cke_toolbar.cke_toolbar_last > .cke_toolbar_end').previousElementSibling;
- var appButton = `
- <a id="cke_queue" class="cke_button cke_button_off" href="javascript:void('Queue')" title="Liste Çıktısı Al" role="button">
- <span class="cke_button_icon" style="background-image: url('https://images2.imgbox.com/6a/18/KWBxXjc7_o.png'); background-position: 0 0px; background-size: 16px;"></span>
- </a>
- `;
- appsArea.insertAdjacentHTML("beforeend", appButton);
- appsArea.querySelector('#cke_queue').onclick = function() {
- var library = GM_getValue("queueArray");
- var promtText = 'Aşağıdaki listelerden çıktısını almak istediğinizin numarısını girin:' + enter;
- for (let x = 0; x < library.length; x++) {
- promtText += enter + x + " - " + library[x][0].name;
- }
- var queueNo = prompt(promtText);
- if (queueNo) {
- var infos = library[queueNo][0];
- var array = [];
- arrayFilter(library[queueNo][1], array);
- arraySorter(array, "object", infos.sortBy);
- var queueHTMLli = '';
- for (let x = 0; x < array.length; x++) {
- var a =array[x];
- queueHTMLli += `<li><strong><a href="https://www.planetdp.org/title/-dp` + a.cardId + `" rel="external nofollow">PlanetDP</a> | <a href="https://www.imdb.com/title/tt` + a.imdbID + `" rel="external nofollow">IMDb</a></strong> >> <strong>` + a.cardTitle + ` (` + a.year + `)</strong></li>`;
- }
- var queueHTML = '<p>Liste: <strong>' + infos.name + ' (' + array.length + ')</strong></p><ul>' + queueHTMLli + '</ul>';
- appsArea.closest('.cke_inner.cke_reset').querySelector('div.cke_enable_context_menu.cke_editable[role="textbox"]').insertAdjacentHTML("beforeend", queueHTML);
- }
- };
- }
- function waitForKeyElements (
- selectorTxt, /* Required: The jQuery selector string that
- specifies the desired element(s).
- */
- actionFunction, /* Required: The code to run when elements are
- found. It is passed a jNode to the matched
- element.
- */
- bWaitOnce, /* Optional: If false, will continue to scan for
- new elements even after the first match is
- found.
- */
- iframeSelector /* Optional: If set, identifies the iframe to
- search.
- */
- ) {
- var targetNodes, btargetsFound;
- if (typeof iframeSelector == "undefined")
- targetNodes = $(selectorTxt);
- else
- targetNodes = $(iframeSelector).contents ()
- .find (selectorTxt);
- if (targetNodes && targetNodes.length > 0) {
- btargetsFound = true;
- /*--- Found target node(s). Go through each and act if they
- are new.
- */
- targetNodes.each ( function () {
- var jThis = $(this);
- var alreadyFound = jThis.data ('alreadyFound') || false;
- if (!alreadyFound) {
- //--- Call the payload function.
- var cancelFound = actionFunction (jThis);
- if (cancelFound)
- btargetsFound = false;
- else
- jThis.data ('alreadyFound', true);
- }
- } );
- }
- else {
- btargetsFound = false;
- }
- //--- Get the timer-control variable for this selector.
- var controlObj = waitForKeyElements.controlObj || {};
- var controlKey = selectorTxt.replace (/[^\w]/g, "_");
- var timeControl = controlObj [controlKey];
- //--- Now set or clear the timer as appropriate.
- if (btargetsFound && bWaitOnce && timeControl) {
- //--- The only condition where we need to clear the timer.
- clearInterval (timeControl);
- delete controlObj [controlKey];
- }
- else {
- //--- Set a timer, if needed.
- if ( ! timeControl) {
- timeControl = setInterval ( function () {
- waitForKeyElements ( selectorTxt,
- actionFunction,
- bWaitOnce,
- iframeSelector
- );
- },
- 300
- );
- controlObj [controlKey] = timeControl;
- }
- }
- waitForKeyElements.controlObj = controlObj;
- }
- })();