1 | /** |
---|
2 | * editor_plugin_src.js |
---|
3 | * |
---|
4 | * Copyright 2009, Moxiecode Systems AB |
---|
5 | * Released under LGPL License. |
---|
6 | * |
---|
7 | * License: http://tinymce.moxiecode.com/license |
---|
8 | * Contributing: http://tinymce.moxiecode.com/contributing |
---|
9 | */ |
---|
10 | |
---|
11 | (function() { |
---|
12 | var DOM = tinymce.DOM; |
---|
13 | |
---|
14 | tinymce.create('tinymce.plugins.FullScreenPlugin', { |
---|
15 | init : function(ed, url) { |
---|
16 | var t = this, s = {}, vp, posCss; |
---|
17 | |
---|
18 | t.editor = ed; |
---|
19 | |
---|
20 | // Register commands |
---|
21 | ed.addCommand('mceFullScreen', function() { |
---|
22 | var win, de = DOM.doc.documentElement; |
---|
23 | |
---|
24 | if (ed.getParam('fullscreen_is_enabled')) { |
---|
25 | if (ed.getParam('fullscreen_new_window')) |
---|
26 | closeFullscreen(); // Call to close in new window |
---|
27 | else { |
---|
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({format : 'raw'}), {format : 'raw'}); |
---|
31 | tinyMCE.remove(ed); |
---|
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 |
---|
37 | }, 10); |
---|
38 | } |
---|
39 | |
---|
40 | return; |
---|
41 | } |
---|
42 | |
---|
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); |
---|
45 | try { |
---|
46 | win.resizeTo(screen.availWidth, screen.availHeight); |
---|
47 | } catch (e) { |
---|
48 | // Ignore |
---|
49 | } |
---|
50 | } else { |
---|
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; |
---|
57 | |
---|
58 | // Fixes an Opera bug where the scrollbars doesn't reappear |
---|
59 | if (tinymce.isOpera && s.fullscreen_overflow == 'visible') |
---|
60 | s.fullscreen_overflow = 'auto'; |
---|
61 | |
---|
62 | // Fixes an IE bug where horizontal scrollbars would appear |
---|
63 | if (tinymce.isIE && s.fullscreen_overflow == 'scroll') |
---|
64 | s.fullscreen_overflow = 'auto'; |
---|
65 | |
---|
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'; |
---|
69 | |
---|
70 | if (s.fullscreen_overflow == '0px') |
---|
71 | s.fullscreen_overflow = ''; |
---|
72 | |
---|
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); |
---|
77 | |
---|
78 | if (tinymce.isIE) |
---|
79 | vp.h -= 1; |
---|
80 | |
---|
81 | // Use fixed position if it exists |
---|
82 | if (tinymce.isIE6) |
---|
83 | posCss = 'absolute;top:' + vp.y; |
---|
84 | else |
---|
85 | posCss = 'fixed;top:0'; |
---|
86 | |
---|
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'}); |
---|
91 | |
---|
92 | tinymce.each(ed.settings, function(v, n) { |
---|
93 | s[n] = v; |
---|
94 | }); |
---|
95 | |
---|
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({format : 'raw'}), {format : 'raw'}); |
---|
104 | ed.execCommand('mceSave'); |
---|
105 | }; |
---|
106 | |
---|
107 | tinymce.each(ed.getParam('fullscreen_settings'), function(v, k) { |
---|
108 | s[k] = v; |
---|
109 | }); |
---|
110 | |
---|
111 | if (s.theme_advanced_toolbar_location === 'external') |
---|
112 | s.theme_advanced_toolbar_location = 'top'; |
---|
113 | |
---|
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(); |
---|
118 | }); |
---|
119 | |
---|
120 | t.fullscreenEditor.render(); |
---|
121 | |
---|
122 | t.fullscreenElement = new tinymce.dom.Element('mce_fullscreen_container'); |
---|
123 | t.fullscreenElement.update(); |
---|
124 | //document.body.overflow = 'hidden'; |
---|
125 | |
---|
126 | t.resizeFunc = tinymce.dom.Event.add(DOM.win, 'resize', function() { |
---|
127 | var vp = tinymce.DOM.getViewPort(), fed = t.fullscreenEditor, outerSize, innerSize; |
---|
128 | |
---|
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().firstChild); |
---|
131 | innerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('iframe')[0]); |
---|
132 | |
---|
133 | fed.theme.resizeTo(vp.w - outerSize.w + innerSize.w, vp.h - outerSize.h + innerSize.h); |
---|
134 | }); |
---|
135 | } |
---|
136 | }); |
---|
137 | |
---|
138 | // Register buttons |
---|
139 | ed.addButton('fullscreen', {title : 'fullscreen.desc', cmd : 'mceFullScreen'}); |
---|
140 | |
---|
141 | ed.onNodeChange.add(function(ed, cm) { |
---|
142 | cm.setActive('fullscreen', ed.getParam('fullscreen_is_enabled')); |
---|
143 | }); |
---|
144 | }, |
---|
145 | |
---|
146 | getInfo : function() { |
---|
147 | return { |
---|
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 |
---|
153 | }; |
---|
154 | } |
---|
155 | }); |
---|
156 | |
---|
157 | // Register plugin |
---|
158 | tinymce.PluginManager.add('fullscreen', tinymce.plugins.FullScreenPlugin); |
---|
159 | })(); |
---|