| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336 | /* ***** BEGIN LICENSE BLOCK ***** * This file is part of DotClear. * Copyright (c) 2004 Olivier Meunier and contributors. All rights * reserved. * * DotClear is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. *  * DotClear is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. *  * You should have received a copy of the GNU General Public License * along with DotClear; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * * ***** END LICENSE BLOCK ***** */ function dcToolBar(textarea,format,img_path){	this.addButton		= function() {}	this.addSpace		= function() {}	this.draw			= function() {}	this.btStrong		= function() {}	this.btEm			= function() {}	this.btIns		= function() {}	this.btDel		= function() {}	this.btQ			= function() {}	this.btCode		= function() {}	this.btBr			= function() {}	this.btBquote		= function() {}	this.btPre		= function() {}	this.btList		= function() {}	this.btLink		= function() {}	this.btImgLink		= function() {}	this.btImg		= function() {}	this.insImg		= function() {}		if (!document.createElement) {		return;	}		if ((typeof(document["selection"]) == "undefined")	&& (typeof(textarea["setSelectionRange"]) == "undefined")) {		return;	}		var toolbar = document.createElement("div");	toolbar.id = "dctoolbar";		function getFormat() {		if (format.value == 'wiki') {			return 'wiki';		} else {			return 'html';		}	}		function addButton(src, title, fn) {		var i = document.createElement('img');		i.src = src;		i.title = title;		i.onclick = function() { try { fn() } catch (e) { } return false };		i.tabIndex = 400;		toolbar.appendChild(i);		addSpace(2);	}		function addSpace(w)	{		s = document.createElement('span');		s.style.padding='0 '+w+'px 0 0';		s.appendChild(document.createTextNode(' '));		toolbar.appendChild(s);	}		function encloseSelection(prefix, suffix, fn) {		textarea.focus();		var start, end, sel, scrollPos, subst;				if (typeof(document["selection"]) != "undefined") {			sel = document.selection.createRange().text;		} else if (typeof(textarea["setSelectionRange"]) != "undefined") {			start = textarea.selectionStart;			end = textarea.selectionEnd;			scrollPos = textarea.scrollTop;			sel = textarea.value.substring(start, end);		}				if (sel.match(/ $/)) { // exclude ending space char, if any			sel = sel.substring(0, sel.length - 1);			suffix = suffix + " ";		}				if (typeof(fn) == 'function') {			var res = (sel) ? fn(sel) : fn('');		} else {			var res = (sel) ? sel : '';		}				subst = prefix + res + suffix;				if (typeof(document["selection"]) != "undefined") {			var range = document.selection.createRange().text = subst;			textarea.caretPos -= suffix.length;		} else if (typeof(textarea["setSelectionRange"]) != "undefined") {			textarea.value = textarea.value.substring(0, start) + subst +			textarea.value.substring(end);			if (sel) {				textarea.setSelectionRange(start + subst.length, start + subst.length);			} else {				textarea.setSelectionRange(start + prefix.length, start + prefix.length);			}			textarea.scrollTop = scrollPos;		}	}		function draw(msg) {		p = document.createElement('em');		p.style.display='block';		p.style.margin='-0.5em 0 0.5em 0';		p.appendChild(document.createTextNode(msg));		textarea.parentNode.insertBefore(p, textarea);		textarea.parentNode.insertBefore(toolbar, textarea);	}			// ---	function singleTag(wtag,htag,wetag) {		if (getFormat() == 'wiki') {			var stag = wtag;			var etag = (wetag) ? wetag : wtag;		} else {			var stag = '<'+htag+'>';			var etag = '</'+htag+'>';		}		encloseSelection(stag,etag);	}		function btStrong(label) {		addButton(img_path+'bt_strong.png',label,		function() { singleTag('__','strong'); });	}		function btEm(label) {		addButton(img_path+'bt_em.png',label,		function() { singleTag("''",'em'); });	}		function btIns(label) {		addButton(img_path+'bt_ins.png',label,		function() { singleTag('++','ins'); });	}		function btDel(label) {		addButton(img_path+'bt_del.png',label,		function() { singleTag('--','del'); });	}		function btQ(label) {		addButton(img_path+'bt_quote.png',label,		function() { singleTag('{{','q','}}'); });	}		function btCode(label) {		addButton(img_path+'bt_code.png',label,		function() { singleTag('@@','code'); });	}		function btBr(label) {		addButton(img_path+'bt_br.png',label,		function() {			var tag = getFormat() == 'wiki' ? "%%%\n" : "<br />\n";			encloseSelection('',tag);		});	}		function btBquote(label) {		addButton(img_path+'bt_bquote.png',label,		function() {			encloseSelection("\n",'',			function(str) {				if (getFormat() == 'wiki') {					str = str.replace(/\r/g,'');					return '> '+str.replace(/\n/g,"\n> ");				} else {					return "<blockquote>"+str+"</blockquote>\n";				}			});		});	}		function btPre(label) {		addButton(img_path+'bt_pre.png',label,		function() {			encloseSelection("\n",'',			function(str) {				if (getFormat() == 'wiki') {					str = str.replace(/\r/g,'');					return ' '+str.replace(/\n/g,"\n ");				} else {					return "<pre>"+str+"</pre>\n";				}			});		});	}		function btList(label,type) {		var img = (type == 'ul') ? 'bt_ul.png' : 'bt_ol.png';		var wtag = (type == 'ul') ? '*' : '#';				addButton(img_path+img,label,		function() {			encloseSelection("",'',			function(str) {				if (getFormat() == 'wiki') {					str = str.replace(/\r/g,'');					return wtag+' '+str.replace(/\n/g,"\n"+wtag+' ');				} else {					str = str.replace(/\r/g,'');					str = str.replace(/\n/g,"</li>\n <li>");					return "<"+type+">\n <li>"+str+"</li>\n</"+type+">";				}			});		});	}		function btLink(label,msg_url,msg_lang,default_lang) {		addButton(img_path+'bt_link.png',label,		function() {			var href = window.prompt(msg_url,'');			if (!href) { return; }						var hreflang = window.prompt(msg_lang,default_lang);						if (getFormat() == 'wiki') {				stag = '[';				var etag = '|'+href;				if (hreflang) { etag = etag+'|'+hreflang; }				etag = etag+']';			} else {				var stag = '<a href="'+href+'"';				if (hreflang) { stag = stag+' hreflang="'+hreflang+'"'; }				stag = stag+'>';				etag = '</a>';			}						encloseSelection(stag,etag);		});	}		function btImgLink(label,msg_src)	{		addButton(img_path+'bt_img_link.png',label,		function() {			encloseSelection('','',			function(str) {				var src = window.prompt(msg_src,'');				if (!src) { return str; }								if (getFormat() == 'wiki') {					if (str) {						return '(('+src+'|'+str+'))';					} else {						return '(('+src+'))';					}				} else {					if (str) {						return '<img src="'+src+'" alt="'+str+'" />';					} else {						return '<img src="'+src+'" alt="" />';					}				}			});		});	}		function btImg(label,url)	{		addButton(img_path+'bt_img.png',label,		function() {			popup(url);		});	}		function insImg(src)	{		if (document.all) {			textarea.focus();			if (getFormat() == 'wiki') {				textarea.value = textarea.value+'(('+src+'))';			} else {				textarea.value = textarea.value+'<img src="'+src+'" alt="" />';			}		} else {			encloseSelection('','',			function(str) {				if (getFormat() == 'wiki') {					if (str) {						return '(('+src+'|'+str+'))';					} else {						return '(('+src+'))';					}				} else {					if (str) {						return '<img src="'+src+'" alt="'+str+'" />';					} else {						return '<img src="'+src+'" alt="" />';					}				}			});		}	}		// methods	this.addButton		= addButton;	this.addSpace		= addSpace;	this.draw			= draw;	this.btStrong		= btStrong;	this.btEm			= btEm;	this.btIns		= btIns;	this.btDel		= btDel;	this.btQ			= btQ;	this.btCode		= btCode;	this.btBr			= btBr;	this.btBquote		= btBquote;	this.btPre		= btPre;	this.btList		= btList;	this.btLink		= btLink;	this.btImgLink		= btImgLink;	this.btImg		= btImg;	this.insImg		= insImg;}
 |