1 |
8 |
ahitrov@rambler.ru |
/** |
2 |
|
|
* $Id: editor_plugin_src.js 923 2008-09-09 16:45:29Z spocke $ |
3 |
|
|
* |
4 |
|
|
* @author Moxiecode |
5 |
|
|
* @copyright Copyright � 2004-2008, Moxiecode Systems AB, All rights reserved. |
6 |
|
|
*/ |
7 |
|
|
|
8 |
|
|
(function() { |
9 |
|
|
var DOM = tinymce.DOM; |
10 |
|
|
|
11 |
|
|
tinymce.create('tinymce.plugins.FullScreenPlugin', { |
12 |
|
|
init : function(ed, url) { |
13 |
|
|
var t = this, s = {}, vp; |
14 |
|
|
|
15 |
|
|
t.editor = ed; |
16 |
|
|
|
17 |
|
|
// Register commands |
18 |
|
|
ed.addCommand('mceFullScreen', function() { |
19 |
|
|
var win, de = DOM.doc.documentElement; |
20 |
|
|
|
21 |
|
|
if (ed.getParam('fullscreen_is_enabled')) { |
22 |
|
|
if (ed.getParam('fullscreen_new_window')) |
23 |
|
|
closeFullscreen(); // Call to close in new window |
24 |
|
|
else { |
25 |
|
|
DOM.win.setTimeout(function() { |
26 |
|
|
tinymce.dom.Event.remove(DOM.win, 'resize', t.resizeFunc); |
27 |
|
|
tinyMCE.get(ed.getParam('fullscreen_editor_id')).setContent(ed.getContent({format : 'raw'}), {format : 'raw'}); |
28 |
|
|
tinyMCE.remove(ed); |
29 |
|
|
DOM.remove('mce_fullscreen_container'); |
30 |
|
|
de.style.overflow = ed.getParam('fullscreen_html_overflow'); |
31 |
|
|
DOM.setStyle(DOM.doc.body, 'overflow', ed.getParam('fullscreen_overflow')); |
32 |
|
|
DOM.win.scrollTo(ed.getParam('fullscreen_scrollx'), ed.getParam('fullscreen_scrolly')); |
33 |
|
|
tinyMCE.settings = tinyMCE.oldSettings; // Restore old settings |
34 |
|
|
}, 10); |
35 |
|
|
} |
36 |
|
|
|
37 |
|
|
return; |
38 |
|
|
} |
39 |
|
|
|
40 |
|
|
if (ed.getParam('fullscreen_new_window')) { |
41 |
|
|
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); |
42 |
|
|
try { |
43 |
|
|
win.resizeTo(screen.availWidth, screen.availHeight); |
44 |
|
|
} catch (e) { |
45 |
|
|
// Ignore |
46 |
|
|
} |
47 |
|
|
} else { |
48 |
|
|
tinyMCE.oldSettings = tinyMCE.settings; // Store old settings |
49 |
|
|
s.fullscreen_overflow = DOM.getStyle(DOM.doc.body, 'overflow', 1) || 'auto'; |
50 |
|
|
s.fullscreen_html_overflow = DOM.getStyle(de, 'overflow', 1); |
51 |
|
|
vp = DOM.getViewPort(); |
52 |
|
|
s.fullscreen_scrollx = vp.x; |
53 |
|
|
s.fullscreen_scrolly = vp.y; |
54 |
|
|
|
55 |
|
|
// Fixes an Opera bug where the scrollbars doesn't reappear |
56 |
|
|
if (tinymce.isOpera && s.fullscreen_overflow == 'visible') |
57 |
|
|
s.fullscreen_overflow = 'auto'; |
58 |
|
|
|
59 |
|
|
// Fixes an IE bug where horizontal scrollbars would appear |
60 |
|
|
if (tinymce.isIE && s.fullscreen_overflow == 'scroll') |
61 |
|
|
s.fullscreen_overflow = 'auto'; |
62 |
|
|
|
63 |
|
|
// Fixes an IE bug where the scrollbars doesn't reappear |
64 |
|
|
if (tinymce.isIE && (s.fullscreen_html_overflow == 'visible' || s.fullscreen_html_overflow == 'scroll')) |
65 |
|
|
s.fullscreen_html_overflow = 'auto'; |
66 |
|
|
|
67 |
|
|
if (s.fullscreen_overflow == '0px') |
68 |
|
|
s.fullscreen_overflow = ''; |
69 |
|
|
|
70 |
|
|
DOM.setStyle(DOM.doc.body, 'overflow', 'hidden'); |
71 |
|
|
de.style.overflow = 'hidden'; //Fix for IE6/7 |
72 |
|
|
vp = DOM.getViewPort(); |
73 |
|
|
DOM.win.scrollTo(0, 0); |
74 |
|
|
|
75 |
|
|
if (tinymce.isIE) |
76 |
|
|
vp.h -= 1; |
77 |
|
|
|
78 |
|
|
n = DOM.add(DOM.doc.body, 'div', {id : 'mce_fullscreen_container', style : 'position:' + (tinymce.isIE6 || (tinymce.isIE && !DOM.boxModel) ? 'absolute' : 'fixed') + ';top:0;left:0;width:' + vp.w + 'px;height:' + vp.h + 'px;z-index:200000;'}); |
79 |
|
|
DOM.add(n, 'div', {id : 'mce_fullscreen'}); |
80 |
|
|
|
81 |
|
|
tinymce.each(ed.settings, function(v, n) { |
82 |
|
|
s[n] = v; |
83 |
|
|
}); |
84 |
|
|
|
85 |
|
|
s.id = 'mce_fullscreen'; |
86 |
|
|
s.width = n.clientWidth; |
87 |
|
|
s.height = n.clientHeight - 15; |
88 |
|
|
s.fullscreen_is_enabled = true; |
89 |
|
|
s.fullscreen_editor_id = ed.id; |
90 |
|
|
s.theme_advanced_resizing = false; |
91 |
|
|
s.save_onsavecallback = function() { |
92 |
|
|
ed.setContent(tinyMCE.get(s.id).getContent({format : 'raw'}), {format : 'raw'}); |
93 |
|
|
ed.execCommand('mceSave'); |
94 |
|
|
}; |
95 |
|
|
|
96 |
|
|
tinymce.each(ed.getParam('fullscreen_settings'), function(v, k) { |
97 |
|
|
s[k] = v; |
98 |
|
|
}); |
99 |
|
|
|
100 |
|
|
if (s.theme_advanced_toolbar_location === 'external') |
101 |
|
|
s.theme_advanced_toolbar_location = 'top'; |
102 |
|
|
|
103 |
|
|
t.fullscreenEditor = new tinymce.Editor('mce_fullscreen', s); |
104 |
|
|
t.fullscreenEditor.onInit.add(function() { |
105 |
|
|
t.fullscreenEditor.setContent(ed.getContent()); |
106 |
|
|
t.fullscreenEditor.focus(); |
107 |
|
|
}); |
108 |
|
|
|
109 |
|
|
t.fullscreenEditor.render(); |
110 |
|
|
tinyMCE.add(t.fullscreenEditor); |
111 |
|
|
|
112 |
|
|
t.fullscreenElement = new tinymce.dom.Element('mce_fullscreen_container'); |
113 |
|
|
t.fullscreenElement.update(); |
114 |
|
|
//document.body.overflow = 'hidden'; |
115 |
|
|
|
116 |
|
|
t.resizeFunc = tinymce.dom.Event.add(DOM.win, 'resize', function() { |
117 |
|
|
var vp = tinymce.DOM.getViewPort(); |
118 |
|
|
|
119 |
|
|
t.fullscreenEditor.theme.resizeTo(vp.w, vp.h); |
120 |
|
|
}); |
121 |
|
|
} |
122 |
|
|
}); |
123 |
|
|
|
124 |
|
|
// Register buttons |
125 |
|
|
ed.addButton('fullscreen', {title : 'fullscreen.desc', cmd : 'mceFullScreen'}); |
126 |
|
|
|
127 |
|
|
ed.onNodeChange.add(function(ed, cm) { |
128 |
|
|
cm.setActive('fullscreen', ed.getParam('fullscreen_is_enabled')); |
129 |
|
|
}); |
130 |
|
|
}, |
131 |
|
|
|
132 |
|
|
getInfo : function() { |
133 |
|
|
return { |
134 |
|
|
longname : 'Fullscreen', |
135 |
|
|
author : 'Moxiecode Systems AB', |
136 |
|
|
authorurl : 'http://tinymce.moxiecode.com', |
137 |
|
|
infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullscreen', |
138 |
|
|
version : tinymce.majorVersion + "." + tinymce.minorVersion |
139 |
|
|
}; |
140 |
|
|
} |
141 |
|
|
}); |
142 |
|
|
|
143 |
|
|
// Register plugin |
144 |
|
|
tinymce.PluginManager.add('fullscreen', tinymce.plugins.FullScreenPlugin); |
145 |
|
|
})(); |