/static/scripts/tiny_mce/plugins/fullscreen/editor_plugin_src.js

http://n23.googlecode.com/ · JavaScript · 141 lines · 102 code · 26 blank · 13 comment · 16 complexity · 338b4b5028103d25a6c3183ec2e93fd5 MD5 · raw file

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