mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
235 lines
8.0 KiB
JavaScript
235 lines
8.0 KiB
JavaScript
/**
|
|
* editor_plugin_src.js
|
|
*
|
|
* Copyright 2009, Moxiecode Systems AB
|
|
* Released under LGPL License.
|
|
*
|
|
* License: http://tinymce.moxiecode.com/license
|
|
* Contributing: http://tinymce.moxiecode.com/contributing
|
|
*/
|
|
|
|
(function() {
|
|
var DOM = tinymce.DOM;
|
|
|
|
// State Transfer function
|
|
var transferState = function(oldEditor, newEditor, bookmark) {
|
|
var transferColorButtonState = function(swapme) {
|
|
var c = oldEditor.controlManager.get(swapme);
|
|
var newC = newEditor.controlManager.get(swapme);
|
|
|
|
if (c && newC) {
|
|
newC.displayColor(c.value);
|
|
}
|
|
|
|
};
|
|
|
|
transferColorButtonState('forecolor');
|
|
transferColorButtonState('backcolor');
|
|
newEditor.setContent(oldEditor.getContent({format : 'raw'}), {format : 'raw'});
|
|
newEditor.selection.moveToBookmark(bookmark);
|
|
|
|
if (oldEditor.plugins.spellchecker && newEditor.plugins.spellchecker) {
|
|
newEditor.plugins.spellchecker.setLanguage(oldEditor.plugins.spellchecker.selectedLang);
|
|
}
|
|
};
|
|
|
|
tinymce.create('tinymce.plugins.FullScreenPlugin', {
|
|
init : function(ed, url) {
|
|
var t = this, s = {}, de = DOM.doc.documentElement, vp, fullscreen_overflow, fullscreen_html_overflow, fullscreen_scrollx, fullscreen_scrolly, posCss, bookmark;
|
|
|
|
// Register commands
|
|
ed.addCommand('mceFullScreen', function() {
|
|
var win, oed;
|
|
|
|
if (ed.getParam('fullscreen_is_enabled')) {
|
|
if (ed.getParam('fullscreen_new_window'))
|
|
closeFullscreen(); // Call to close in fullscreen.htm
|
|
else {
|
|
DOM.win.setTimeout(function() {
|
|
var fullscreenEditor = ed;
|
|
|
|
// find the editor that opened this one, execute restore function there
|
|
var originalEditor = tinyMCE.get(fullscreenEditor.getParam('fullscreen_editor_id'));
|
|
originalEditor.plugins.fullscreen.saveState(fullscreenEditor);
|
|
|
|
tinyMCE.remove(fullscreenEditor);
|
|
}, 10);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
if (ed.getParam('fullscreen_new_window')) {
|
|
t.fullscreenSettings = {
|
|
bookmark: ed.selection.getBookmark()
|
|
};
|
|
win = DOM.win.open(url + "/fullscreen.htm", "mceFullScreenPopup", "fullscreen=yes,menubar=no,toolbar=no,scrollbars=no,resizable=yes,left=0,top=0,width=" + screen.availWidth + ",height=" + screen.availHeight);
|
|
try {
|
|
win.resizeTo(screen.availWidth, screen.availHeight);
|
|
} catch (e) {
|
|
// Ignore
|
|
}
|
|
} else {
|
|
fullscreen_overflow = DOM.getStyle(DOM.doc.body, 'overflow', 1) || 'auto';
|
|
fullscreen_html_overflow = DOM.getStyle(de, 'overflow', 1);
|
|
vp = DOM.getViewPort();
|
|
fullscreen_scrollx = vp.x;
|
|
fullscreen_scrolly = vp.y;
|
|
|
|
// Fixes an Opera bug where the scrollbars doesn't reappear
|
|
if (tinymce.isOpera && fullscreen_overflow == 'visible')
|
|
fullscreen_overflow = 'auto';
|
|
|
|
// Fixes an IE bug where horizontal scrollbars would appear
|
|
if (tinymce.isIE && fullscreen_overflow == 'scroll')
|
|
fullscreen_overflow = 'auto';
|
|
|
|
// Fixes an IE bug where the scrollbars doesn't reappear
|
|
if (tinymce.isIE && (fullscreen_html_overflow == 'visible' || fullscreen_html_overflow == 'scroll'))
|
|
fullscreen_html_overflow = 'auto';
|
|
|
|
if (fullscreen_overflow == '0px')
|
|
fullscreen_overflow = '';
|
|
|
|
DOM.setStyle(DOM.doc.body, 'overflow', 'hidden');
|
|
de.style.overflow = 'hidden'; //Fix for IE6/7
|
|
vp = DOM.getViewPort();
|
|
DOM.win.scrollTo(0, 0);
|
|
|
|
if (tinymce.isIE)
|
|
vp.h -= 1;
|
|
|
|
// Use fixed position if it exists
|
|
if (tinymce.isIE6 || document.compatMode == 'BackCompat')
|
|
posCss = 'absolute;top:' + vp.y;
|
|
else
|
|
posCss = 'fixed;top:0';
|
|
|
|
n = DOM.add(DOM.doc.body, 'div', {
|
|
id : 'mce_fullscreen_container',
|
|
style : 'position:' + posCss + ';left:0;width:' + vp.w + 'px;height:' + vp.h + 'px;z-index:200000;'});
|
|
DOM.add(n, 'div', {id : 'mce_fullscreen'});
|
|
|
|
tinymce.each(ed.settings, function(v, n) {
|
|
s[n] = v;
|
|
});
|
|
|
|
s.id = 'mce_fullscreen';
|
|
s.width = n.clientWidth;
|
|
s.height = n.clientHeight - 15;
|
|
s.fullscreen_is_enabled = true;
|
|
s.fullscreen_editor_id = ed.id;
|
|
s.theme_advanced_resizing = false;
|
|
s.save_onsavecallback = function() {
|
|
ed.setContent(tinyMCE.get(s.id).getContent());
|
|
ed.execCommand('mceSave');
|
|
};
|
|
|
|
tinymce.each(ed.getParam('fullscreen_settings'), function(v, k) {
|
|
s[k] = v;
|
|
});
|
|
|
|
t.fullscreenSettings = {
|
|
bookmark: ed.selection.getBookmark(),
|
|
fullscreen_overflow: fullscreen_overflow,
|
|
fullscreen_html_overflow: fullscreen_html_overflow,
|
|
fullscreen_scrollx: fullscreen_scrollx,
|
|
fullscreen_scrolly: fullscreen_scrolly
|
|
};
|
|
|
|
if (s.theme_advanced_toolbar_location === 'external')
|
|
s.theme_advanced_toolbar_location = 'top';
|
|
|
|
tinyMCE.oldSettings = tinyMCE.settings; // Store old settings, the Editor constructor overwrites them
|
|
t.fullscreenEditor = new tinymce.Editor('mce_fullscreen', s);
|
|
t.fullscreenEditor.onInit.add(function() {
|
|
t.loadState(t.fullscreenEditor);
|
|
});
|
|
|
|
t.fullscreenEditor.render();
|
|
|
|
t.fullscreenElement = new tinymce.dom.Element('mce_fullscreen_container');
|
|
t.fullscreenElement.update();
|
|
//document.body.overflow = 'hidden';
|
|
|
|
t.resizeFunc = tinymce.dom.Event.add(DOM.win, 'resize', function() {
|
|
var vp = tinymce.DOM.getViewPort(), fed = t.fullscreenEditor, outerSize, innerSize;
|
|
|
|
// Get outer/inner size to get a delta size that can be used to calc the new iframe size
|
|
outerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('table')[0]);
|
|
innerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('iframe')[0]);
|
|
|
|
fed.theme.resizeTo(vp.w - outerSize.w + innerSize.w, vp.h - outerSize.h + innerSize.h);
|
|
});
|
|
}
|
|
});
|
|
|
|
// Register buttons
|
|
ed.addButton('fullscreen', {title : 'fullscreen.desc', cmd : 'mceFullScreen'});
|
|
|
|
ed.onNodeChange.add(function(ed, cm) {
|
|
cm.setActive('fullscreen', ed.getParam('fullscreen_is_enabled'));
|
|
});
|
|
|
|
// fullscreenEditor is a param here because in window mode we don't create it
|
|
t.loadState = function(fullscreenEditor) {
|
|
if (!(fullscreenEditor && t.fullscreenSettings)) {
|
|
throw "No fullscreen editor to load to";
|
|
}
|
|
|
|
transferState(ed, fullscreenEditor, t.fullscreenSettings.bookmark);
|
|
fullscreenEditor.focus();
|
|
|
|
};
|
|
|
|
// fullscreenEditor is a param here because in window mode we don't create it
|
|
t.saveState = function(fullscreenEditor) {
|
|
if (!(fullscreenEditor && t.fullscreenSettings)) {
|
|
throw "No fullscreen editor to restore from";
|
|
}
|
|
var settings = t.fullscreenSettings;
|
|
|
|
transferState(fullscreenEditor, ed, fullscreenEditor.selection.getBookmark());
|
|
|
|
// cleanup only required if window mode isn't used
|
|
if (!ed.getParam('fullscreen_new_window')) {
|
|
tinymce.dom.Event.remove(DOM.win, 'resize', t.resizeFunc);
|
|
delete t.resizeFunc;
|
|
|
|
DOM.remove('mce_fullscreen_container');
|
|
|
|
DOM.doc.documentElement.style.overflow = settings.fullscreen_html_overflow;
|
|
DOM.setStyle(DOM.doc.body, 'overflow', settings.fullscreen_overflow);
|
|
DOM.win.scrollTo(settings.fullscreen_scrollx, settings.fullscreen_scrolly);
|
|
}
|
|
tinyMCE.settings = tinyMCE.oldSettings; // Restore old settings
|
|
|
|
// clear variables
|
|
delete tinyMCE.oldSettings;
|
|
delete t.fullscreenEditor;
|
|
delete t.fullscreenElement;
|
|
delete t.fullscreenSettings;
|
|
|
|
// allow the fullscreen editor to be removed before restoring focus and selection
|
|
DOM.win.setTimeout(function() {
|
|
ed.selection.moveToBookmark(bookmark);
|
|
ed.focus();
|
|
}, 10);
|
|
};
|
|
},
|
|
|
|
getInfo : function() {
|
|
return {
|
|
longname : 'Fullscreen',
|
|
author : 'Moxiecode Systems AB',
|
|
authorurl : 'http://tinymce.moxiecode.com',
|
|
infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullscreen',
|
|
version : tinymce.majorVersion + "." + tinymce.minorVersion
|
|
};
|
|
}
|
|
});
|
|
|
|
// Register plugin
|
|
tinymce.PluginManager.add('fullscreen', tinymce.plugins.FullScreenPlugin);
|
|
})();
|