~ubuntu-branches/debian/jessie/wordpress/jessie

« back to all changes in this revision

Viewing changes to wp-includes/js/tinymce/plugins/fullscreen/editor_plugin_src.js

  • Committer: Package Import Robot
  • Author(s): Craig Small
  • Date: 2014-04-17 20:56:19 UTC
  • mfrom: (1.2.35)
  • Revision ID: package-import@ubuntu.com-20140417205619-nurbet6eho4yvwfv
Tags: 3.9+dfsg-1
* New upstream release
* 3.9 seems to handle different locations for plugins so the
  plugin directory handling patches have been cut back.

Show diffs side-by-side

added added

removed removed

Lines of Context:
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
 
        // State Transfer function
15
 
        var transferState = function(oldEditor, newEditor, bookmark) {
16
 
                var transferColorButtonState = function(swapme) {
17
 
                        var c = oldEditor.controlManager.get(swapme);
18
 
                        var newC = newEditor.controlManager.get(swapme);
19
 
 
20
 
                        if (c && newC) {
21
 
                                newC.displayColor(c.value);
22
 
                        }
23
 
 
24
 
                };
25
 
 
26
 
                transferColorButtonState('forecolor');
27
 
                transferColorButtonState('backcolor');
28
 
                newEditor.setContent(oldEditor.getContent({format : 'raw'}), {format : 'raw'});
29
 
                newEditor.selection.moveToBookmark(bookmark);
30
 
 
31
 
                if (oldEditor.plugins.spellchecker && newEditor.plugins.spellchecker) {
32
 
                        newEditor.plugins.spellchecker.setLanguage(oldEditor.plugins.spellchecker.selectedLang);
33
 
                }
34
 
        };
