2 * editor_plugin_src.js
\r
4 * Copyright 2009, Moxiecode Systems AB
\r
5 * Released under LGPL License.
\r
7 * License: http://tinymce.moxiecode.com/license
\r
8 * Contributing: http://tinymce.moxiecode.com/contributing
\r
12 var DOM = tinymce.DOM;
\r
14 // State Transfer function
\r
15 var transferState = function(oldEditor, newEditor, bookmark) {
\r
16 var transferColorButtonState = function(swapme) {
\r
17 var c = oldEditor.controlManager.get(swapme);
\r
18 var newC = newEditor.controlManager.get(swapme);
\r
21 newC.displayColor(c.value);
\r
26 transferColorButtonState('forecolor');
\r
27 transferColorButtonState('backcolor');
\r
28 newEditor.setContent(oldEditor.getContent({format : 'raw'}), {format : 'raw'});
\r
29 newEditor.selection.moveToBookmark(bookmark);
\r
31 if (oldEditor.plugins.spellchecker && newEditor.plugins.spellchecker) {
\r
32 newEditor.plugins.spellchecker.setLanguage(oldEditor.plugins.spellchecker.selectedLang);
\r
36 tinymce.create('tinymce.plugins.FullScreenPlugin', {
\r
37 init : function(ed, url) {
\r
38 var t = this, s = {}, de = DOM.doc.documentElement, vp, fullscreen_overflow, fullscreen_html_overflow, fullscreen_scrollx, fullscreen_scrolly, posCss, bookmark;
\r
40 // Register commands
\r
41 ed.addCommand('mceFullScreen', function() {
\r
44 if (ed.getParam('fullscreen_is_enabled')) {
\r
45 if (ed.getParam('fullscreen_new_window'))
\r
46 closeFullscreen(); // Call to close in fullscreen.htm
\r
48 DOM.win.setTimeout(function() {
\r
49 var fullscreenEditor = ed;
\r
51 // find the editor that opened this one, execute restore function there
\r
52 var originalEditor = tinyMCE.get(fullscreenEditor.getParam('fullscreen_editor_id'));
\r
53 originalEditor.plugins.fullscreen.saveState(fullscreenEditor);
\r
55 tinyMCE.remove(fullscreenEditor);
\r
62 if (ed.getParam('fullscreen_new_window')) {
\r
63 t.fullscreenSettings = {
\r
64 bookmark: ed.selection.getBookmark()
\r
66 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);
\r
68 win.resizeTo(screen.availWidth, screen.availHeight);
\r
73 fullscreen_overflow = DOM.getStyle(DOM.doc.body, 'overflow', 1) || 'auto';
\r
74 fullscreen_html_overflow = DOM.getStyle(de, 'overflow', 1);
\r
75 vp = DOM.getViewPort();
\r
76 fullscreen_scrollx = vp.x;
\r
77 fullscreen_scrolly = vp.y;
\r
79 // Fixes an Opera bug where the scrollbars doesn't reappear
\r
80 if (tinymce.isOpera && fullscreen_overflow == 'visible')
\r
81 fullscreen_overflow = 'auto';
\r
83 // Fixes an IE bug where horizontal scrollbars would appear
\r
84 if (tinymce.isIE && fullscreen_overflow == 'scroll')
\r
85 fullscreen_overflow = 'auto';
\r
87 // Fixes an IE bug where the scrollbars doesn't reappear
\r
88 if (tinymce.isIE && (fullscreen_html_overflow == 'visible' || fullscreen_html_overflow == 'scroll'))
\r
89 fullscreen_html_overflow = 'auto';
\r
91 if (fullscreen_overflow == '0px')
\r
92 fullscreen_overflow = '';
\r
94 DOM.setStyle(DOM.doc.body, 'overflow', 'hidden');
\r
95 de.style.overflow = 'hidden'; //Fix for IE6/7
\r
96 vp = DOM.getViewPort();
\r
97 DOM.win.scrollTo(0, 0);
\r
102 // Use fixed position if it exists
\r
103 if (tinymce.isIE6 || document.compatMode == 'BackCompat')
\r
104 posCss = 'absolute;top:' + vp.y;
\r
106 posCss = 'fixed;top:0';
\r
108 n = DOM.add(DOM.doc.body, 'div', {
\r
109 id : 'mce_fullscreen_container',
\r
110 style : 'position:' + posCss + ';left:0;width:' + vp.w + 'px;height:' + vp.h + 'px;z-index:200000;'});
\r
111 DOM.add(n, 'div', {id : 'mce_fullscreen'});
\r
113 tinymce.each(ed.settings, function(v, n) {
\r
117 s.id = 'mce_fullscreen';
\r
118 s.width = n.clientWidth;
\r
119 s.height = n.clientHeight - 15;
\r
120 s.fullscreen_is_enabled = true;
\r
121 s.fullscreen_editor_id = ed.id;
\r
122 s.theme_advanced_resizing = false;
\r
123 s.save_onsavecallback = function() {
\r
124 ed.setContent(tinyMCE.get(s.id).getContent());
\r
125 ed.execCommand('mceSave');
\r
128 tinymce.each(ed.getParam('fullscreen_settings'), function(v, k) {
\r
132 t.fullscreenSettings = {
\r
133 bookmark: ed.selection.getBookmark(),
\r
134 fullscreen_overflow: fullscreen_overflow,
\r
135 fullscreen_html_overflow: fullscreen_html_overflow,
\r
136 fullscreen_scrollx: fullscreen_scrollx,
\r
137 fullscreen_scrolly: fullscreen_scrolly
\r
140 if (s.theme_advanced_toolbar_location === 'external')
\r
141 s.theme_advanced_toolbar_location = 'top';
\r
143 tinyMCE.oldSettings = tinyMCE.settings; // Store old settings, the Editor constructor overwrites them
\r
144 t.fullscreenEditor = new tinymce.Editor('mce_fullscreen', s);
\r
145 t.fullscreenEditor.onInit.add(function() {
\r
146 t.loadState(t.fullscreenEditor);
\r
149 t.fullscreenEditor.render();
\r
151 t.fullscreenElement = new tinymce.dom.Element('mce_fullscreen_container');
\r
152 t.fullscreenElement.update();
\r
153 //document.body.overflow = 'hidden';
\r
155 t.resizeFunc = tinymce.dom.Event.add(DOM.win, 'resize', function() {
\r
156 var vp = tinymce.DOM.getViewPort(), fed = t.fullscreenEditor, outerSize, innerSize;
\r
158 // Get outer/inner size to get a delta size that can be used to calc the new iframe size
\r
159 outerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('table')[0]);
\r
160 innerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('iframe')[0]);
\r
162 fed.theme.resizeTo(vp.w - outerSize.w + innerSize.w, vp.h - outerSize.h + innerSize.h);
\r
167 // Register buttons
\r
168 ed.addButton('fullscreen', {title : 'fullscreen.desc', cmd : 'mceFullScreen'});
\r
170 ed.onNodeChange.add(function(ed, cm) {
\r
171 cm.setActive('fullscreen', ed.getParam('fullscreen_is_enabled'));
\r
174 // fullscreenEditor is a param here because in window mode we don't create it
\r
175 t.loadState = function(fullscreenEditor) {
\r
176 if (!(fullscreenEditor && t.fullscreenSettings)) {
\r
177 throw "No fullscreen editor to load to";
\r
180 transferState(ed, fullscreenEditor, t.fullscreenSettings.bookmark);
\r
181 fullscreenEditor.focus();
\r
185 // fullscreenEditor is a param here because in window mode we don't create it
\r
186 t.saveState = function(fullscreenEditor) {
\r
187 if (!(fullscreenEditor && t.fullscreenSettings)) {
\r
188 throw "No fullscreen editor to restore from";
\r
190 var settings = t.fullscreenSettings;
\r
192 transferState(fullscreenEditor, ed, fullscreenEditor.selection.getBookmark());
\r
194 // cleanup only required if window mode isn't used
\r
195 if (!ed.getParam('fullscreen_new_window')) {
\r
196 tinymce.dom.Event.remove(DOM.win, 'resize', t.resizeFunc);
\r
197 delete t.resizeFunc;
\r
199 DOM.remove('mce_fullscreen_container');
\r
201 DOM.doc.documentElement.style.overflow = settings.fullscreen_html_overflow;
\r
202 DOM.setStyle(DOM.doc.body, 'overflow', settings.fullscreen_overflow);
\r
203 DOM.win.scrollTo(settings.fullscreen_scrollx, settings.fullscreen_scrolly);
\r
205 tinyMCE.settings = tinyMCE.oldSettings; // Restore old settings
\r
208 delete tinyMCE.oldSettings;
\r
209 delete t.fullscreenEditor;
\r
210 delete t.fullscreenElement;
\r
211 delete t.fullscreenSettings;
\r
213 // allow the fullscreen editor to be removed before restoring focus and selection
\r
214 DOM.win.setTimeout(function() {
\r
215 ed.selection.moveToBookmark(bookmark);
\r
221 getInfo : function() {
\r
223 longname : 'Fullscreen',
\r
224 author : 'Moxiecode Systems AB',
\r
225 authorurl : 'http://tinymce.moxiecode.com',
\r
226 infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullscreen',
\r
227 version : tinymce.majorVersion + "." + tinymce.minorVersion
\r
233 tinymce.PluginManager.add('fullscreen', tinymce.plugins.FullScreenPlugin);
\r