4 * Copyright 2009, Moxiecode Systems AB
5 * Released under LGPL License.
7 * License: http://tinymce.moxiecode.com/license
8 * Contributing: http://tinymce.moxiecode.com/contributing
12 var DOM = tinymce.DOM;
14 tinymce.create('tinymce.plugins.FullScreenPlugin', {
15 init : function(ed, url) {
16 var t = this, s = {}, vp, posCss;
21 ed.addCommand('mceFullScreen', function() {
22 var win, de = DOM.doc.documentElement;
24 if (ed.getParam('fullscreen_is_enabled')) {
25 if (ed.getParam('fullscreen_new_window'))
26 closeFullscreen(); // Call to close in new window
28 DOM.win.setTimeout(function() {
29 tinymce.dom.Event.remove(DOM.win, 'resize', t.resizeFunc);
30 tinyMCE.get(ed.getParam('fullscreen_editor_id')).setContent(ed.getContent());
32 DOM.remove('mce_fullscreen_container');
33 de.style.overflow = ed.getParam('fullscreen_html_overflow');
34 DOM.setStyle(DOM.doc.body, 'overflow', ed.getParam('fullscreen_overflow'));
35 DOM.win.scrollTo(ed.getParam('fullscreen_scrollx'), ed.getParam('fullscreen_scrolly'));
36 tinyMCE.settings = tinyMCE.oldSettings; // Restore old settings
43 if (ed.getParam('fullscreen_new_window')) {
44 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);
46 win.resizeTo(screen.availWidth, screen.availHeight);
51 tinyMCE.oldSettings = tinyMCE.settings; // Store old settings
52 s.fullscreen_overflow = DOM.getStyle(DOM.doc.body, 'overflow', 1) || 'auto';
53 s.fullscreen_html_overflow = DOM.getStyle(de, 'overflow', 1);
54 vp = DOM.getViewPort();
55 s.fullscreen_scrollx = vp.x;
56 s.fullscreen_scrolly = vp.y;
58 // Fixes an Opera bug where the scrollbars doesn't reappear
59 if (tinymce.isOpera && s.fullscreen_overflow == 'visible')
60 s.fullscreen_overflow = 'auto';
62 // Fixes an IE bug where horizontal scrollbars would appear
63 if (tinymce.isIE && s.fullscreen_overflow == 'scroll')
64 s.fullscreen_overflow = 'auto';
66 // Fixes an IE bug where the scrollbars doesn't reappear
67 if (tinymce.isIE && (s.fullscreen_html_overflow == 'visible' || s.fullscreen_html_overflow == 'scroll'))
68 s.fullscreen_html_overflow = 'auto';
70 if (s.fullscreen_overflow == '0px')
71 s.fullscreen_overflow = '';
73 DOM.setStyle(DOM.doc.body, 'overflow', 'hidden');
74 de.style.overflow = 'hidden'; //Fix for IE6/7
75 vp = DOM.getViewPort();
76 DOM.win.scrollTo(0, 0);
81 // Use fixed position if it exists
82 if (tinymce.isIE6 || document.compatMode == 'BackCompat')
83 posCss = 'absolute;top:' + vp.y;
85 posCss = 'fixed;top:0';
87 n = DOM.add(DOM.doc.body, 'div', {
88 id : 'mce_fullscreen_container',
89 style : 'position:' + posCss + ';left:0;width:' + vp.w + 'px;height:' + vp.h + 'px;z-index:200000;'});
90 DOM.add(n, 'div', {id : 'mce_fullscreen'});
92 tinymce.each(ed.settings, function(v, n) {
96 s.id = 'mce_fullscreen';
97 s.width = n.clientWidth;
98 s.height = n.clientHeight - 15;
99 s.fullscreen_is_enabled = true;
100 s.fullscreen_editor_id = ed.id;
101 s.theme_advanced_resizing = false;
102 s.save_onsavecallback = function() {
103 ed.setContent(tinyMCE.get(s.id).getContent());
104 ed.execCommand('mceSave');
107 tinymce.each(ed.getParam('fullscreen_settings'), function(v, k) {
111 if (s.theme_advanced_toolbar_location === 'external')
112 s.theme_advanced_toolbar_location = 'top';
114 t.fullscreenEditor = new tinymce.Editor('mce_fullscreen', s);
115 t.fullscreenEditor.onInit.add(function() {
116 t.fullscreenEditor.setContent(ed.getContent());
117 t.fullscreenEditor.focus();
120 t.fullscreenEditor.render();
122 t.fullscreenElement = new tinymce.dom.Element('mce_fullscreen_container');
123 t.fullscreenElement.update();
124 //document.body.overflow = 'hidden';
126 t.resizeFunc = tinymce.dom.Event.add(DOM.win, 'resize', function() {
127 var vp = tinymce.DOM.getViewPort(), fed = t.fullscreenEditor, outerSize, innerSize;
129 // Get outer/inner size to get a delta size that can be used to calc the new iframe size
130 outerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('table')[0]);
131 innerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('iframe')[0]);
133 fed.theme.resizeTo(vp.w - outerSize.w + innerSize.w, vp.h - outerSize.h + innerSize.h);
139 ed.addButton('fullscreen', {title : 'fullscreen.desc', cmd : 'mceFullScreen'});
141 ed.onNodeChange.add(function(ed, cm) {
142 cm.setActive('fullscreen', ed.getParam('fullscreen_is_enabled'));
146 getInfo : function() {
148 longname : 'Fullscreen',
149 author : 'Moxiecode Systems AB',
150 authorurl : 'http://tinymce.moxiecode.com',
151 infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullscreen',
152 version : tinymce.majorVersion + "." + tinymce.minorVersion
158 tinymce.PluginManager.add('fullscreen', tinymce.plugins.FullScreenPlugin);