Edenya-Script

Addon Edenya

目前為 2019-01-21 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         Edenya-Script
// @namespace    http://tampermonkey.net/
// @version      0.100020
// @description  Addon Edenya
// @author       Valkazaar
// @match        http://www.edenya.net/_vahal/*
// @grant        none
// @include      http://www.edenya.net/_vahal/*
// @include      https://www.edenya.net/_vahal/*
// @require      https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js
// ==/UserScript==

function checkMessages(){
    $.ajax({
        type: 'GET',
        url: 'https://www.edenya.net/index2.php?loca=communiquer/forum/messages',
        //data: datas,
        success: function(data) {
            var i = (data.split("#AA2020")).length - 1;
            var texte = "envelope-open";
            if(i>0){
                $('#ValkHidden').prepend('<span title="'+i+' Message(s) Non Lus"><a href="https://www.edenya.net/index2.php?loca=communiquer/forum/messages"><i class ="fa fa-envelope" /><small>('+i+') </small></a></span>');
            }else{
                $('#ValkHidden').prepend('<span title="Aucun message non lu"> <a href="https://www.edenya.net/index2.php?loca=communiquer/forum/messages"><i class ="fa fa-envelope-open" /></a></span>');
            }
        }});
    }

(function () {
    $('head').append('<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" type="text/css">');
    'use strict';

    // Vérification de la présence de la variable localStorage EdenyaColor
    // et instanciation de base si nécessaire
    var localColor = localStorage.getItem('EdenyaColor');
    if (localColor === null) {
        localColor = {};
        localColor.cadre2 = '#dda0dd';
        localColor.ligneA = '#000000';
        localColor.dialogue = '#ffffff';
        localColor.narration = '#ffd700';
        localColor.cri = '#9acd32';
        localColor.hj = '#FFDAB9';
        localColor.BlackDate = '#B09070';
        localStorage.setItem('EdenyaColor', JSON.stringify(localColor));
        localColor = localStorage.getItem('EdenyaColor');
    }

    var localColorParsed = JSON.parse(localColor);
    if (localColorParsed.BlackDate === undefined) {
        localColorParsed.BlackDate = '#B09070';
        localStorage.setItem('EdenyaColor', JSON.stringify(localColorParsed));
    }

    // Remplacement des dates écrites en noir dans les forums.
    $("font[color*='#000000']").attr( "color", localColorParsed.BlackDate );
    $("font[color='#990000']").attr( "color", '#FF0000' );
    $("font[color*='#990000']").attr( "color", '#00DD00' );

    // Colorisation des éléments
    var baliseHeader = document.querySelector('head');
    var styleToAdd = document.createElement('style');
    for (var item in localColorParsed) {
        styleToAdd.innerText += '.' +item + '{color:'+ localColorParsed[item]+'}';
    }
    styleToAdd.innerText += 'td.cadre2 a:visited {color:'+ localColorParsed.cadre2+'}';
    styleToAdd.innerText += 'td.cadre2 a:link {color:'+ localColorParsed.cadre2+'}';
    styleToAdd.innerText += 'menu {margin-block-start:0;margin-block-end:0;}';
    styleToAdd.innerText += 'menu#menuValk {padding:0px;list-style-type: none;-webkit-padding-start: 0px;};';
    baliseHeader.appendChild(styleToAdd);

    var locationPath = window.location.pathname.split("/");

    // Dans Vahal, sur page 'normale'
    if (locationPath[locationPath.length - 2] == "_vahal" && locationPath[locationPath.length - 1] == "index.php"){
        jQuery.fn.Valk_Refresh = function() {
            var first = true;
            var z = JSON.parse(localStorage.getItem('EdenyaShortcut'));
            $('#menuValk').html('');
            for (var item in z) {
                var shortcutToAdd = "<li><small>";
                shortcutToAdd += "<i class='fa fa-chevron-up' onclick='$(document).Valk_Up(\"" + item + "\");' />";
                shortcutToAdd += "<i class='fa fa-chevron-down'  onclick='$(document).Valk_Down(\"" + item + "\");' />";
                shortcutToAdd += "<i class='fa fa-edit' onclick='$(document).Valk_Rename(\"" + item + "\");' />";
                shortcutToAdd += "<i class='fa fa-times-circle'  onclick='$(document).Valk_Del(\"" + item + "\");' />";
                shortcutToAdd += '</small> <a href="'+ z[item] +'">'+item+'</a>';
                shortcutToAdd += "</li>";
                $('#menuValk').append(shortcutToAdd);
            }
            $('#menuValk li:first-child small i:nth-child(1)').removeAttr("onclick")
            $('#menuValk li:last-child small i:nth-child(2)').removeAttr("onclick")
            return this; // This is needed so others can keep chaining off of this
        };
        jQuery.fn.Valk_Rename = function(itemIn){
            var nom=prompt('A renommer en ?');
            if (nom!==null){
                var y = {};
                var z = JSON.parse(localStorage.getItem('EdenyaShortcut'));
                for (var item in z) {
                    if(item == itemIn){
                        y[nom]=z[item];
                    }else{
                        y[item]=z[item];
                    }
                };
                localStorage.setItem('EdenyaShortcut',JSON.stringify(y));
                $(document).Valk_Refresh();
            }
            return this; // This is needed so others can keep chaining off of this
        }
        jQuery.fn.Valk_Down = function(itemIn) {
            var next = null;
            var y = {};
            var z = JSON.parse(localStorage.getItem('EdenyaShortcut'));
            for (var item in z) {
                if (item != itemIn) {
                    y[item] = z[item];
                    if (next != null) {
                        for (var bidule in next) {
                            y[bidule] = next[bidule];
                        }
                        next = null;
                    }
                }else {
                    next = {};
                    next[item] = z[item];
                }
            }
            localStorage.setItem('EdenyaShortcut', JSON.stringify(y));
            $(document).Valk_Refresh();
            return this; // This is needed so others can keep chaining off of this
        }
        jQuery.fn.Valk_Up = function(itemIn){
            var previous = null;var y={};
            var z = JSON.parse(localStorage.getItem('EdenyaShortcut'));
            for (let item in z) {
                if (previous != null){
                    if (item == itemIn){
                        y[item]=z[item];
                    }
                    for (bidule in previous){
                        if (bidule != itemIn){
                            y[bidule]=previous[bidule];
                        }
                    }
                };
                previous={};
                previous[item]=z[item]
                ;
            }
            for (var bidule in previous) {
                if (bidule != itemIn){
                    y[bidule]=previous[bidule];
                }
            }
            localStorage.setItem('EdenyaShortcut',JSON.stringify(y));$(document).Valk_Refresh();
            return this; // This is needed so others can keep chaining off of this
        }
        jQuery.fn.Valk_Add = function(){
            var nom=prompt('Nom du shortcut ?');
            if (nom!==null){
                var z = JSON.parse(localStorage.getItem('EdenyaShortcut'));
                z[nom]=document.URL;
                localStorage.setItem('EdenyaShortcut',JSON.stringify(z));
                $(document).Valk_Refresh();
                //Valk_Refresh();
            }
            return this; // This is needed so others can keep chaining off of this
        }
        jQuery.fn.Valk_Del = function(item){
            var z = JSON.parse(localStorage.getItem('EdenyaShortcut'));
            delete z[item];
            localStorage.setItem('EdenyaShortcut',JSON.stringify(z));
            $(document).Valk_Refresh();
            return this; // This is needed so others can keep chaining off of this
        }
        jQuery.fn.Valk_ChgCol = function(id){
            var z = JSON.parse(localStorage.getItem('EdenyaColor'));
            z[id] = $("#"+id).val();
            localStorage.setItem('EdenyaColor',JSON.stringify(z));
            location.href = location.href;
            return this; // This is needed so others can keep chaining off of this
        }

        // Positionnement sur la colone de gauche pour y ajouter les éléments (raccourcis et gestion des couleurs)
        if($(".menu").length > 0){
            $(".menu").append('<img src="images/interface/jour/pluie/chains.gif" />');
            $(".menu").append('<div id="cadreValk" class="cadre" style="width:194px;" />');
            $("#cadreValk").append('<div id="ValkHidden" />');
            checkMessages();
            $('#ValkHidden').append('<span style="padding-right:10px" title="Evénements récents"><a href="#"><i class="fa fa-calendar" onclick="javascript:window.open(\'vide.php?loca=evenements\',\'events\',\'scrollbars=1,width=500,height=450\')" /></a></span>');
            $("#ValkHidden").append("<span title='Ajouter un raccourci'><a href='#' onclick='$(document).Valk_Add()'> <i class='fa fa-plus-circle'/> Raccourci</a></span>");
            $("#cadreValk").append('<hr /><menu id="menuValk" />');
            $("#cadreValk").append('<hr /><div>Couleurs utilisées :</div>');

            var localShortcut = localStorage.getItem('EdenyaShortcut');
            if (localShortcut === null) {
                var shortcut = { 'accueil': 'https://www.edenya.net/_vahal/' };
                localStorage.setItem('EdenyaShortcut', JSON.stringify(shortcut));
                localShortcut = localStorage.getItem('EdenyaShortcut');
            }
            var localShortcutParsed = JSON.parse(localShortcut);
            $(document).Valk_Refresh();

            var localTips = localStorage.getItem('EdenyaTips');
            if (localTips === null) {
                localTips = {};
                localTips.cadre2 = "Couleur générale titre, panneau PJ,...";
                localTips.ligneA = "Couleur texte hors balises RP";
                localTips.dialogue = "Texte d'un dialogue";
                localTips.narration = "Texte de narration";
                localTips.cri = "Texte crié";
                localTips.hj = "descriptions HJ";
                localTips.BlackDate = "couleur des dates dans les forums";
                localStorage.setItem('EdenyaTips', JSON.stringify(localTips));
                localTips = localStorage.getItem('EdenyaTips');
            }
            var localTipsParsed = JSON.parse(localTips);

            for (item in localColorParsed) {
                var itemToAdd = '<input id="' + item + '" type="color" class="bouton" value="'+ localColorParsed[item] +'" style="width:25;padding:0"';
                itemToAdd += " onChange='$(document).Valk_ChgCol(\"" + item + "\")'";
                itemToAdd += ' onMouseOver=\'ShowHelpTab("<b>Usage :</b><br>'+(localTipsParsed[item]).replace("'", " ")+'")\'';
                itemToAdd += ' onMouseOut="HideHelp()"';
                itemToAdd += ' title="'+ localTipsParsed[item] +'"';
                itemToAdd += '</input>';
                $("#cadreValk").append(itemToAdd);
            }
            var localPreview = localStorage.getItem('EdenyaPreview');
            if(localPreview === null) {
                localPreview = true;
                localStorage.setItem('EdenyaPreview', localPreview);
            }
            var localPreviewParsed = JSON.parse(localPreview);
            $("#cadreValk").append('<span>Prévisualisation de post : <input type="checkbox" onclick="localStorage.setItem(\'EdenyaPreview\', !JSON.parse(localStorage.getItem(\'EdenyaPreview\')));" '+ (localPreviewParsed?'checked':'') +' ></input></span>');
        }
    }
    if (locationPath[locationPath.length - 2] == "_vahal" && locationPath[locationPath.length - 1] == "vide.php" && ((document.getElementsByClassName("titre"))[0]).innerText == "Nouveau message" && JSON.parse(localStorage.getItem('EdenyaPreview'))){
        jQuery.fn.Valk_insertBalise = function(balise){
            var field = $('#message')[0];
            $('#message').focus();
            var debut = field.selectionStart;
            var fin = field.selectionEnd;
            var startSelection   = $('#message').val().substring(0, debut);
            var currentSelection = $('#message').val().substring(debut, fin);
            var endSelection     = $('#message').val().substring(fin);

            $('#message').val(startSelection + "["+balise+"]" + currentSelection + "[/"+balise+"]" + endSelection);
            $('#message').focus(); // On remet le focus sur la zone de texte
            field.setSelectionRange(startSelection.length + balise.length + 2, startSelection.length + balise.length + 2 + currentSelection.length);
            return this; // This is needed so others can keep chaining off of this
        };
        jQuery.fn.Valk_Previsualise = function(){
            var initial_texte = $("[name='message']").val();
            var regexpOpen = /\[(narration|dialogue|cri|hj|ecriture)\]/g;
            var regexpClose = /\[\/(narration|dialogue|cri|hj|ecriture)\]/g;
            var previsu_texte = initial_texte.replace(regexpOpen, "<span class=\"$1\">");
            previsu_texte = previsu_texte.replace(regexpClose, "</span><!--$1-->");
            var regexpImg = /\[img\]([^\[]*)\[\/img\]/g;
            previsu_texte = previsu_texte.replace(regexpImg, "<img src=\"$1\" border=\"0\"\/>");
            previsu_texte = previsu_texte.replace(/\n/g, "<"+"br/>");
            $("#previewText").html(previsu_texte);
            return this; // This is needed so others can keep chaining off of this
        };

        $(".saisie tbody tr td img").attr("onclick", function (){var z=$(this).attr("onclick"); z=z.replace("clickfuncmult(this,'","$(document).Valk_insertBalise('");return z})
        $("[name='Submit']").after("<button class='bouton' type='button' onclick='$(document).Valk_Previsualise()'>Prévisualiser</button>")
        $("table.saisie").after("<hr /><div id='previewText' style='text-align:left;'></div><hr />");
    }
    window.oncontextmenu = null;
})();