Skip to content

Instantly share code, notes, and snippets.

Created October 25, 2013 10:58
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save anonymous/7152904 to your computer and use it in GitHub Desktop.
Save anonymous/7152904 to your computer and use it in GitHub Desktop.
// ==UserScript==
// @name DDPlus
// @namespace http://ddunlimited.net
// @description Nice addon
// @include http://ddunlimited.net/*
// @include http://ddunlimited.net/*
// ==/UserScript==
// Changelog:
// v. 0.0.7.13 : - Aggiornato elenco host
// - colori borda immagine
// - sistemati tasti Apri Nuova Discussione
// v. 0.0.7.12 : - sistemati tasti Apri Nuova Discussione
// - aggiornamento elenco Host
// v. 0.0.7.11 : - compatibilità con firefox 10.*
// - aggiunta code text e vimeo
// v. 0.0.7.10 : - compatibilità con firefox 9.*
// v. 0.0.7.9 : - compatibilità con firefox 8.*
// v. 0.0.7.8 : - compatibilità con firefox 5.*
// - aggiunto Carica immagine su... > Imgur
// v. 0.0.7.7 : - aggiornamento elenco Host
// - inserimento bbcode Musicforum, Musictopic e OST
// - inserimento tasto nuove discussioni skin DDGirlz
// - menu tasto dx : Carica immagine su ImageShack e ImageUrlHost
// - inserimento copia bbcode forum, topic, post, MP, profile [Music]
// - eliminazione link modifica avatar e firma nel profilo
// v. 0.0.7.6 : - aggiornamento elenco Host
// v. 0.0.7.5 : - aggiornamento elenco Host Free
// - inserimento bbcode [Roll, Alink, Anchor]
// - inserimento copia bbcode PM
// - inserimento carattere 250 e 300
// v. 0.0.7.4 : - allineamento elenco Host Free
// v. 0.0.7.3 : - release ufficiale
// v. 0.0.7.2 : - beta - riorganizzazione toolbar BBCode [sperimentale]
//
// v. 0.0.7.1 : - bugfix emoticons
// v. 0.0.7.0 : - creazione di set di emoticon personalizzati
//
// v. 0.0.6.6 : - profilo utente : aggiunti link per modifica di Firma ed Avatar
// - bugfix : corretto il rilevamento di alcuni servizi di hosting
//
// v. 0.0.6.5 : - bugfix : corretta incompatibilita' con Google Toolbar
//
// v. 0.0.6.4 : - bugfix : corretto il "Copia BBCode" per i topic con icon-post
// - Preferenze: numero pulsanti liberamente impostabile
// v. 0.0.6.3 : - Preferenze: aggiunto "Importa / Esporta" opzioni e pulsanti
// - Preferenze: visualizza pulsanti personalizzati in "Dividi argomento"
// v. 0.0.6.2 : - menu tasto dx : copia un link nella Clipboard come tag BBCode
// - menu tasto dx : carica immagine su ImageShack
// - bugfix : visualizzazione pulsanti extra durante la divisione topic
//
// v. 0.0.6.1 : - Preferenze: Numero pulsanti personalizzabile
// - Allineamento elenco Hostfree
// v. 0.0.6.0 : - Sposta argomento : selezione del forum tramite pulsanti
//
// v. 0.0.5.6 : - dimensione avatr portata a 150x150
//
// v. 0.0.5.5 : - corretto controllo Avatars
//
// v. 0.0.5.4 : - controllo siti host-free piu' generico
// - Pulsante ApriNuoveDiscussioni : diversificato per skin
// v. 0.0.5.3 : - prima versione by kickstart
// - allineamento elenco siti host-free
//
// v. 0.0.5.2 : - ultima versione by iluvatar
//
//
Function.prototype.bind = function(object, data) {
if (typeof data == "undefined")
data = null;
if (typeof data != "object")
data = [data];
var __method = this;
return function(evt) {
return __method.apply(object, [evt].concat(data));
};
}
var ddplus = {
// kick : costanti per il controllo degli Avatar
AvMaxHeight : 150,
AvMaxWidth : 150,
isDDBlack: function() {
// kick : determina la skin selezionata
// controllando il link della prima immagine contenuta nel "body" (sperando che sia il banner !!)
return (document.images[0].src.indexOf('//images.ddalternate.net/skin/black/')>0);
},
isDDGirlz: function() {
// kick : determina la skin selezionata
// controllando il link della prima immagine contenuta nel "body" (sperando che sia il banner !!)
return (document.images[0].src.indexOf('//images.ddalternate.net/skin/ddugirlz/')>0);
},
pulsanteApriDiscussioni : function() {
// kick : trasformata in funzione
// ritorna l'immagine del pulsante in base alla skin selezionata
if (this.isDDBlack()) {
// DDBlack
return "";
}
if(this.isDDGirlz()) {
// DDGirlz
return "";
}
// ProSilver
return "";
},
allowedImageHost: [ '//ddunlimited.net/',
'//www.ddunlimited.net/',
'//ddunlimited.net/',
'//ddunlimited.net/images/',
'//static.ddunlimited.net/',
'//imageshack.us/',
'.imageshack.us/',
'.imageurlhost.com/',
'.imgur.com/',
'.imgplace.com/',
'.freeimagehosting.net/',
'.imagevenue.com/',
'.hostpic.biz/',
'.tinypic.com/',
'.imagestime.com/',
'.postimage.org/',
'.yeuxverts.net/',
'.imagehost.org/',
'.imagebanana.com/',
'.iouppo.com/',
'.4freeimagehost.com/',
'.xtremeshack.com/',
'.hdimage.org/',
'.imagebam.com/',
'.turboimagehost.com/',
'.abload.de/',
'.hostingfiles.net/',
'.fileden.com/',
'.photobucket.com/',
'.webshots.com/',
'.image-upload.net/',
// non in lista ufficiale:
'.exs.cx/',
],
getElementsByClass : function(searchClass,node,tag) {
var classElements = new Array();
if ( node == null )
node = document;
if ( tag == null )
tag = '*';
var els = node.getElementsByTagName(tag);
var elsLen = els.length;
var pattern = new RegExp("(^|\\s)"+searchClass+"(\\s|$)");
for (i = 0, j = 0; i < elsLen; i++) {
if ( pattern.test(els[i].className) ) {
classElements[j] = els[i];
j++;
}
}
return classElements;
},
inint: function() {
this.accorciaTitolo();
switch (this.getAction()) {
case 'mcp':
var bCestino = false;
var bPulsanti = false;
if (document.getElementById('move_leave_shadow')) { // "Sposta discussione"
bCestino = true;
bPulsanti = true;
}
else { // "Dividi discussione"
if (document.getElementsByName('to_forum_id') && (!document.getElementById('confirm'))) {
bCestino = true;
if (this.getValue('movForce',false )) // opzione utente
bPulsanti = true;
}
};
if (bCestino)
this.pulsanteCestinoSposta();
if (bPulsanti)
this.aggiungiPulsantiExtra(this.getValue('movNum','10'),'mov');
this.tuttePagineDivisione();
this.visualeEspansa();
break;
case 'viewforum':
this.pulsanteApriTutteNuoveDiscussioni();
break;
case 'posting':
/*
// segnalazione utente agli Hunters
if (this.getMode() == 'reply') {
user_profile = this.getValue("hunt_for_user","");
if (user_profile!="") {
unsafeWindow.insert_text(user_profile+" : ");
this.delValue("hunt_for_user");
}
}
*/
case 'ucp':
this.customToolbar();
this.aggiungiPulsantiExtra(this.getValue('txtNum','15'),'txt');
if (this.getMode() != "drafts")
this.customEmoticons();
window.addEventListener('resize',this.ingrandisciTextArea,false);
this.ingrandisciTextArea(); //PER ULTIMO!
break;
case 'viewtopic':
this.sfogliaImmaginiDiscussioni();
break;
case 'memberlist':
if (this.getMode() == 'viewprofile') {
this.sfogliaImmaginiProfilo();
break;
};
}
},
checkInint: function(x) {
return (typeof x != "undefined");
},
xPath: function(xpathExpression) {
return document.evaluate(xpathExpression, document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
},
getValue: function(key,defaultValue) {
return GM_getValue(key, defaultValue);
},
setValue: function(key,value) {
return GM_setValue(key, value);
},
delValue : function (key) {
return GM_remove(key);
},
getPageBody: function() {
if (!checkInint(this.pageBody))
this.pageBody = document.getElementByID('page-body');
return this.pageBody;
},
getTopicList: function(i) {
if (!checkInint(this.topicList)) {
var topicl = this.getPageBody().getElementsByTagName('li');
this.topicList = [];
for (var j=0;topicl(j);j++) {
if(topicl(j).className = "row")
topicList.push(topicl(j));
}
}
if (checkInint(i)) {
return this.TopicList[i];
}
else
return this.TopicList;
},
getAction: function() {
if (!this.checkInint(this.forumAction)) {
this.forumAction = document.baseURI.substring(document.baseURI.lastIndexOf('/')+1,document.baseURI.indexOf('.php'));
}
return this.forumAction;
},
getMode: function() {
if (!this.checkInint(this.forumMode)) {
var inizio = document.baseURI.indexOf('mode=')+5;
if (inizio == 4) //Non trovato -1+5 = 4
return '';
var fine = document.baseURI.indexOf('&', inizio);
fine = (fine == -1) ? document.baseURI.length : fine;
this.forumMode = document.baseURI.substring(inizio,fine);
}
return this.forumMode;
},
nuovoPulsante: function(titolo,name,value) {
var pulsante = document.createElement('input');
pulsante.type = 'button';
pulsante.className = 'button2';
pulsante.name = name;
pulsante.title = titolo;
pulsante.value = value;
return pulsante;
},
accorciaTitolo: function() {
var inde = document.title.indexOf(' - ');
if (inde > 1)
document.title = document.title.substr(inde+3);
},
pulsanteApriTutteNuoveDiscussioni: function() {
var pulsanti = this.xPath("//div[@class='buttons']");
var img;
var link;
for (var i=0;pulsanti.snapshotItem(i);i++) {
img = document.createElement('img');
img.style.cursor = 'pointer';
img.src = this.pulsanteApriDiscussioni(); // kick : trasformata in funzione per renderla skin-aware
pulsanti.snapshotItem(i).appendChild(img);
img.addEventListener('click', this.apriTutteNuoveDiscussioni.bind(this), false);
}
},
apriTutteNuoveDiscussioni: function() {
var threads = this.xPath("//a[@href[contains(.,'view=unread#unread')]]");
for (var i=0;threads.snapshotItem(i);i++) {
window.open(threads.snapshotItem(i).href);
}
},
controllaDimensioneImmagine: function(immagine) {
if (immagine.naturalHeight > this.AvMaxHeight || immagine.naturalWidth > this.AvMaxWidth)
return true;
return false;
},
controllaHostImmagine: function(immagine) {
var i = 0;
while (this.allowedImageHost[i]) {
if (immagine.src.indexOf(this.allowedImageHost[i]) > 0)
return false;
i++;
}
return true;
},
bordaImmagine: function(nodo, erroreA, erroreB) {
nodo.style.borderColor = (erroreA) ? 'green' : 'red';
nodo.style.borderStyle = (erroreA) ? 'dashed' : 'dotted';
nodo.style.borderWidth = '2px';
},
controllaImmagini: function(immagine, dimensione) {
if ( !(immagine) || !(immagine.src) )
return;
var errore=0;
var erroDim = false;
if (dimensione)
erroDim = this.controllaDimensioneImmagine(immagine);
var erroHost = this.controllaHostImmagine(immagine);
if (erroHost || erroDim) {
immagine.src;
this.bordaImmagine(immagine, erroDim, erroHost);
}
},
sfogliaImmaginiDiscussioni: function() {
// var avatars = this.xPath("//dl[@class='postprofile']//dt//img");
// kick : modificato estrazione immagini Avatars
var avatars = this.xPath("//dl[@class='postprofile']//dd/a//img");
for (var i=0;avatars.snapshotItem(i);i++) {
this.controllaImmagini(avatars.snapshotItem(i),true);
}
var imagePost = this.xPath("//div[@class='postbody']//div[@class='content']//img");
for (var i=0;imagePost.snapshotItem(i);i++) {
this.controllaImmagini(imagePost.snapshotItem(i));
}
var imageSign = this.xPath("//div[@class='postbody']//div[@class='signature']//img");
for (var i=0;imageSign.snapshotItem(i);i++) {
this.controllaImmagini(imageSign.snapshotItem(i));
}
},
sfogliaImmaginiProfilo: function() {
var avatars = this.xPath("//div[@id='page-body']//div[@class='inner']//dl//img");
// kick : modificato estrazione immagini Avatars - panel bg1
// var avatars = this.xPath("//div[@id='page-body']//div[@class='inner']//dt//img");
if (avatars.snapshotItem(0)) {
this.controllaImmagini(avatars.snapshotItem(0),true);
}
var imageSign = this.xPath("//div[@class='signature']//img");
for (var i=0;imageSign.snapshotItem(i);i++) {
this.controllaImmagini(imageSign.snapshotItem(i));
}
},
ingrandisciTextArea: function() {
var textArea = document.getElementById('message');
if (!textArea || textArea.tagName != "TEXTAREA")
return;
textArea.rows = 1;
var max = textArea.parentNode.parentNode.clientHeight;
while (max == textArea.parentNode.parentNode.clientHeight)
textArea.rows++;
textArea.rows--;
textArea.rows = Math.max(textArea.rows,15);
},
inserisciTestoVeloce: function(n) {
unsafeWindow.insert_text(this.getValue('txtv'+n,''),false);
},
salvaTestoVeloce: function(n,tipo) {
if (tipo=='txt') {
if (!confirm('Sei sicuro di voler salvare il testo veloce '+n+'?'))
return(false);
this.setValue(tipo+'v'+n,document.getElementById('message').value);
}
else
this.setValue(tipo+'v'+n,document.getElementsByName('to_forum_id')[0].value);
return(true);
},
salvaTestoEtichetta: function(n,tipo) {
var etichetta = this.getValue(tipo+'l'+n);
if (!etichetta)
etichetta = " - ";
etichetta = prompt("Digita l' etichetta per il pulsante "+n, etichetta);
if (!etichetta)
etichetta = " - ";
this.setValue(tipo+'l'+n,etichetta);
document.getElementsByName(tipo+'v'+n)[0].value=etichetta;
return true;
},
aggiungiPulsantiExtra: function(num,tipo) {
/* kick:
tipologia di pulsanti : 'txt' - pulsante Testo veloce
'mov' - pulsante Sposta
*/
if (tipo=='txt') { // pulsanti Testo Veloce
if (!document.getElementById('format-buttons'))
return;
var div = document.createElement('div');
div.id = 'format-buttons-extra';
div.style.marginTop = '5px';
document.getElementById('format-buttons').parentNode.insertBefore(div, document.getElementById('format-buttons').nextSibling);
var caption = 'Text ';
var hint = 'Premere CTRL per salvare, CTRL+Shift per cambiare etichetta.';
}
else { // pulsanti Sposta
var selectForum = document.getElementsByName('to_forum_id');
if (selectForum.length == 0)
return;
var div = document.createElement('div');
div.id = 'move-buttons-extra';
div.style.marginTop = '5px';
document.getElementsByName('to_forum_id')[0].parentNode.appendChild(div)
var caption = '';
var hint = 'Premere CTRL per salvare la selezione corrente.';
}
var pulsante; // creazione nuovi pulsanti
for (var i=0;i<num;i++) {
pulsante = this.nuovoPulsante(caption+(i+1)+'. '+hint,tipo+'v'+(i+1),this.getValue(tipo+'l'+(i+1)," - "));
div.appendChild(pulsante);
div.appendChild(document.createTextNode(' '));
}
if (tipo=='txt')
div.addEventListener('click', this.eventoPulsanteTestoVeloce.bind(this), false);
else
div.addEventListener('click', this.eventoPulsanteSposta.bind(this,'to_forum_id'), false);
},
eventoPulsanteSposta: function(evt, name) {
var n = evt.target.name.substr(4);
if (evt.ctrlKey) {
if (this.salvaTestoEtichetta(n,'mov'))
this.salvaTestoVeloce(n,'mov');
}
else {
var to_forum_id = this.getValue('movv'+n,'');
if (to_forum_id) {
document.getElementsByName('to_forum_id')[0].value = to_forum_id;
var i = document.getElementsByName('to_forum_id')[0][document.getElementsByName('to_forum_id')[0].selectedIndex].value;
if (i != to_forum_id )
alert('Errore nella selezione del forum !!');
}
}
},
eventoPulsanteTestoVeloce: function(evt) {
var n = evt.target.name.substr(4);
if (evt.ctrlKey) {
if (evt.shiftKey)
this.salvaTestoEtichetta(n,'txt');
else {
if (this.salvaTestoVeloce(n,'txt'))
this.salvaTestoEtichetta(n,'txt');
}
}
else
this.inserisciTestoVeloce(n);
},
pulsanteCestinoSposta: function() {
var selectForum = document.getElementsByName('to_forum_id');
if (selectForum.length == 0)
return;
selectForum = selectForum[0];
var pulsante = this.nuovoPulsante('Seleziona il cestino','cestino','Cestino');
selectForum.parentNode.appendChild(document.createTextNode(' '));
selectForum.parentNode.appendChild(pulsante);
pulsante.addEventListener('click', this.eventoPulsanteCestino.bind(this,'to_forum_id'), false);
},
eventoPulsanteCestino: function(evt, name) {
document.getElementsByName('to_forum_id')[0].value = 124;
if (document.getElementsByName('move_leave_shadow').length == 1)
document.getElementsByName('move_leave_shadow')[0].checked = false;
},
tuttePagineDivisione: function() {
var postPerPage = document.getElementById('posts_per_page');
if (!postPerPage)
return false;
if (postPerPage.value == '999')
return false;
postPerPage.value = 999
var click = document.createEvent("MouseEvents");
click.initMouseEvent("click", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
document.getElementsByName('sort')[0].dispatchEvent(click);
return true;
},
visualeEspansa: function() {
if (!document.getElementById('review') || !document.getElementById('review').getElementsByTagName('a') || !document.getElementById('review').getElementsByTagName('a').item(0))
return;
var espandere = document.getElementById('review').getElementsByTagName('a').item(0);
var click = document.createEvent("MouseEvents");
click.initMouseEvent("click", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
espandere.dispatchEvent(click);
},
aggiungiLinkHunter : function() {
// Funzioni Hunters:
// mi serve il nome utente e non lo "user_id" !!!!
//
// posso ricavare il "nome utente" dalla funzione "Aggiungi amico"
// il link contiene : "i=zebra&add="
// oppure dal titotlo (già buono grazie alla funzione "accorciatitolo()" ) :
user_name = document.title;
var sub = this.getElementsByClass("details")[1];
if (sub) {
var dt = document.createElement("dt");
dt.style.marginTop = '10px';
dt.appendChild(document.createTextNode('Opzioni Hunters :'));
sub.appendChild(dt);
var dd = document.createElement("dd");
dd.style.marginTop = '10px';
sub.appendChild(dd);
var hr = document.createElement("a");
hr.setAttribute("href", "./mcp.php?"+user_name);
hr.appendChild(document.createTextNode('Modifica Avatar'))
dd.appendChild(hr);
var br = document.createElement('br'); // serve per andare a capo
dd.appendChild(br);
var hr2 = document.createElement("a");
hr2.setAttribute("href", "./mcp.php?i="+user_name);
hr2.appendChild(document.createTextNode('Modifica Firma'))
dd.appendChild(hr2);
};
},
nuovoCombo : function(nome,elementi) {
var select = document.createElement('select');
select.name = nome;
// select.setAttribute("accesskey",elementi[1][3]);
for (var i in elementi) {
var choice = document.createElement('option');
choice.value = elementi[i][0];
choice.appendChild(document.createTextNode(elementi[i][0]));
choice.setAttribute("onclick",elementi[i][1]);
choice.setAttribute("title",elementi[i][2]);
// choice.setAttribute("accesskey",elementi[i][3]);
choice.setAttribute("style",elementi[i][4]);
select.appendChild(choice);
};
return select;
},
customToolbar : function() {
// return;
if (this.getValue('tbarCustom','0')=='0')
return false;
// definizione Toolbar pulsanti ----------------------------------------------------
//
// pulsante = [ caption, script, hint, access_key, style ]
var aButtons = [
[' G ','bbfontstyle("[b]","[/b]")','Grassetto: [b]testo[/b]','b',"font-weight:bold; width: 30px"],
[' i ','bbfontstyle("[i]","[/i]")','Corsivo: [i]testo[/i]','i',"font-style:italic; width: 30px"],
[' s ','bbfontstyle("[u]","[/u]")','Sottolineato: [u]testo[/u]','u',"text-decoration: underline; width: 30px"],
[' - ','bbfontstyle("[s]","[/s]")','Testo barrato : [s]testo[/s]','s',''],
[
['Minuscolo','bbfontstyle("[size=50]" ,"[/size]")','Dimensione testo: [size=50]testo minuscolo[/size]','',''],
['Piccolo' ,'bbfontstyle("[size=85]" ,"[/size]")','Dimensione testo: [size=85]testo piccolo[/size]','',''],
['Normale' ,'bbfontstyle("[size=100]","[/size]")','Dimensione testo: [size=100]testo normale[/size]','',''],
['Medio' ,'bbfontstyle("[size=150]","[/size]")','Dimensione testo: [size=150]testo medio[/size]','',''],
['Grande' ,'bbfontstyle("[size=200]","[/size]")','Dimensione testo: [size=200]testo grande[/size]','',''],
['Enorme' ,'bbfontstyle("[size=250]","[/size]")','Dimensione testo: [size=250]testo enorme[/size]','',''],
['Extra' ,'bbfontstyle("[size=300]","[/size]")','Dimensione testo: [size=300]testo extra[/size]','',''],
],
['Colore','change_palette()','Colore: [color=red]testo[/color] Tip: puoi usare anche codici esadecimali dei colori color=#FF0000','',''],
[
['Centrato','bbfontstyle("[center]","[/center]")','Allinea il testo al centro: [center]testo centrato[/center].','',''],
['Giustificato','bbfontstyle("[justify]","[/justify]")','Giustifica il testo: [justify]testo giustificato[/justify]','',''],
['Destra','bbfontstyle("[right]","[/right]")','Allinea il testo a destra: [right]testo a destra[/right]','','']
],
['Spoiler','bbfontstyle("[spoiler]","[/spoiler]")','Spoiler: nascondi il testo.','',''],
[
['Cita' ,'bbfontstyle("[quote]","[/quote]")' ,'Cita: [quote]testo[/quote]','q',''],
['Edit' ,'bbfontstyle("[edit]","[/edit]")' ,'Edit : [edit]testo[/edit]','',''],
['Code' ,'bbfontstyle("[code]","[/code]")' ,'Codice : [code]testo[/code]','c',''],
['Legend','bbfontstyle("[legend=Titolo]","[/legend]")','Legend : [legend=Titolo]testo[/legend]','',''],
['Cartello','bbfontstyle("[cartello]","[/cartello]")','[cartello] il mio testo [/cartello] - inserisce il testo in un cartello','',''],
['Note' ,'bbfontstyle("[note]","[/note]")' ,'Note moderatori: [note]testo[/note]','',''],
['Text' ,'bbfontstyle("[text]","[/text]")' ,'Text : [text]testo[/text]','',''],
['Alink','bbfontstyle("[alink=Testo]","[/alink]")','Alink : [alink=Testo]testo[/alink]','',''],
['Anchor','bbfontstyle("[anchor]","[/anchor]")','Anchor : [anchor]testo[/anchor]','','']
],
[
['Elenco puntato','bbfontstyle("[list]","[/list]")','Elenco puntato : [list][*]uno [*]due[/list]','l',''],
['Elenco : 1.2.3.','bbfontstyle("[list=1]","[/list]")','Elenco numerato (1. 2. 3.) : [list=1][*]uno [*]due[/list]','',''],
['Elenco : a. b. c.','bbfontstyle("[list=a]","[/list]")','Elenco (a. b. c.) : [list=a][*]uno [*]due[/list]','',''],
['Elenco : i. ii.','bbfontstyle("[list=i]","[/list]")','Elenco (i. ii. iii.) : [list=i][*]uno [*]due[/list]','',''],
['Elemento','bbfontstyle("[*]","")','Elemento della lista: [*]testo','t','']
],
[
['Immagine','bbfontstyle("[img]","[/img]")','Immagine: [img]http://immagine_url[/img]','p',''],
['allinea a Sx','bbfontstyle("[imgl]","[/imgl]")','Immagine allineata a sinistra','',''],
['allinea a Dx','bbfontstyle("[imgr]","[/imgr]")','Immagine allineata a destra','',''],
['[IMGS]','bbfontstyle("[imgs]","[/imgs]")','Immagine ospitata sul server : [imgs]right.png[/imgs]','',''],
['Roll','bbfontstyle("[roll=]","[/roll]")','Roll Immagine : [roll=http://immagine_url]http://immagine_url[/roll]','','']
],
[
['URL','bbfontstyle("[url=]","[/url]")','Collegamento: [url]http://url[/url] o [url=http://url]testo aggiuntivo[/url]','w',''],
['Forum','bbfontstyle("[forum=]","[/forum]")','Link ad una sezione : [forum=NumeroForum]Descrizione[/forum] il numero si trova nell\' url dopo f=','',''],
['Topic','bbfontstyle("[topic=]","[/topic]")','Link ad una discussione : [topic=NumeroTopic]Descrizione[/topic] il numero si trova nell\' url dopo t=','',''],
['Post','bbfontstyle("[post=]","[/post]")','Link ad un singolo post : [post=NumeroPost]Descrizione[/post] il numero si trova nell\' url dopo #p' ,'',''],
['PM','bbfontstyle("[pm=]","[/pm]")','Link per l\' invio di un messaggio personale : [pm=numero_utente]Descrizione[/pm]','',''],
['Profilo','bbfontstyle("[profile=]","[/profile]")','Link al profilo utente (solo moderatori!): [profile=numero_utente]Descrizione[/profile]','',''],
['YouTube','bbfontstyle("[youtube]","[/youtube]")','[youtube]CODICE[/youtube] dove CODICE lo trovate dopo it.youtube.com/watch?v=','',''],
['Vimeo','bbfontstyle("[vimeo]","[/vimeo]")','[vimeo]CODICE[/vimeo] dove CODICE lo trovate dopo http://vimeo.com/','',''],
['MusicForum','bbfontstyle("[musicforum=]","[/musicforum]")','Link ad una sezione : [musicforum=NumeroForum]Descrizione[/musicforum] il numero si trova nell\' url dopo f=','',''],
['MusicTopic','bbfontstyle("[musictopic=]","[/musictopic]")','Link ad una discussione : [musictopic=NumeroTopic]Descrizione[/musictopic] il numero si trova nell\' url dopo t=','',''],
['OST','bbfontstyle("[ost]","[/ost]")','Link ad una discussione : [ost]NumeroTopic[/ost] il numero si trova nell\' url dopo t=','',''],
],
];
// ----------------------------------------------------
var div = document.getElementById("format-buttons");
if (!div)
return false;
// rimuovo i pulsanti standard
while (div.firstChild) {
div.removeChild(div.firstChild);
};
for (var i in aButtons) {
switch (typeof(aButtons[i][0])) {
case 'object' : // combobox
var ctrl = this.nuovoCombo('cb'+aButtons[i][0][0],aButtons[i]);
break;
default : // pulsante
var ctrl = this.nuovoPulsante('hint','btn'+aButtons[i][0],aButtons[i][0]);
ctrl.setAttribute("onclick",aButtons[i][1]);
ctrl.setAttribute("title",aButtons[i][2]);
ctrl.setAttribute("accesskey",aButtons[i][3]);
ctrl.setAttribute("style",aButtons[i][4]);
break;
};
div.appendChild(ctrl);
div.appendChild(document.createTextNode(' '));
};
},
/*
exportChildNodes : function(div) {
// export nella text_area dei pulsanti standard
var s="";
var div = document.getElementById("format-buttons");
while ((div) && (div.firstChild)) {
if (div.firstChild.className=="button2") {
s = s+ div.firstChild.getAttribute("value")+";" +div.firstChild.getAttribute("style")+";"
+ div.firstChild.getAttribute("onclick")+";"+ div.firstChild.getAttribute("onchange")+";"
+ div.firstChild.getAttribute("accesskey")+";"+ div.firstChild.getAttribute("title")+'\n';
}
div.removeChild(div.firstChild);
}
unsafeWindow.insert_text(s);
},
*/
// ------------------------------------------------------- Personalizzazione emoticons ---------------------------------------------------------------------
//
// la variabile "emoSelect" contiene l'elenco dei nomi delle variabili dei set personalizzati e ne stabilisce l'ordine di visualizzazione
// emoSelect = nome_var1|nome_var2|nome_var3
//
// i set personalizzati vengono memorizzati dalle variabili : "emocust_1", "emocust_2" , etc.
// emocust_1 = testo da visaulizzare|url_immagine|url_immagine
//
// contenitore per le emoticons standard
emoBaseImg : new Array(),
emoBaseCode : new Array(),
emo_empty_url : 'http://ddunlimited.net/images/smilies/empathy2.gif',
emoInitNewSet : function(set_name) {
emoSelect = document.getElementsByName("emoSelect")[0];
// conto le immagini visualizzate
var emo_list = document.getElementById('smiley-box').getElementsByTagName('a');
// img_count = 0;
s = set_name+"|";
for (i=0;i<emo_list.length;i++) {
if (emo_list[i].getAttribute("href")=='#') {
// img_count++;
s = s + 'no_image' + '|';
};
};
i = emoSelect.length+1; // forzo la somma (per non avere la concatenazione di stringa)
var_name = 'emocust_'+i;
if (this.getValue("emoSelect")) {
var a = this.getValue("emoSelect").split('|');
while (a.indexOf(var_name)>0) { // incremento di una posizione finchè non trovo
i++; // un nome libero per la variabile
var_name = 'emocust_'+i;
};
};
this.setValue(var_name,s.substring(0, s.length-1));
return var_name;
},
emoAddSet : function(var_name) {
emoSelect = document.getElementsByName("emoSelect")[0];
if (this.getValue(var_name)) {
set_name =this.getValue(var_name).split("|")[0];
var choice = document.createElement('option');
choice.value = var_name;
choice.appendChild(document.createTextNode(set_name));
emoSelect.appendChild(choice);
return choice.value;
};
},
emoSaveSelect : function() {
emoSelect = document.getElementsByName("emoSelect")[0];
value = "";
for (i=0;i<emoSelect.length;i++) {
value = value +emoSelect[i].value +"|";
};
this.setValue("emoSelect",value.substring(0, value.length-1));
},
emoBtnClick : function(evt, btn_name) {
switch (btn_name) {
case 'emobtn_0' :
// Aggiunge un nuovo set
str = prompt("Descrizione nuovo set di emoticons : ");
if (str!="") {
if (str.indexOf('|')>0) {
alert("Il carattere '|' non e' ammesso !");
break;
}
try {
var_name = this.emoInitNewSet(str);
this.emoAddSet(var_name);
}
finally {
this.emoSaveSelect();
};
};
break;
case 'emobtn_1' : // Elimina il set selezionato
emoSelect = document.getElementsByName("emoSelect")[0];
if (emoSelect.selectedIndex>0) {
if (confirm('Vuoi eliminare il set di icone "'+emoSelect[emoSelect.selectedIndex].text+'" ?')) {
// (!) elimnare la variabile dalle preferenze PRIMA !!!:
this.delValue(emoSelect[emoSelect.selectedIndex].value);
if ( this.getValue("emoDefault","") == emoSelect[emoSelect.selectedIndex].value )
this.setValue("emoDefault","emobase");
emoSelect.removeChild(emoSelect[emoSelect.selectedIndex]);
this.emoSaveSelect();
this.emoSelectChange(this,emoSelect);
}
}
else
alert("Non è possibile eliminare il Set Base !");
break;
};
},
customEmoticons : function() {
if (this.getValue('emoCustom','0')=='0')
return false;
var emo_box = document.getElementById('smiley-box');
if (emo_box) {
var emo_list = emo_box.getElementsByTagName('a');
var div = document.createElement('div');
div.id = 'emoticon-buttons-extra';
div.style.marginTop = '5px';
var emoSelect = document.createElement('select');
emoSelect.name = 'emoSelect';
div.appendChild(emoSelect);
emoSelect.addEventListener('change', this.emoSelectChange.bind(this,emoSelect), false);
var choice = document.createElement('option');
choice.value = 'emobase';
choice.appendChild(document.createTextNode('Set Base'));
emoSelect.appendChild(choice);
a = Array(Array('+','Crea un nuovo set'),Array('-','Elimina il set selezionato'));
for (i=0;i<a[0].length;i++) {
div.appendChild(document.createTextNode(' '));
pulsante = this.nuovoPulsante(a[i][1],"emobtn_"+i,a[i][0]);
div.appendChild(pulsante);
div.appendChild(document.createTextNode(' '));
pulsante.addEventListener('click', this.emoBtnClick.bind(this,pulsante.name), false);
};
var div2 = document.createElement('div');
div2.id = 'emoticon-separator-extra';
div2.style.marginTop = '5px';
div.appendChild(div2);
emo_box.insertBefore(div,emo_list[0]);
// salvo i valori del "Set Base" -------------------------------------------------
sImg = "emobase|";
sCode = "emobase|";
for (i=0;i<emo_list.length;i++) {
if (emo_list[i].getAttribute("href")=='#') {
sImg = sImg + emo_list[i].lastChild.getAttribute("src") + "|";
sCode = sCode + emo_list[i].lastChild.getAttribute("alt") + "|";
// sostituisco la originale "onclick" con il bind alla mia funzione
emo_list[i].setAttribute("onclick","return false");
emo_list[i].addEventListener('click', this.emoImgClick.bind(this,emo_list[i].lastChild), false);
}
};
sImg = sImg.substring(0, sImg.length-1);
sCode = sCode.substring(0, sCode.length-1);
this.emoBaseImg = sImg.split("|");
this.emoBaseCode = sCode.split("|");
// riempimento combo-box -------------------------------------------------
if (this.getValue("emoSelect")) {
var a = this.getValue("emoSelect").split('|');
for (i=1;i<a.length;i++) { // salto il set base
this.emoAddSet(a[i]);
};
};
// seleziono il Set predefinito
emoSelect.value=this.getValue("emoDefault","emobase");
if (emoSelect.value!="emobase")
this.emoSelectChange(this,emoSelect);
};
return true;
},
/*
emoImgClick : function(evt,emo_img) {
bbcode = emo_img.getAttribute("alt");
imgurl = emo_img.getAttribute("src");
if (bbcode!="")
str = bbcode
else
str = "[img]"+imgurl+"[/img]";
if ((evt.ctrlKey) || (imgurl==this.emo_empty_url)) {
if (bbcode=="") { // solo il Set Base ha dei bbcode associati alle emoticon
imgurl = prompt("Digita l' indirizzo dell'emoticon");
if (imgurl) {
this.emoImgReplace(emo_img,'',imgurl);
this.emoSaveSet();
}
}
else
alert("Il Set Base non è personalizzabile !")
}
else
unsafeWindow.insert_text(" "+str+" ",false);
},
*/
emoImgClick : function(evt,emo_img) {
bbcode = emo_img.getAttribute("alt");
imgurl = emo_img.getAttribute("src");
if (bbcode!="")
str = " "+bbcode+" "
else
str = "[img]"+imgurl+"[/img]";
if ((evt.ctrlKey) || (imgurl==this.emo_empty_url)) {
if (bbcode=="") { // solo il Set Base ha dei bbcode associati alle emoticon
if (evt.shiftKey) {
if (confirm("Sei sicuro di voler eliminare la personalizzazione ? ")) {
this.emoImgReplace(emo_img,'',this.emo_empty_url);
this.emoSaveSet();
}
}
else {
imgurl = prompt("Digita l' indirizzo dell'emoticon");
if (imgurl) {
this.emoImgReplace(emo_img,'',imgurl);
this.emoSaveSet();
}
}
}
else
alert("Il Set Base non è personalizzabile !")
}
else
unsafeWindow.insert_text(str,false);
},
emoImgReplace : function(emo_img,bbcode,imgurl) {
// emo_img = emo_item.lastChild;
emo_img.setAttribute("src",imgurl);
emo_img.setAttribute("alt",bbcode);
emo_img.setAttribute("width","");
emo_img.setAttribute("height","");
if (imgurl==this.emo_empty_url)
hint = "Cliccare sull'immagine per cambiare l'emoticon"
else
hint = "Tenere premuto Ctrl per cambiare l'emoticon, Ctrl+Shift per cancellarla";
emo_img.setAttribute("title",hint);
return true;
},
emoSelectChange : function(evt, emoSelect) {
var_name = emoSelect[emoSelect.selectedIndex].value;
var emo_box = document.getElementById('smiley-box');
var emo_list = emo_box.getElementsByTagName('a');
if (emoSelect.selectedIndex>0)
var emoCustomImg = this.getValue(var_name).replace(/no_image/g,this.emo_empty_url).split('|');
for (i=0;i<emo_list.length;i++) {
if (emo_list[i].getAttribute("href")=='#') {
if (emoSelect.selectedIndex==0)
// set base (con codici)
this.emoImgReplace(emo_list[i].lastChild,this.emoBaseCode[i+1],this.emoBaseImg[i+1])
else
this.emoImgReplace(emo_list[i].lastChild,"",emoCustomImg[i+1]);
};
};
this.ingrandisciTextArea();
},
emoSaveSet: function() {
emoSelect = document.getElementsByName("emoSelect")[0];
var_name = emoSelect[emoSelect.selectedIndex].value;
var emo_box = document.getElementById('smiley-box');
var emo_list = emo_box.getElementsByTagName('a');
var s =emoSelect[emoSelect.selectedIndex].text+"|";
for (i=0;i<emo_list.length;i++) {
if (emo_list[i].getAttribute("href")=='#') {
s = s + emo_list[i].lastChild.src.replace(new RegExp(this.emo_empty_url,"g"),"no_image")+"|";
};
};
this.setValue(var_name,s.substring(0, s.length-1));
},
} // var DDPlus
ddplus.inint();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment