2003-08-15 15:15:37 +00:00
|
|
|
// new edit toolbar used with permission
|
|
|
|
// by Alex King
|
|
|
|
// http://www.alexking.org/
|
|
|
|
|
2003-10-13 07:36:00 +00:00
|
|
|
var edButtons = new Array();
|
|
|
|
var edLinks = new Array();
|
|
|
|
var edOpenTags = new Array();
|
|
|
|
|
|
|
|
function edButton(id, display, tagStart, tagEnd, access, open) {
|
|
|
|
this.id = id; // used to name the toolbar button
|
|
|
|
this.display = display; // label on button
|
|
|
|
this.tagStart = tagStart; // open tag
|
|
|
|
this.tagEnd = tagEnd; // close tag
|
|
|
|
this.access = access; // access key
|
|
|
|
this.open = open; // set to -1 if tag does not need to be closed
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
|
2003-10-13 07:36:00 +00:00
|
|
|
/*
|
|
|
|
** TODO: Make it so ins and del have proper datetime attributes, formatted as so: **
|
|
|
|
1999-02-22T16:03:30-08:00
|
|
|
|
|
|
|
|
** Here's my start **
|
|
|
|
var now = new Date();
|
|
|
|
var datetime = now.getFullYear() + '-' +
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_strong'
|
|
|
|
,'B'
|
|
|
|
,'<strong>'
|
|
|
|
,'</strong>'
|
|
|
|
,'b'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_em'
|
|
|
|
,'i'
|
|
|
|
,'<em>'
|
|
|
|
,'</em>'
|
|
|
|
,'i'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_del'
|
|
|
|
,'del'
|
|
|
|
,'<del>'
|
|
|
|
,'</del>'
|
|
|
|
,'d'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_ins'
|
|
|
|
,'ins'
|
|
|
|
,'<ins>'
|
|
|
|
,'</ins>'
|
|
|
|
,'d'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_link'
|
|
|
|
,'link'
|
|
|
|
,''
|
|
|
|
,'</a>'
|
|
|
|
,'a'
|
|
|
|
); // special case
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_img'
|
|
|
|
,'img'
|
|
|
|
,''
|
|
|
|
,''
|
|
|
|
,'m'
|
|
|
|
,-1
|
|
|
|
); // special case
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_ul'
|
|
|
|
,'ul'
|
|
|
|
,'<ul>'
|
|
|
|
,'</ul>'
|
|
|
|
,'u'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_ol'
|
|
|
|
,'ol'
|
|
|
|
,'<ol>'
|
|
|
|
,'</ol>'
|
|
|
|
,'o'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_li'
|
|
|
|
,'li'
|
|
|
|
,'<li>'
|
|
|
|
,'</li>'
|
|
|
|
,'l'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_block'
|
|
|
|
,'b-quote'
|
|
|
|
,'<blockquote>'
|
|
|
|
,'</blockquote>'
|
|
|
|
,'q'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_pre'
|
|
|
|
,'pre'
|
|
|
|
,'<pre>'
|
|
|
|
,'</pre>'
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_more'
|
|
|
|
,'more'
|
|
|
|
,'<!--more-->'
|
|
|
|
,''
|
|
|
|
,'t'
|
|
|
|
,-1
|
|
|
|
);
|
|
|
|
|
|
|
|
edButtons[edButtons.length] = new edButton('ed_next'
|
|
|
|
,'n-page'
|
|
|
|
,'<!--nextpage-->'
|
|
|
|
,''
|
|
|
|
,'p'
|
|
|
|
,-1
|
|
|
|
);
|
|
|
|
|
|
|
|
function edLink() {
|
|
|
|
this.display = '';
|
|
|
|
this.URL = '';
|
|
|
|
this.newWin = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
edLinks[edLinks.length] = new edLink('WordPress'
|
|
|
|
,'http://wordpress.org/'
|
|
|
|
);
|
|
|
|
|
|
|
|
edLinks[edLinks.length] = new edLink('alexking.org'
|
|
|
|
,'http://www.alexking.org/'
|
|
|
|
);
|
|
|
|
|
|
|
|
function edShowButton(button, i) {
|
|
|
|
if (button.id == 'ed_img') {
|
|
|
|
document.write('<input type="button" id="' + button.id + '" accesskey="' + button.access + '" class="ed_button" onclick="edInsertImage(edCanvas);" value="' + button.display + '" />');
|
|
|
|
}
|
|
|
|
else if (button.id == 'ed_link') {
|
|
|
|
document.write('<input type="button" id="' + button.id + '" accesskey="' + button.access + '" class="ed_button" onclick="edInsertLink(edCanvas, ' + i + ');" value="' + button.display + '" />');
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
document.write('<input type="button" id="' + button.id + '" accesskey="' + button.access + '" class="ed_button" onclick="edInsertTag(edCanvas, ' + i + ');" value="' + button.display + '" />');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edShowLinks() {
|
|
|
|
var tempStr = '<select onchange="edQuickLink(this.options[this.selectedIndex].value, this);"><option value="-1" selected>(Quick Links)</option>';
|
|
|
|
for (i = 0; i < edLinks.length; i++) {
|
|
|
|
tempStr += '<option value="' + i + '">' + edLinks[i].display + '</option>';
|
|
|
|
}
|
|
|
|
tempStr += '</select>';
|
|
|
|
document.write(tempStr);
|
|
|
|
}
|
2003-08-15 15:15:37 +00:00
|
|
|
|
|
|
|
function edAddTag(button) {
|
2003-10-13 07:36:00 +00:00
|
|
|
if (edButtons[button].tagEnd != '') {
|
2003-08-15 15:15:37 +00:00
|
|
|
edOpenTags[edOpenTags.length] = button;
|
2003-10-13 07:36:00 +00:00
|
|
|
document.getElementById(edButtons[button].id).value = '/' + document.getElementById(edButtons[button].id).value;
|
2003-08-15 15:15:37 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edRemoveTag(button) {
|
|
|
|
for (i = 0; i < edOpenTags.length; i++) {
|
|
|
|
if (edOpenTags[i] == button) {
|
|
|
|
edOpenTags.splice(i, 1);
|
2003-10-13 07:36:00 +00:00
|
|
|
document.getElementById(edButtons[button].id).value = document.getElementById(edButtons[button].id).value.replace('/', '');
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edCheckOpenTags(button) {
|
|
|
|
var tag = 0;
|
|
|
|
for (i = 0; i < edOpenTags.length; i++) {
|
|
|
|
if (edOpenTags[i] == button) {
|
|
|
|
tag++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (tag > 0) {
|
|
|
|
return true; // tag found
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return false; // tag not found
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edCloseAllTags() {
|
|
|
|
var count = edOpenTags.length;
|
|
|
|
for (o = 0; o < count; o++) {
|
|
|
|
edInsertTag(edCanvas, edOpenTags[edOpenTags.length - 1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edQuickLink(i, thisSelect) {
|
|
|
|
if (i > -1) {
|
|
|
|
var newWin = '';
|
2003-10-13 07:36:00 +00:00
|
|
|
if (edLinks[i].newWin == 1) {
|
2003-08-15 15:15:37 +00:00
|
|
|
newWin = ' target="_blank"';
|
|
|
|
}
|
2003-10-13 07:36:00 +00:00
|
|
|
var tempStr = '<a href="' + edLinks[i].URL + '"' + newWin + '>'
|
|
|
|
+ edLinks[i].display
|
|
|
|
+ '</a>';
|
|
|
|
thisSelect.selectedIndex = 0;
|
2003-08-15 15:15:37 +00:00
|
|
|
edInsertContent(edCanvas, tempStr);
|
|
|
|
}
|
2003-10-13 07:36:00 +00:00
|
|
|
else {
|
|
|
|
thisSelect.selectedIndex = 0;
|
|
|
|
}
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function edSpell(myField) {
|
|
|
|
var word = '';
|
|
|
|
if (document.selection) {
|
|
|
|
myField.focus();
|
|
|
|
var sel = document.selection.createRange();
|
|
|
|
if (sel.text.length > 0) {
|
|
|
|
word = sel.text;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (myField.selectionStart || myField.selectionStart == '0') {
|
|
|
|
var startPos = myField.selectionStart;
|
|
|
|
var endPos = myField.selectionEnd;
|
|
|
|
if (startPos != endPos) {
|
|
|
|
word = myField.value.substring(startPos, endPos);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (word == '') {
|
|
|
|
word = prompt('Enter a word to look up:', '');
|
|
|
|
}
|
|
|
|
if (word != '') {
|
2003-10-13 07:36:00 +00:00
|
|
|
window.open('http://dictionary.reference.com/search?q=' + escape(word));
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edToolbar() {
|
|
|
|
document.write('<div id="ed_toolbar">');
|
2003-10-13 07:36:00 +00:00
|
|
|
for (i = 0; i < edButtons.length; i++) {
|
|
|
|
edShowButton(edButtons[i], i);
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
2003-08-15 16:23:04 +00:00
|
|
|
document.write('<input type="button" id="ed_spell" class="ed_button" onclick="edSpell(edCanvas);" title="Dictionary lookup" value="Dict." />');
|
|
|
|
document.write('<input type="button" id="ed_close" class="ed_button" onclick="edCloseAllTags();" title="Close all open tags" value="Close Tags" />');
|
2003-08-15 15:15:37 +00:00
|
|
|
// edShowLinks(); // disabled by default
|
|
|
|
document.write('</div>');
|
|
|
|
}
|
|
|
|
|
|
|
|
// insertion code
|
|
|
|
|
|
|
|
function edInsertTag(myField, i) {
|
|
|
|
//IE support
|
|
|
|
if (document.selection) {
|
|
|
|
myField.focus();
|
|
|
|
sel = document.selection.createRange();
|
|
|
|
if (sel.text.length > 0) {
|
2003-10-13 07:36:00 +00:00
|
|
|
sel.text = edButtons[i].tagStart + sel.text + edButtons[i].tagEnd;
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
else {
|
2003-10-13 07:36:00 +00:00
|
|
|
if (!edCheckOpenTags(i) || edButtons[i].tagEnd == '') {
|
|
|
|
sel.text = edButtons[i].tagStart;
|
2003-08-15 15:15:37 +00:00
|
|
|
edAddTag(i);
|
|
|
|
}
|
|
|
|
else {
|
2003-10-13 07:36:00 +00:00
|
|
|
sel.text = edButtons[i].tagEnd;
|
2003-08-15 15:15:37 +00:00
|
|
|
edRemoveTag(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
myField.focus();
|
|
|
|
}
|
|
|
|
//MOZILLA/NETSCAPE support
|
|
|
|
else if (myField.selectionStart || myField.selectionStart == '0') {
|
|
|
|
var startPos = myField.selectionStart;
|
|
|
|
var endPos = myField.selectionEnd;
|
|
|
|
var cursorPos;
|
|
|
|
if (startPos != endPos) {
|
|
|
|
myField.value = myField.value.substring(0, startPos)
|
2003-10-13 07:36:00 +00:00
|
|
|
+ edButtons[i].tagStart
|
2003-08-15 15:15:37 +00:00
|
|
|
+ myField.value.substring(startPos, endPos)
|
2003-10-13 07:36:00 +00:00
|
|
|
+ edButtons[i].tagEnd
|
2003-08-15 15:15:37 +00:00
|
|
|
+ myField.value.substring(endPos, myField.value.length);
|
2003-10-13 07:36:00 +00:00
|
|
|
cursorPos = endPos
|
|
|
|
+ edButtons[i].tagStart.length
|
|
|
|
+ edButtons[i].length;
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
else {
|
2003-10-13 07:36:00 +00:00
|
|
|
if (!edCheckOpenTags(i) || edButtons[i].tagEnd == '') {
|
2003-08-15 15:15:37 +00:00
|
|
|
myField.value = myField.value.substring(0, startPos)
|
2003-10-13 07:36:00 +00:00
|
|
|
+ edButtons[i].tagStart
|
2003-08-15 15:15:37 +00:00
|
|
|
+ myField.value.substring(endPos, myField.value.length);
|
|
|
|
edAddTag(i);
|
2003-10-13 07:36:00 +00:00
|
|
|
cursorPos = startPos + edButtons[i].tagStart.length;
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
myField.value = myField.value.substring(0, startPos)
|
2003-10-13 07:36:00 +00:00
|
|
|
+ edButtons[i].tagEnd
|
2003-08-15 15:15:37 +00:00
|
|
|
+ myField.value.substring(endPos, myField.value.length);
|
|
|
|
edRemoveTag(i);
|
2003-10-13 07:36:00 +00:00
|
|
|
cursorPos = startPos + edButtons[i].tagEnd.length;
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
myField.focus();
|
|
|
|
myField.selectionStart = cursorPos;
|
|
|
|
myField.selectionEnd = cursorPos;
|
|
|
|
}
|
|
|
|
else {
|
2003-10-13 07:36:00 +00:00
|
|
|
if (!edCheckOpenTags(i) || edButtons[i].tagEnd == '') {
|
|
|
|
myField.value += edButtons[i].tagStart;
|
2003-08-15 15:15:37 +00:00
|
|
|
edAddTag(i);
|
|
|
|
}
|
|
|
|
else {
|
2003-10-13 07:36:00 +00:00
|
|
|
myField.value += edButtons[i].tagEnd;
|
2003-08-15 15:15:37 +00:00
|
|
|
edRemoveTag(i);
|
|
|
|
}
|
|
|
|
myField.focus();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function edInsertContent(myField, myValue) {
|
|
|
|
//IE support
|
|
|
|
if (document.selection) {
|
|
|
|
myField.focus();
|
|
|
|
sel = document.selection.createRange();
|
|
|
|
sel.text = myValue;
|
|
|
|
myField.focus();
|
|
|
|
}
|
|
|
|
//MOZILLA/NETSCAPE support
|
|
|
|
else if (myField.selectionStart || myField.selectionStart == '0') {
|
|
|
|
var startPos = myField.selectionStart;
|
|
|
|
var endPos = myField.selectionEnd;
|
|
|
|
myField.value = myField.value.substring(0, startPos)
|
|
|
|
+ myValue
|
|
|
|
+ myField.value.substring(endPos, myField.value.length);
|
|
|
|
myField.focus();
|
|
|
|
myField.selectionStart = startPos + myValue.length;
|
|
|
|
myField.selectionEnd = startPos + myValue.length;
|
|
|
|
} else {
|
|
|
|
myField.value += myValue;
|
|
|
|
myField.focus();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-10-13 07:36:00 +00:00
|
|
|
function edInsertLink(myField, i, defaultValue) {
|
|
|
|
if (!defaultValue) {
|
|
|
|
defaultValue = 'http://';
|
|
|
|
}
|
2003-08-15 15:15:37 +00:00
|
|
|
if (!edCheckOpenTags(i)) {
|
2003-10-13 07:36:00 +00:00
|
|
|
edButtons[i].tagStart = '<a href="'
|
|
|
|
+ prompt('Enter the URL'
|
|
|
|
,defaultValue
|
|
|
|
)
|
2003-10-22 08:53:52 +00:00
|
|
|
+ '">';
|
2003-08-15 15:15:37 +00:00
|
|
|
}
|
|
|
|
edInsertTag(myField, i);
|
|
|
|
}
|
|
|
|
|
|
|
|
function edInsertImage(myField) {
|
2003-10-13 07:36:00 +00:00
|
|
|
var myValue = '<img src="'
|
|
|
|
+ prompt('Enter the URL of the image', 'http://')
|
|
|
|
+ '" alt="'
|
|
|
|
+ prompt('Enter a description of the image', '')
|
|
|
|
+ '" />';
|
2003-08-15 15:15:37 +00:00
|
|
|
edInsertContent(myField, myValue);
|
|
|
|
}
|