2 * $Id: editor_plugin_src.js 232 2007-03-05 17:00:27Z spocke $
\r
5 * @copyright Copyright © 2004-2007, Moxiecode Systems AB, All rights reserved.
\r
8 /* Import plugin specific language pack */
\r
9 tinyMCE.importPluginLanguagePack('fullpage');
\r
11 var TinyMCE_FullPagePlugin = {
\r
12 getInfo : function() {
\r
14 longname : 'Fullpage',
\r
15 author : 'Moxiecode Systems AB',
\r
16 authorurl : 'http://tinymce.moxiecode.com',
\r
17 infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullpage',
\r
18 version : tinyMCE.majorVersion + "." + tinyMCE.minorVersion
\r
22 getControlHTML : function(cn) {
\r
25 return tinyMCE.getButtonHTML(cn, 'lang_fullpage_desc', '{$pluginurl}/images/fullpage.gif', 'mceFullPageProperties');
\r
31 execCommand : function(editor_id, element, command, user_interface, value) {
\r
34 case "mceFullPageProperties":
\r
35 var template = new Array();
\r
37 template['file'] = '../../plugins/fullpage/fullpage.htm';
\r
38 template['width'] = 430;
\r
39 template['height'] = 485 + (tinyMCE.isOpera ? 5 : 0);
\r
41 template['width'] += tinyMCE.getLang('lang_fullpage_delta_width', 0);
\r
42 template['height'] += tinyMCE.getLang('lang_fullpage_delta_height', 0);
\r
44 tinyMCE.openWindow(template, {editor_id : editor_id, inline : "yes"});
\r
47 case "mceFullPageUpdate":
\r
48 TinyMCE_FullPagePlugin._addToHead(tinyMCE.getInstanceById(editor_id));
\r
52 // Pass to next handler in chain
\r
56 cleanup : function(type, content, inst) {
\r
58 case "insert_to_editor":
\r
59 var tmp = content.toLowerCase();
\r
60 var pos = tmp.indexOf('<body'), pos2;
\r
62 // Split page in header and body chunks
\r
64 pos = tmp.indexOf('>', pos);
\r
65 pos2 = tmp.lastIndexOf('</body>');
\r
66 inst.fullpageTopContent = content.substring(0, pos + 1);
\r
67 content = content.substring(pos + 1, pos2);
\r
68 // tinyMCE.debug(inst.fullpageTopContent, content);
\r
70 if (!inst.fullpageTopContent) {
\r
71 var docType = tinyMCE.getParam("fullpage_default_doctype", '<!DOCTYPE html PUBLIC "-/'+'/W3C//DTD XHTML 1.0 Transitional/'+'/EN" "http:/'+'/www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">');
\r
72 var enc = tinyMCE.getParam("fullpage_default_encoding", 'utf-8');
\r
73 var title = tinyMCE.getParam("fullpage_default_title", 'Untitled document');
\r
74 var lang = tinyMCE.getParam("fullpage_default_langcode", 'en');
\r
75 var pi = tinyMCE.getParam("fullpage_default_xml_pi", true);
\r
76 var ff = tinyMCE.getParam("fullpage_default_font_family", "");
\r
77 var fz = tinyMCE.getParam("fullpage_default_font_size", "");
\r
78 var ds = tinyMCE.getParam("fullpage_default_style", "");
\r
79 var dtc = tinyMCE.getParam("fullpage_default_text_color", "");
\r
82 title = title.replace(/&/g, '&');
\r
83 title = title.replace(/\"/g, '"');
\r
84 title = title.replace(/</g, '<');
\r
85 title = title.replace(/>/g, '>');
\r
89 // Make default chunk
\r
91 tmp += '<?xml version="1.0" encoding="' + enc + '"?>\n';
\r
93 tmp += docType + '\n';
\r
94 tmp += '<html xmlns="http:/'+'/www.w3.org/1999/xhtml" lang="' + lang + '" xml:lang="' + lang + '">\n';
\r
96 tmp += '\t<title>' + title + '</title>\n';
\r
97 tmp += '\t<meta http-equiv="Content-Type" content="text/html; charset=' + enc + '" />\n';
\r
101 if (ff != '' || fz != '') {
\r
108 tmp += 'font-family: ' + ff + ";";
\r
111 tmp += 'font-size: ' + fz + ";";
\r
117 tmp += ' text="' + dtc + '"';
\r
121 inst.fullpageTopContent = tmp;
\r
125 this._addToHead(inst);
\r
129 case "get_from_editor":
\r
130 if (inst.fullpageTopContent && !tinyMCE.getParam("fullpage_hide_in_source_view", false)) {
\r
131 content = content.replace(/(\s)?mce\_[a-z_]+\=[^\s>]+(\s|\>)/i, ''); // Remove internal stuff
\r
132 content = inst.fullpageTopContent + content + "\n</body>\n</html>";
\r
137 case "submit_content":
\r
138 if (inst.fullpageTopContent && tinyMCE.getParam("fullpage_hide_in_source_view", false))
\r
139 content = inst.fullpageTopContent + content + "\n</body>\n</html>";
\r
144 // Pass through to next handler in chain
\r
148 // Private plugin internal methods
\r
150 _addToHead : function(inst) {
\r
151 var doc = inst.getDoc();
\r
152 var head = doc.getElementsByTagName("head")[0];
\r
153 var body = doc.body;
\r
154 var h = inst.fullpageTopContent;
\r
155 var e = doc.createElement("body");
\r
156 var nl, i, le, tmp;
\r
158 // Remove stuff we don't want
\r
159 h = h.replace(/(\r|\n)/gi, '');
\r
160 h = h.replace(/<\?[^\>]*\>/gi, '');
\r
161 h = h.replace(/<\/?(!DOCTYPE|head|html)[^\>]*\>/gi, '');
\r
162 h = h.replace(/<script(.*?)<\/script>/gi, '');
\r
163 h = h.replace(/<title(.*?)<\/title>/gi, '');
\r
164 h = h.replace(/<(meta|base)[^>]*>/gi, '');
\r
166 // Make link and style elements into pre
\r
167 h = h.replace(/<link([^>]*)\/>/gi, '<pre mce_type="link" $1></pre>');
\r
168 //h = h.replace(/<style([^>]*)>(.*?)<\/style>/gi, '<pre mce_type="style" $1>$2</pre>');
\r
171 h = h.replace(/<body/gi, '<div mce_type="body"');
\r
174 // Now crapy MSIE can parse it
\r
177 // Reset all body attributes
\r
178 body.vLink = body.aLink = body.link = body.text = '';
\r
179 body.style.cssText = '';
\r
181 // Delete all old links
\r
182 nl = head.getElementsByTagName('link');
\r
183 for (i=0; i<nl.length; i++) {
\r
184 if (tinyMCE.getAttrib(nl[i], 'mce_head') == "true")
\r
185 nl[i].parentNode.removeChild(nl[i]);
\r
188 // Add link elements
\r
189 nl = e.getElementsByTagName('pre');
\r
190 for (i=0; i<nl.length; i++) {
\r
191 tmp = tinyMCE.getAttrib(nl[i], 'media');
\r
192 if (tinyMCE.getAttrib(nl[i], 'mce_type') == "link" && (tmp == "" || tmp == "screen" || tmp == "all") && tinyMCE.getAttrib(nl[i], 'rel') == "stylesheet") {
\r
193 le = doc.createElement("link");
\r
195 le.rel = "stylesheet";
\r
196 le.href = tinyMCE.getAttrib(nl[i], 'href');
\r
197 le.setAttribute("mce_head", "true");
\r
199 head.appendChild(le);
\r
203 // Add body attributes
\r
204 nl = e.getElementsByTagName('div');
\r
205 if (nl.length > 0) {
\r
206 body.style.cssText = tinyMCE.getAttrib(nl[0], 'style');
\r
208 if ((tmp = tinyMCE.getAttrib(nl[0], 'leftmargin')) != '' && body.style.marginLeft == '')
\r
209 body.style.marginLeft = tmp + "px";
\r
211 if ((tmp = tinyMCE.getAttrib(nl[0], 'rightmargin')) != '' && body.style.marginRight == '')
\r
212 body.style.marginRight = tmp + "px";
\r
214 if ((tmp = tinyMCE.getAttrib(nl[0], 'topmargin')) != '' && body.style.marginTop == '')
\r
215 body.style.marginTop = tmp + "px";
\r
217 if ((tmp = tinyMCE.getAttrib(nl[0], 'bottommargin')) != '' && body.style.marginBottom == '')
\r
218 body.style.marginBottom = tmp + "px";
\r
220 body.dir = tinyMCE.getAttrib(nl[0], 'dir');
\r
221 body.vLink = tinyMCE.getAttrib(nl[0], 'vlink');
\r
222 body.aLink = tinyMCE.getAttrib(nl[0], 'alink');
\r
223 body.link = tinyMCE.getAttrib(nl[0], 'link');
\r
224 body.text = tinyMCE.getAttrib(nl[0], 'text');
\r
226 if ((tmp = tinyMCE.getAttrib(nl[0], 'background')) != '')
\r
227 body.style.backgroundImage = "url('" + tmp + "')";
\r
229 if ((tmp = tinyMCE.getAttrib(nl[0], 'bgcolor')) != '')
\r
230 body.style.backgroundColor = tmp;
\r
235 tinyMCE.addPlugin("fullpage", TinyMCE_FullPagePlugin);
\r