]> scripts.mit.edu Git - autoinstalls/wordpress.git/blob - wp-includes/js/tinymce/plugins/fullscreen/editor_plugin_src.js
WordPress 3.4
[autoinstalls/wordpress.git] / wp-includes / js / tinymce / plugins / fullscreen / editor_plugin_src.js
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());
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());
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 })();