Edenya-Script

Addon Edenya

Você precisará instalar uma extensão como Tampermonkey, Greasemonkey ou Violentmonkey para instalar este script.

Você precisará instalar uma extensão como Tampermonkey ou Violentmonkey para instalar este script.

Você precisará instalar uma extensão como Tampermonkey ou Violentmonkey para instalar este script.

Você precisará instalar uma extensão como Tampermonkey ou Userscripts para instalar este script.

Você precisará instalar uma extensão como o Tampermonkey para instalar este script.

Você precisará instalar um gerenciador de scripts de usuário para instalar este script.

(Eu já tenho um gerenciador de scripts de usuário, me deixe instalá-lo!)

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar uma extensão como o Stylus para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

Você precisará instalar um gerenciador de estilos de usuário para instalar este estilo.

(Eu já possuo um gerenciador de estilos de usuário, me deixar fazer a instalação!)

// ==UserScript==
// @name         Edenya-Script
// @namespace    http://tampermonkey.net/
// @version      0.100021
// @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');
    $('a:has(i:has(span))').attr( "class", "narration" );
    for (var item in localColorParsed) {
        styleToAdd.innerText += '.' +item + '{color:'+ localColorParsed[item]+'!important}';
    }
    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;
})();