bgneal@45: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> bgneal@45: <html xmlns="http://www.w3.org/1999/xhtml"> bgneal@45: <head> bgneal@45: <title></title> bgneal@45: <script type="text/javascript" src="../../tiny_mce.js"></script> bgneal@45: <script type="text/javascript"> bgneal@45: function patchCallback(settings, key) { bgneal@45: if (settings[key]) bgneal@45: settings[key] = "window.opener." + settings[key]; bgneal@45: } bgneal@45: bgneal@45: var settings = {}, paSe = window.opener.tinyMCE.activeEditor.settings, oeID = window.opener.tinyMCE.activeEditor.id; bgneal@45: bgneal@45: // Clone array bgneal@45: for (var n in paSe) bgneal@45: settings[n] = paSe[n]; bgneal@45: bgneal@45: // Override options for fullscreen bgneal@45: for (var n in paSe.fullscreen_settings) bgneal@45: settings[n] = paSe.fullscreen_settings[n]; bgneal@45: bgneal@45: // Patch callbacks, make them point to window.opener bgneal@45: patchCallback(settings, 'urlconverter_callback'); bgneal@45: patchCallback(settings, 'insertlink_callback'); bgneal@45: patchCallback(settings, 'insertimage_callback'); bgneal@45: patchCallback(settings, 'setupcontent_callback'); bgneal@45: patchCallback(settings, 'save_callback'); bgneal@45: patchCallback(settings, 'onchange_callback'); bgneal@45: patchCallback(settings, 'init_instance_callback'); bgneal@45: patchCallback(settings, 'file_browser_callback'); bgneal@45: patchCallback(settings, 'cleanup_callback'); bgneal@45: patchCallback(settings, 'execcommand_callback'); bgneal@45: patchCallback(settings, 'oninit'); bgneal@45: bgneal@45: // Set options bgneal@45: delete settings.id; bgneal@45: settings['mode'] = 'exact'; bgneal@45: settings['elements'] = 'fullscreenarea'; bgneal@45: settings['add_unload_trigger'] = false; bgneal@45: settings['ask'] = false; bgneal@45: settings['document_base_url'] = window.opener.tinyMCE.activeEditor.documentBaseURI.getURI(); bgneal@45: settings['fullscreen_is_enabled'] = true; bgneal@45: settings['fullscreen_editor_id'] = oeID; bgneal@45: settings['theme_advanced_resizing'] = false; bgneal@45: settings['strict_loading_mode'] = true; bgneal@45: bgneal@45: settings.save_onsavecallback = function() { bgneal@45: window.opener.tinyMCE.get(oeID).setContent(tinyMCE.get('fullscreenarea').getContent({format : 'raw'}), {format : 'raw'}); bgneal@45: window.opener.tinyMCE.get(oeID).execCommand('mceSave'); bgneal@45: window.close(); bgneal@45: }; bgneal@45: bgneal@45: function unloadHandler(e) { bgneal@45: moveContent(); bgneal@45: } bgneal@45: bgneal@45: function moveContent() { bgneal@45: window.opener.tinyMCE.get(oeID).setContent(tinyMCE.activeEditor.getContent()); bgneal@45: } bgneal@45: bgneal@45: function closeFullscreen() { bgneal@45: moveContent(); bgneal@45: window.close(); bgneal@45: } bgneal@45: bgneal@45: function doParentSubmit() { bgneal@45: moveContent(); bgneal@45: bgneal@45: if (window.opener.tinyMCE.selectedInstance.formElement.form) bgneal@45: window.opener.tinyMCE.selectedInstance.formElement.form.submit(); bgneal@45: bgneal@45: window.close(); bgneal@45: bgneal@45: return false; bgneal@45: } bgneal@45: bgneal@45: function render() { bgneal@45: var e = document.getElementById('fullscreenarea'), vp, ed, ow, oh, dom = tinymce.DOM; bgneal@45: bgneal@45: e.value = window.opener.tinyMCE.get(oeID).getContent(); bgneal@45: bgneal@45: vp = dom.getViewPort(); bgneal@45: settings.width = vp.w; bgneal@45: settings.height = vp.h - 15; bgneal@45: bgneal@45: tinymce.dom.Event.add(window, 'resize', function() { bgneal@45: var vp = dom.getViewPort(); bgneal@45: bgneal@45: tinyMCE.activeEditor.theme.resizeTo(vp.w, vp.h); bgneal@45: }); bgneal@45: bgneal@45: tinyMCE.init(settings); bgneal@45: } bgneal@45: bgneal@45: // Add onunload bgneal@45: tinymce.dom.Event.add(window, "beforeunload", unloadHandler); bgneal@45: </script> bgneal@45: </head> bgneal@45: <body style="margin:0;overflow:hidden;width:100%;height:100%" scrolling="no" scroll="no"> bgneal@45: <form onsubmit="doParentSubmit();"> bgneal@45: <textarea id="fullscreenarea" style="width:100%; height:100%"></textarea> bgneal@45: </form> bgneal@45: bgneal@45: <script type="text/javascript"> bgneal@45: render(); bgneal@45: </script> bgneal@45: bgneal@45: </body> bgneal@45: </html>