mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-05 06:10:07 -05:00
167 lines
6.2 KiB
JavaScript
167 lines
6.2 KiB
JavaScript
|
$(document).ready(function() {
|
||
|
Squire.prototype.testPresenceinSelection = function(name, action, format,
|
||
|
validation) {
|
||
|
var path = this.getPath(),
|
||
|
test = (validation.test(path) | this.hasFormat(format));
|
||
|
if (name == action && test) {
|
||
|
return true;
|
||
|
} else {
|
||
|
return false;
|
||
|
}
|
||
|
};
|
||
|
SquireUI = function(options) {
|
||
|
if (typeof options.buildPath == "undefined") {
|
||
|
options.buildPath = 'build/';
|
||
|
}
|
||
|
// Create instance of iFrame
|
||
|
var container, editor;
|
||
|
if (options.replace) {
|
||
|
container = $(options.replace).parent();
|
||
|
$(options.replace).remove();
|
||
|
} else if (options.div) {
|
||
|
container = $(options.div);
|
||
|
} else {
|
||
|
throw new Error(
|
||
|
"No element was defined for the editor to inject to.");
|
||
|
}
|
||
|
var iframe = document.createElement('iframe');
|
||
|
var div = document.createElement('div');
|
||
|
div.className = 'Squire-UI';
|
||
|
iframe.height = options.height;
|
||
|
|
||
|
$(div).load(options.buildPath + 'Squire-UI.html', function() {
|
||
|
this.linkDrop = new Drop({
|
||
|
target: $('#makeLink').first()[0],
|
||
|
content: $('#drop-link').html(),
|
||
|
position: 'bottom center',
|
||
|
openOn: 'click'
|
||
|
});
|
||
|
|
||
|
this.linkDrop.on('open', function () {
|
||
|
$('.quit').click(function () {
|
||
|
$(this).parent().parent().removeClass('drop-open');
|
||
|
});
|
||
|
|
||
|
$('.submitLink').click(function () {
|
||
|
var editor = iframe.contentWindow.editor;
|
||
|
editor.makeLink($(this).parent().children('#url').first().val());
|
||
|
$(this).parent().parent().removeClass('drop-open');
|
||
|
$(this).parent().children('#url').attr('value', '');
|
||
|
});
|
||
|
});
|
||
|
|
||
|
this.imageDrop = new Drop({
|
||
|
target: $('#insertImage').first()[0],
|
||
|
content: $('#drop-image').html(),
|
||
|
position: 'bottom center',
|
||
|
openOn: 'click'
|
||
|
});
|
||
|
|
||
|
this.imageDrop.on('open', function () {
|
||
|
$('.quit').unbind().click(function () {
|
||
|
$(this).parent().parent().removeClass('drop-open');
|
||
|
});
|
||
|
|
||
|
$('.sumbitImageURL').unbind().click(function () {
|
||
|
console.log("Passed through .sumbitImageURL");
|
||
|
var editor = iframe.contentWindow.editor;
|
||
|
url = $(this).parent().children('#imageUrl').first()[0];
|
||
|
editor.insertImage(url.value);
|
||
|
$(this).parent().parent().removeClass('drop-open');
|
||
|
$(this).parent().children('#imageUrl').attr('value', '');
|
||
|
});
|
||
|
|
||
|
});
|
||
|
|
||
|
this.fontDrop = new Drop({
|
||
|
target: $('#selectFont').first()[0],
|
||
|
content: $('#drop-font').html(),
|
||
|
position: 'bottom center',
|
||
|
openOn: 'click'
|
||
|
});
|
||
|
|
||
|
this.fontDrop.on('open', function () {
|
||
|
$('.quit').click(function () {
|
||
|
$(this).parent().parent().removeClass('drop-open');
|
||
|
});
|
||
|
|
||
|
$('.submitFont').unbind().click(function () {
|
||
|
var editor = iframe.contentWindow.editor;
|
||
|
var selectedFonts = $('select#fontSelect option:selected').last().data('fonts');
|
||
|
var fontSize = $('select#textSelector option:selected').last().data('size') + 'px';
|
||
|
editor.setFontSize(fontSize);
|
||
|
|
||
|
try {
|
||
|
editor.setFontFace(selectedFonts);
|
||
|
} catch (e) {
|
||
|
alert('Please make a selection of text.');
|
||
|
} finally {
|
||
|
$(this).parent().parent().removeClass('drop-open');
|
||
|
}
|
||
|
|
||
|
});
|
||
|
|
||
|
|
||
|
});
|
||
|
|
||
|
$('.item').click(function() {
|
||
|
var iframe = $(this).parents('.Squire-UI').next('iframe').first()[0];
|
||
|
var editor = iframe.contentWindow.editor;
|
||
|
var action = $(this).data('action');
|
||
|
|
||
|
test = {
|
||
|
value: $(this).data('action'),
|
||
|
testBold: editor.testPresenceinSelection('bold',
|
||
|
action, 'B', (/>B\b/)),
|
||
|
testItalic: editor.testPresenceinSelection('italic',
|
||
|
action, 'I', (/>I\b/)),
|
||
|
testUnderline: editor.testPresenceinSelection(
|
||
|
'underline', action, 'U', (/>U\b/)),
|
||
|
testOrderedList: editor.testPresenceinSelection(
|
||
|
'makeOrderedList', action, 'OL', (/>OL\b/)),
|
||
|
testLink: editor.testPresenceinSelection('makeLink',
|
||
|
action, 'A', (/>A\b/)),
|
||
|
testQuote: editor.testPresenceinSelection(
|
||
|
'increaseQuoteLevel', action, 'blockquote', (
|
||
|
/>blockquote\b/)),
|
||
|
isNotValue: function (a) {return (a == action && this.value !== ''); }
|
||
|
};
|
||
|
|
||
|
editor.alignRight = function () { editor.setTextAlignment('right'); };
|
||
|
editor.alignCenter = function () { editor.setTextAlignment('center'); };
|
||
|
editor.alignLeft = function () { editor.setTextAlignment('left'); };
|
||
|
editor.alignJustify = function () { editor.setTextAlignment('justify'); };
|
||
|
editor.makeHeading = function () { editor.setFontSize('2em'); editor.bold(); };
|
||
|
|
||
|
if (test.testBold | test.testItalic | test.testUnderline | test.testOrderedList | test.testLink | test.testQuote) {
|
||
|
if (test.testBold) editor.removeBold();
|
||
|
if (test.testItalic) editor.removeItalic();
|
||
|
if (test.testUnderline) editor.removeUnderline();
|
||
|
if (test.testLink) editor.removeLink();
|
||
|
if (test.testOrderedList) editor.removeList();
|
||
|
if (test.testQuote) editor.decreaseQuoteLevel();
|
||
|
} else if (test.isNotValue('makeLink') | test.isNotValue('insertImage') | test.isNotValue('selectFont')) {
|
||
|
// do nothing these are dropdowns.
|
||
|
} else {
|
||
|
if (editor.getSelectedText() === '' && !(action == 'insertImage' || action == 'makeOrderedList' || action == 'increaseQuoteLevel' || action == 'redo' || action == 'undo')) return;
|
||
|
editor[action]();
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
|
||
|
$(container).append(div);
|
||
|
$(container).append(iframe);
|
||
|
|
||
|
var style = document.createElement('style');
|
||
|
style.innerHTML = 'blockquote { border-left: 3px green solid; padding-left: 5px; }';
|
||
|
|
||
|
|
||
|
iframe.contentWindow.editor = new Squire(iframe.contentWindow.document);
|
||
|
iframe.addEventListener('load', function() {
|
||
|
iframe.contentWindow.editor = new Squire(iframe.contentWindow.document);
|
||
|
});
|
||
|
|
||
|
iframe.contentWindow.document.head.appendChild(style);
|
||
|
return iframe.contentWindow.editor;
|
||
|
};
|
||
|
});
|