35
 
 
36
 
        tinymce.create('tinymce.plugins.FullScreenPlugin', {
37
 
                init : function(ed, url) {
38
 
                        var t = this, s = {}, de = DOM.doc.documentElement, vp, fullscreen_overflow, fullscreen_html_overflow, fullscreen_scrollx, fullscreen_scrolly, posCss, bookmark;
39
 
 
40
 
                        // Register commands
41
 
                        ed.addCommand('mceFullScreen', function() {
42
 
                                var win, oed;
43
 
 
44
 
                                if (ed.getParam('fullscreen_is_enabled')) {
45
 
                                        if (ed.getParam('fullscreen_new_window'))
46
 
                                                closeFullscreen(); // Call to close in fullscreen.htm
47
 
                                        else {
48
 
                                                DOM.win.setTimeout(function() {
49
 
                                                        var fullscreenEditor = ed;
50
 
 
51
 
                                                        // find the editor that opened this one, execute restore function there
52
 
                                                        var originalEditor = tinyMCE.get(fullscreenEditor.getParam('fullscreen_editor_id'));
53
 
                                                        originalEditor.plugins.fullscreen.saveState(fullscreenEditor);
54
 
 
55
 
                                                        tinyMCE.remove(fullscreenEditor);
56
 
                                                }, 10);
57
 
                                        }
58
 
 
59
 
                                        return;
60
 
                                }
61
 
 
62
 
                                if (ed.getParam('fullscreen_new_window')) {
63
 
                                        t.fullscreenSettings = {
64
 
                                                bookmark: ed.selection.getBookmark()
65
 
                                        };
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);
67
 
                                        try {
68
 
                                                win.resizeTo(screen.availWidth, screen.availHeight);
69
 
                                        } catch (e) {
70
 
                                                // Ignore
71
 
                                        }
72
 
                                } else {
73
 
                                        fullscreen_overflow = DOM.getStyle(DOM.doc.body, 'overflow', 1) || 'auto';
74
 
                                        fullscreen_html_overflow = DOM.getStyle(de, 'overflow', 1);
75
 
                                        vp = DOM.getViewPort();
76
 
                                        fullscreen_scrollx = vp.x;
77
 
                                        fullscreen_scrolly = vp.y;
78
 
 
79
 
                                        // Fixes an Opera bug where the scrollbars doesn't reappear
80
 
                                        if (tinymce.isOpera && fullscreen_overflow == 'visible')
81
 
                                                fullscreen_overflow = 'auto';
82
 
 
83
 
                                        // Fixes an IE bug where horizontal scrollbars would appear
84
 
                                        if (tinymce.isIE && fullscreen_overflow == 'scroll')
85
 
                                                fullscreen_overflow = 'auto';
86
 
 
87
 
                                        // Fixes an IE bug where the scrollbars doesn't reappear
88
 
                                        if (tinymce.isIE && (fullscreen_html_overflow == 'visible' || fullscreen_html_overflow == 'scroll'))
89
 
                                                fullscreen_html_overflow = 'auto';
90
 
 
91
 
                                        if (fullscreen_overflow == '0px')
92
 
                                                fullscreen_overflow = '';
93
 
 
94
 
                                        DOM.setStyle(DOM.doc.body, 'overflow', 'hidden');
95
 
                                        de.style.overflow = 'hidden'; //Fix for IE6/7
96
 
                                        vp = DOM.getViewPort();
97
 
                                        DOM.win.scrollTo(0, 0);
98
 
 
99
 
                                        if (tinymce.isIE)
100
 
                                                vp.h -= 1;
101
 
 
102
 
                                        // Use fixed position if it exists
103
 
                                        if (tinymce.isIE6 || document.compatMode == 'BackCompat')
104
 
                                                posCss = 'absolute;top:' + vp.y;
105
 
                                        else
106
 
                                                posCss = 'fixed;top:0';
107
 
 
108
 
                                        n = DOM.add(DOM.doc.body, 'div', {
109
 
                                                id : 'mce_fullscreen_container',
110
 
                                                style : 'position:' + posCss + ';left:0;width:' + vp.w + 'px;height:' + vp.h + 'px;z-index:200000;'});
111
 
                                        DOM.add(n, 'div', {id : 'mce_fullscreen'});
112
 
 
113
 
                                        tinymce.each(ed.settings, function(v, n) {
114
 
                                                s[n] = v;
115
 
                                        });
116
 
 
117
 
                                        s.id = 'mce_fullscreen';
118
 
                                        s.width = n.clientWidth;
119
 
                                        s.height = n.clientHeight - 15;
120
 
                                        s.fullscreen_is_enabled = true;
121
 
                                        s.fullscreen_editor_id = ed.id;
122
 
                                        s.theme_advanced_resizing = false;
123
 
                                        s.save_onsavecallback = function() {
124
 
                                                ed.setContent(tinyMCE.get(s.id).getContent());
125
 
                                                ed.execCommand('mceSave');
126
 
                                        };
127
 
 
128
 
                                        tinymce.each(ed.getParam('fullscreen_settings'), function(v, k) {
129
 
                                                s[k] = v;
130
 
                                        });
131
 
 
132
 
                                        t.fullscreenSettings = {
133
 
                                                bookmark: ed.selection.getBookmark(),
134
 
                                                fullscreen_overflow: fullscreen_overflow,
135
 
                                                fullscreen_html_overflow: fullscreen_html_overflow,
136
 
                                                fullscreen_scrollx: fullscreen_scrollx,
137
 
                                                fullscreen_scrolly: fullscreen_scrolly
138
 
                                        };
139
 
 
140
 
                                        if (s.theme_advanced_toolbar_location === 'external')
141
 
                                                s.theme_advanced_toolbar_location = 'top';
142
 
 
143
 
                                        tinyMCE.oldSettings = tinyMCE.settings; // Store old settings, the Editor constructor overwrites them
144
 
                                        t.fullscreenEditor = new tinymce.Editor('mce_fullscreen', s);
145
 
                                        t.fullscreenEditor.onInit.add(function() {
146
 
                                                t.loadState(t.fullscreenEditor);
147
 
                                        });
148
 
 
149
 
                                        t.fullscreenEditor.render();
150
 
 
151
 
                                        t.fullscreenElement = new tinymce.dom.Element('mce_fullscreen_container');
152
 
                                        t.fullscreenElement.update();
153
 
                                        //document.body.overflow = 'hidden';
154
 
 
155
 
                                        t.resizeFunc = tinymce.dom.Event.add(DOM.win, 'resize', function() {
156
 
                                                var vp = tinymce.DOM.getViewPort(), fed = t.fullscreenEditor, outerSize, innerSize;
157
 
 
158
 
                                                // Get outer/inner size to get a delta size that can be used to calc the new iframe size
159
 
                                                outerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('table')[0]);
160
 
                                                innerSize = fed.dom.getSize(fed.getContainer().getElementsByTagName('iframe')[0]);
161
 
 
162
 
                                                fed.theme.resizeTo(vp.w - outerSize.w + innerSize.w, vp.h - outerSize.h + innerSize.h);
163
 
                                        });
164
 
                                }
165
 
                        });
166
 
 
167
 
                        // Register buttons
168
 
                        ed.addButton('fullscreen', {title : 'fullscreen.desc', cmd : 'mceFullScreen'});
169
 
 
170
 
                        ed.onNodeChange.add(function(ed, cm) {
171
 
                                cm.setActive('fullscreen', ed.getParam('fullscreen_is_enabled'));
172
 
                        });
173
 
 
174
 
                        // fullscreenEditor is a param here because in window mode we don't create it
175
 
                        t.loadState = function(fullscreenEditor) {
176
 
                                if (!(fullscreenEditor && t.fullscreenSettings)) {
177
 
                                        throw "No fullscreen editor to load to";
178
 
                                }
179
 
 
180
 
                                transferState(ed, fullscreenEditor, t.fullscreenSettings.bookmark);
181
 
                                fullscreenEditor.focus();
182
 
 
183
 
                        };
184
 
 
185
 
                        // fullscreenEditor is a param here because in window mode we don't create it
186
 
                        t.saveState = function(fullscreenEditor) {
187
 
                                if (!(fullscreenEditor && t.fullscreenSettings)) {
188
 
                                        throw "No fullscreen editor to restore from";
189
 
                                }
190
 
                                var settings = t.fullscreenSettings;
191
 
 
192
 
                                transferState(fullscreenEditor, ed, fullscreenEditor.selection.getBookmark());
193
 
 
194
 
                                // cleanup only required if window mode isn't used
195
 
                                if (!ed.getParam('fullscreen_new_window')) {
196
 
                                        tinymce.dom.Event.remove(DOM.win, 'resize', t.resizeFunc);
197
 
                                        delete t.resizeFunc;
198
 
 
199
 
                                        DOM.remove('mce_fullscreen_container');
200
 
 
201
 
                                        DOM.doc.documentElement.style.overflow = settings.fullscreen_html_overflow;
202
 
                                        DOM.setStyle(DOM.doc.body, 'overflow', settings.fullscreen_overflow);
203
 
                                        DOM.win.scrollTo(settings.fullscreen_scrollx, settings.fullscreen_scrolly);
204
 
                                }
205
 
                                tinyMCE.settings = tinyMCE.oldSettings; // Restore old settings
206
 
 
207
 
                                // clear variables
208
 
                                delete tinyMCE.oldSettings;
209
 
                                delete t.fullscreenEditor;
210
 
                                delete t.fullscreenElement;
211
 
                                delete t.fullscreenSettings;
212
 
 
213
 
                                // allow the fullscreen editor to be removed before restoring focus and selection
214
 
                                DOM.win.setTimeout(function() {
215
 
                                        ed.selection.moveToBookmark(bookmark);
216
 
                                        ed.focus();
217
 
                                }, 10);
218
 
                        };
219
 
                },
220
 
 
221
 
                getInfo : function() {
222
 
                        return {
223
 
                                longname : 'Fullscreen',
224
 
                                author : 'Moxiecode Systems AB',
225
 
                                authorurl : 'http://tinymce.moxiecode.com',
226
 
                                infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullscreen',
227
 
                                version : tinymce.majorVersion + "." + tinymce.minorVersion
228
 
                        };
229
 
                }
230
 
        });
231
 
 
232
 
        // Register plugin
233
 
        tinymce.PluginManager.add('fullscreen', tinymce.plugins.FullScreenPlugin);
234
 
})();