Third pass at adding key files
							
								
								
									
										154
									
								
								site/forum.slowtwitch.com/www/static/fileman/tinymce/langs/en.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,154 @@ | ||||
| tinyMCE.addI18n({en:{ | ||||
| common:{ | ||||
| edit_confirm:"Do you want to use the WYSIWYG mode for this textarea?", | ||||
| apply:"Apply", | ||||
| insert:"Insert", | ||||
| update:"Update", | ||||
| cancel:"Cancel", | ||||
| close:"Close", | ||||
| browse:"Browse", | ||||
| class_name:"Class", | ||||
| not_set:"-- Not set --", | ||||
| clipboard_msg:"Copy/Cut/Paste is not available in Mozilla and Firefox.\nDo you want more information about this issue?", | ||||
| clipboard_no_support:"Currently not supported by your browser, use keyboard shortcuts instead.", | ||||
| popup_blocked:"Sorry, but we have noticed that your popup-blocker has disabled a window that provides application functionality. You will need to disable popup blocking on this site in order to fully utilize this tool.", | ||||
| invalid_data:"Error: Invalid values entered, these are marked in red.", | ||||
| more_colors:"More colors" | ||||
| }, | ||||
| contextmenu:{ | ||||
| align:"Alignment", | ||||
| left:"Left", | ||||
| center:"Center", | ||||
| right:"Right", | ||||
| full:"Full" | ||||
| }, | ||||
| insertdatetime:{ | ||||
| date_fmt:"%Y-%m-%d", | ||||
| time_fmt:"%H:%M:%S", | ||||
| insertdate_desc:"Insert date", | ||||
| inserttime_desc:"Insert time", | ||||
| months_long:"January,February,March,April,May,June,July,August,September,October,November,December", | ||||
| months_short:"Jan,Feb,Mar,Apr,May,Jun,Jul,Aug,Sep,Oct,Nov,Dec", | ||||
| day_long:"Sunday,Monday,Tuesday,Wednesday,Thursday,Friday,Saturday,Sunday", | ||||
| day_short:"Sun,Mon,Tue,Wed,Thu,Fri,Sat,Sun" | ||||
| }, | ||||
| print:{ | ||||
| print_desc:"Print" | ||||
| }, | ||||
| preview:{ | ||||
| preview_desc:"Preview" | ||||
| }, | ||||
| directionality:{ | ||||
| ltr_desc:"Direction left to right", | ||||
| rtl_desc:"Direction right to left" | ||||
| }, | ||||
| layer:{ | ||||
| insertlayer_desc:"Insert new layer", | ||||
| forward_desc:"Move forward", | ||||
| backward_desc:"Move backward", | ||||
| absolute_desc:"Toggle absolute positioning", | ||||
| content:"New layer..." | ||||
| }, | ||||
| save:{ | ||||
| save_desc:"Save", | ||||
| cancel_desc:"Cancel all changes" | ||||
| }, | ||||
| nonbreaking:{ | ||||
| nonbreaking_desc:"Insert non-breaking space character" | ||||
| }, | ||||
| iespell:{ | ||||
| iespell_desc:"Run spell checking", | ||||
| download:"ieSpell not detected. Do you want to install it now?" | ||||
| }, | ||||
| advhr:{ | ||||
| advhr_desc:"Horizontal rule" | ||||
| }, | ||||
| emotions:{ | ||||
| emotions_desc:"Emotions" | ||||
| }, | ||||
| searchreplace:{ | ||||
| search_desc:"Find", | ||||
| replace_desc:"Find/Replace" | ||||
| }, | ||||
| advimage:{ | ||||
| image_desc:"Insert/edit image" | ||||
| }, | ||||
| advlink:{ | ||||
| link_desc:"Insert/edit link" | ||||
| }, | ||||
| xhtmlxtras:{ | ||||
| cite_desc:"Citation", | ||||
| abbr_desc:"Abbreviation", | ||||
| acronym_desc:"Acronym", | ||||
| del_desc:"Deletion", | ||||
| ins_desc:"Insertion", | ||||
| attribs_desc:"Insert/Edit Attributes" | ||||
| }, | ||||
| style:{ | ||||
| desc:"Edit CSS Style" | ||||
| }, | ||||
| paste:{ | ||||
| paste_text_desc:"Paste as Plain Text", | ||||
| paste_word_desc:"Paste from Word", | ||||
| selectall_desc:"Select All" | ||||
| }, | ||||
| paste_dlg:{ | ||||
| text_title:"Use CTRL+V on your keyboard to paste the text into the window.", | ||||
| text_linebreaks:"Keep linebreaks", | ||||
| word_title:"Use CTRL+V on your keyboard to paste the text into the window." | ||||
| }, | ||||
| table:{ | ||||
| desc:"Inserts a new table", | ||||
| row_before_desc:"Insert row before", | ||||
| row_after_desc:"Insert row after", | ||||
| delete_row_desc:"Delete row", | ||||
| col_before_desc:"Insert column before", | ||||
| col_after_desc:"Insert column after", | ||||
| delete_col_desc:"Remove column", | ||||
| split_cells_desc:"Split merged table cells", | ||||
| merge_cells_desc:"Merge table cells", | ||||
| row_desc:"Table row properties", | ||||
| cell_desc:"Table cell properties", | ||||
| props_desc:"Table properties", | ||||
| paste_row_before_desc:"Paste table row before", | ||||
| paste_row_after_desc:"Paste table row after", | ||||
| cut_row_desc:"Cut table row", | ||||
| copy_row_desc:"Copy table row", | ||||
| del:"Delete table", | ||||
| row:"Row", | ||||
| col:"Column", | ||||
| cell:"Cell" | ||||
| }, | ||||
| autosave:{ | ||||
| unload_msg:"The changes you made will be lost if you navigate away from this page." | ||||
| }, | ||||
| fullscreen:{ | ||||
| desc:"Toggle fullscreen mode" | ||||
| }, | ||||
| media:{ | ||||
| desc:"Insert / edit embedded media", | ||||
| edit:"Edit embedded media" | ||||
| }, | ||||
| fullpage:{ | ||||
| desc:"Document properties" | ||||
| }, | ||||
| template:{ | ||||
| desc:"Insert predefined template content" | ||||
| }, | ||||
| visualchars:{ | ||||
| desc:"Visual control characters on/off." | ||||
| }, | ||||
| spellchecker:{ | ||||
| desc:"Toggle spellchecker", | ||||
| menu:"Spellchecker settings", | ||||
| ignore_word:"Ignore word", | ||||
| ignore_words:"Ignore all", | ||||
| langs:"Languages", | ||||
| wait:"Please wait...", | ||||
| sug:"Suggestions", | ||||
| no_sug:"No suggestions", | ||||
| no_mpell:"No misspellings found." | ||||
| }, | ||||
| pagebreak:{ | ||||
| desc:"Insert page break." | ||||
| }}}); | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.AdvancedHRPlugin',{init:function(ed,url){ed.addCommand('mceAdvancedHr',function(){ed.windowManager.open({file:url+'/rule.htm',width:250+parseInt(ed.getLang('advhr.delta_width',0)),height:160+parseInt(ed.getLang('advhr.delta_height',0)),inline:1},{plugin_url:url});});ed.addButton('advhr',{title:'advhr.advhr_desc',cmd:'mceAdvancedHr'});ed.onNodeChange.add(function(ed,cm,n){cm.setActive('advhr',n.nodeName=='HR');});ed.onClick.add(function(ed,e){e=e.target;if(e.nodeName==='HR')ed.selection.select(e);});},getInfo:function(){return{longname:'Advanced HR',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/advhr',version:tinymce.majorVersion+"."+tinymce.minorVersion};}});tinymce.PluginManager.add('advhr',tinymce.plugins.AdvancedHRPlugin);})(); | ||||
| @@ -0,0 +1,54 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:25 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.AdvancedHRPlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceAdvancedHr', function() { | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/rule.htm', | ||||
| 					width : 250 + parseInt(ed.getLang('advhr.delta_width', 0)), | ||||
| 					height : 160 + parseInt(ed.getLang('advhr.delta_height', 0)), | ||||
| 					inline : 1 | ||||
| 				}, { | ||||
| 					plugin_url : url | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('advhr', { | ||||
| 				title : 'advhr.advhr_desc', | ||||
| 				cmd : 'mceAdvancedHr' | ||||
| 			}); | ||||
|  | ||||
| 			ed.onNodeChange.add(function(ed, cm, n) { | ||||
| 				cm.setActive('advhr', n.nodeName == 'HR'); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onClick.add(function(ed, e) { | ||||
| 				e = e.target; | ||||
|  | ||||
| 				if (e.nodeName === 'HR') | ||||
| 					ed.selection.select(e); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Advanced HR', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/advhr', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('advhr', tinymce.plugins.AdvancedHRPlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,43 @@ | ||||
| var AdvHRDialog = { | ||||
| 	init : function(ed) { | ||||
| 		var dom = ed.dom, f = document.forms[0], n = ed.selection.getNode(), w; | ||||
|  | ||||
| 		w = dom.getAttrib(n, 'width'); | ||||
| 		f.width.value = w ? parseInt(w) : (dom.getStyle('width') || ''); | ||||
| 		f.size.value = dom.getAttrib(n, 'size') || parseInt(dom.getStyle('height')) || ''; | ||||
| 		f.noshade.checked = !!dom.getAttrib(n, 'noshade') || !!dom.getStyle('border-width'); | ||||
| 		selectByValue(f, 'width2', w.indexOf('%') != -1 ? '%' : 'px'); | ||||
| 	}, | ||||
|  | ||||
| 	update : function() { | ||||
| 		var ed = tinyMCEPopup.editor, h, f = document.forms[0], st = ''; | ||||
|  | ||||
| 		h = '<hr'; | ||||
|  | ||||
| 		if (f.size.value) { | ||||
| 			h += ' size="' + f.size.value + '"'; | ||||
| 			st += ' height:' + f.size.value + 'px;'; | ||||
| 		} | ||||
|  | ||||
| 		if (f.width.value) { | ||||
| 			h += ' width="' + f.width.value + (f.width2.value == '%' ? '%' : '') + '"'; | ||||
| 			st += ' width:' + f.width.value + (f.width2.value == '%' ? '%' : 'px') + ';'; | ||||
| 		} | ||||
|  | ||||
| 		if (f.noshade.checked) { | ||||
| 			h += ' noshade="noshade"'; | ||||
| 			st += ' border-width: 1px; border-style: solid; border-color: #CCCCCC; color: #ffffff;'; | ||||
| 		} | ||||
|  | ||||
| 		if (ed.settings.inline_styles) | ||||
| 			h += ' style="' + tinymce.trim(st) + '"'; | ||||
|  | ||||
| 		h += ' />'; | ||||
|  | ||||
| 		ed.execCommand("mceInsertContent", false, h); | ||||
| 		tinyMCEPopup.close(); | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| tinyMCEPopup.requireLangPack(); | ||||
| tinyMCEPopup.onInit.add(AdvHRDialog.init, AdvHRDialog); | ||||
| @@ -0,0 +1,5 @@ | ||||
| tinyMCE.addI18n('en.advhr_dlg',{ | ||||
| width:"Width", | ||||
| size:"Height", | ||||
| noshade:"No shadow" | ||||
| }); | ||||
| @@ -0,0 +1,63 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advhr.advhr_desc}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/rule.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<link href="css/advhr.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body> | ||||
| <form onsubmit="AdvHRDialog.update();return false;" action="#"> | ||||
| 	<div class="tabs"> | ||||
| 		<ul> | ||||
| 			<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#advhr.advhr_desc}</a></span></li> | ||||
| 		</ul> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="panel_wrapper"> | ||||
| 		<div id="general_panel" class="panel current"> | ||||
| 			<table border="0" cellpadding="4" cellspacing="0"> | ||||
|                     <tr> | ||||
|                         <td><label for="width">{#advhr_dlg.width}</label></td> | ||||
|                         <td nowrap="nowrap"> | ||||
|                             <input id="width" name="width" type="text" value="" class="mceFocus" /> | ||||
|                             <select name="width2" id="width2"> | ||||
|                                 <option value="">px</option> | ||||
|                                 <option value="%">%</option> | ||||
|                             </select> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <tr> | ||||
|                         <td><label for="size">{#advhr_dlg.size}</label></td> | ||||
|                         <td><select id="size" name="size"> | ||||
|                             <option value="">Normal</option> | ||||
|                             <option value="1">1</option> | ||||
|                             <option value="2">2</option> | ||||
|                             <option value="3">3</option> | ||||
|                             <option value="4">4</option> | ||||
|                             <option value="5">5</option> | ||||
|                         </select></td> | ||||
|                     </tr> | ||||
|                     <tr> | ||||
|                         <td><label for="noshade">{#advhr_dlg.noshade}</label></td> | ||||
|                         <td><input type="checkbox" name="noshade" id="noshade" class="radio" /></td> | ||||
|                     </tr> | ||||
|             </table> | ||||
| 		</div> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right"> | ||||
| 			<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.AdvancedImagePlugin',{init:function(ed,url){ed.addCommand('mceAdvImage',function(){if(ed.dom.getAttrib(ed.selection.getNode(),'class').indexOf('mceItem')!=-1)return;ed.windowManager.open({file:url+'/image.htm',width:480+parseInt(ed.getLang('advimage.delta_width',0)),height:385+parseInt(ed.getLang('advimage.delta_height',0)),inline:1},{plugin_url:url});});ed.addButton('image',{title:'advimage.image_desc',cmd:'mceAdvImage'});},getInfo:function(){return{longname:'Advanced image',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/advimage',version:tinymce.majorVersion+"."+tinymce.minorVersion};}});tinymce.PluginManager.add('advimage',tinymce.plugins.AdvancedImagePlugin);})(); | ||||
| @@ -0,0 +1,47 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:25 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.AdvancedImagePlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceAdvImage', function() { | ||||
| 				// Internal image object like a flash placeholder | ||||
| 				if (ed.dom.getAttrib(ed.selection.getNode(), 'class').indexOf('mceItem') != -1) | ||||
| 					return; | ||||
|  | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/image.htm', | ||||
| 					width : 480 + parseInt(ed.getLang('advimage.delta_width', 0)), | ||||
| 					height : 385 + parseInt(ed.getLang('advimage.delta_height', 0)), | ||||
| 					inline : 1 | ||||
| 				}, { | ||||
| 					plugin_url : url | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('image', { | ||||
| 				title : 'advimage.image_desc', | ||||
| 				cmd : 'mceAdvImage' | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Advanced image', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/advimage', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('advimage', tinymce.plugins.AdvancedImagePlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,238 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advimage_dlg.dialog_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/validate.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||||
| 	<script type="text/javascript" src="js/image.js"></script> | ||||
| 	<link href="css/advimage.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="advimage" style="display: none"> | ||||
|     <form onsubmit="ImageDialog.insert();return false;" action="#">  | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#advimage_dlg.tab_general}</a></span></li> | ||||
| 				<li id="appearance_tab"><span><a href="javascript:mcTabs.displayTab('appearance_tab','appearance_panel');" onmousedown="return false;">{#advimage_dlg.tab_appearance}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#advimage_dlg.tab_advanced}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 						<legend>{#advimage_dlg.general}</legend> | ||||
|  | ||||
| 						<table class="properties"> | ||||
| 							<tr> | ||||
| 								<td class="column1"><label id="srclabel" for="src">{#advimage_dlg.src}</label></td> | ||||
| 								<td colspan="2"><table border="0" cellspacing="0" cellpadding="0"> | ||||
| 									<tr>  | ||||
| 									  <td><input name="src" type="text" id="src" value="" class="mceFocus" onchange="ImageDialog.showPreviewImage(this.value);" /></td>  | ||||
| 									  <td id="srcbrowsercontainer"> </td> | ||||
| 									</tr> | ||||
| 								  </table></td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><label for="src_list">{#advimage_dlg.image_list}</label></td> | ||||
| 								<td><select id="src_list" name="src_list" onchange="document.getElementById('src').value=this.options[this.selectedIndex].value;document.getElementById('alt').value=this.options[this.selectedIndex].text;document.getElementById('title').value=this.options[this.selectedIndex].text;ImageDialog.showPreviewImage(this.options[this.selectedIndex].value);"></select></td> | ||||
| 							</tr> | ||||
| 							<tr>  | ||||
| 								<td class="column1"><label id="altlabel" for="alt">{#advimage_dlg.alt}</label></td>  | ||||
| 								<td colspan="2"><input id="alt" name="alt" type="text" value="" /></td>  | ||||
| 							</tr>  | ||||
| 							<tr>  | ||||
| 								<td class="column1"><label id="titlelabel" for="title">{#advimage_dlg.title}</label></td>  | ||||
| 								<td colspan="2"><input id="title" name="title" type="text" value="" /></td>  | ||||
| 							</tr> | ||||
| 						</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#advimage_dlg.preview}</legend> | ||||
| 					<div id="prev"></div> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="appearance_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#advimage_dlg.tab_appearance}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr>  | ||||
| 							<td class="column1"><label id="alignlabel" for="align">{#advimage_dlg.align}</label></td>  | ||||
| 							<td><select id="align" name="align" onchange="ImageDialog.updateStyle('align');ImageDialog.changeAppearance();">  | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="baseline">{#advimage_dlg.align_baseline}</option> | ||||
| 									<option value="top">{#advimage_dlg.align_top}</option> | ||||
| 									<option value="middle">{#advimage_dlg.align_middle}</option> | ||||
| 									<option value="bottom">{#advimage_dlg.align_bottom}</option> | ||||
| 									<option value="text-top">{#advimage_dlg.align_texttop}</option> | ||||
| 									<option value="text-bottom">{#advimage_dlg.align_textbottom}</option> | ||||
| 									<option value="left">{#advimage_dlg.align_left}</option> | ||||
| 									<option value="right">{#advimage_dlg.align_right}</option> | ||||
| 								</select>  | ||||
| 							</td> | ||||
| 							<td rowspan="6" valign="top"> | ||||
| 								<div class="alignPreview"> | ||||
| 									<img id="alignSampleImg" src="img/sample.gif" alt="{#advimage_dlg.example_img}" /> | ||||
| 									Lorem ipsum, Dolor sit amet, consectetuer adipiscing loreum ipsum edipiscing elit, sed diam | ||||
| 									nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.Loreum ipsum | ||||
| 									edipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam | ||||
| 									erat volutpat. | ||||
| 								</div> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="widthlabel" for="width">{#advimage_dlg.dimensions}</label></td> | ||||
| 							<td nowrap="nowrap"> | ||||
| 								<input name="width" type="text" id="width" value="" size="5" maxlength="5" class="size" onchange="ImageDialog.changeHeight();" /> x  | ||||
| 								<input name="height" type="text" id="height" value="" size="5" maxlength="5" class="size" onchange="ImageDialog.changeWidth();" /> px | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td> </td> | ||||
| 							<td><table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="constrain" type="checkbox" name="constrain" class="checkbox" /></td> | ||||
| 										<td><label id="constrainlabel" for="constrain">{#advimage_dlg.constrain_proportions}</label></td> | ||||
| 									</tr> | ||||
| 								</table></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="vspacelabel" for="vspace">{#advimage_dlg.vspace}</label></td>  | ||||
| 							<td><input name="vspace" type="text" id="vspace" value="" size="3" maxlength="3" class="number" onchange="ImageDialog.updateStyle('vspace');ImageDialog.changeAppearance();" onblur="ImageDialog.updateStyle('vspace');ImageDialog.changeAppearance();" /> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr>  | ||||
| 							<td class="column1"><label id="hspacelabel" for="hspace">{#advimage_dlg.hspace}</label></td>  | ||||
| 							<td><input name="hspace" type="text" id="hspace" value="" size="3" maxlength="3" class="number" onchange="ImageDialog.updateStyle('hspace');ImageDialog.changeAppearance();" onblur="ImageDialog.updateStyle('hspace');ImageDialog.changeAppearance();" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="borderlabel" for="border">{#advimage_dlg.border}</label></td>  | ||||
| 							<td><input id="border" name="border" type="text" value="" size="3" maxlength="3" class="number" onchange="ImageDialog.updateStyle('border');ImageDialog.changeAppearance();" onblur="ImageDialog.updateStyle('border');ImageDialog.changeAppearance();" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="class_list">{#class_name}</label></td> | ||||
| 							<td colspan="2"><select id="class_list" name="class_list" class="mceEditableSelect"></select></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="stylelabel" for="style">{#advimage_dlg.style}</label></td>  | ||||
| 							<td colspan="2"><input id="style" name="style" type="text" value="" onchange="ImageDialog.changeAppearance();" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<!-- <tr> | ||||
| 							<td class="column1"><label id="classeslabel" for="classes">{#advimage_dlg.classes}</label></td>  | ||||
| 							<td colspan="2"><input id="classes" name="classes" type="text" value="" onchange="selectByValue(this.form,'classlist',this.value,true);" /></td>  | ||||
| 						</tr> --> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#advimage_dlg.swap_image}</legend> | ||||
|  | ||||
| 					<input type="checkbox" id="onmousemovecheck" name="onmousemovecheck" class="checkbox" onclick="ImageDialog.setSwapImage(this.checked);" /> | ||||
| 					<label id="onmousemovechecklabel" for="onmousemovecheck">{#advimage_dlg.alt_image}</label> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0" width="100%"> | ||||
| 							<tr> | ||||
| 								<td class="column1"><label id="onmouseoversrclabel" for="onmouseoversrc">{#advimage_dlg.mouseover}</label></td>  | ||||
| 								<td><table border="0" cellspacing="0" cellpadding="0">  | ||||
| 									<tr>  | ||||
| 									  <td><input id="onmouseoversrc" name="onmouseoversrc" type="text" value="" /></td>  | ||||
| 									  <td id="onmouseoversrccontainer"> </td> | ||||
| 									</tr> | ||||
| 								  </table></td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><label for="over_list">{#advimage_dlg.image_list}</label></td> | ||||
| 								<td><select id="over_list" name="over_list" onchange="document.getElementById('onmouseoversrc').value=this.options[this.selectedIndex].value;"></select></td> | ||||
| 							</tr> | ||||
| 							<tr>  | ||||
| 								<td class="column1"><label id="onmouseoutsrclabel" for="onmouseoutsrc">{#advimage_dlg.mouseout}</label></td>  | ||||
| 								<td class="column2"><table border="0" cellspacing="0" cellpadding="0">  | ||||
| 									<tr>  | ||||
| 									  <td><input id="onmouseoutsrc" name="onmouseoutsrc" type="text" value="" /></td>  | ||||
| 									  <td id="onmouseoutsrccontainer"> </td> | ||||
| 									</tr>  | ||||
| 								  </table></td>  | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><label for="out_list">{#advimage_dlg.image_list}</label></td> | ||||
| 								<td><select id="out_list" name="out_list" onchange="document.getElementById('onmouseoutsrc').value=this.options[this.selectedIndex].value;"></select></td> | ||||
| 							</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#advimage_dlg.misc}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="idlabel" for="id">{#advimage_dlg.id}</label></td>  | ||||
| 							<td><input id="id" name="id" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="dirlabel" for="dir">{#advimage_dlg.langdir}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="dir" name="dir" onchange="ImageDialog.changeAppearance();">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="ltr">{#advimage_dlg.ltr}</option>  | ||||
| 										<option value="rtl">{#advimage_dlg.rtl}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="langlabel" for="lang">{#advimage_dlg.langcode}</label></td>  | ||||
| 							<td> | ||||
| 								<input id="lang" name="lang" type="text" value="" /> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="usemaplabel" for="usemap">{#advimage_dlg.map}</label></td>  | ||||
| 							<td> | ||||
| 								<input id="usemap" name="usemap" type="text" value="" /> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="longdesclabel" for="longdesc">{#advimage_dlg.long_desc}</label></td> | ||||
| 							<td><table border="0" cellspacing="0" cellpadding="0"> | ||||
| 									<tr> | ||||
| 									  <td><input id="longdesc" name="longdesc" type="text" value="" /></td> | ||||
| 									  <td id="longdesccontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table></td>  | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
|     </form> | ||||
| </body>  | ||||
| </html>  | ||||
| After Width: | Height: | Size: 1.6 KiB | 
| @@ -0,0 +1,441 @@ | ||||
| var ImageDialog = { | ||||
| 	preInit : function() { | ||||
| 		var url; | ||||
|  | ||||
| 		tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| 		if (url = tinyMCEPopup.getParam("external_image_list_url")) | ||||
| 			document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>'); | ||||
| 	}, | ||||
|  | ||||
| 	init : function(ed) { | ||||
| 		var f = document.forms[0], nl = f.elements, ed = tinyMCEPopup.editor, dom = ed.dom, n = ed.selection.getNode(); | ||||
|  | ||||
| 		tinyMCEPopup.resizeToInnerSize(); | ||||
| 		this.fillClassList('class_list'); | ||||
| 		this.fillFileList('src_list', 'tinyMCEImageList'); | ||||
| 		this.fillFileList('over_list', 'tinyMCEImageList'); | ||||
| 		this.fillFileList('out_list', 'tinyMCEImageList'); | ||||
| 		TinyMCE_EditableSelects.init(); | ||||
|  | ||||
| 		if (n.nodeName == 'IMG') { | ||||
| 			nl.src.value = dom.getAttrib(n, 'src'); | ||||
| 			nl.width.value = dom.getAttrib(n, 'width'); | ||||
| 			nl.height.value = dom.getAttrib(n, 'height'); | ||||
| 			nl.alt.value = dom.getAttrib(n, 'alt'); | ||||
| 			nl.title.value = dom.getAttrib(n, 'title'); | ||||
| 			nl.vspace.value = this.getAttrib(n, 'vspace'); | ||||
| 			nl.hspace.value = this.getAttrib(n, 'hspace'); | ||||
| 			nl.border.value = this.getAttrib(n, 'border'); | ||||
| 			selectByValue(f, 'align', this.getAttrib(n, 'align')); | ||||
| 			selectByValue(f, 'class_list', dom.getAttrib(n, 'class'), true, true); | ||||
| 			nl.style.value = dom.getAttrib(n, 'style'); | ||||
| 			nl.id.value = dom.getAttrib(n, 'id'); | ||||
| 			nl.dir.value = dom.getAttrib(n, 'dir'); | ||||
| 			nl.lang.value = dom.getAttrib(n, 'lang'); | ||||
| 			nl.usemap.value = dom.getAttrib(n, 'usemap'); | ||||
| 			nl.longdesc.value = dom.getAttrib(n, 'longdesc'); | ||||
| 			nl.insert.value = ed.getLang('update'); | ||||
|  | ||||
| 			if (/^\s*this.src\s*=\s*\'([^\']+)\';?\s*$/.test(dom.getAttrib(n, 'onmouseover'))) | ||||
| 				nl.onmouseoversrc.value = dom.getAttrib(n, 'onmouseover').replace(/^\s*this.src\s*=\s*\'([^\']+)\';?\s*$/, '$1'); | ||||
|  | ||||
| 			if (/^\s*this.src\s*=\s*\'([^\']+)\';?\s*$/.test(dom.getAttrib(n, 'onmouseout'))) | ||||
| 				nl.onmouseoutsrc.value = dom.getAttrib(n, 'onmouseout').replace(/^\s*this.src\s*=\s*\'([^\']+)\';?\s*$/, '$1'); | ||||
|  | ||||
| 			if (ed.settings.inline_styles) { | ||||
| 				// Move attribs to styles | ||||
| 				if (dom.getAttrib(n, 'align')) | ||||
| 					this.updateStyle('align'); | ||||
|  | ||||
| 				if (dom.getAttrib(n, 'hspace')) | ||||
| 					this.updateStyle('hspace'); | ||||
|  | ||||
| 				if (dom.getAttrib(n, 'border')) | ||||
| 					this.updateStyle('border'); | ||||
|  | ||||
| 				if (dom.getAttrib(n, 'vspace')) | ||||
| 					this.updateStyle('vspace'); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// Setup browse button | ||||
| 		document.getElementById('srcbrowsercontainer').innerHTML = getBrowserHTML('srcbrowser','src','image','theme_advanced_image'); | ||||
| 		if (isVisible('srcbrowser')) | ||||
| 			document.getElementById('src').style.width = '260px'; | ||||
|  | ||||
| 		// Setup browse button | ||||
| 		document.getElementById('onmouseoversrccontainer').innerHTML = getBrowserHTML('overbrowser','onmouseoversrc','image','theme_advanced_image'); | ||||
| 		if (isVisible('overbrowser')) | ||||
| 			document.getElementById('onmouseoversrc').style.width = '260px'; | ||||
|  | ||||
| 		// Setup browse button | ||||
| 		document.getElementById('onmouseoutsrccontainer').innerHTML = getBrowserHTML('outbrowser','onmouseoutsrc','image','theme_advanced_image'); | ||||
| 		if (isVisible('outbrowser')) | ||||
| 			document.getElementById('onmouseoutsrc').style.width = '260px'; | ||||
|  | ||||
| 		// If option enabled default contrain proportions to checked | ||||
| 		if (ed.getParam("advimage_constrain_proportions", true)) | ||||
| 			f.constrain.checked = true; | ||||
|  | ||||
| 		// Check swap image if valid data | ||||
| 		if (nl.onmouseoversrc.value || nl.onmouseoutsrc.value) | ||||
| 			this.setSwapImage(true); | ||||
| 		else | ||||
| 			this.setSwapImage(false); | ||||
|  | ||||
| 		this.changeAppearance(); | ||||
| 		this.showPreviewImage(nl.src.value, 1); | ||||
| 	}, | ||||
|  | ||||
| 	insert : function(file, title) { | ||||
| 		var ed = tinyMCEPopup.editor, t = this, f = document.forms[0]; | ||||
|  | ||||
| 		if (f.src.value === '') { | ||||
| 			if (ed.selection.getNode().nodeName == 'IMG') { | ||||
| 				ed.dom.remove(ed.selection.getNode()); | ||||
| 				ed.execCommand('mceRepaint'); | ||||
| 			} | ||||
|  | ||||
| 			tinyMCEPopup.close(); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (tinyMCEPopup.getParam("accessibility_warnings", 1)) { | ||||
| 			if (!f.alt.value) { | ||||
| 				tinyMCEPopup.editor.windowManager.confirm(tinyMCEPopup.getLang('advimage_dlg.missing_alt'), function(s) { | ||||
| 					if (s) | ||||
| 						t.insertAndClose(); | ||||
| 				}); | ||||
|  | ||||
| 				return; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		t.insertAndClose(); | ||||
| 	}, | ||||
|  | ||||
| 	insertAndClose : function() { | ||||
| 		var ed = tinyMCEPopup.editor, f = document.forms[0], nl = f.elements, v, args = {}, el; | ||||
|  | ||||
| 		tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 		// Fixes crash in Safari | ||||
| 		if (tinymce.isWebKit) | ||||
| 			ed.getWin().focus(); | ||||
|  | ||||
| 		if (!ed.settings.inline_styles) { | ||||
| 			args = { | ||||
| 				vspace : nl.vspace.value, | ||||
| 				hspace : nl.hspace.value, | ||||
| 				border : nl.border.value, | ||||
| 				align : getSelectValue(f, 'align') | ||||
| 			}; | ||||
| 		} else { | ||||
| 			// Remove deprecated values | ||||
| 			args = { | ||||
| 				vspace : '', | ||||
| 				hspace : '', | ||||
| 				border : '', | ||||
| 				align : '' | ||||
| 			}; | ||||
| 		} | ||||
|  | ||||
| 		tinymce.extend(args, { | ||||
| 			src : nl.src.value, | ||||
| 			width : nl.width.value, | ||||
| 			height : nl.height.value, | ||||
| 			alt : nl.alt.value, | ||||
| 			title : nl.title.value, | ||||
| 			'class' : getSelectValue(f, 'class_list'), | ||||
| 			style : nl.style.value, | ||||
| 			id : nl.id.value, | ||||
| 			dir : nl.dir.value, | ||||
| 			lang : nl.lang.value, | ||||
| 			usemap : nl.usemap.value, | ||||
| 			longdesc : nl.longdesc.value | ||||
| 		}); | ||||
|  | ||||
| 		args.onmouseover = args.onmouseout = ''; | ||||
|  | ||||
| 		if (f.onmousemovecheck.checked) { | ||||
| 			if (nl.onmouseoversrc.value) | ||||
| 				args.onmouseover = "this.src='" + nl.onmouseoversrc.value + "';"; | ||||
|  | ||||
| 			if (nl.onmouseoutsrc.value) | ||||
| 				args.onmouseout = "this.src='" + nl.onmouseoutsrc.value + "';"; | ||||
| 		} | ||||
|  | ||||
| 		el = ed.selection.getNode(); | ||||
|  | ||||
| 		if (el && el.nodeName == 'IMG') { | ||||
| 			ed.dom.setAttribs(el, args); | ||||
| 		} else { | ||||
| 			ed.execCommand('mceInsertContent', false, '<img id="__mce_tmp" />', {skip_undo : 1}); | ||||
| 			ed.dom.setAttribs('__mce_tmp', args); | ||||
| 			ed.dom.setAttrib('__mce_tmp', 'id', ''); | ||||
| 			ed.undoManager.add(); | ||||
| 		} | ||||
|  | ||||
| 		tinyMCEPopup.close(); | ||||
| 	}, | ||||
|  | ||||
| 	getAttrib : function(e, at) { | ||||
| 		var ed = tinyMCEPopup.editor, dom = ed.dom, v, v2; | ||||
|  | ||||
| 		if (ed.settings.inline_styles) { | ||||
| 			switch (at) { | ||||
| 				case 'align': | ||||
| 					if (v = dom.getStyle(e, 'float')) | ||||
| 						return v; | ||||
|  | ||||
| 					if (v = dom.getStyle(e, 'vertical-align')) | ||||
| 						return v; | ||||
|  | ||||
| 					break; | ||||
|  | ||||
| 				case 'hspace': | ||||
| 					v = dom.getStyle(e, 'margin-left') | ||||
| 					v2 = dom.getStyle(e, 'margin-right'); | ||||
|  | ||||
| 					if (v && v == v2) | ||||
| 						return parseInt(v.replace(/[^0-9]/g, '')); | ||||
|  | ||||
| 					break; | ||||
|  | ||||
| 				case 'vspace': | ||||
| 					v = dom.getStyle(e, 'margin-top') | ||||
| 					v2 = dom.getStyle(e, 'margin-bottom'); | ||||
| 					if (v && v == v2) | ||||
| 						return parseInt(v.replace(/[^0-9]/g, '')); | ||||
|  | ||||
| 					break; | ||||
|  | ||||
| 				case 'border': | ||||
| 					v = 0; | ||||
|  | ||||
| 					tinymce.each(['top', 'right', 'bottom', 'left'], function(sv) { | ||||
| 						sv = dom.getStyle(e, 'border-' + sv + '-width'); | ||||
|  | ||||
| 						// False or not the same as prev | ||||
| 						if (!sv || (sv != v && v !== 0)) { | ||||
| 							v = 0; | ||||
| 							return false; | ||||
| 						} | ||||
|  | ||||
| 						if (sv) | ||||
| 							v = sv; | ||||
| 					}); | ||||
|  | ||||
| 					if (v) | ||||
| 						return parseInt(v.replace(/[^0-9]/g, '')); | ||||
|  | ||||
| 					break; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if (v = dom.getAttrib(e, at)) | ||||
| 			return v; | ||||
|  | ||||
| 		return ''; | ||||
| 	}, | ||||
|  | ||||
| 	setSwapImage : function(st) { | ||||
| 		var f = document.forms[0]; | ||||
|  | ||||
| 		f.onmousemovecheck.checked = st; | ||||
| 		setBrowserDisabled('overbrowser', !st); | ||||
| 		setBrowserDisabled('outbrowser', !st); | ||||
|  | ||||
| 		if (f.over_list) | ||||
| 			f.over_list.disabled = !st; | ||||
|  | ||||
| 		if (f.out_list) | ||||
| 			f.out_list.disabled = !st; | ||||
|  | ||||
| 		f.onmouseoversrc.disabled = !st; | ||||
| 		f.onmouseoutsrc.disabled  = !st; | ||||
| 	}, | ||||
|  | ||||
| 	fillClassList : function(id) { | ||||
| 		var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl; | ||||
|  | ||||
| 		if (v = tinyMCEPopup.getParam('theme_advanced_styles')) { | ||||
| 			cl = []; | ||||
|  | ||||
| 			tinymce.each(v.split(';'), function(v) { | ||||
| 				var p = v.split('='); | ||||
|  | ||||
| 				cl.push({'title' : p[0], 'class' : p[1]}); | ||||
| 			}); | ||||
| 		} else | ||||
| 			cl = tinyMCEPopup.editor.dom.getClasses(); | ||||
|  | ||||
| 		if (cl.length > 0) { | ||||
| 			lst.options[lst.options.length] = new Option(tinyMCEPopup.getLang('not_set'), ''); | ||||
|  | ||||
| 			tinymce.each(cl, function(o) { | ||||
| 				lst.options[lst.options.length] = new Option(o.title || o['class'], o['class']); | ||||
| 			}); | ||||
| 		} else | ||||
| 			dom.remove(dom.getParent(id, 'tr')); | ||||
| 	}, | ||||
|  | ||||
| 	fillFileList : function(id, l) { | ||||
| 		var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl; | ||||
|  | ||||
| 		l = window[l]; | ||||
|  | ||||
| 		if (l && l.length > 0) { | ||||
| 			lst.options[lst.options.length] = new Option('', ''); | ||||
|  | ||||
| 			tinymce.each(l, function(o) { | ||||
| 				lst.options[lst.options.length] = new Option(o[0], o[1]); | ||||
| 			}); | ||||
| 		} else | ||||
| 			dom.remove(dom.getParent(id, 'tr')); | ||||
| 	}, | ||||
|  | ||||
| 	resetImageData : function() { | ||||
| 		var f = document.forms[0]; | ||||
|  | ||||
| 		f.elements.width.value = f.elements.height.value = ''; | ||||
| 	}, | ||||
|  | ||||
| 	updateImageData : function(img, st) { | ||||
| 		var f = document.forms[0]; | ||||
|  | ||||
| 		if (!st) { | ||||
| 			f.elements.width.value = img.width; | ||||
| 			f.elements.height.value = img.height; | ||||
| 		} | ||||
|  | ||||
| 		this.preloadImg = img; | ||||
| 	}, | ||||
|  | ||||
| 	changeAppearance : function() { | ||||
| 		var ed = tinyMCEPopup.editor, f = document.forms[0], img = document.getElementById('alignSampleImg'); | ||||
|  | ||||
| 		if (img) { | ||||
| 			if (ed.getParam('inline_styles')) { | ||||
| 				ed.dom.setAttrib(img, 'style', f.style.value); | ||||
| 			} else { | ||||
| 				img.align = f.align.value; | ||||
| 				img.border = f.border.value; | ||||
| 				img.hspace = f.hspace.value; | ||||
| 				img.vspace = f.vspace.value; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	changeHeight : function() { | ||||
| 		var f = document.forms[0], tp, t = this; | ||||
|  | ||||
| 		if (!f.constrain.checked || !t.preloadImg) { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (f.width.value == "" || f.height.value == "") | ||||
| 			return; | ||||
|  | ||||
| 		tp = (parseInt(f.width.value) / parseInt(t.preloadImg.width)) * t.preloadImg.height; | ||||
| 		f.height.value = tp.toFixed(0); | ||||
| 	}, | ||||
|  | ||||
| 	changeWidth : function() { | ||||
| 		var f = document.forms[0], tp, t = this; | ||||
|  | ||||
| 		if (!f.constrain.checked || !t.preloadImg) { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (f.width.value == "" || f.height.value == "") | ||||
| 			return; | ||||
|  | ||||
| 		tp = (parseInt(f.height.value) / parseInt(t.preloadImg.height)) * t.preloadImg.width; | ||||
| 		f.width.value = tp.toFixed(0); | ||||
| 	}, | ||||
|  | ||||
| 	updateStyle : function(ty) { | ||||
| 		var dom = tinyMCEPopup.dom, st, v, f = document.forms[0], img = dom.create('img', {style : dom.get('style').value}); | ||||
|  | ||||
| 		if (tinyMCEPopup.editor.settings.inline_styles) { | ||||
| 			// Handle align | ||||
| 			if (ty == 'align') { | ||||
| 				dom.setStyle(img, 'float', ''); | ||||
| 				dom.setStyle(img, 'vertical-align', ''); | ||||
|  | ||||
| 				v = getSelectValue(f, 'align'); | ||||
| 				if (v) { | ||||
| 					if (v == 'left' || v == 'right') | ||||
| 						dom.setStyle(img, 'float', v); | ||||
| 					else | ||||
| 						img.style.verticalAlign = v; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// Handle border | ||||
| 			if (ty == 'border') { | ||||
| 				dom.setStyle(img, 'border', ''); | ||||
|  | ||||
| 				v = f.border.value; | ||||
| 				if (v || v == '0') { | ||||
| 					if (v == '0') | ||||
| 						img.style.border = '0'; | ||||
| 					else | ||||
| 						img.style.border = v + 'px solid black'; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// Handle hspace | ||||
| 			if (ty == 'hspace') { | ||||
| 				dom.setStyle(img, 'marginLeft', ''); | ||||
| 				dom.setStyle(img, 'marginRight', ''); | ||||
|  | ||||
| 				v = f.hspace.value; | ||||
| 				if (v) { | ||||
| 					img.style.marginLeft = v + 'px'; | ||||
| 					img.style.marginRight = v + 'px'; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// Handle vspace | ||||
| 			if (ty == 'vspace') { | ||||
| 				dom.setStyle(img, 'marginTop', ''); | ||||
| 				dom.setStyle(img, 'marginBottom', ''); | ||||
|  | ||||
| 				v = f.vspace.value; | ||||
| 				if (v) { | ||||
| 					img.style.marginTop = v + 'px'; | ||||
| 					img.style.marginBottom = v + 'px'; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// Merge | ||||
| 			dom.get('style').value = dom.serializeStyle(dom.parseStyle(img.style.cssText)); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	changeMouseMove : function() { | ||||
| 	}, | ||||
|  | ||||
| 	showPreviewImage : function(u, st) { | ||||
| 		if (!u) { | ||||
| 			tinyMCEPopup.dom.setHTML('prev', ''); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (!st && tinyMCEPopup.getParam("advimage_update_dimensions_onchange", true)) | ||||
| 			this.resetImageData(); | ||||
|  | ||||
| 		u = tinyMCEPopup.editor.documentBaseURI.toAbsolute(u); | ||||
|  | ||||
| 		if (!st) | ||||
| 			tinyMCEPopup.dom.setHTML('prev', '<img id="previewImg" src="' + u + '" border="0" onload="ImageDialog.updateImageData(this);" onerror="ImageDialog.resetImageData();" />'); | ||||
| 		else | ||||
| 			tinyMCEPopup.dom.setHTML('prev', '<img id="previewImg" src="' + u + '" border="0" onload="ImageDialog.updateImageData(this, 1);" />'); | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| ImageDialog.preInit(); | ||||
| tinyMCEPopup.onInit.add(ImageDialog.init, ImageDialog); | ||||
| @@ -0,0 +1,43 @@ | ||||
| tinyMCE.addI18n('en.advimage_dlg',{ | ||||
| tab_general:"General", | ||||
| tab_appearance:"Appearance", | ||||
| tab_advanced:"Advanced", | ||||
| general:"General", | ||||
| title:"Title", | ||||
| preview:"Preview", | ||||
| constrain_proportions:"Constrain proportions", | ||||
| langdir:"Language direction", | ||||
| langcode:"Language code", | ||||
| long_desc:"Long description link", | ||||
| style:"Style", | ||||
| classes:"Classes", | ||||
| ltr:"Left to right", | ||||
| rtl:"Right to left", | ||||
| id:"Id", | ||||
| map:"Image map", | ||||
| swap_image:"Swap image", | ||||
| alt_image:"Alternative image", | ||||
| mouseover:"for mouse over", | ||||
| mouseout:"for mouse out", | ||||
| misc:"Miscellaneous", | ||||
| example_img:"Appearance preview image", | ||||
| missing_alt:"Are you sure you want to continue without including an Image Description? Without it the image may not be accessible to some users with disabilities, or to those using a text browser, or browsing the Web with images turned off.", | ||||
| dialog_title:"Insert/edit image", | ||||
| src:"Image URL", | ||||
| alt:"Image description", | ||||
| list:"Image list", | ||||
| border:"Border", | ||||
| dimensions:"Dimensions", | ||||
| vspace:"Vertical space", | ||||
| hspace:"Horizontal space", | ||||
| align:"Alignment", | ||||
| align_baseline:"Baseline", | ||||
| align_top:"Top", | ||||
| align_middle:"Middle", | ||||
| align_bottom:"Bottom", | ||||
| align_texttop:"Text top", | ||||
| align_textbottom:"Text bottom", | ||||
| align_left:"Left", | ||||
| align_right:"Right", | ||||
| image_list:"Image list" | ||||
| }); | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.AdvancedLinkPlugin',{init:function(ed,url){this.editor=ed;ed.addCommand('mceAdvLink',function(){var se=ed.selection;if(se.isCollapsed()&&!ed.dom.getParent(se.getNode(),'A'))return;ed.windowManager.open({file:url+'/link.htm',width:480+parseInt(ed.getLang('advlink.delta_width',0)),height:400+parseInt(ed.getLang('advlink.delta_height',0)),inline:1},{plugin_url:url});});ed.addButton('link',{title:'advlink.link_desc',cmd:'mceAdvLink'});ed.addShortcut('ctrl+k','advlink.advlink_desc','mceAdvLink');ed.onNodeChange.add(function(ed,cm,n,co){cm.setDisabled('link',co&&n.nodeName!='A');cm.setActive('link',n.nodeName=='A'&&!n.name);});},getInfo:function(){return{longname:'Advanced link',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/advlink',version:tinymce.majorVersion+"."+tinymce.minorVersion};}});tinymce.PluginManager.add('advlink',tinymce.plugins.AdvancedLinkPlugin);})(); | ||||
| @@ -0,0 +1,58 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:25 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.AdvancedLinkPlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			this.editor = ed; | ||||
|  | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceAdvLink', function() { | ||||
| 				var se = ed.selection; | ||||
|  | ||||
| 				// No selection and not in link | ||||
| 				if (se.isCollapsed() && !ed.dom.getParent(se.getNode(), 'A')) | ||||
| 					return; | ||||
|  | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/link.htm', | ||||
| 					width : 480 + parseInt(ed.getLang('advlink.delta_width', 0)), | ||||
| 					height : 400 + parseInt(ed.getLang('advlink.delta_height', 0)), | ||||
| 					inline : 1 | ||||
| 				}, { | ||||
| 					plugin_url : url | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('link', { | ||||
| 				title : 'advlink.link_desc', | ||||
| 				cmd : 'mceAdvLink' | ||||
| 			}); | ||||
|  | ||||
| 			ed.addShortcut('ctrl+k', 'advlink.advlink_desc', 'mceAdvLink'); | ||||
|  | ||||
| 			ed.onNodeChange.add(function(ed, cm, n, co) { | ||||
| 				cm.setDisabled('link', co && n.nodeName != 'A'); | ||||
| 				cm.setActive('link', n.nodeName == 'A' && !n.name); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Advanced link', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/advlink', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('advlink', tinymce.plugins.AdvancedLinkPlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,528 @@ | ||||
| /* Functions for the advlink plugin popup */ | ||||
|  | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var templates = { | ||||
| 	"window.open" : "window.open('${url}','${target}','${options}')" | ||||
| }; | ||||
|  | ||||
| function preinit() { | ||||
| 	var url; | ||||
|  | ||||
| 	if (url = tinyMCEPopup.getParam("external_link_list_url")) | ||||
| 		document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>'); | ||||
| } | ||||
|  | ||||
| function changeClass() { | ||||
| 	var f = document.forms[0]; | ||||
|  | ||||
| 	f.classes.value = getSelectValue(f, 'classlist'); | ||||
| } | ||||
|  | ||||
| function init() { | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var inst = tinyMCEPopup.editor; | ||||
| 	var elm = inst.selection.getNode(); | ||||
| 	var action = "insert"; | ||||
| 	var html; | ||||
|  | ||||
| 	document.getElementById('hrefbrowsercontainer').innerHTML = getBrowserHTML('hrefbrowser','href','file','advlink'); | ||||
| 	document.getElementById('popupurlbrowsercontainer').innerHTML = getBrowserHTML('popupurlbrowser','popupurl','file','advlink'); | ||||
| 	document.getElementById('linklisthrefcontainer').innerHTML = getLinkListHTML('linklisthref','href'); | ||||
| 	document.getElementById('anchorlistcontainer').innerHTML = getAnchorListHTML('anchorlist','href'); | ||||
| 	document.getElementById('targetlistcontainer').innerHTML = getTargetListHTML('targetlist','target'); | ||||
|  | ||||
| 	// Link list | ||||
| 	html = getLinkListHTML('linklisthref','href'); | ||||
| 	if (html == "") | ||||
| 		document.getElementById("linklisthrefrow").style.display = 'none'; | ||||
| 	else | ||||
| 		document.getElementById("linklisthrefcontainer").innerHTML = html; | ||||
|  | ||||
| 	// Resize some elements | ||||
| 	if (isVisible('hrefbrowser')) | ||||
| 		document.getElementById('href').style.width = '260px'; | ||||
|  | ||||
| 	if (isVisible('popupurlbrowser')) | ||||
| 		document.getElementById('popupurl').style.width = '180px'; | ||||
|  | ||||
| 	elm = inst.dom.getParent(elm, "A"); | ||||
| 	if (elm != null && elm.nodeName == "A") | ||||
| 		action = "update"; | ||||
|  | ||||
| 	formObj.insert.value = tinyMCEPopup.getLang(action, 'Insert', true);  | ||||
|  | ||||
| 	setPopupControlsDisabled(true); | ||||
|  | ||||
| 	if (action == "update") { | ||||
| 		var href = inst.dom.getAttrib(elm, 'href'); | ||||
| 		var onclick = inst.dom.getAttrib(elm, 'onclick'); | ||||
|  | ||||
| 		// Setup form data | ||||
| 		setFormValue('href', href); | ||||
| 		setFormValue('title', inst.dom.getAttrib(elm, 'title')); | ||||
| 		setFormValue('id', inst.dom.getAttrib(elm, 'id')); | ||||
| 		setFormValue('style', inst.dom.getAttrib(elm, "style")); | ||||
| 		setFormValue('rel', inst.dom.getAttrib(elm, 'rel')); | ||||
| 		setFormValue('rev', inst.dom.getAttrib(elm, 'rev')); | ||||
| 		setFormValue('charset', inst.dom.getAttrib(elm, 'charset')); | ||||
| 		setFormValue('hreflang', inst.dom.getAttrib(elm, 'hreflang')); | ||||
| 		setFormValue('dir', inst.dom.getAttrib(elm, 'dir')); | ||||
| 		setFormValue('lang', inst.dom.getAttrib(elm, 'lang')); | ||||
| 		setFormValue('tabindex', inst.dom.getAttrib(elm, 'tabindex', typeof(elm.tabindex) != "undefined" ? elm.tabindex : "")); | ||||
| 		setFormValue('accesskey', inst.dom.getAttrib(elm, 'accesskey', typeof(elm.accesskey) != "undefined" ? elm.accesskey : "")); | ||||
| 		setFormValue('type', inst.dom.getAttrib(elm, 'type')); | ||||
| 		setFormValue('onfocus', inst.dom.getAttrib(elm, 'onfocus')); | ||||
| 		setFormValue('onblur', inst.dom.getAttrib(elm, 'onblur')); | ||||
| 		setFormValue('onclick', onclick); | ||||
| 		setFormValue('ondblclick', inst.dom.getAttrib(elm, 'ondblclick')); | ||||
| 		setFormValue('onmousedown', inst.dom.getAttrib(elm, 'onmousedown')); | ||||
| 		setFormValue('onmouseup', inst.dom.getAttrib(elm, 'onmouseup')); | ||||
| 		setFormValue('onmouseover', inst.dom.getAttrib(elm, 'onmouseover')); | ||||
| 		setFormValue('onmousemove', inst.dom.getAttrib(elm, 'onmousemove')); | ||||
| 		setFormValue('onmouseout', inst.dom.getAttrib(elm, 'onmouseout')); | ||||
| 		setFormValue('onkeypress', inst.dom.getAttrib(elm, 'onkeypress')); | ||||
| 		setFormValue('onkeydown', inst.dom.getAttrib(elm, 'onkeydown')); | ||||
| 		setFormValue('onkeyup', inst.dom.getAttrib(elm, 'onkeyup')); | ||||
| 		setFormValue('target', inst.dom.getAttrib(elm, 'target')); | ||||
| 		setFormValue('classes', inst.dom.getAttrib(elm, 'class')); | ||||
|  | ||||
| 		// Parse onclick data | ||||
| 		if (onclick != null && onclick.indexOf('window.open') != -1) | ||||
| 			parseWindowOpen(onclick); | ||||
| 		else | ||||
| 			parseFunction(onclick); | ||||
|  | ||||
| 		// Select by the values | ||||
| 		selectByValue(formObj, 'dir', inst.dom.getAttrib(elm, 'dir')); | ||||
| 		selectByValue(formObj, 'rel', inst.dom.getAttrib(elm, 'rel')); | ||||
| 		selectByValue(formObj, 'rev', inst.dom.getAttrib(elm, 'rev')); | ||||
| 		selectByValue(formObj, 'linklisthref', href); | ||||
|  | ||||
| 		if (href.charAt(0) == '#') | ||||
| 			selectByValue(formObj, 'anchorlist', href); | ||||
|  | ||||
| 		addClassesToList('classlist', 'advlink_styles'); | ||||
|  | ||||
| 		selectByValue(formObj, 'classlist', inst.dom.getAttrib(elm, 'class'), true); | ||||
| 		selectByValue(formObj, 'targetlist', inst.dom.getAttrib(elm, 'target'), true); | ||||
| 	} else | ||||
| 		addClassesToList('classlist', 'advlink_styles'); | ||||
| } | ||||
|  | ||||
| function checkPrefix(n) { | ||||
| 	if (n.value && Validator.isEmail(n) && !/^\s*mailto:/i.test(n.value) && confirm(tinyMCEPopup.getLang('advlink_dlg.is_email'))) | ||||
| 		n.value = 'mailto:' + n.value; | ||||
|  | ||||
| 	if (/^\s*www./i.test(n.value) && confirm(tinyMCEPopup.getLang('advlink_dlg.is_external'))) | ||||
| 		n.value = 'http://' + n.value; | ||||
| } | ||||
|  | ||||
| function setFormValue(name, value) { | ||||
| 	document.forms[0].elements[name].value = value; | ||||
| } | ||||
|  | ||||
| function parseWindowOpen(onclick) { | ||||
| 	var formObj = document.forms[0]; | ||||
|  | ||||
| 	// Preprocess center code | ||||
| 	if (onclick.indexOf('return false;') != -1) { | ||||
| 		formObj.popupreturn.checked = true; | ||||
| 		onclick = onclick.replace('return false;', ''); | ||||
| 	} else | ||||
| 		formObj.popupreturn.checked = false; | ||||
|  | ||||
| 	var onClickData = parseLink(onclick); | ||||
|  | ||||
| 	if (onClickData != null) { | ||||
| 		formObj.ispopup.checked = true; | ||||
| 		setPopupControlsDisabled(false); | ||||
|  | ||||
| 		var onClickWindowOptions = parseOptions(onClickData['options']); | ||||
| 		var url = onClickData['url']; | ||||
|  | ||||
| 		formObj.popupname.value = onClickData['target']; | ||||
| 		formObj.popupurl.value = url; | ||||
| 		formObj.popupwidth.value = getOption(onClickWindowOptions, 'width'); | ||||
| 		formObj.popupheight.value = getOption(onClickWindowOptions, 'height'); | ||||
|  | ||||
| 		formObj.popupleft.value = getOption(onClickWindowOptions, 'left'); | ||||
| 		formObj.popuptop.value = getOption(onClickWindowOptions, 'top'); | ||||
|  | ||||
| 		if (formObj.popupleft.value.indexOf('screen') != -1) | ||||
| 			formObj.popupleft.value = "c"; | ||||
|  | ||||
| 		if (formObj.popuptop.value.indexOf('screen') != -1) | ||||
| 			formObj.popuptop.value = "c"; | ||||
|  | ||||
| 		formObj.popuplocation.checked = getOption(onClickWindowOptions, 'location') == "yes"; | ||||
| 		formObj.popupscrollbars.checked = getOption(onClickWindowOptions, 'scrollbars') == "yes"; | ||||
| 		formObj.popupmenubar.checked = getOption(onClickWindowOptions, 'menubar') == "yes"; | ||||
| 		formObj.popupresizable.checked = getOption(onClickWindowOptions, 'resizable') == "yes"; | ||||
| 		formObj.popuptoolbar.checked = getOption(onClickWindowOptions, 'toolbar') == "yes"; | ||||
| 		formObj.popupstatus.checked = getOption(onClickWindowOptions, 'status') == "yes"; | ||||
| 		formObj.popupdependent.checked = getOption(onClickWindowOptions, 'dependent') == "yes"; | ||||
|  | ||||
| 		buildOnClick(); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function parseFunction(onclick) { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var onClickData = parseLink(onclick); | ||||
|  | ||||
| 	// TODO: Add stuff here | ||||
| } | ||||
|  | ||||
| function getOption(opts, name) { | ||||
| 	return typeof(opts[name]) == "undefined" ? "" : opts[name]; | ||||
| } | ||||
|  | ||||
| function setPopupControlsDisabled(state) { | ||||
| 	var formObj = document.forms[0]; | ||||
|  | ||||
| 	formObj.popupname.disabled = state; | ||||
| 	formObj.popupurl.disabled = state; | ||||
| 	formObj.popupwidth.disabled = state; | ||||
| 	formObj.popupheight.disabled = state; | ||||
| 	formObj.popupleft.disabled = state; | ||||
| 	formObj.popuptop.disabled = state; | ||||
| 	formObj.popuplocation.disabled = state; | ||||
| 	formObj.popupscrollbars.disabled = state; | ||||
| 	formObj.popupmenubar.disabled = state; | ||||
| 	formObj.popupresizable.disabled = state; | ||||
| 	formObj.popuptoolbar.disabled = state; | ||||
| 	formObj.popupstatus.disabled = state; | ||||
| 	formObj.popupreturn.disabled = state; | ||||
| 	formObj.popupdependent.disabled = state; | ||||
|  | ||||
| 	setBrowserDisabled('popupurlbrowser', state); | ||||
| } | ||||
|  | ||||
| function parseLink(link) { | ||||
| 	link = link.replace(new RegExp(''', 'g'), "'"); | ||||
|  | ||||
| 	var fnName = link.replace(new RegExp("\\s*([A-Za-z0-9\.]*)\\s*\\(.*", "gi"), "$1"); | ||||
|  | ||||
| 	// Is function name a template function | ||||
| 	var template = templates[fnName]; | ||||
| 	if (template) { | ||||
| 		// Build regexp | ||||
| 		var variableNames = template.match(new RegExp("'?\\$\\{[A-Za-z0-9\.]*\\}'?", "gi")); | ||||
| 		var regExp = "\\s*[A-Za-z0-9\.]*\\s*\\("; | ||||
| 		var replaceStr = ""; | ||||
| 		for (var i=0; i<variableNames.length; i++) { | ||||
| 			// Is string value | ||||
| 			if (variableNames[i].indexOf("'${") != -1) | ||||
| 				regExp += "'(.*)'"; | ||||
| 			else // Number value | ||||
| 				regExp += "([0-9]*)"; | ||||
|  | ||||
| 			replaceStr += "$" + (i+1); | ||||
|  | ||||
| 			// Cleanup variable name | ||||
| 			variableNames[i] = variableNames[i].replace(new RegExp("[^A-Za-z0-9]", "gi"), ""); | ||||
|  | ||||
| 			if (i != variableNames.length-1) { | ||||
| 				regExp += "\\s*,\\s*"; | ||||
| 				replaceStr += "<delim>"; | ||||
| 			} else | ||||
| 				regExp += ".*"; | ||||
| 		} | ||||
|  | ||||
| 		regExp += "\\);?"; | ||||
|  | ||||
| 		// Build variable array | ||||
| 		var variables = []; | ||||
| 		variables["_function"] = fnName; | ||||
| 		var variableValues = link.replace(new RegExp(regExp, "gi"), replaceStr).split('<delim>'); | ||||
| 		for (var i=0; i<variableNames.length; i++) | ||||
| 			variables[variableNames[i]] = variableValues[i]; | ||||
|  | ||||
| 		return variables; | ||||
| 	} | ||||
|  | ||||
| 	return null; | ||||
| } | ||||
|  | ||||
| function parseOptions(opts) { | ||||
| 	if (opts == null || opts == "") | ||||
| 		return []; | ||||
|  | ||||
| 	// Cleanup the options | ||||
| 	opts = opts.toLowerCase(); | ||||
| 	opts = opts.replace(/;/g, ","); | ||||
| 	opts = opts.replace(/[^0-9a-z=,]/g, ""); | ||||
|  | ||||
| 	var optionChunks = opts.split(','); | ||||
| 	var options = []; | ||||
|  | ||||
| 	for (var i=0; i<optionChunks.length; i++) { | ||||
| 		var parts = optionChunks[i].split('='); | ||||
|  | ||||
| 		if (parts.length == 2) | ||||
| 			options[parts[0]] = parts[1]; | ||||
| 	} | ||||
|  | ||||
| 	return options; | ||||
| } | ||||
|  | ||||
| function buildOnClick() { | ||||
| 	var formObj = document.forms[0]; | ||||
|  | ||||
| 	if (!formObj.ispopup.checked) { | ||||
| 		formObj.onclick.value = ""; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	var onclick = "window.open('"; | ||||
| 	var url = formObj.popupurl.value; | ||||
|  | ||||
| 	onclick += url + "','"; | ||||
| 	onclick += formObj.popupname.value + "','"; | ||||
|  | ||||
| 	if (formObj.popuplocation.checked) | ||||
| 		onclick += "location=yes,"; | ||||
|  | ||||
| 	if (formObj.popupscrollbars.checked) | ||||
| 		onclick += "scrollbars=yes,"; | ||||
|  | ||||
| 	if (formObj.popupmenubar.checked) | ||||
| 		onclick += "menubar=yes,"; | ||||
|  | ||||
| 	if (formObj.popupresizable.checked) | ||||
| 		onclick += "resizable=yes,"; | ||||
|  | ||||
| 	if (formObj.popuptoolbar.checked) | ||||
| 		onclick += "toolbar=yes,"; | ||||
|  | ||||
| 	if (formObj.popupstatus.checked) | ||||
| 		onclick += "status=yes,"; | ||||
|  | ||||
| 	if (formObj.popupdependent.checked) | ||||
| 		onclick += "dependent=yes,"; | ||||
|  | ||||
| 	if (formObj.popupwidth.value != "") | ||||
| 		onclick += "width=" + formObj.popupwidth.value + ","; | ||||
|  | ||||
| 	if (formObj.popupheight.value != "") | ||||
| 		onclick += "height=" + formObj.popupheight.value + ","; | ||||
|  | ||||
| 	if (formObj.popupleft.value != "") { | ||||
| 		if (formObj.popupleft.value != "c") | ||||
| 			onclick += "left=" + formObj.popupleft.value + ","; | ||||
| 		else | ||||
| 			onclick += "left='+(screen.availWidth/2-" + (formObj.popupwidth.value/2) + ")+',"; | ||||
| 	} | ||||
|  | ||||
| 	if (formObj.popuptop.value != "") { | ||||
| 		if (formObj.popuptop.value != "c") | ||||
| 			onclick += "top=" + formObj.popuptop.value + ","; | ||||
| 		else | ||||
| 			onclick += "top='+(screen.availHeight/2-" + (formObj.popupheight.value/2) + ")+',"; | ||||
| 	} | ||||
|  | ||||
| 	if (onclick.charAt(onclick.length-1) == ',') | ||||
| 		onclick = onclick.substring(0, onclick.length-1); | ||||
|  | ||||
| 	onclick += "');"; | ||||
|  | ||||
| 	if (formObj.popupreturn.checked) | ||||
| 		onclick += "return false;"; | ||||
|  | ||||
| 	// tinyMCE.debug(onclick); | ||||
|  | ||||
| 	formObj.onclick.value = onclick; | ||||
|  | ||||
| 	if (formObj.href.value == "") | ||||
| 		formObj.href.value = url; | ||||
| } | ||||
|  | ||||
| function setAttrib(elm, attrib, value) { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var valueElm = formObj.elements[attrib.toLowerCase()]; | ||||
| 	var dom = tinyMCEPopup.editor.dom; | ||||
|  | ||||
| 	if (typeof(value) == "undefined" || value == null) { | ||||
| 		value = ""; | ||||
|  | ||||
| 		if (valueElm) | ||||
| 			value = valueElm.value; | ||||
| 	} | ||||
|  | ||||
| 	// Clean up the style | ||||
| 	if (attrib == 'style') | ||||
| 		value = dom.serializeStyle(dom.parseStyle(value)); | ||||
|  | ||||
| 	dom.setAttrib(elm, attrib, value); | ||||
| } | ||||
|  | ||||
| function getAnchorListHTML(id, target) { | ||||
| 	var inst = tinyMCEPopup.editor; | ||||
| 	var nodes = inst.dom.select('a.mceItemAnchor,img.mceItemAnchor'), name, i; | ||||
| 	var html = ""; | ||||
|  | ||||
| 	html += '<select id="' + id + '" name="' + id + '" class="mceAnchorList" o2nfocus="tinyMCE.addSelectAccessibility(event, this, window);" onchange="this.form.' + target + '.value='; | ||||
| 	html += 'this.options[this.selectedIndex].value;">'; | ||||
| 	html += '<option value="">---</option>'; | ||||
|  | ||||
| 	for (i=0; i<nodes.length; i++) { | ||||
| 		if ((name = inst.dom.getAttrib(nodes[i], "name")) != "") | ||||
| 			html += '<option value="#' + name + '">' + name + '</option>'; | ||||
| 	} | ||||
|  | ||||
| 	html += '</select>'; | ||||
|  | ||||
| 	return html; | ||||
| } | ||||
|  | ||||
| function insertAction() { | ||||
| 	var inst = tinyMCEPopup.editor; | ||||
| 	var elm, elementArray, i; | ||||
|  | ||||
| 	elm = inst.selection.getNode(); | ||||
| 	checkPrefix(document.forms[0].href); | ||||
|  | ||||
| 	elm = inst.dom.getParent(elm, "A"); | ||||
|  | ||||
| 	// Remove element if there is no href | ||||
| 	if (!document.forms[0].href.value) { | ||||
| 		tinyMCEPopup.execCommand("mceBeginUndoLevel"); | ||||
| 		i = inst.selection.getBookmark(); | ||||
| 		inst.dom.remove(elm, 1); | ||||
| 		inst.selection.moveToBookmark(i); | ||||
| 		tinyMCEPopup.execCommand("mceEndUndoLevel"); | ||||
| 		tinyMCEPopup.close(); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	tinyMCEPopup.execCommand("mceBeginUndoLevel"); | ||||
|  | ||||
| 	// Create new anchor elements | ||||
| 	if (elm == null) { | ||||
| 		tinyMCEPopup.execCommand("CreateLink", false, "#mce_temp_url#", {skip_undo : 1}); | ||||
|  | ||||
| 		elementArray = tinymce.grep(inst.dom.select("a"), function(n) {return inst.dom.getAttrib(n, 'href') == '#mce_temp_url#';}); | ||||
| 		for (i=0; i<elementArray.length; i++) | ||||
| 			setAllAttribs(elm = elementArray[i]); | ||||
| 	} else | ||||
| 		setAllAttribs(elm); | ||||
|  | ||||
| 	// Don't move caret if selection was image | ||||
| 	if (elm.childNodes.length != 1 || elm.firstChild.nodeName != 'IMG') { | ||||
| 		inst.focus(); | ||||
| 		inst.selection.select(elm); | ||||
| 		inst.selection.collapse(0); | ||||
| 		tinyMCEPopup.storeSelection(); | ||||
| 	} | ||||
|  | ||||
| 	tinyMCEPopup.execCommand("mceEndUndoLevel"); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function setAllAttribs(elm) { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var href = formObj.href.value; | ||||
| 	var target = getSelectValue(formObj, 'targetlist'); | ||||
|  | ||||
| 	setAttrib(elm, 'href', href); | ||||
| 	setAttrib(elm, 'mce_href', href); | ||||
| 	setAttrib(elm, 'title'); | ||||
| 	setAttrib(elm, 'target', target == '_self' ? '' : target); | ||||
| 	setAttrib(elm, 'id'); | ||||
| 	setAttrib(elm, 'style'); | ||||
| 	setAttrib(elm, 'class', getSelectValue(formObj, 'classlist')); | ||||
| 	setAttrib(elm, 'rel'); | ||||
| 	setAttrib(elm, 'rev'); | ||||
| 	setAttrib(elm, 'charset'); | ||||
| 	setAttrib(elm, 'hreflang'); | ||||
| 	setAttrib(elm, 'dir'); | ||||
| 	setAttrib(elm, 'lang'); | ||||
| 	setAttrib(elm, 'tabindex'); | ||||
| 	setAttrib(elm, 'accesskey'); | ||||
| 	setAttrib(elm, 'type'); | ||||
| 	setAttrib(elm, 'onfocus'); | ||||
| 	setAttrib(elm, 'onblur'); | ||||
| 	setAttrib(elm, 'onclick'); | ||||
| 	setAttrib(elm, 'ondblclick'); | ||||
| 	setAttrib(elm, 'onmousedown'); | ||||
| 	setAttrib(elm, 'onmouseup'); | ||||
| 	setAttrib(elm, 'onmouseover'); | ||||
| 	setAttrib(elm, 'onmousemove'); | ||||
| 	setAttrib(elm, 'onmouseout'); | ||||
| 	setAttrib(elm, 'onkeypress'); | ||||
| 	setAttrib(elm, 'onkeydown'); | ||||
| 	setAttrib(elm, 'onkeyup'); | ||||
|  | ||||
| 	// Refresh in old MSIE | ||||
| 	if (tinyMCE.isMSIE5) | ||||
| 		elm.outerHTML = elm.outerHTML; | ||||
| } | ||||
|  | ||||
| function getSelectValue(form_obj, field_name) { | ||||
| 	var elm = form_obj.elements[field_name]; | ||||
|  | ||||
| 	if (elm == null || elm.options == null) | ||||
| 		return ""; | ||||
|  | ||||
| 	return elm.options[elm.selectedIndex].value; | ||||
| } | ||||
|  | ||||
| function getLinkListHTML(elm_id, target_form_element, onchange_func) { | ||||
| 	if (typeof(tinyMCELinkList) == "undefined" || tinyMCELinkList.length == 0) | ||||
| 		return ""; | ||||
|  | ||||
| 	var html = ""; | ||||
|  | ||||
| 	html += '<select id="' + elm_id + '" name="' + elm_id + '"'; | ||||
| 	html += ' class="mceLinkList" onfoc2us="tinyMCE.addSelectAccessibility(event, this, window);" onchange="this.form.' + target_form_element + '.value='; | ||||
| 	html += 'this.options[this.selectedIndex].value;'; | ||||
|  | ||||
| 	if (typeof(onchange_func) != "undefined") | ||||
| 		html += onchange_func + '(\'' + target_form_element + '\',this.options[this.selectedIndex].text,this.options[this.selectedIndex].value);'; | ||||
|  | ||||
| 	html += '"><option value="">---</option>'; | ||||
|  | ||||
| 	for (var i=0; i<tinyMCELinkList.length; i++) | ||||
| 		html += '<option value="' + tinyMCELinkList[i][1] + '">' + tinyMCELinkList[i][0] + '</option>'; | ||||
|  | ||||
| 	html += '</select>'; | ||||
|  | ||||
| 	return html; | ||||
|  | ||||
| 	// tinyMCE.debug('-- image list start --', html, '-- image list end --'); | ||||
| } | ||||
|  | ||||
| function getTargetListHTML(elm_id, target_form_element) { | ||||
| 	var targets = tinyMCEPopup.getParam('theme_advanced_link_targets', '').split(';'); | ||||
| 	var html = ''; | ||||
|  | ||||
| 	html += '<select id="' + elm_id + '" name="' + elm_id + '" onf2ocus="tinyMCE.addSelectAccessibility(event, this, window);" onchange="this.form.' + target_form_element + '.value='; | ||||
| 	html += 'this.options[this.selectedIndex].value;">'; | ||||
| 	html += '<option value="_self">' + tinyMCEPopup.getLang('advlink_dlg.target_same') + '</option>'; | ||||
| 	html += '<option value="_blank">' + tinyMCEPopup.getLang('advlink_dlg.target_blank') + ' (_blank)</option>'; | ||||
| 	html += '<option value="_parent">' + tinyMCEPopup.getLang('advlink_dlg.target_parent') + ' (_parent)</option>'; | ||||
| 	html += '<option value="_top">' + tinyMCEPopup.getLang('advlink_dlg.target_top') + ' (_top)</option>'; | ||||
|  | ||||
| 	for (var i=0; i<targets.length; i++) { | ||||
| 		var key, value; | ||||
|  | ||||
| 		if (targets[i] == "") | ||||
| 			continue; | ||||
|  | ||||
| 		key = targets[i].split('=')[0]; | ||||
| 		value = targets[i].split('=')[1]; | ||||
|  | ||||
| 		html += '<option value="' + key + '">' + value + ' (' + key + ')</option>'; | ||||
| 	} | ||||
|  | ||||
| 	html += '</select>'; | ||||
|  | ||||
| 	return html; | ||||
| } | ||||
|  | ||||
| // While loading | ||||
| preinit(); | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,52 @@ | ||||
| tinyMCE.addI18n('en.advlink_dlg',{ | ||||
| title:"Insert/edit link", | ||||
| url:"Link URL", | ||||
| target:"Target", | ||||
| titlefield:"Title", | ||||
| is_email:"The URL you entered seems to be an email address, do you want to add the required mailto: prefix?", | ||||
| is_external:"The URL you entered seems to external link, do you want to add the required http:// prefix?", | ||||
| list:"Link list", | ||||
| general_tab:"General", | ||||
| popup_tab:"Popup", | ||||
| events_tab:"Events", | ||||
| advanced_tab:"Advanced", | ||||
| general_props:"General properties", | ||||
| popup_props:"Popup properties", | ||||
| event_props:"Events", | ||||
| advanced_props:"Advanced properties", | ||||
| popup_opts:"Options", | ||||
| anchor_names:"Anchors", | ||||
| target_same:"Open in this window / frame", | ||||
| target_parent:"Open in parent window / frame", | ||||
| target_top:"Open in top frame (replaces all frames)", | ||||
| target_blank:"Open in new window", | ||||
| popup:"Javascript popup", | ||||
| popup_url:"Popup URL", | ||||
| popup_name:"Window name", | ||||
| popup_return:"Insert 'return false'", | ||||
| popup_scrollbars:"Show scrollbars", | ||||
| popup_statusbar:"Show status bar", | ||||
| popup_toolbar:"Show toolbars", | ||||
| popup_menubar:"Show menu bar", | ||||
| popup_location:"Show location bar", | ||||
| popup_resizable:"Make window resizable", | ||||
| popup_dependent:"Dependent (Mozilla/Firefox only)", | ||||
| popup_size:"Size", | ||||
| popup_position:"Position (X/Y)", | ||||
| id:"Id", | ||||
| style:"Style", | ||||
| classes:"Classes", | ||||
| target_name:"Target name", | ||||
| langdir:"Language direction", | ||||
| target_langcode:"Target language", | ||||
| langcode:"Language code", | ||||
| encoding:"Target character encoding", | ||||
| mime:"Target MIME type", | ||||
| rel:"Relationship page to target", | ||||
| rev:"Relationship target to page", | ||||
| tabindex:"Tabindex", | ||||
| accesskey:"Accesskey", | ||||
| ltr:"Left to right", | ||||
| rtl:"Right to left", | ||||
| link_list:"Link list" | ||||
| }); | ||||
| @@ -0,0 +1,339 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advlink_dlg.title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/validate.js"></script> | ||||
| 	<script type="text/javascript" src="js/advlink.js"></script> | ||||
| 	<link href="css/advlink.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="advlink" style="display: none"> | ||||
|     <form onsubmit="insertAction();return false;" action="#"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#advlink_dlg.general_tab}</a></span></li> | ||||
| 				<li id="popup_tab"><span><a href="javascript:mcTabs.displayTab('popup_tab','popup_panel');" onmousedown="return false;">{#advlink_dlg.popup_tab}</a></span></li> | ||||
| 				<li id="events_tab"><span><a href="javascript:mcTabs.displayTab('events_tab','events_panel');" onmousedown="return false;">{#advlink_dlg.events_tab}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#advlink_dlg.advanced_tab}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#advlink_dlg.general_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 						  <td nowrap="nowrap"><label id="hreflabel" for="href">{#advlink_dlg.url}</label></td> | ||||
| 						  <td><table border="0" cellspacing="0" cellpadding="0"> | ||||
| 								<tr> | ||||
| 								  <td><input id="href" name="href" type="text" class="mceFocus" value="" onchange="selectByValue(this.form,'linklisthref',this.value);" /></td> | ||||
| 								  <td id="hrefbrowsercontainer"> </td> | ||||
| 								</tr> | ||||
| 							  </table></td> | ||||
| 						</tr> | ||||
| 						<tr id="linklisthrefrow"> | ||||
| 							<td class="column1"><label for="linklisthref">{#advlink_dlg.list}</label></td> | ||||
| 							<td colspan="2" id="linklisthrefcontainer"> </td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="anchorlist">{#advlink_dlg.anchor_names}</label></td> | ||||
| 							<td colspan="2" id="anchorlistcontainer"> </td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td><label id="targetlistlabel" for="targetlist">{#advlink_dlg.target}</label></td> | ||||
| 							<td id="targetlistcontainer"> </td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label id="titlelabel" for="title">{#advlink_dlg.titlefield}</label></td> | ||||
| 							<td><input id="title" name="title" type="text" value="" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td><label id="classlabel" for="classlist">{#class_name}</label></td> | ||||
| 							<td> | ||||
| 								 <select id="classlist" name="classlist" onchange="changeClass();"> | ||||
| 									<option value="" selected>{#not_set}</option> | ||||
| 								 </select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="popup_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#advlink_dlg.popup_props}</legend> | ||||
|  | ||||
| 					<input type="checkbox" id="ispopup" name="ispopup" class="radio" onclick="setPopupControlsDisabled(!this.checked);buildOnClick();" /> | ||||
| 					<label id="ispopuplabel" for="ispopup">{#advlink_dlg.popup}</label> | ||||
|  | ||||
| 					<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="popupurl">{#advlink_dlg.popup_url}</label> </td> | ||||
| 							<td> | ||||
| 								<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="text" name="popupurl" id="popupurl" value="" onchange="buildOnClick();" /></td> | ||||
| 										<td id="popupurlbrowsercontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="popupname">{#advlink_dlg.popup_name}</label> </td> | ||||
| 							<td><input type="text" name="popupname" id="popupname" value="" onchange="buildOnClick();" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label>{#advlink_dlg.popup_size}</label> </td> | ||||
| 							<td nowrap="nowrap"> | ||||
| 								<input type="text" id="popupwidth" name="popupwidth" value="" onchange="buildOnClick();" /> x | ||||
| 								<input type="text" id="popupheight" name="popupheight" value="" onchange="buildOnClick();" /> px | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap" id="labelleft"><label>{#advlink_dlg.popup_position}</label> </td> | ||||
| 							<td nowrap="nowrap"> | ||||
| 								<input type="text" id="popupleft" name="popupleft" value="" onchange="buildOnClick();" /> /                                 | ||||
| 								<input type="text" id="popuptop" name="popuptop" value="" onchange="buildOnClick();" /> (c /c = center) | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
|  | ||||
| 					<fieldset> | ||||
| 						<legend>{#advlink_dlg.popup_opts}</legend> | ||||
|  | ||||
| 						<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 							<tr> | ||||
| 								<td><input type="checkbox" id="popuplocation" name="popuplocation" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popuplocationlabel" for="popuplocation">{#advlink_dlg.popup_location}</label></td> | ||||
| 								<td><input type="checkbox" id="popupscrollbars" name="popupscrollbars" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popupscrollbarslabel" for="popupscrollbars">{#advlink_dlg.popup_scrollbars}</label></td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><input type="checkbox" id="popupmenubar" name="popupmenubar" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popupmenubarlabel" for="popupmenubar">{#advlink_dlg.popup_menubar}</label></td> | ||||
| 								<td><input type="checkbox" id="popupresizable" name="popupresizable" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popupresizablelabel" for="popupresizable">{#advlink_dlg.popup_resizable}</label></td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><input type="checkbox" id="popuptoolbar" name="popuptoolbar" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popuptoolbarlabel" for="popuptoolbar">{#advlink_dlg.popup_toolbar}</label></td> | ||||
| 								<td><input type="checkbox" id="popupdependent" name="popupdependent" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popupdependentlabel" for="popupdependent">{#advlink_dlg.popup_dependent}</label></td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><input type="checkbox" id="popupstatus" name="popupstatus" class="checkbox" onchange="buildOnClick();" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popupstatuslabel" for="popupstatus">{#advlink_dlg.popup_statusbar}</label></td> | ||||
| 								<td><input type="checkbox" id="popupreturn" name="popupreturn" class="checkbox" onchange="buildOnClick();" checked="checked" /></td> | ||||
| 								<td nowrap="nowrap"><label id="popupreturnlabel" for="popupreturn">{#advlink_dlg.popup_return}</label></td> | ||||
| 							</tr> | ||||
| 						</table> | ||||
| 					</fieldset> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 			<fieldset> | ||||
| 					<legend>{#advlink_dlg.advanced_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="idlabel" for="id">{#advlink_dlg.id}</label></td>  | ||||
| 							<td><input id="id" name="id" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="stylelabel" for="style">{#advlink_dlg.style}</label></td> | ||||
| 							<td><input type="text" id="style" name="style" value="" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="classeslabel" for="classes">{#advlink_dlg.classes}</label></td> | ||||
| 							<td><input type="text" id="classes" name="classes" value="" onchange="selectByValue(this.form,'classlist',this.value,true);" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="targetlabel" for="target">{#advlink_dlg.target_name}</label></td> | ||||
| 							<td><input type="text" id="target" name="target" value="" onchange="selectByValue(this.form,'targetlist',this.value,true);" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="dirlabel" for="dir">{#advlink_dlg.langdir}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="dir" name="dir">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="ltr">{#advlink_dlg.ltr}</option>  | ||||
| 										<option value="rtl">{#advlink_dlg.rtl}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="hreflanglabel" for="hreflang">{#advlink_dlg.target_langcode}</label></td> | ||||
| 							<td><input type="text" id="hreflang" name="hreflang" value="" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="langlabel" for="lang">{#advlink_dlg.langcode}</label></td>  | ||||
| 							<td> | ||||
| 								<input id="lang" name="lang" type="text" value="" /> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="charsetlabel" for="charset">{#advlink_dlg.encoding}</label></td> | ||||
| 							<td><input type="text" id="charset" name="charset" value="" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="typelabel" for="type">{#advlink_dlg.mime}</label></td> | ||||
| 							<td><input type="text" id="type" name="type" value="" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="rellabel" for="rel">{#advlink_dlg.rel}</label></td> | ||||
| 							<td><select id="rel" name="rel">  | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="lightbox">Lightbox</option>  | ||||
| 									<option value="alternate">Alternate</option>  | ||||
| 									<option value="designates">Designates</option>  | ||||
| 									<option value="stylesheet">Stylesheet</option>  | ||||
| 									<option value="start">Start</option>  | ||||
| 									<option value="next">Next</option>  | ||||
| 									<option value="prev">Prev</option>  | ||||
| 									<option value="contents">Contents</option>  | ||||
| 									<option value="index">Index</option>  | ||||
| 									<option value="glossary">Glossary</option>  | ||||
| 									<option value="copyright">Copyright</option>  | ||||
| 									<option value="chapter">Chapter</option>  | ||||
| 									<option value="subsection">Subsection</option>  | ||||
| 									<option value="appendix">Appendix</option>  | ||||
| 									<option value="help">Help</option>  | ||||
| 									<option value="bookmark">Bookmark</option> | ||||
| 									<option value="nofollow">No Follow</option> | ||||
| 									<option value="tag">Tag</option> | ||||
| 								</select>  | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="revlabel" for="rev">{#advlink_dlg.rev}</label></td> | ||||
| 							<td><select id="rev" name="rev">  | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="alternate">Alternate</option>  | ||||
| 									<option value="designates">Designates</option>  | ||||
| 									<option value="stylesheet">Stylesheet</option>  | ||||
| 									<option value="start">Start</option>  | ||||
| 									<option value="next">Next</option>  | ||||
| 									<option value="prev">Prev</option>  | ||||
| 									<option value="contents">Contents</option>  | ||||
| 									<option value="index">Index</option>  | ||||
| 									<option value="glossary">Glossary</option>  | ||||
| 									<option value="copyright">Copyright</option>  | ||||
| 									<option value="chapter">Chapter</option>  | ||||
| 									<option value="subsection">Subsection</option>  | ||||
| 									<option value="appendix">Appendix</option>  | ||||
| 									<option value="help">Help</option>  | ||||
| 									<option value="bookmark">Bookmark</option>  | ||||
| 								</select>  | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="tabindexlabel" for="tabindex">{#advlink_dlg.tabindex}</label></td> | ||||
| 							<td><input type="text" id="tabindex" name="tabindex" value="" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label id="accesskeylabel" for="accesskey">{#advlink_dlg.accesskey}</label></td> | ||||
| 							<td><input type="text" id="accesskey" name="accesskey" value="" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="events_panel" class="panel"> | ||||
| 			<fieldset> | ||||
| 					<legend>{#advlink_dlg.event_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onfocus">onfocus</label></td>  | ||||
| 							<td><input id="onfocus" name="onfocus" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onblur">onblur</label></td>  | ||||
| 							<td><input id="onblur" name="onblur" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onclick">onclick</label></td>  | ||||
| 							<td><input id="onclick" name="onclick" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="ondblclick">ondblclick</label></td>  | ||||
| 							<td><input id="ondblclick" name="ondblclick" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onmousedown">onmousedown</label></td>  | ||||
| 							<td><input id="onmousedown" name="onmousedown" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onmouseup">onmouseup</label></td>  | ||||
| 							<td><input id="onmouseup" name="onmouseup" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onmouseover">onmouseover</label></td>  | ||||
| 							<td><input id="onmouseover" name="onmouseover" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onmousemove">onmousemove</label></td>  | ||||
| 							<td><input id="onmousemove" name="onmousemove" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onmouseout">onmouseout</label></td>  | ||||
| 							<td><input id="onmouseout" name="onmouseout" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onkeypress">onkeypress</label></td>  | ||||
| 							<td><input id="onkeypress" name="onkeypress" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onkeydown">onkeydown</label></td>  | ||||
| 							<td><input id="onkeydown" name="onkeydown" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="onkeyup">onkeyup</label></td>  | ||||
| 							<td><input id="onkeyup" name="onkeyup" type="text" value="" /></td>  | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
|     </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.FullPagePlugin',{init:function(ed,url){var t=this;t.editor=ed;ed.addCommand('mceFullPageProperties',function(){ed.windowManager.open({file:url+'/fullpage.htm',width:430+parseInt(ed.getLang('fullpage.delta_width',0)),height:495+parseInt(ed.getLang('fullpage.delta_height',0)),inline:1},{plugin_url:url,head_html:t.head});});ed.addButton('fullpage',{title:'fullpage.desc',cmd:'mceFullPageProperties'});ed.onBeforeSetContent.add(t._setContent,t);ed.onSetContent.add(t._setBodyAttribs,t);ed.onGetContent.add(t._getContent,t);},getInfo:function(){return{longname:'Fullpage',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullpage',version:tinymce.majorVersion+"."+tinymce.minorVersion};},_setBodyAttribs:function(ed,o){var bdattr,i,len,kv,k,v,t,attr=this.head.match(/body(.*?)>/i);if(attr&&attr[1]){bdattr=attr[1].match(/\s*(\w+\s*=\s*".*?"|\w+\s*=\s*'.*?'|\w+\s*=\s*\w+|\w+)\s*/g);for(i=0,len=bdattr.length;i<len;i++){kv=bdattr[i].split('=');k=kv[0].replace(/\s/,'');v=kv[1];if(v){v=v.replace(/^\s+/,'').replace(/\s+$/,'');t=v.match(/^["'](.*)["']$/);if(t)v=t[1];}else v=k;ed.dom.setAttrib(ed.getBody(),'style',v);}}},_createSerializer:function(){return new tinymce.dom.Serializer({dom:this.editor.dom,apply_source_formatting:true});},_setContent:function(ed,o){var t=this,sp,ep,c=o.content,v,st='';c=c.replace(/<(\/?)BODY/gi,'<$1body');sp=c.indexOf('<body');if(sp!=-1){sp=c.indexOf('>',sp);t.head=c.substring(0,sp+1);ep=c.indexOf('</body',sp);if(ep==-1)ep=c.indexOf('</body',ep);o.content=c.substring(sp+1,ep);t.foot=c.substring(ep);function low(s){return s.replace(/<\/?[A-Z]+/g,function(a){return a.toLowerCase();})};t.head=low(t.head);t.foot=low(t.foot);}else{t.head='';if(ed.getParam('fullpage_default_xml_pi'))t.head+='<?xml version="1.0" encoding="'+ed.getParam('fullpage_default_encoding','ISO-8859-1')+'" ?>\n';t.head+=ed.getParam('fullpage_default_doctype','<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">');t.head+='\n<html>\n<head>\n<title>'+ed.getParam('fullpage_default_title','Untitled document')+'</title>\n';if(v=ed.getParam('fullpage_default_encoding'))t.head+='<meta http-equiv="Content-Type" content="'+v+'" />\n';if(v=ed.getParam('fullpage_default_font_family'))st+='font-family: '+v+';';if(v=ed.getParam('fullpage_default_font_size'))st+='font-size: '+v+';';if(v=ed.getParam('fullpage_default_text_color'))st+='color: '+v+';';t.head+='</head>\n<body'+(st?' style="'+st+'"':'')+'>\n';t.foot='\n</body>\n</html>';}},_getContent:function(ed,o){var t=this;o.content=tinymce.trim(t.head)+'\n'+tinymce.trim(o.content)+'\n'+tinymce.trim(t.foot);}});tinymce.PluginManager.add('fullpage',tinymce.plugins.FullPagePlugin);})(); | ||||
| @@ -0,0 +1,140 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:26 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.FullPagePlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			var t = this; | ||||
|  | ||||
| 			t.editor = ed; | ||||
|  | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceFullPageProperties', function() { | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/fullpage.htm', | ||||
| 					width : 430 + parseInt(ed.getLang('fullpage.delta_width', 0)), | ||||
| 					height : 495 + parseInt(ed.getLang('fullpage.delta_height', 0)), | ||||
| 					inline : 1 | ||||
| 				}, { | ||||
| 					plugin_url : url, | ||||
| 					head_html : t.head | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('fullpage', {title : 'fullpage.desc', cmd : 'mceFullPageProperties'}); | ||||
|  | ||||
| 			ed.onBeforeSetContent.add(t._setContent, t); | ||||
| 			ed.onSetContent.add(t._setBodyAttribs, t); | ||||
| 			ed.onGetContent.add(t._getContent, t); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Fullpage', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/fullpage', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		// Private plugin internal methods | ||||
|  | ||||
| 		_setBodyAttribs : function(ed, o) { | ||||
| 			var bdattr, i, len, kv, k, v, t, attr = this.head.match(/body(.*?)>/i); | ||||
|  | ||||
| 			if (attr && attr[1]) { | ||||
| 				bdattr = attr[1].match(/\s*(\w+\s*=\s*".*?"|\w+\s*=\s*'.*?'|\w+\s*=\s*\w+|\w+)\s*/g); | ||||
|  | ||||
| 				for(i = 0, len = bdattr.length; i < len; i++) { | ||||
| 					kv = bdattr[i].split('='); | ||||
| 					k = kv[0].replace(/\s/,''); | ||||
| 					v = kv[1]; | ||||
|  | ||||
| 					if (v) { | ||||
| 						v = v.replace(/^\s+/,'').replace(/\s+$/,''); | ||||
| 						t = v.match(/^["'](.*)["']$/); | ||||
|  | ||||
| 						if (t) | ||||
| 							v = t[1]; | ||||
| 					} else | ||||
| 						v = k; | ||||
|  | ||||
| 					ed.dom.setAttrib(ed.getBody(), 'style', v); | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_createSerializer : function() { | ||||
| 			return new tinymce.dom.Serializer({ | ||||
| 				dom : this.editor.dom, | ||||
| 				apply_source_formatting : true | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		_setContent : function(ed, o) { | ||||
| 			var t = this, sp, ep, c = o.content, v, st = ''; | ||||
|  | ||||
| 			// Parse out head, body and footer | ||||
| 			c = c.replace(/<(\/?)BODY/gi, '<$1body'); | ||||
| 			sp = c.indexOf('<body'); | ||||
|  | ||||
| 			if (sp != -1) { | ||||
| 				sp = c.indexOf('>', sp); | ||||
| 				t.head = c.substring(0, sp + 1); | ||||
|  | ||||
| 				ep = c.indexOf('</body', sp); | ||||
| 				if (ep == -1) | ||||
| 					ep = c.indexOf('</body', ep); | ||||
|  | ||||
| 				o.content = c.substring(sp + 1, ep); | ||||
| 				t.foot = c.substring(ep); | ||||
|  | ||||
| 				function low(s) { | ||||
| 					return s.replace(/<\/?[A-Z]+/g, function(a) { | ||||
| 						return a.toLowerCase(); | ||||
| 					}) | ||||
| 				}; | ||||
|  | ||||
| 				t.head = low(t.head); | ||||
| 				t.foot = low(t.foot); | ||||
| 			} else { | ||||
| 				t.head = ''; | ||||
| 				if (ed.getParam('fullpage_default_xml_pi')) | ||||
| 					t.head += '<?xml version="1.0" encoding="' + ed.getParam('fullpage_default_encoding', 'ISO-8859-1') + '" ?>\n'; | ||||
|  | ||||
| 				t.head += ed.getParam('fullpage_default_doctype', '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">'); | ||||
| 				t.head += '\n<html>\n<head>\n<title>' + ed.getParam('fullpage_default_title', 'Untitled document') + '</title>\n'; | ||||
|  | ||||
| 				if (v = ed.getParam('fullpage_default_encoding')) | ||||
| 					t.head += '<meta http-equiv="Content-Type" content="' + v + '" />\n'; | ||||
|  | ||||
| 				if (v = ed.getParam('fullpage_default_font_family')) | ||||
| 					st += 'font-family: ' + v + ';'; | ||||
|  | ||||
| 				if (v = ed.getParam('fullpage_default_font_size')) | ||||
| 					st += 'font-size: ' + v + ';'; | ||||
|  | ||||
| 				if (v = ed.getParam('fullpage_default_text_color')) | ||||
| 					st += 'color: ' + v + ';'; | ||||
|  | ||||
| 				t.head += '</head>\n<body' + (st ? ' style="' + st + '"' : '') + '>\n'; | ||||
| 				t.foot = '\n</body>\n</html>'; | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_getContent : function(ed, o) { | ||||
| 			var t = this; | ||||
|  | ||||
| 			o.content = tinymce.trim(t.head) + '\n' + tinymce.trim(o.content) + '\n' + tinymce.trim(t.foot); | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('fullpage', tinymce.plugins.FullPagePlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,577 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#fullpage_dlg.title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="js/fullpage.js"></script> | ||||
| 	<link href="css/fullpage.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="advlink" style="display: none"> | ||||
|     <form onsubmit="updateAction();return false;" name="fullpage" action="#"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="meta_tab" class="current"><span><a href="javascript:mcTabs.displayTab('meta_tab','meta_panel');" onmousedown="return false;">{#fullpage_dlg.meta_tab}</a></span></li> | ||||
| 				<li id="appearance_tab"><span><a href="javascript:mcTabs.displayTab('appearance_tab','appearance_panel');" onmousedown="return false;">{#fullpage_dlg.appearance_tab}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#fullpage_dlg.advanced_tab}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="meta_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.meta_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="metatitle">{#fullpage_dlg.meta_title}</label> </td> | ||||
| 							<td><input type="text" id="metatitle" name="metatitle" value="" class="mceFocus" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="metakeywords">{#fullpage_dlg.meta_keywords}</label> </td> | ||||
| 							<td><textarea id="metakeywords" name="metakeywords" rows="4"></textarea></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="metadescription">{#fullpage_dlg.meta_description}</label> </td> | ||||
| 							<td><textarea id="metadescription" name="metadescription" rows="4"></textarea></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="metaauthor">{#fullpage_dlg.author}</label> </td> | ||||
| 							<td><input type="text" id="metaauthor" name="metaauthor" value="" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="metacopyright">{#fullpage_dlg.copyright}</label> </td> | ||||
| 							<td><input type="text" id="metacopyright" name="metacopyright" value="" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="metarobots">{#fullpage_dlg.meta_robots}</label> </td> | ||||
| 							<td> | ||||
| 								<select id="metarobots" name="metarobots"> | ||||
| 											<option value="">{#not_set}</option>  | ||||
| 											<option value="index,follow">{#fullpage_dlg.meta_index_follow}</option> | ||||
| 											<option value="index,nofollow">{#fullpage_dlg.meta_index_nofollow}</option> | ||||
| 											<option value="noindex,follow">{#fullpage_dlg.meta_noindex_follow}</option> | ||||
| 											<option value="noindex,nofollow">{#fullpage_dlg.meta_noindex_nofollow}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.langprops}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="docencoding">{#fullpage_dlg.encoding}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="docencoding" name="docencoding">  | ||||
| 										<option value="">{#not_set}</option> | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="doctypes">{#fullpage_dlg.doctypes}</label> </td> | ||||
| 							<td> | ||||
| 								<select id="doctypes" name="doctypes"> | ||||
| 										<option value="">{#not_set}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="langcode">{#fullpage_dlg.langcode}</label> </td> | ||||
| 							<td><input type="text" id="langcode" name="langcode" value="" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="langdir">{#fullpage_dlg.langdir}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="langdir" name="langdir">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="ltr">{#fullpage_dlg.ltr}</option>  | ||||
| 										<option value="rtl">{#fullpage_dlg.rtl}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td nowrap="nowrap"><label for="xml_pi">{#fullpage_dlg.xml_pi}</label> </td> | ||||
| 							<td><input type="checkbox" id="xml_pi" name="xml_pi" class="checkbox" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="appearance_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.appearance_textprops}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="fontface">{#fullpage_dlg.fontface}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="fontface" name="fontface" onchange="changedStyleField(this);"> | ||||
| 										<option value="">{#not_set}</option> | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="fontsize">{#fullpage_dlg.fontsize}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="fontsize" name="fontsize" onchange="changedStyleField(this);"> | ||||
| 										<option value="">{#not_set}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="textcolor">{#fullpage_dlg.textcolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="textcolor" name="textcolor" type="text" value="" size="9" onchange="updateColor('textcolor_pick','textcolor');changedStyleField(this);" /></td> | ||||
| 										<td id="textcolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.appearance_bgprops}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bgimage">{#fullpage_dlg.bgimage}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bgimage" name="bgimage" type="text" value="" onchange="changedStyleField(this);" /></td> | ||||
| 										<td id="bgimage_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bgcolor">{#fullpage_dlg.bgcolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedStyleField(this);" /></td> | ||||
| 										<td id="bgcolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.appearance_marginprops}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="leftmargin">{#fullpage_dlg.left_margin}</label></td>  | ||||
| 							<td><input id="leftmargin" name="leftmargin" type="text" value="" onchange="changedStyleField(this);" /></td> | ||||
| 							<td class="column1"><label for="rightmargin">{#fullpage_dlg.right_margin}</label></td>  | ||||
| 							<td><input id="rightmargin" name="rightmargin" type="text" value="" onchange="changedStyleField(this);" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="topmargin">{#fullpage_dlg.top_margin}</label></td>  | ||||
| 							<td><input id="topmargin" name="topmargin" type="text" value="" onchange="changedStyleField(this);" /></td> | ||||
| 							<td class="column1"><label for="bottommargin">{#fullpage_dlg.bottom_margin}</label></td>  | ||||
| 							<td><input id="bottommargin" name="bottommargin" type="text" value="" onchange="changedStyleField(this);" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.appearance_linkprops}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="link_color">{#fullpage_dlg.link_color}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="link_color" name="link_color" type="text" value="" size="9" onchange="updateColor('link_color_pick','link_color');changedStyleField(this);" /></td> | ||||
| 										<td id="link_color_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td class="column1"><label for="visited_color">{#fullpage_dlg.visited_color}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="visited_color" name="visited_color" type="text" value="" size="9" onchange="updateColor('visited_color_pick','visited_color');changedStyleField(this);" /></td> | ||||
| 										<td id="visited_color_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="active_color">{#fullpage_dlg.active_color}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="active_color" name="active_color" type="text" value="" size="9" onchange="updateColor('active_color_pick','active_color');changedStyleField(this);" /></td> | ||||
| 										<td id="active_color_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td> </td> | ||||
| 							<td> </td> | ||||
|  | ||||
| <!--							<td class="column1"><label for="hover_color">{#fullpage_dlg.hover_color}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="hover_color" name="hover_color" type="text" value="" size="9" onchange="changedStyleField(this);" /></td> | ||||
| 										<td id="hover_color_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> --> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.appearance_style}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="stylesheet">{#fullpage_dlg.stylesheet}</label></td>  | ||||
| 							<td><table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="stylesheet" name="stylesheet" type="text" value="" /></td> | ||||
| 										<td id="stylesheet_browsercontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="style">{#fullpage_dlg.style}</label></td>  | ||||
| 							<td><input id="style" name="style" type="text" value="" onchange="changedStyleField(this);" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 				<div id="addmenu"> | ||||
| 					<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 						<tr><td><a href="javascript:addHeadElm('title');" onmousedown="return false;"><span>{#fullpage_dlg.add_title}</span></a></td></tr> | ||||
| 						<tr><td><a href="javascript:addHeadElm('meta');" onmousedown="return false;"><span>{#fullpage_dlg.add_meta}</span></a></td></tr> | ||||
| 						<tr><td><a href="javascript:addHeadElm('script');" onmousedown="return false;"><span>{#fullpage_dlg.add_script}</span></a></td></tr> | ||||
| 						<tr><td><a href="javascript:addHeadElm('style');" onmousedown="return false;"><span>{#fullpage_dlg.add_style}</span></a></td></tr> | ||||
| 						<tr><td><a href="javascript:addHeadElm('link');" onmousedown="return false;"><span>{#fullpage_dlg.add_link}</span></a></td></tr> | ||||
| 						<tr><td><a href="javascript:addHeadElm('base');" onmousedown="return false;"><span>{#fullpage_dlg.add_base}</span></a></td></tr> | ||||
| 						<tr><td><a href="javascript:addHeadElm('comment');" onmousedown="return false;"><span>{#fullpage_dlg.add_comment}</span></a></td></tr> | ||||
| 					</table> | ||||
| 				</div> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#fullpage_dlg.head_elements}</legend> | ||||
|  | ||||
| 					<div class="headlistwrapper"> | ||||
| 						<div class="toolbar"> | ||||
| 							<div style="float: left"> | ||||
| 								<a id="addbutton" href="javascript:showAddMenu();" onmousedown="return false;" class="addbutton" title="{#fullpage_dlg.add}"></a> | ||||
| 								<a href="#" onmousedown="return false;" class="removebutton" title="{#fullpage_dlg.remove}"></a> | ||||
| 							</div> | ||||
| 							<div style="float: right"> | ||||
| 								<a href="#" onmousedown="return false;" class="moveupbutton" title="{#fullpage_dlg.moveup}"></a> | ||||
| 								<a href="#" onmousedown="return false;" class="movedownbutton" title="{#fullpage_dlg.movedown}"></a> | ||||
| 							</div> | ||||
| 							<br style="clear: both" /> | ||||
| 						</div> | ||||
| 						<select id="headlist" size="26" onchange="updateHeadElm(this.options[this.selectedIndex].value);"> | ||||
| 							<option value="title_0"><title>Some title bla bla bla</title></option> | ||||
| 							<option value="meta_1"><meta name="keywords">Some bla bla bla</meta></option> | ||||
| 							<option value="meta_2"><meta name="description">Some bla bla bla bla bla bla bla bla bla</meta></option> | ||||
| 							<option value="script_3"><script language="javascript">...</script></option> | ||||
| 							<option value="style_4"><style>...</style></option> | ||||
| 							<option value="base_5"><base href="." /></option> | ||||
| 							<option value="comment_6"><!-- ... --></option> | ||||
| 							<option value="link_7"><link href="." /></option> | ||||
| 						</select> | ||||
| 					</div> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="meta_element"> | ||||
| 					<legend>{#fullpage_dlg.meta_element}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="element_meta_type">{#fullpage_dlg.type}</label></td>  | ||||
| 							<td><select id="element_meta_type"> | ||||
| 										<option value="name">name</option> | ||||
| 										<option value="http-equiv">http-equiv</option> | ||||
| 								</select></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="element_meta_name">{#fullpage_dlg.name}</label></td>  | ||||
| 							<td><input id="element_meta_name" name="element_meta_name" type="text" value="" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="element_meta_content">{#fullpage_dlg.content}</label></td>  | ||||
| 							<td><input id="element_meta_content" name="element_meta_content" type="text" value="" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
|  | ||||
| 					<input type="button" id="meta_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="title_element"> | ||||
| 					<legend>{#fullpage_dlg.title_element}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="element_title">{#fullpage_dlg.meta_title}</label></td>  | ||||
| 							<td><input id="element_title" name="element_title" type="text" value="" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
|  | ||||
| 					<input type="button" id="title_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="script_element"> | ||||
| 					<legend>{#fullpage_dlg.script_element}</legend> | ||||
|  | ||||
| 					<div class="tabs"> | ||||
| 						<ul> | ||||
| 							<li id="script_props_tab" class="current"><span><a href="javascript:mcTabs.displayTab('script_props_tab','script_props_panel');" onmousedown="return false;">{#fullpage_dlg.properties}</a></span></li> | ||||
| 							<li id="script_value_tab"><span><a href="javascript:mcTabs.displayTab('script_value_tab','script_value_panel');" onmousedown="return false;">{#fullpage_dlg.value}</a></span></li> | ||||
| 						</ul> | ||||
| 					</div> | ||||
|  | ||||
| 					<br style="clear: both" /> | ||||
|  | ||||
| 					<div class="panel_wrapper"> | ||||
| 						<div id="script_props_panel" class="panel current"> | ||||
| 							<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_script_type">{#fullpage_dlg.type}</label></td>  | ||||
| 									<td><select id="element_script_type"> | ||||
| 										<option value="text/javascript">text/javascript</option> | ||||
| 										<option value="text/jscript">text/jscript</option> | ||||
| 										<option value="text/vbscript">text/vbscript</option> | ||||
| 										<option value="text/vbs">text/vbs</option> | ||||
| 										<option value="text/ecmascript">text/ecmascript</option> | ||||
| 										<option value="text/xml">text/xml</option> | ||||
| 									</select></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_script_src">{#fullpage_dlg.src}</label></td>  | ||||
| 									<td><table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="element_script_src" name="element_script_src" type="text" value="" /></td> | ||||
| 										<td id="script_src_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_script_charset">{#fullpage_dlg.charset}</label></td>  | ||||
| 									<td><select id="element_script_charset"><option value="">{#not_set}</option></select></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_script_defer">{#fullpage_dlg.defer}</label></td>  | ||||
| 									<td><input type="checkbox" id="element_script_defer" name="element_script_defer" class="checkbox" /></td> | ||||
| 								</tr> | ||||
| 							</table> | ||||
| 						</div> | ||||
|  | ||||
| 						<div id="script_value_panel" class="panel"> | ||||
| 							<textarea id="element_script_value"></textarea> | ||||
| 						</div> | ||||
| 					</div> | ||||
|  | ||||
| 					<input type="button" id="script_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="style_element"> | ||||
| 					<legend>{#fullpage_dlg.style_element}</legend> | ||||
|  | ||||
| 					<div class="tabs"> | ||||
| 						<ul> | ||||
| 							<li id="style_props_tab" class="current"><span><a href="javascript:mcTabs.displayTab('style_props_tab','style_props_panel');" onmousedown="return false;">{#fullpage_dlg.properties}</a></span></li> | ||||
| 							<li id="style_value_tab"><span><a href="javascript:mcTabs.displayTab('style_value_tab','style_value_panel');" onmousedown="return false;">{#fullpage_dlg.value}</a></span></li> | ||||
| 						</ul> | ||||
| 					</div> | ||||
|  | ||||
| 					<br style="clear: both" /> | ||||
|  | ||||
| 					<div class="panel_wrapper"> | ||||
| 						<div id="style_props_panel" class="panel current"> | ||||
| 							<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_style_type">{#fullpage_dlg.type}</label></td>  | ||||
| 									<td><select id="element_style_type"> | ||||
| 										<option value="text/css">text/css</option> | ||||
| 									</select></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_style_media">{#fullpage_dlg.media}</label></td>  | ||||
| 									<td><select id="element_style_media"></select></td> | ||||
| 								</tr> | ||||
| 							</table> | ||||
| 						</div> | ||||
|  | ||||
| 						<div id="style_value_panel" class="panel"> | ||||
| 							<textarea id="element_style_value"></textarea> | ||||
| 						</div> | ||||
| 					</div> | ||||
|  | ||||
| 					<input type="button" id="style_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="base_element"> | ||||
| 					<legend>{#fullpage_dlg.base_element}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="element_base_href">{#fullpage_dlg.href}</label></td>  | ||||
| 							<td><input id="element_base_href" name="element_base_href" type="text" value="" /></td> | ||||
| 						</tr> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="element_base_target">{#fullpage_dlg.target}</label></td>  | ||||
| 							<td><input id="element_base_target" name="element_base_target" type="text" value="" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
|  | ||||
| 					<input type="button" id="base_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="link_element"> | ||||
| 					<legend>{#fullpage_dlg.link_element}</legend> | ||||
|  | ||||
| 					<div class="tabs"> | ||||
| 						<ul> | ||||
| 							<li id="link_general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('link_general_tab','link_general_panel');" onmousedown="return false;">{#fullpage_dlg.general_props}</a></span></li> | ||||
| 							<li id="link_advanced_tab"><span><a href="javascript:mcTabs.displayTab('link_advanced_tab','link_advanced_panel');" onmousedown="return false;">{#fullpage_dlg.advanced_props}</a></span></li> | ||||
| 						</ul> | ||||
| 					</div> | ||||
|  | ||||
| 					<br style="clear: both" /> | ||||
|  | ||||
| 					<div class="panel_wrapper"> | ||||
| 						<div id="link_general_panel" class="panel current"> | ||||
| 							<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_href">{#fullpage_dlg.href}</label></td>  | ||||
| 									<td><table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="element_link_href" name="element_link_href" type="text" value="" /></td> | ||||
| 										<td id="link_href_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_title">{#fullpage_dlg.meta_title}</label></td>  | ||||
| 									<td><input id="element_link_title" name="element_link_title" type="text" value="" /></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_type">{#fullpage_dlg.type}</label></td>  | ||||
| 									<td><select id="element_link_type" name="element_link_type"> | ||||
| 										<option value="text/css">text/css</option> | ||||
| 										<option value="text/javascript">text/javascript</option> | ||||
| 									</select></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_media">{#fullpage_dlg.media}</label></td>  | ||||
| 									<td><select id="element_link_media" name="element_link_media"></select></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td><label for="element_style_rel">{#fullpage_dlg.rel}</label></td> | ||||
| 									<td><select id="element_style_rel" name="element_style_rel">  | ||||
| 											<option value="">{#not_set}</option>  | ||||
| 											<option value="stylesheet">Stylesheet</option> | ||||
| 											<option value="alternate">Alternate</option> | ||||
| 											<option value="designates">Designates</option> | ||||
| 											<option value="start">Start</option> | ||||
| 											<option value="next">Next</option> | ||||
| 											<option value="prev">Prev</option> | ||||
| 											<option value="contents">Contents</option> | ||||
| 											<option value="index">Index</option> | ||||
| 											<option value="glossary">Glossary</option> | ||||
| 											<option value="copyright">Copyright</option> | ||||
| 											<option value="chapter">Chapter</option> | ||||
| 											<option value="subsection">Subsection</option> | ||||
| 											<option value="appendix">Appendix</option> | ||||
| 											<option value="help">Help</option> | ||||
| 											<option value="bookmark">Bookmark</option> | ||||
| 										</select>  | ||||
| 									</td> | ||||
| 								</tr> | ||||
| 							</table> | ||||
| 						</div> | ||||
|  | ||||
| 						<div id="link_advanced_panel" class="panel"> | ||||
| 							<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_charset">{#fullpage_dlg.charset}</label></td>  | ||||
| 									<td><select id="element_link_charset"><option value="">{#not_set}</option></select></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_hreflang">{#fullpage_dlg.hreflang}</label></td>  | ||||
| 									<td><input id="element_link_hreflang" name="element_link_hreflang" type="text" value="" /></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td class="column1"><label for="element_link_target">{#fullpage_dlg.target}</label></td>  | ||||
| 									<td><input id="element_link_target" name="element_link_target" type="text" value="" /></td> | ||||
| 								</tr> | ||||
| 								<tr> | ||||
| 									<td><label for="element_style_rev">{#fullpage_dlg.rev}</label></td> | ||||
| 									<td><select id="element_style_rev" name="element_style_rev">  | ||||
| 											<option value="">{#not_set}</option>  | ||||
| 											<option value="alternate">Alternate</option>  | ||||
| 											<option value="designates">Designates</option>  | ||||
| 											<option value="stylesheet">Stylesheet</option>  | ||||
| 											<option value="start">Start</option>  | ||||
| 											<option value="next">Next</option>  | ||||
| 											<option value="prev">Prev</option>  | ||||
| 											<option value="contents">Contents</option>  | ||||
| 											<option value="index">Index</option>  | ||||
| 											<option value="glossary">Glossary</option>  | ||||
| 											<option value="copyright">Copyright</option>  | ||||
| 											<option value="chapter">Chapter</option>  | ||||
| 											<option value="subsection">Subsection</option>  | ||||
| 											<option value="appendix">Appendix</option>  | ||||
| 											<option value="help">Help</option>  | ||||
| 											<option value="bookmark">Bookmark</option>  | ||||
| 										</select>  | ||||
| 									</td> | ||||
| 								</tr> | ||||
| 							</table> | ||||
| 						</div> | ||||
| 					</div> | ||||
|  | ||||
| 					<input type="button" id="link_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="comment_element"> | ||||
| 					<legend>{#fullpage_dlg.comment_element}</legend> | ||||
|  | ||||
| 					<textarea id="element_comment_value"></textarea> | ||||
|  | ||||
| 					<input type="button" id="comment_updateelement" class="updateElementButton" name="update" value="{#update}" onclick="updateElement();" /> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="submit" id="insert" name="update" value="{#update}" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
|     </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,462 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var doc; | ||||
|  | ||||
| var defaultDocTypes =  | ||||
| 	'XHTML 1.0 Transitional=<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">,' + | ||||
| 	'XHTML 1.0 Frameset=<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">,' + | ||||
| 	'XHTML 1.0 Strict=<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">,' + | ||||
| 	'XHTML 1.1=<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">,' + | ||||
| 	'HTML 4.01 Transitional=<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">,' + | ||||
| 	'HTML 4.01 Strict=<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">,' + | ||||
| 	'HTML 4.01 Frameset=<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd">'; | ||||
|  | ||||
| var defaultEncodings =  | ||||
| 	'Western european (iso-8859-1)=iso-8859-1,' + | ||||
| 	'Central European (iso-8859-2)=iso-8859-2,' + | ||||
| 	'Unicode (UTF-8)=utf-8,' + | ||||
| 	'Chinese traditional (Big5)=big5,' + | ||||
| 	'Cyrillic (iso-8859-5)=iso-8859-5,' + | ||||
| 	'Japanese (iso-2022-jp)=iso-2022-jp,' + | ||||
| 	'Greek (iso-8859-7)=iso-8859-7,' + | ||||
| 	'Korean (iso-2022-kr)=iso-2022-kr,' + | ||||
| 	'ASCII (us-ascii)=us-ascii'; | ||||
|  | ||||
| var defaultMediaTypes =  | ||||
| 	'all=all,' + | ||||
| 	'screen=screen,' + | ||||
| 	'print=print,' + | ||||
| 	'tty=tty,' + | ||||
| 	'tv=tv,' + | ||||
| 	'projection=projection,' + | ||||
| 	'handheld=handheld,' + | ||||
| 	'braille=braille,' + | ||||
| 	'aural=aural'; | ||||
|  | ||||
| var defaultFontNames = 'Arial=arial,helvetica,sans-serif;Courier New=courier new,courier,monospace;Georgia=georgia,times new roman,times,serif;Tahoma=tahoma,arial,helvetica,sans-serif;Times New Roman=times new roman,times,serif;Verdana=verdana,arial,helvetica,sans-serif;Impact=impact;WingDings=wingdings'; | ||||
| var defaultFontSizes = '10px,11px,12px,13px,14px,15px,16px'; | ||||
|  | ||||
| function init() { | ||||
| 	var f = document.forms['fullpage'], el = f.elements, e, i, p, doctypes, encodings, mediaTypes, fonts, ed = tinyMCEPopup.editor, dom = tinyMCEPopup.dom, style; | ||||
|  | ||||
| 	// Setup doctype select box | ||||
| 	doctypes = ed.getParam("fullpage_doctypes", defaultDocTypes).split(','); | ||||
| 	for (i=0; i<doctypes.length; i++) { | ||||
| 		p = doctypes[i].split('='); | ||||
|  | ||||
| 		if (p.length > 1) | ||||
| 			addSelectValue(f, 'doctypes', p[0], p[1]); | ||||
| 	} | ||||
|  | ||||
| 	// Setup fonts select box | ||||
| 	fonts = ed.getParam("fullpage_fonts", defaultFontNames).split(';'); | ||||
| 	for (i=0; i<fonts.length; i++) { | ||||
| 		p = fonts[i].split('='); | ||||
|  | ||||
| 		if (p.length > 1) | ||||
| 			addSelectValue(f, 'fontface', p[0], p[1]); | ||||
| 	} | ||||
|  | ||||
| 	// Setup fontsize select box | ||||
| 	fonts = ed.getParam("fullpage_fontsizes", defaultFontSizes).split(','); | ||||
| 	for (i=0; i<fonts.length; i++) | ||||
| 		addSelectValue(f, 'fontsize', fonts[i], fonts[i]); | ||||
|  | ||||
| 	// Setup mediatype select boxs | ||||
| 	mediaTypes = ed.getParam("fullpage_media_types", defaultMediaTypes).split(','); | ||||
| 	for (i=0; i<mediaTypes.length; i++) { | ||||
| 		p = mediaTypes[i].split('='); | ||||
|  | ||||
| 		if (p.length > 1) { | ||||
| 			addSelectValue(f, 'element_style_media', p[0], p[1]); | ||||
| 			addSelectValue(f, 'element_link_media', p[0], p[1]); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// Setup encodings select box | ||||
| 	encodings = ed.getParam("fullpage_encodings", defaultEncodings).split(','); | ||||
| 	for (i=0; i<encodings.length; i++) { | ||||
| 		p = encodings[i].split('='); | ||||
|  | ||||
| 		if (p.length > 1) { | ||||
| 			addSelectValue(f, 'docencoding', p[0], p[1]); | ||||
| 			addSelectValue(f, 'element_script_charset', p[0], p[1]); | ||||
| 			addSelectValue(f, 'element_link_charset', p[0], p[1]); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor'); | ||||
| 	document.getElementById('link_color_pickcontainer').innerHTML = getColorPickerHTML('link_color_pick','link_color'); | ||||
| 	//document.getElementById('hover_color_pickcontainer').innerHTML = getColorPickerHTML('hover_color_pick','hover_color'); | ||||
| 	document.getElementById('visited_color_pickcontainer').innerHTML = getColorPickerHTML('visited_color_pick','visited_color'); | ||||
| 	document.getElementById('active_color_pickcontainer').innerHTML = getColorPickerHTML('active_color_pick','active_color'); | ||||
| 	document.getElementById('textcolor_pickcontainer').innerHTML = getColorPickerHTML('textcolor_pick','textcolor'); | ||||
| 	document.getElementById('stylesheet_browsercontainer').innerHTML = getBrowserHTML('stylesheetbrowser','stylesheet','file','fullpage'); | ||||
| 	document.getElementById('link_href_pickcontainer').innerHTML = getBrowserHTML('link_href_browser','element_link_href','file','fullpage'); | ||||
| 	document.getElementById('script_src_pickcontainer').innerHTML = getBrowserHTML('script_src_browser','element_script_src','file','fullpage'); | ||||
| 	document.getElementById('bgimage_pickcontainer').innerHTML = getBrowserHTML('bgimage_browser','bgimage','image','fullpage'); | ||||
|  | ||||
| 	// Resize some elements | ||||
| 	if (isVisible('stylesheetbrowser')) | ||||
| 		document.getElementById('stylesheet').style.width = '220px'; | ||||
|  | ||||
| 	if (isVisible('link_href_browser')) | ||||
| 		document.getElementById('element_link_href').style.width = '230px'; | ||||
|  | ||||
| 	if (isVisible('bgimage_browser')) | ||||
| 		document.getElementById('bgimage').style.width = '210px'; | ||||
|  | ||||
| 	// Add iframe | ||||
| 	dom.add(document.body, 'iframe', {id : 'documentIframe', src : 'javascript:""', style : {display : 'none'}}); | ||||
| 	doc = dom.get('documentIframe').contentWindow.document; | ||||
| 	h = tinyMCEPopup.getWindowArg('head_html'); | ||||
|  | ||||
| 	// Preprocess the HTML disable scripts and urls | ||||
| 	h = h.replace(/<script>/gi, '<script type="text/javascript">'); | ||||
| 	h = h.replace(/type=([\"\'])?/gi, 'type=$1-mce-'); | ||||
| 	h = h.replace(/(src=|href=)/g, 'mce_$1'); | ||||
|  | ||||
| 	// Write in the content in the iframe | ||||
| 	doc.write(h + '</body></html>'); | ||||
| 	doc.close(); | ||||
|  | ||||
| 	// Parse xml and doctype | ||||
| 	xmlVer = getReItem(/<\?\s*?xml.*?version\s*?=\s*?"(.*?)".*?\?>/gi, h, 1); | ||||
| 	xmlEnc = getReItem(/<\?\s*?xml.*?encoding\s*?=\s*?"(.*?)".*?\?>/gi, h, 1); | ||||
| 	docType = getReItem(/<\!DOCTYPE.*?>/gi, h, 0); | ||||
| 	f.langcode.value = getReItem(/lang="(.*?)"/gi, h, 1); | ||||
|  | ||||
| 	// Parse title | ||||
| 	if (e = doc.getElementsByTagName('title')[0]) | ||||
| 		el.metatitle.value = e.textContent || e.text; | ||||
|  | ||||
| 	// Parse meta | ||||
| 	tinymce.each(doc.getElementsByTagName('meta'), function(n) { | ||||
| 		var na = (n.getAttribute('name', 2) || '').toLowerCase(), va = n.getAttribute('content', 2), eq = n.getAttribute('httpEquiv', 2) || ''; | ||||
|  | ||||
| 		e = el['meta' + na]; | ||||
|  | ||||
| 		if (na == 'robots') { | ||||
| 			selectByValue(f, 'metarobots', tinymce.trim(va), true, true); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		switch (eq.toLowerCase()) { | ||||
| 			case "content-type": | ||||
| 				tmp = getReItem(/charset\s*=\s*(.*)\s*/gi, value, 1); | ||||
|  | ||||
| 				// Override XML encoding | ||||
| 				if (tmp != "") | ||||
| 					xmlEnc = tmp; | ||||
|  | ||||
| 				return; | ||||
| 		} | ||||
|  | ||||
| 		if (e) | ||||
| 			e.value = va; | ||||
| 	}); | ||||
|  | ||||
| 	selectByValue(f, 'doctypes', docType, true, true); | ||||
| 	selectByValue(f, 'docencoding', xmlEnc, true, true); | ||||
| 	selectByValue(f, 'langdir', doc.body.getAttribute('dir', 2) || '', true, true); | ||||
|  | ||||
| 	if (xmlVer != '') | ||||
| 		el.xml_pi.checked = true; | ||||
|  | ||||
| 	// Parse appearance | ||||
|  | ||||
| 	// Parse primary stylesheet | ||||
| 	tinymce.each(doc.getElementsByTagName("link"), function(l) { | ||||
| 		var m = l.getAttribute('media', 2) || '', t = l.getAttribute('type', 2) || ''; | ||||
|  | ||||
| 		if (t == "-mce-text/css" && (m == "" || m == "screen" || m == "all") && (l.getAttribute('rel', 2) || '') == "stylesheet") { | ||||
| 			f.stylesheet.value = l.getAttribute('mce_href', 2) || ''; | ||||
| 			return false; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Get from style elements | ||||
| 	tinymce.each(doc.getElementsByTagName("style"), function(st) { | ||||
| 		var tmp = parseStyleElement(st); | ||||
|  | ||||
| 		for (x=0; x<tmp.length; x++) { | ||||
| 			if (tmp[x].rule.indexOf('a:visited') != -1 && tmp[x].data['color']) | ||||
| 				f.visited_color.value = tmp[x].data['color']; | ||||
|  | ||||
| 			if (tmp[x].rule.indexOf('a:link') != -1 && tmp[x].data['color']) | ||||
| 				f.link_color.value = tmp[x].data['color']; | ||||
|  | ||||
| 			if (tmp[x].rule.indexOf('a:active') != -1 && tmp[x].data['color']) | ||||
| 				f.active_color.value = tmp[x].data['color']; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	f.textcolor.value = tinyMCEPopup.dom.getAttrib(doc.body, "text"); | ||||
| 	f.active_color.value = tinyMCEPopup.dom.getAttrib(doc.body, "alink"); | ||||
| 	f.link_color.value = tinyMCEPopup.dom.getAttrib(doc.body, "link"); | ||||
| 	f.visited_color.value = tinyMCEPopup.dom.getAttrib(doc.body, "vlink"); | ||||
| 	f.bgcolor.value = tinyMCEPopup.dom.getAttrib(doc.body, "bgcolor"); | ||||
| 	f.bgimage.value = tinyMCEPopup.dom.getAttrib(doc.body, "background"); | ||||
|  | ||||
| 	// Get from style info | ||||
| 	style = tinyMCEPopup.dom.parseStyle(tinyMCEPopup.dom.getAttrib(doc.body, 'style')); | ||||
|  | ||||
| 	if (style['font-family']) | ||||
| 		selectByValue(f, 'fontface', style['font-family'], true, true); | ||||
| 	else | ||||
| 		selectByValue(f, 'fontface', ed.getParam("fullpage_default_fontface", ""), true, true); | ||||
|  | ||||
| 	if (style['font-size']) | ||||
| 		selectByValue(f, 'fontsize', style['font-size'], true, true); | ||||
| 	else | ||||
| 		selectByValue(f, 'fontsize', ed.getParam("fullpage_default_fontsize", ""), true, true); | ||||
|  | ||||
| 	if (style['color']) | ||||
| 		f.textcolor.value = convertRGBToHex(style['color']); | ||||
|  | ||||
| 	if (style['background-image']) | ||||
| 		f.bgimage.value = style['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
|  | ||||
| 	if (style['background-color']) | ||||
| 		f.bgcolor.value = style['background-color']; | ||||
|  | ||||
| 	if (style['margin']) { | ||||
| 		tmp = style['margin'].replace(/[^0-9 ]/g, ''); | ||||
| 		tmp = tmp.split(/ +/); | ||||
| 		f.topmargin.value = tmp.length > 0 ? tmp[0] : ''; | ||||
| 		f.rightmargin.value = tmp.length > 1 ? tmp[1] : tmp[0]; | ||||
| 		f.bottommargin.value = tmp.length > 2 ? tmp[2] : tmp[0]; | ||||
| 		f.leftmargin.value = tmp.length > 3 ? tmp[3] : tmp[0]; | ||||
| 	} | ||||
|  | ||||
| 	if (style['margin-left']) | ||||
| 		f.leftmargin.value = style['margin-left'].replace(/[^0-9]/g, ''); | ||||
|  | ||||
| 	if (style['margin-right']) | ||||
| 		f.rightmargin.value = style['margin-right'].replace(/[^0-9]/g, ''); | ||||
|  | ||||
| 	if (style['margin-top']) | ||||
| 		f.topmargin.value = style['margin-top'].replace(/[^0-9]/g, ''); | ||||
|  | ||||
| 	if (style['margin-bottom']) | ||||
| 		f.bottommargin.value = style['margin-bottom'].replace(/[^0-9]/g, ''); | ||||
|  | ||||
| 	f.style.value = tinyMCEPopup.dom.serializeStyle(style); | ||||
|  | ||||
| 	// Update colors | ||||
| 	updateColor('textcolor_pick', 'textcolor'); | ||||
| 	updateColor('bgcolor_pick', 'bgcolor'); | ||||
| 	updateColor('visited_color_pick', 'visited_color'); | ||||
| 	updateColor('active_color_pick', 'active_color'); | ||||
| 	updateColor('link_color_pick', 'link_color'); | ||||
| } | ||||
|  | ||||
| function getReItem(r, s, i) { | ||||
| 	var c = r.exec(s); | ||||
|  | ||||
| 	if (c && c.length > i) | ||||
| 		return c[i]; | ||||
|  | ||||
| 	return ''; | ||||
| } | ||||
|  | ||||
| function updateAction() { | ||||
| 	var f = document.forms[0], nl, i, h, v, s, head, html, l, tmp, addlink = true, ser; | ||||
|  | ||||
| 	head = doc.getElementsByTagName('head')[0]; | ||||
|  | ||||
| 	// Fix scripts without a type | ||||
| 	nl = doc.getElementsByTagName('script'); | ||||
| 	for (i=0; i<nl.length; i++) { | ||||
| 		if (tinyMCEPopup.dom.getAttrib(nl[i], 'mce_type') == '') | ||||
| 			nl[i].setAttribute('mce_type', 'text/javascript'); | ||||
| 	} | ||||
|  | ||||
| 	// Get primary stylesheet | ||||
| 	nl = doc.getElementsByTagName("link"); | ||||
| 	for (i=0; i<nl.length; i++) { | ||||
| 		l = nl[i]; | ||||
|  | ||||
| 		tmp = tinyMCEPopup.dom.getAttrib(l, 'media'); | ||||
|  | ||||
| 		if (tinyMCEPopup.dom.getAttrib(l, 'mce_type') == "text/css" && (tmp == "" || tmp == "screen" || tmp == "all") && tinyMCEPopup.dom.getAttrib(l, 'rel') == "stylesheet") { | ||||
| 			addlink = false; | ||||
|  | ||||
| 			if (f.stylesheet.value == '') | ||||
| 				l.parentNode.removeChild(l); | ||||
| 			else | ||||
| 				l.setAttribute('mce_href', f.stylesheet.value); | ||||
|  | ||||
| 			break; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// Add new link | ||||
| 	if (f.stylesheet.value != '') { | ||||
| 		l = doc.createElement('link'); | ||||
|  | ||||
| 		l.setAttribute('type', 'text/css'); | ||||
| 		l.setAttribute('mce_href', f.stylesheet.value); | ||||
| 		l.setAttribute('rel', 'stylesheet'); | ||||
|  | ||||
| 		head.appendChild(l); | ||||
| 	} | ||||
|  | ||||
| 	setMeta(head, 'keywords', f.metakeywords.value); | ||||
| 	setMeta(head, 'description', f.metadescription.value); | ||||
| 	setMeta(head, 'author', f.metaauthor.value); | ||||
| 	setMeta(head, 'copyright', f.metacopyright.value); | ||||
| 	setMeta(head, 'robots', getSelectValue(f, 'metarobots')); | ||||
| 	setMeta(head, 'Content-Type', getSelectValue(f, 'docencoding')); | ||||
|  | ||||
| 	doc.body.dir = getSelectValue(f, 'langdir'); | ||||
| 	doc.body.style.cssText = f.style.value; | ||||
|  | ||||
| 	doc.body.setAttribute('vLink', f.visited_color.value); | ||||
| 	doc.body.setAttribute('link', f.link_color.value); | ||||
| 	doc.body.setAttribute('text', f.textcolor.value); | ||||
| 	doc.body.setAttribute('aLink', f.active_color.value); | ||||
|  | ||||
| 	doc.body.style.fontFamily = getSelectValue(f, 'fontface'); | ||||
| 	doc.body.style.fontSize = getSelectValue(f, 'fontsize'); | ||||
| 	doc.body.style.backgroundColor = f.bgcolor.value; | ||||
|  | ||||
| 	if (f.leftmargin.value != '') | ||||
| 		doc.body.style.marginLeft = f.leftmargin.value + 'px'; | ||||
|  | ||||
| 	if (f.rightmargin.value != '') | ||||
| 		doc.body.style.marginRight = f.rightmargin.value + 'px'; | ||||
|  | ||||
| 	if (f.bottommargin.value != '') | ||||
| 		doc.body.style.marginBottom = f.bottommargin.value + 'px'; | ||||
|  | ||||
| 	if (f.topmargin.value != '') | ||||
| 		doc.body.style.marginTop = f.topmargin.value + 'px'; | ||||
|  | ||||
| 	html = doc.getElementsByTagName('html')[0]; | ||||
| 	html.setAttribute('lang', f.langcode.value); | ||||
| 	html.setAttribute('xml:lang', f.langcode.value); | ||||
|  | ||||
| 	if (f.bgimage.value != '') | ||||
| 		doc.body.style.backgroundImage = "url('" + f.bgimage.value + "')"; | ||||
| 	else | ||||
| 		doc.body.style.backgroundImage = ''; | ||||
|  | ||||
| 	ser = tinyMCEPopup.editor.plugins.fullpage._createSerializer(); | ||||
| 	ser.setRules('-title,meta[http-equiv|name|content],base[href|target],link[href|rel|type|title|media],style[type],script[type|language|src],html[lang|xml::lang|xmlns],body[style|dir|vlink|link|text|alink],head'); | ||||
|  | ||||
| 	h = ser.serialize(doc.documentElement); | ||||
| 	h = h.substring(0, h.lastIndexOf('</body>')); | ||||
|  | ||||
| 	if (h.indexOf('<title>') == -1) | ||||
| 		h = h.replace(/<head.*?>/, '$&\n' + '<title>' + tinyMCEPopup.dom.encode(f.metatitle.value) + '</title>'); | ||||
| 	else | ||||
| 		h = h.replace(/<title>(.*?)<\/title>/, '<title>' + tinyMCEPopup.dom.encode(f.metatitle.value) + '</title>'); | ||||
|  | ||||
| 	if ((v = getSelectValue(f, 'doctypes')) != '') | ||||
| 		h = v + '\n' + h; | ||||
|  | ||||
| 	if (f.xml_pi.checked) { | ||||
| 		s = '<?xml version="1.0"'; | ||||
|  | ||||
| 		if ((v = getSelectValue(f, 'docencoding')) != '') | ||||
| 			s += ' encoding="' + v + '"'; | ||||
|  | ||||
| 		s += '?>\n'; | ||||
| 		h = s + h; | ||||
| 	} | ||||
|  | ||||
| 	h = h.replace(/type=\"\-mce\-/gi, 'type="'); | ||||
|  | ||||
| 	tinyMCEPopup.editor.plugins.fullpage.head = h; | ||||
| 	tinyMCEPopup.editor.plugins.fullpage._setBodyAttribs(tinyMCEPopup.editor, {}); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function changedStyleField(field) { | ||||
| 	//alert(field.id); | ||||
| } | ||||
|  | ||||
| function setMeta(he, k, v) { | ||||
| 	var nl, i, m; | ||||
|  | ||||
| 	nl = he.getElementsByTagName('meta'); | ||||
| 	for (i=0; i<nl.length; i++) { | ||||
| 		if (k == 'Content-Type' && tinyMCEPopup.dom.getAttrib(nl[i], 'http-equiv') == k) { | ||||
| 			if (v == '') | ||||
| 				nl[i].parentNode.removeChild(nl[i]); | ||||
| 			else | ||||
| 				nl[i].setAttribute('content', "text/html; charset=" + v); | ||||
|  | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (tinyMCEPopup.dom.getAttrib(nl[i], 'name') == k) { | ||||
| 			if (v == '') | ||||
| 				nl[i].parentNode.removeChild(nl[i]); | ||||
| 			else | ||||
| 				nl[i].setAttribute('content', v); | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (v == '') | ||||
| 		return; | ||||
|  | ||||
| 	m = doc.createElement('meta'); | ||||
|  | ||||
| 	if (k == 'Content-Type') | ||||
| 		m.httpEquiv = k; | ||||
| 	else | ||||
| 		m.setAttribute('name', k); | ||||
|  | ||||
| 	m.setAttribute('content', v); | ||||
| 	he.appendChild(m); | ||||
| } | ||||
|  | ||||
| function parseStyleElement(e) { | ||||
| 	var v = e.innerHTML; | ||||
| 	var p, i, r; | ||||
|  | ||||
| 	v = v.replace(/<!--/gi, ''); | ||||
| 	v = v.replace(/-->/gi, ''); | ||||
| 	v = v.replace(/[\n\r]/gi, ''); | ||||
| 	v = v.replace(/\s+/gi, ' '); | ||||
|  | ||||
| 	r = []; | ||||
| 	p = v.split(/{|}/); | ||||
|  | ||||
| 	for (i=0; i<p.length; i+=2) { | ||||
| 		if (p[i] != "") | ||||
| 			r[r.length] = {rule : tinymce.trim(p[i]), data : tinyMCEPopup.dom.parseStyle(p[i+1])}; | ||||
| 	} | ||||
|  | ||||
| 	return r; | ||||
| } | ||||
|  | ||||
| function serializeStyleElement(d) { | ||||
| 	var i, s, st; | ||||
|  | ||||
| 	s = '<!--\n'; | ||||
|  | ||||
| 	for (i=0; i<d.length; i++) { | ||||
| 		s += d[i].rule + ' {\n'; | ||||
|  | ||||
| 		st = tinyMCE.serializeStyle(d[i].data); | ||||
|  | ||||
| 		if (st != '') | ||||
| 			st += ';'; | ||||
|  | ||||
| 		s += st.replace(/;/g, ';\n'); | ||||
| 		s += '}\n'; | ||||
|  | ||||
| 		if (i != d.length - 1) | ||||
| 			s += '\n'; | ||||
| 	} | ||||
|  | ||||
| 	s += '\n-->'; | ||||
|  | ||||
| 	return s; | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,85 @@ | ||||
| tinyMCE.addI18n('en.fullpage_dlg',{ | ||||
| title:"Document properties", | ||||
| meta_tab:"General", | ||||
| appearance_tab:"Appearance", | ||||
| advanced_tab:"Advanced", | ||||
| meta_props:"Meta information", | ||||
| langprops:"Language and encoding", | ||||
| meta_title:"Title", | ||||
| meta_keywords:"Keywords", | ||||
| meta_description:"Description", | ||||
| meta_robots:"Robots", | ||||
| doctypes:"Doctype", | ||||
| langcode:"Language code", | ||||
| langdir:"Language direction", | ||||
| ltr:"Left to right", | ||||
| rtl:"Right to left", | ||||
| xml_pi:"XML declaration", | ||||
| encoding:"Character encoding", | ||||
| appearance_bgprops:"Background properties", | ||||
| appearance_marginprops:"Body margins", | ||||
| appearance_linkprops:"Link colors", | ||||
| appearance_textprops:"Text properties", | ||||
| bgcolor:"Background color", | ||||
| bgimage:"Background image", | ||||
| left_margin:"Left margin", | ||||
| right_margin:"Right margin", | ||||
| top_margin:"Top margin", | ||||
| bottom_margin:"Bottom margin", | ||||
| text_color:"Text color", | ||||
| font_size:"Font size", | ||||
| font_face:"Font face", | ||||
| link_color:"Link color", | ||||
| hover_color:"Hover color", | ||||
| visited_color:"Visited color", | ||||
| active_color:"Active color", | ||||
| textcolor:"Color", | ||||
| fontsize:"Font size", | ||||
| fontface:"Font family", | ||||
| meta_index_follow:"Index and follow the links", | ||||
| meta_index_nofollow:"Index and don't follow the links", | ||||
| meta_noindex_follow:"Do not index but follow the links", | ||||
| meta_noindex_nofollow:"Do not index and don\'t follow the links", | ||||
| appearance_style:"Stylesheet and style properties", | ||||
| stylesheet:"Stylesheet", | ||||
| style:"Style", | ||||
| author:"Author", | ||||
| copyright:"Copyright", | ||||
| add:"Add new element", | ||||
| remove:"Remove selected element", | ||||
| moveup:"Move selected element up", | ||||
| movedown:"Move selected element down", | ||||
| head_elements:"Head elements", | ||||
| info:"Information", | ||||
| add_title:"Title element", | ||||
| add_meta:"Meta element", | ||||
| add_script:"Script element", | ||||
| add_style:"Style element", | ||||
| add_link:"Link element", | ||||
| add_base:"Base element", | ||||
| add_comment:"Comment node", | ||||
| title_element:"Title element", | ||||
| script_element:"Script element", | ||||
| style_element:"Style element", | ||||
| base_element:"Base element", | ||||
| link_element:"Link element", | ||||
| meta_element:"Meta element", | ||||
| comment_element:"Comment", | ||||
| src:"Src", | ||||
| language:"Language", | ||||
| href:"Href", | ||||
| target:"Target", | ||||
| type:"Type", | ||||
| charset:"Charset", | ||||
| defer:"Defer", | ||||
| media:"Media", | ||||
| properties:"Properties", | ||||
| name:"Name", | ||||
| value:"Value", | ||||
| content:"Content", | ||||
| rel:"Rel", | ||||
| rev:"Rev", | ||||
| hreflang:"Href lang", | ||||
| general_props:"General", | ||||
| advanced_props:"Advanced" | ||||
| }); | ||||
| @@ -0,0 +1,365 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:27 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	var each = tinymce.each; | ||||
|  | ||||
| 	tinymce.create('tinymce.plugins.MediaPlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			var t = this; | ||||
| 			 | ||||
| 			t.editor = ed; | ||||
| 			t.url = url; | ||||
|  | ||||
| 			function isMediaElm(n) { | ||||
| 				return /^(mceItemFlash|mceItemShockWave|mceItemWindowsMedia|mceItemQuickTime|mceItemRealMedia)$/.test(n.className); | ||||
| 			}; | ||||
|  | ||||
| 			ed.onPreInit.add(function() { | ||||
| 				// Force in _value parameter this extra parameter is required for older Opera versions | ||||
| 				ed.serializer.addRules('param[name|value|_value]'); | ||||
| 			}); | ||||
|  | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceMedia', function() { | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/media.htm', | ||||
| 					width : 430 + parseInt(ed.getLang('media.delta_width', 0)), | ||||
| 					height : 470 + parseInt(ed.getLang('media.delta_height', 0)), | ||||
| 					inline : 1 | ||||
| 				}, { | ||||
| 					plugin_url : url | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('media', {title : 'media.desc', cmd : 'mceMedia'}); | ||||
|  | ||||
| 			ed.onNodeChange.add(function(ed, cm, n) { | ||||
| 				cm.setActive('media', n.nodeName == 'IMG' && isMediaElm(n)); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onInit.add(function() { | ||||
| 				var lo = { | ||||
| 					mceItemFlash : 'flash', | ||||
| 					mceItemShockWave : 'shockwave', | ||||
| 					mceItemWindowsMedia : 'windowsmedia', | ||||
| 					mceItemQuickTime : 'quicktime', | ||||
| 					mceItemRealMedia : 'realmedia' | ||||
| 				}; | ||||
|  | ||||
| 				if (ed.settings.content_css !== false) | ||||
| 					ed.dom.loadCSS(url + "/css/content.css"); | ||||
|  | ||||
| 				if (ed.theme.onResolveName) { | ||||
| 					ed.theme.onResolveName.add(function(th, o) { | ||||
| 						if (o.name == 'img') { | ||||
| 							each(lo, function(v, k) { | ||||
| 								if (ed.dom.hasClass(o.node, k)) { | ||||
| 									o.name = v; | ||||
| 									o.title = ed.dom.getAttrib(o.node, 'title'); | ||||
| 									return false; | ||||
| 								} | ||||
| 							}); | ||||
| 						} | ||||
| 					}); | ||||
| 				} | ||||
|  | ||||
| 				if (ed && ed.plugins.contextmenu) { | ||||
| 					ed.plugins.contextmenu.onContextMenu.add(function(th, m, e) { | ||||
| 						if (e.nodeName == 'IMG' && /mceItem(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)/.test(e.className)) { | ||||
| 							m.add({title : 'media.edit', icon : 'media', cmd : 'mceMedia'}); | ||||
| 						} | ||||
| 					}); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			ed.onBeforeSetContent.add(function(ed, o) { | ||||
| 				var h = o.content; | ||||
|  | ||||
| 				h = h.replace(/<script[^>]*>\s*write(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)\(\{([^\)]*)\}\);\s*<\/script>/gi, function(a, b, c) { | ||||
| 					var o = t._parse(c); | ||||
|  | ||||
| 					return '<img class="mceItem' + b + '" title="' + ed.dom.encode(c) + '" src="' + url + '/img/trans.gif" width="' + o.width + '" height="' + o.height + '" />' | ||||
| 				}); | ||||
|  | ||||
| 				h = h.replace(/<object([^>]*)>/gi, '<span class="mceItemObject" $1>'); | ||||
| 				h = h.replace(/<embed([^>]*)\/>/gi, '<span class="mceItemEmbed" $1>'); | ||||
| 				h = h.replace(/<embed([^>]*)>/gi, '<span class="mceItemEmbed" $1>'); | ||||
| 				h = h.replace(/<\/(object|embed)([^>]*)>/gi, '</span>'); | ||||
| 				h = h.replace(/<param([^>]*)>/gi, function(a, b) {return '<span ' + b.replace(/value=/gi, '_value=') + ' class="mceItemParam"></span>'}); | ||||
| 				h = h.replace(/\/ class=\"mceItemParam\"><\/span>/gi, 'class="mceItemParam"></span>'); | ||||
|  | ||||
| 				o.content = h; | ||||
| 			}); | ||||
|  | ||||
| 			ed.onSetContent.add(function() { | ||||
| 				t._spansToImgs(ed.getBody()); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onPreProcess.add(function(ed, o) { | ||||
| 				var dom = ed.dom; | ||||
|  | ||||
| 				if (o.set) { | ||||
| 					t._spansToImgs(o.node); | ||||
|  | ||||
| 					each(dom.select('IMG', o.node), function(n) { | ||||
| 						var p; | ||||
|  | ||||
| 						if (isMediaElm(n)) { | ||||
| 							p = t._parse(n.title); | ||||
| 							dom.setAttrib(n, 'width', dom.getAttrib(n, 'width', p.width || 100)); | ||||
| 							dom.setAttrib(n, 'height', dom.getAttrib(n, 'height', p.height || 100)); | ||||
| 						} | ||||
| 					}); | ||||
| 				} | ||||
|  | ||||
| 				if (o.get) { | ||||
| 					each(dom.select('IMG', o.node), function(n) { | ||||
| 						var ci, cb, mt; | ||||
|  | ||||
| 						if (ed.getParam('media_use_script')) { | ||||
| 							if (isMediaElm(n)) | ||||
| 								n.className = n.className.replace(/mceItem/g, 'mceTemp'); | ||||
|  | ||||
| 							return; | ||||
| 						} | ||||
|  | ||||
| 						switch (n.className) { | ||||
| 							case 'mceItemFlash': | ||||
| 								ci = 'd27cdb6e-ae6d-11cf-96b8-444553540000'; | ||||
| 								cb = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0'; | ||||
| 								mt = 'application/x-shockwave-flash'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'mceItemShockWave': | ||||
| 								ci = '166b1bca-3f9c-11cf-8075-444553540000'; | ||||
| 								cb = 'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0'; | ||||
| 								mt = 'application/x-director'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'mceItemWindowsMedia': | ||||
| 								ci = ed.getParam('media_wmp6_compatible') ? '05589fa1-c356-11ce-bf01-00aa0055595a' : '6bf52a52-394a-11d3-b153-00c04f79faa6'; | ||||
| 								cb = 'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701'; | ||||
| 								mt = 'application/x-mplayer2'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'mceItemQuickTime': | ||||
| 								ci = '02bf25d5-8c17-4b23-bc80-d3488abddc6b'; | ||||
| 								cb = 'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0'; | ||||
| 								mt = 'video/quicktime'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'mceItemRealMedia': | ||||
| 								ci = 'cfcdaa03-8be4-11cf-b84b-0020afbbccfa'; | ||||
| 								cb = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0'; | ||||
| 								mt = 'audio/x-pn-realaudio-plugin'; | ||||
| 								break; | ||||
| 						} | ||||
|  | ||||
| 						if (ci) { | ||||
| 							dom.replace(t._buildObj({ | ||||
| 								classid : ci, | ||||
| 								codebase : cb, | ||||
| 								type : mt | ||||
| 							}, n), n); | ||||
| 						} | ||||
| 					}); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			ed.onPostProcess.add(function(ed, o) { | ||||
| 				o.content = o.content.replace(/_value=/g, 'value='); | ||||
| 			}); | ||||
|  | ||||
| 			if (ed.getParam('media_use_script')) { | ||||
| 				function getAttr(s, n) { | ||||
| 					n = new RegExp(n + '=\"([^\"]+)\"', 'g').exec(s); | ||||
|  | ||||
| 					return n ? ed.dom.decode(n[1]) : ''; | ||||
| 				}; | ||||
|  | ||||
| 				ed.onPostProcess.add(function(ed, o) { | ||||
| 					o.content = o.content.replace(/<img[^>]+>/g, function(im) { | ||||
| 						var cl = getAttr(im, 'class'); | ||||
|  | ||||
| 						if (/^(mceTempFlash|mceTempShockWave|mceTempWindowsMedia|mceTempQuickTime|mceTempRealMedia)$/.test(cl)) { | ||||
| 							at = t._parse(getAttr(im, 'title')); | ||||
| 							at.width = getAttr(im, 'width'); | ||||
| 							at.height = getAttr(im, 'height'); | ||||
| 							im = '<script type="text/javascript">write' + cl.substring(7) + '({' + t._serialize(at) + '});</script>'; | ||||
| 						} | ||||
|  | ||||
| 						return im; | ||||
| 					}); | ||||
| 				}); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Media', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/media', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		// Private methods | ||||
|  | ||||
| 		_buildObj : function(o, n) { | ||||
| 			var ob, ed = this.editor, dom = ed.dom, p = this._parse(n.title); | ||||
|  | ||||
| 			p.width = o.width = dom.getAttrib(n, 'width') || 100; | ||||
| 			p.height = o.height = dom.getAttrib(n, 'height') || 100; | ||||
|  | ||||
| 			ob = dom.create('span', { | ||||
| 				mce_name : 'object', | ||||
| 				classid : "clsid:" + o.classid, | ||||
| 				codebase : o.codebase, | ||||
| 				width : o.width, | ||||
| 				height : o.height | ||||
| 			}); | ||||
|  | ||||
| 			if (p.src) | ||||
| 				p.src = ed.convertURL(p.src, 'src', n); | ||||
|  | ||||
| 			each (p, function(v, k) { | ||||
| 				if (!/^(width|height|codebase|classid)$/.test(k)) { | ||||
| 					// Use url instead of src in IE for Windows media | ||||
| 					if (o.type == 'application/x-mplayer2' && k == 'src') | ||||
| 						k = 'url'; | ||||
|  | ||||
| 					dom.add(ob, 'span', {mce_name : 'param', name : k, '_value' : v}); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			dom.add(ob, 'span', tinymce.extend({mce_name : 'embed', type : o.type}, p)); | ||||
|  | ||||
| 			return ob; | ||||
| 		}, | ||||
|  | ||||
| 		_spansToImgs : function(p) { | ||||
| 			var t = this, dom = t.editor.dom, im, ci; | ||||
|  | ||||
| 			each(dom.select('span', p), function(n) { | ||||
| 				// Convert object into image | ||||
| 				if (dom.getAttrib(n, 'class') == 'mceItemObject') { | ||||
| 					ci = dom.getAttrib(n, "classid").toLowerCase().replace(/\s+/g, ''); | ||||
|  | ||||
| 					switch (ci) { | ||||
| 						case 'clsid:d27cdb6e-ae6d-11cf-96b8-444553540000': | ||||
| 							dom.replace(t._createImg('mceItemFlash', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'clsid:166b1bca-3f9c-11cf-8075-444553540000': | ||||
| 							dom.replace(t._createImg('mceItemShockWave', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'clsid:6bf52a52-394a-11d3-b153-00c04f79faa6': | ||||
| 						case 'clsid:22d6f312-b0f6-11d0-94ab-0080c74c7e95': | ||||
| 						case 'clsid:05589fa1-c356-11ce-bf01-00aa0055595a': | ||||
| 							dom.replace(t._createImg('mceItemWindowsMedia', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'clsid:02bf25d5-8c17-4b23-bc80-d3488abddc6b': | ||||
| 							dom.replace(t._createImg('mceItemQuickTime', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'clsid:cfcdaa03-8be4-11cf-b84b-0020afbbccfa': | ||||
| 							dom.replace(t._createImg('mceItemRealMedia', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						default: | ||||
| 							dom.replace(t._createImg('mceItemFlash', n), n); | ||||
| 					} | ||||
| 					 | ||||
| 					return; | ||||
| 				} | ||||
|  | ||||
| 				// Convert embed into image | ||||
| 				if (dom.getAttrib(n, 'class') == 'mceItemEmbed') { | ||||
| 					switch (dom.getAttrib(n, 'type')) { | ||||
| 						case 'application/x-shockwave-flash': | ||||
| 							dom.replace(t._createImg('mceItemFlash', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'application/x-director': | ||||
| 							dom.replace(t._createImg('mceItemShockWave', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'application/x-mplayer2': | ||||
| 							dom.replace(t._createImg('mceItemWindowsMedia', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'video/quicktime': | ||||
| 							dom.replace(t._createImg('mceItemQuickTime', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						case 'audio/x-pn-realaudio-plugin': | ||||
| 							dom.replace(t._createImg('mceItemRealMedia', n), n); | ||||
| 							break; | ||||
|  | ||||
| 						default: | ||||
| 							dom.replace(t._createImg('mceItemFlash', n), n); | ||||
| 					} | ||||
| 				}			 | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		_createImg : function(cl, n) { | ||||
| 			var im, dom = this.editor.dom, pa = {}, ti = ''; | ||||
|  | ||||
| 			// Create image | ||||
| 			im = dom.create('img', { | ||||
| 				src : this.url + '/img/trans.gif', | ||||
| 				width : dom.getAttrib(n, 'width') || 100, | ||||
| 				height : dom.getAttrib(n, 'height') || 100, | ||||
| 				'class' : cl | ||||
| 			}); | ||||
|  | ||||
| 			// Setup base parameters | ||||
| 			each(['id', 'name', 'width', 'height', 'bgcolor', 'align', 'flashvars', 'src', 'wmode'], function(na) { | ||||
| 				var v = dom.getAttrib(n, na); | ||||
|  | ||||
| 				if (v) | ||||
| 					pa[na] = v; | ||||
| 			}); | ||||
|  | ||||
| 			// Add optional parameters | ||||
| 			each(dom.select('span', n), function(n) { | ||||
| 				if (dom.hasClass(n, 'mceItemParam')) | ||||
| 					pa[dom.getAttrib(n, 'name')] = dom.getAttrib(n, '_value'); | ||||
| 			}); | ||||
|  | ||||
| 			// Use src not movie | ||||
| 			if (pa.movie) { | ||||
| 				pa.src = pa.movie; | ||||
| 				delete pa.movie; | ||||
| 			} | ||||
|  | ||||
| 			delete pa.width; | ||||
| 			delete pa.height; | ||||
|  | ||||
| 			im.title = this._serialize(pa); | ||||
|  | ||||
| 			return im; | ||||
| 		}, | ||||
|  | ||||
| 		_parse : function(s) { | ||||
| 			return tinymce.util.JSON.parse('{' + s + '}'); | ||||
| 		}, | ||||
|  | ||||
| 		_serialize : function(o) { | ||||
| 			return tinymce.util.JSON.serialize(o).replace(/[{}]/g, ''); | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('media', tinymce.plugins.MediaPlugin); | ||||
| })(); | ||||
| After Width: | Height: | Size: 241 B | 
| After Width: | Height: | Size: 303 B | 
| After Width: | Height: | Size: 439 B | 
| After Width: | Height: | Size: 387 B | 
| After Width: | Height: | Size: 43 B | 
| After Width: | Height: | Size: 415 B | 
| @@ -0,0 +1,73 @@ | ||||
| /** | ||||
|  * This script contains embed functions for common plugins. This scripts are complety free to use for any purpose. | ||||
|  */ | ||||
|  | ||||
| function writeFlash(p) { | ||||
| 	writeEmbed( | ||||
| 		'D27CDB6E-AE6D-11cf-96B8-444553540000', | ||||
| 		'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0', | ||||
| 		'application/x-shockwave-flash', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeShockWave(p) { | ||||
| 	writeEmbed( | ||||
| 	'166B1BCA-3F9C-11CF-8075-444553540000', | ||||
| 	'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0', | ||||
| 	'application/x-director', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeQuickTime(p) { | ||||
| 	writeEmbed( | ||||
| 		'02BF25D5-8C17-4B23-BC80-D3488ABDDC6B', | ||||
| 		'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0', | ||||
| 		'video/quicktime', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeRealMedia(p) { | ||||
| 	writeEmbed( | ||||
| 		'CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA', | ||||
| 		'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0', | ||||
| 		'audio/x-pn-realaudio-plugin', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeWindowsMedia(p) { | ||||
| 	p.url = p.src; | ||||
| 	writeEmbed( | ||||
| 		'6BF52A52-394A-11D3-B153-00C04F79FAA6', | ||||
| 		'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701', | ||||
| 		'application/x-mplayer2', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeEmbed(cls, cb, mt, p) { | ||||
| 	var h = '', n; | ||||
|  | ||||
| 	h += '<object classid="clsid:' + cls + '" codebase="' + cb + '"'; | ||||
| 	h += typeof(p.id) != "undefined" ? 'id="' + p.id + '"' : ''; | ||||
| 	h += typeof(p.name) != "undefined" ? 'name="' + p.name + '"' : ''; | ||||
| 	h += typeof(p.width) != "undefined" ? 'width="' + p.width + '"' : ''; | ||||
| 	h += typeof(p.height) != "undefined" ? 'height="' + p.height + '"' : ''; | ||||
| 	h += typeof(p.align) != "undefined" ? 'align="' + p.align + '"' : ''; | ||||
| 	h += '>'; | ||||
|  | ||||
| 	for (n in p) | ||||
| 		h += '<param name="' + n + '" value="' + p[n] + '">'; | ||||
|  | ||||
| 	h += '<embed type="' + mt + '"'; | ||||
|  | ||||
| 	for (n in p) | ||||
| 		h += n + '="' + p[n] + '" '; | ||||
|  | ||||
| 	h += '></embed></object>'; | ||||
|  | ||||
| 	document.write(h); | ||||
| } | ||||
| @@ -0,0 +1,628 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var oldWidth, oldHeight, ed, url; | ||||
|  | ||||
| if (url = tinyMCEPopup.getParam("media_external_list_url")) | ||||
| 	document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>'); | ||||
|  | ||||
| function init() { | ||||
| 	var pl = "", f, val; | ||||
| 	var type = "flash", fe, i; | ||||
|  | ||||
| 	ed = tinyMCEPopup.editor; | ||||
|  | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
| 	f = document.forms[0] | ||||
|  | ||||
| 	fe = ed.selection.getNode(); | ||||
| 	if (/mceItem(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)/.test(ed.dom.getAttrib(fe, 'class'))) { | ||||
| 		pl = fe.title; | ||||
|  | ||||
| 		switch (ed.dom.getAttrib(fe, 'class')) { | ||||
| 			case 'mceItemFlash': | ||||
| 				type = 'flash'; | ||||
| 				break; | ||||
|  | ||||
| 			case 'mceItemFlashVideo': | ||||
| 				type = 'flv'; | ||||
| 				break; | ||||
|  | ||||
| 			case 'mceItemShockWave': | ||||
| 				type = 'shockwave'; | ||||
| 				break; | ||||
|  | ||||
| 			case 'mceItemWindowsMedia': | ||||
| 				type = 'wmp'; | ||||
| 				break; | ||||
|  | ||||
| 			case 'mceItemQuickTime': | ||||
| 				type = 'qt'; | ||||
| 				break; | ||||
|  | ||||
| 			case 'mceItemRealMedia': | ||||
| 				type = 'rmp'; | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		document.forms[0].insert.value = ed.getLang('update', 'Insert', true);  | ||||
| 	} | ||||
|  | ||||
| 	document.getElementById('filebrowsercontainer').innerHTML = getBrowserHTML('filebrowser','src','media','media'); | ||||
| 	document.getElementById('qtsrcfilebrowsercontainer').innerHTML = getBrowserHTML('qtsrcfilebrowser','qt_qtsrc','media','media'); | ||||
| 	document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor'); | ||||
|  | ||||
| 	var html = getMediaListHTML('medialist','src','media','media'); | ||||
| 	if (html == "") | ||||
| 		document.getElementById("linklistrow").style.display = 'none'; | ||||
| 	else | ||||
| 		document.getElementById("linklistcontainer").innerHTML = html; | ||||
|  | ||||
| 	// Resize some elements | ||||
| 	if (isVisible('filebrowser')) | ||||
| 		document.getElementById('src').style.width = '230px'; | ||||
|  | ||||
| 	// Setup form | ||||
| 	if (pl != "") { | ||||
| 		pl = tinyMCEPopup.editor.plugins.media._parse(pl); | ||||
|  | ||||
| 		switch (type) { | ||||
| 			case "flash": | ||||
| 				setBool(pl, 'flash', 'play'); | ||||
| 				setBool(pl, 'flash', 'loop'); | ||||
| 				setBool(pl, 'flash', 'menu'); | ||||
| 				setBool(pl, 'flash', 'swliveconnect'); | ||||
| 				setStr(pl, 'flash', 'quality'); | ||||
| 				setStr(pl, 'flash', 'scale'); | ||||
| 				setStr(pl, 'flash', 'salign'); | ||||
| 				setStr(pl, 'flash', 'wmode'); | ||||
| 				setStr(pl, 'flash', 'base'); | ||||
| 				setStr(pl, 'flash', 'flashvars'); | ||||
| 			break; | ||||
|  | ||||
| 			case "qt": | ||||
| 				setBool(pl, 'qt', 'loop'); | ||||
| 				setBool(pl, 'qt', 'autoplay'); | ||||
| 				setBool(pl, 'qt', 'cache'); | ||||
| 				setBool(pl, 'qt', 'controller'); | ||||
| 				setBool(pl, 'qt', 'correction'); | ||||
| 				setBool(pl, 'qt', 'enablejavascript'); | ||||
| 				setBool(pl, 'qt', 'kioskmode'); | ||||
| 				setBool(pl, 'qt', 'autohref'); | ||||
| 				setBool(pl, 'qt', 'playeveryframe'); | ||||
| 				setBool(pl, 'qt', 'tarsetcache'); | ||||
| 				setStr(pl, 'qt', 'scale'); | ||||
| 				setStr(pl, 'qt', 'starttime'); | ||||
| 				setStr(pl, 'qt', 'endtime'); | ||||
| 				setStr(pl, 'qt', 'tarset'); | ||||
| 				setStr(pl, 'qt', 'qtsrcchokespeed'); | ||||
| 				setStr(pl, 'qt', 'volume'); | ||||
| 				setStr(pl, 'qt', 'qtsrc'); | ||||
| 			break; | ||||
|  | ||||
| 			case "shockwave": | ||||
| 				setBool(pl, 'shockwave', 'sound'); | ||||
| 				setBool(pl, 'shockwave', 'progress'); | ||||
| 				setBool(pl, 'shockwave', 'autostart'); | ||||
| 				setBool(pl, 'shockwave', 'swliveconnect'); | ||||
| 				setStr(pl, 'shockwave', 'swvolume'); | ||||
| 				setStr(pl, 'shockwave', 'swstretchstyle'); | ||||
| 				setStr(pl, 'shockwave', 'swstretchhalign'); | ||||
| 				setStr(pl, 'shockwave', 'swstretchvalign'); | ||||
| 			break; | ||||
|  | ||||
| 			case "wmp": | ||||
| 				setBool(pl, 'wmp', 'autostart'); | ||||
| 				setBool(pl, 'wmp', 'enabled'); | ||||
| 				setBool(pl, 'wmp', 'enablecontextmenu'); | ||||
| 				setBool(pl, 'wmp', 'fullscreen'); | ||||
| 				setBool(pl, 'wmp', 'invokeurls'); | ||||
| 				setBool(pl, 'wmp', 'mute'); | ||||
| 				setBool(pl, 'wmp', 'stretchtofit'); | ||||
| 				setBool(pl, 'wmp', 'windowlessvideo'); | ||||
| 				setStr(pl, 'wmp', 'balance'); | ||||
| 				setStr(pl, 'wmp', 'baseurl'); | ||||
| 				setStr(pl, 'wmp', 'captioningid'); | ||||
| 				setStr(pl, 'wmp', 'currentmarker'); | ||||
| 				setStr(pl, 'wmp', 'currentposition'); | ||||
| 				setStr(pl, 'wmp', 'defaultframe'); | ||||
| 				setStr(pl, 'wmp', 'playcount'); | ||||
| 				setStr(pl, 'wmp', 'rate'); | ||||
| 				setStr(pl, 'wmp', 'uimode'); | ||||
| 				setStr(pl, 'wmp', 'volume'); | ||||
| 			break; | ||||
|  | ||||
| 			case "rmp": | ||||
| 				setBool(pl, 'rmp', 'autostart'); | ||||
| 				setBool(pl, 'rmp', 'loop'); | ||||
| 				setBool(pl, 'rmp', 'autogotourl'); | ||||
| 				setBool(pl, 'rmp', 'center'); | ||||
| 				setBool(pl, 'rmp', 'imagestatus'); | ||||
| 				setBool(pl, 'rmp', 'maintainaspect'); | ||||
| 				setBool(pl, 'rmp', 'nojava'); | ||||
| 				setBool(pl, 'rmp', 'prefetch'); | ||||
| 				setBool(pl, 'rmp', 'shuffle'); | ||||
| 				setStr(pl, 'rmp', 'console'); | ||||
| 				setStr(pl, 'rmp', 'controls'); | ||||
| 				setStr(pl, 'rmp', 'numloop'); | ||||
| 				setStr(pl, 'rmp', 'scriptcallbacks'); | ||||
| 			break; | ||||
| 		} | ||||
|  | ||||
| 		setStr(pl, null, 'src'); | ||||
| 		setStr(pl, null, 'id'); | ||||
| 		setStr(pl, null, 'name'); | ||||
| 		setStr(pl, null, 'vspace'); | ||||
| 		setStr(pl, null, 'hspace'); | ||||
| 		setStr(pl, null, 'bgcolor'); | ||||
| 		setStr(pl, null, 'align'); | ||||
| 		setStr(pl, null, 'width'); | ||||
| 		setStr(pl, null, 'height'); | ||||
|  | ||||
| 		if ((val = ed.dom.getAttrib(fe, "width")) != "") | ||||
| 			pl.width = f.width.value = val; | ||||
|  | ||||
| 		if ((val = ed.dom.getAttrib(fe, "height")) != "") | ||||
| 			pl.height = f.height.value = val; | ||||
|  | ||||
| 		oldWidth = pl.width ? parseInt(pl.width) : 0; | ||||
| 		oldHeight = pl.height ? parseInt(pl.height) : 0; | ||||
| 	} else | ||||
| 		oldWidth = oldHeight = 0; | ||||
|  | ||||
| 	selectByValue(f, 'media_type', type); | ||||
| 	changedType(type); | ||||
| 	updateColor('bgcolor_pick', 'bgcolor'); | ||||
|  | ||||
| 	TinyMCE_EditableSelects.init(); | ||||
| 	generatePreview(); | ||||
| } | ||||
|  | ||||
| function insertMedia() { | ||||
| 	var fe, f = document.forms[0], h; | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 	if (!AutoValidator.validate(f)) { | ||||
| 		alert(ed.getLang('invalid_data')); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	f.width.value = f.width.value == "" ? 100 : f.width.value; | ||||
| 	f.height.value = f.height.value == "" ? 100 : f.height.value; | ||||
|  | ||||
| 	fe = ed.selection.getNode(); | ||||
| 	if (fe != null && /mceItem(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)/.test(ed.dom.getAttrib(fe, 'class'))) { | ||||
| 		switch (f.media_type.options[f.media_type.selectedIndex].value) { | ||||
| 			case "flash": | ||||
| 				fe.className = "mceItemFlash"; | ||||
| 				break; | ||||
|  | ||||
| 			case "flv": | ||||
| 				fe.className = "mceItemFlashVideo"; | ||||
| 				break; | ||||
|  | ||||
| 			case "shockwave": | ||||
| 				fe.className = "mceItemShockWave"; | ||||
| 				break; | ||||
|  | ||||
| 			case "qt": | ||||
| 				fe.className = "mceItemQuickTime"; | ||||
| 				break; | ||||
|  | ||||
| 			case "wmp": | ||||
| 				fe.className = "mceItemWindowsMedia"; | ||||
| 				break; | ||||
|  | ||||
| 			case "rmp": | ||||
| 				fe.className = "mceItemRealMedia"; | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		if (fe.width != f.width.value || fe.height != f.height.height) | ||||
| 			ed.execCommand('mceRepaint'); | ||||
|  | ||||
| 		fe.title = serializeParameters(); | ||||
| 		fe.width = f.width.value; | ||||
| 		fe.height = f.height.value; | ||||
| 		fe.style.width = f.width.value + (f.width.value.indexOf('%') == -1 ? 'px' : ''); | ||||
| 		fe.style.height = f.height.value + (f.height.value.indexOf('%') == -1 ? 'px' : ''); | ||||
| 		fe.align = f.align.options[f.align.selectedIndex].value; | ||||
| 	} else { | ||||
| 		h = '<img src="' + tinyMCEPopup.getWindowArg("plugin_url") + '/img/trans.gif"' ; | ||||
|  | ||||
| 		switch (f.media_type.options[f.media_type.selectedIndex].value) { | ||||
| 			case "flash": | ||||
| 				h += ' class="mceItemFlash"'; | ||||
| 				break; | ||||
|  | ||||
| 			case "flv": | ||||
| 				h += ' class="mceItemFlashVideo"'; | ||||
| 				break; | ||||
|  | ||||
| 			case "shockwave": | ||||
| 				h += ' class="mceItemShockWave"'; | ||||
| 				break; | ||||
|  | ||||
| 			case "qt": | ||||
| 				h += ' class="mceItemQuickTime"'; | ||||
| 				break; | ||||
|  | ||||
| 			case "wmp": | ||||
| 				h += ' class="mceItemWindowsMedia"'; | ||||
| 				break; | ||||
|  | ||||
| 			case "rmp": | ||||
| 				h += ' class="mceItemRealMedia"'; | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		h += ' title="' + serializeParameters() + '"'; | ||||
| 		h += ' width="' + f.width.value + '"'; | ||||
| 		h += ' height="' + f.height.value + '"'; | ||||
| 		h += ' align="' + f.align.options[f.align.selectedIndex].value + '"'; | ||||
|  | ||||
| 		h += ' />'; | ||||
|  | ||||
| 		ed.execCommand('mceInsertContent', false, h); | ||||
| 	} | ||||
|  | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function updatePreview() { | ||||
| 	var f = document.forms[0], type; | ||||
|  | ||||
| 	f.width.value = f.width.value || '320'; | ||||
| 	f.height.value = f.height.value || '240'; | ||||
|  | ||||
| 	type = getType(f.src.value); | ||||
| 	selectByValue(f, 'media_type', type); | ||||
| 	changedType(type); | ||||
| 	generatePreview(); | ||||
| } | ||||
|  | ||||
| function getMediaListHTML() { | ||||
| 	if (typeof(tinyMCEMediaList) != "undefined" && tinyMCEMediaList.length > 0) { | ||||
| 		var html = ""; | ||||
|  | ||||
| 		html += '<select id="linklist" name="linklist" style="width: 250px" onchange="this.form.src.value=this.options[this.selectedIndex].value;updatePreview();">'; | ||||
| 		html += '<option value="">---</option>'; | ||||
|  | ||||
| 		for (var i=0; i<tinyMCEMediaList.length; i++) | ||||
| 			html += '<option value="' + tinyMCEMediaList[i][1] + '">' + tinyMCEMediaList[i][0] + '</option>'; | ||||
|  | ||||
| 		html += '</select>'; | ||||
|  | ||||
| 		return html; | ||||
| 	} | ||||
|  | ||||
| 	return ""; | ||||
| } | ||||
|  | ||||
| function getType(v) { | ||||
| 	var fo, i, c, el, x, f = document.forms[0]; | ||||
|  | ||||
| 	fo = ed.getParam("media_types", "flash=swf;flv=flv;shockwave=dcr;qt=mov,qt,mpg,mp3,mp4,mpeg;shockwave=dcr;wmp=avi,wmv,wm,asf,asx,wmx,wvx;rmp=rm,ra,ram").split(';'); | ||||
|  | ||||
| 	// YouTube | ||||
| 	if (v.match(/watch\?v=(.+)(.*)/)) { | ||||
| 		f.width.value = '425'; | ||||
| 		f.height.value = '350'; | ||||
| 		f.src.value = 'http://www.youtube.com/v/' + v.match(/v=(.*)(.*)/)[0].split('=')[1]; | ||||
| 		return 'flash'; | ||||
| 	} | ||||
|  | ||||
| 	// Google video | ||||
| 	if (v.indexOf('http://video.google.com/videoplay?docid=') == 0) { | ||||
| 		f.width.value = '425'; | ||||
| 		f.height.value = '326'; | ||||
| 		f.src.value = 'http://video.google.com/googleplayer.swf?docId=' + v.substring('http://video.google.com/videoplay?docid='.length) + '&hl=en'; | ||||
| 		return 'flash'; | ||||
| 	} | ||||
|  | ||||
| 	for (i=0; i<fo.length; i++) { | ||||
| 		c = fo[i].split('='); | ||||
|  | ||||
| 		el = c[1].split(','); | ||||
| 		for (x=0; x<el.length; x++) | ||||
| 		if (v.indexOf('.' + el[x]) != -1) | ||||
| 			return c[0]; | ||||
| 	} | ||||
|  | ||||
| 	return null; | ||||
| } | ||||
|  | ||||
| function switchType(v) { | ||||
| 	var t = getType(v), d = document, f = d.forms[0]; | ||||
|  | ||||
| 	if (!t) | ||||
| 		return; | ||||
|  | ||||
| 	selectByValue(d.forms[0], 'media_type', t); | ||||
| 	changedType(t); | ||||
|  | ||||
| 	// Update qtsrc also | ||||
| 	if (t == 'qt' && f.src.value.toLowerCase().indexOf('rtsp://') != -1) { | ||||
| 		alert(ed.getLang("media_qt_stream_warn")); | ||||
|  | ||||
| 		if (f.qt_qtsrc.value == '') | ||||
| 			f.qt_qtsrc.value = f.src.value; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function changedType(t) { | ||||
| 	var d = document; | ||||
|  | ||||
| 	d.getElementById('flash_options').style.display = 'none'; | ||||
| 	d.getElementById('flv_options').style.display = 'none'; | ||||
| 	d.getElementById('qt_options').style.display = 'none'; | ||||
| 	d.getElementById('shockwave_options').style.display = 'none'; | ||||
| 	d.getElementById('wmp_options').style.display = 'none'; | ||||
| 	d.getElementById('rmp_options').style.display = 'none'; | ||||
| 	d.getElementById(t + '_options').style.display = 'block'; | ||||
| } | ||||
|  | ||||
| function serializeParameters() { | ||||
| 	var d = document, f = d.forms[0], s = ''; | ||||
|  | ||||
| 	switch (f.media_type.options[f.media_type.selectedIndex].value) { | ||||
| 		case "flash": | ||||
| 			s += getBool('flash', 'play', true); | ||||
| 			s += getBool('flash', 'loop', true); | ||||
| 			s += getBool('flash', 'menu', true); | ||||
| 			s += getBool('flash', 'swliveconnect', false); | ||||
| 			s += getStr('flash', 'quality'); | ||||
| 			s += getStr('flash', 'scale'); | ||||
| 			s += getStr('flash', 'salign'); | ||||
| 			s += getStr('flash', 'wmode'); | ||||
| 			s += getStr('flash', 'base'); | ||||
| 			s += getStr('flash', 'flashvars'); | ||||
| 		break; | ||||
|  | ||||
| 		case "qt": | ||||
| 			s += getBool('qt', 'loop', false); | ||||
| 			s += getBool('qt', 'autoplay', true); | ||||
| 			s += getBool('qt', 'cache', false); | ||||
| 			s += getBool('qt', 'controller', true); | ||||
| 			s += getBool('qt', 'correction', false, 'none', 'full'); | ||||
| 			s += getBool('qt', 'enablejavascript', false); | ||||
| 			s += getBool('qt', 'kioskmode', false); | ||||
| 			s += getBool('qt', 'autohref', false); | ||||
| 			s += getBool('qt', 'playeveryframe', false); | ||||
| 			s += getBool('qt', 'targetcache', false); | ||||
| 			s += getStr('qt', 'scale'); | ||||
| 			s += getStr('qt', 'starttime'); | ||||
| 			s += getStr('qt', 'endtime'); | ||||
| 			s += getStr('qt', 'target'); | ||||
| 			s += getStr('qt', 'qtsrcchokespeed'); | ||||
| 			s += getStr('qt', 'volume'); | ||||
| 			s += getStr('qt', 'qtsrc'); | ||||
| 		break; | ||||
|  | ||||
| 		case "shockwave": | ||||
| 			s += getBool('shockwave', 'sound'); | ||||
| 			s += getBool('shockwave', 'progress'); | ||||
| 			s += getBool('shockwave', 'autostart'); | ||||
| 			s += getBool('shockwave', 'swliveconnect'); | ||||
| 			s += getStr('shockwave', 'swvolume'); | ||||
| 			s += getStr('shockwave', 'swstretchstyle'); | ||||
| 			s += getStr('shockwave', 'swstretchhalign'); | ||||
| 			s += getStr('shockwave', 'swstretchvalign'); | ||||
| 		break; | ||||
|  | ||||
| 		case "wmp": | ||||
| 			s += getBool('wmp', 'autostart', true); | ||||
| 			s += getBool('wmp', 'enabled', false); | ||||
| 			s += getBool('wmp', 'enablecontextmenu', true); | ||||
| 			s += getBool('wmp', 'fullscreen', false); | ||||
| 			s += getBool('wmp', 'invokeurls', true); | ||||
| 			s += getBool('wmp', 'mute', false); | ||||
| 			s += getBool('wmp', 'stretchtofit', false); | ||||
| 			s += getBool('wmp', 'windowlessvideo', false); | ||||
| 			s += getStr('wmp', 'balance'); | ||||
| 			s += getStr('wmp', 'baseurl'); | ||||
| 			s += getStr('wmp', 'captioningid'); | ||||
| 			s += getStr('wmp', 'currentmarker'); | ||||
| 			s += getStr('wmp', 'currentposition'); | ||||
| 			s += getStr('wmp', 'defaultframe'); | ||||
| 			s += getStr('wmp', 'playcount'); | ||||
| 			s += getStr('wmp', 'rate'); | ||||
| 			s += getStr('wmp', 'uimode'); | ||||
| 			s += getStr('wmp', 'volume'); | ||||
| 		break; | ||||
|  | ||||
| 		case "rmp": | ||||
| 			s += getBool('rmp', 'autostart', false); | ||||
| 			s += getBool('rmp', 'loop', false); | ||||
| 			s += getBool('rmp', 'autogotourl', true); | ||||
| 			s += getBool('rmp', 'center', false); | ||||
| 			s += getBool('rmp', 'imagestatus', true); | ||||
| 			s += getBool('rmp', 'maintainaspect', false); | ||||
| 			s += getBool('rmp', 'nojava', false); | ||||
| 			s += getBool('rmp', 'prefetch', false); | ||||
| 			s += getBool('rmp', 'shuffle', false); | ||||
| 			s += getStr('rmp', 'console'); | ||||
| 			s += getStr('rmp', 'controls'); | ||||
| 			s += getStr('rmp', 'numloop'); | ||||
| 			s += getStr('rmp', 'scriptcallbacks'); | ||||
| 		break; | ||||
| 	} | ||||
|  | ||||
| 	s += getStr(null, 'id'); | ||||
| 	s += getStr(null, 'name'); | ||||
| 	s += getStr(null, 'src'); | ||||
| 	s += getStr(null, 'align'); | ||||
| 	s += getStr(null, 'bgcolor'); | ||||
| 	s += getInt(null, 'vspace'); | ||||
| 	s += getInt(null, 'hspace'); | ||||
| 	s += getStr(null, 'width'); | ||||
| 	s += getStr(null, 'height'); | ||||
|  | ||||
| 	s = s.length > 0 ? s.substring(0, s.length - 1) : s; | ||||
|  | ||||
| 	return s; | ||||
| } | ||||
|  | ||||
| function setBool(pl, p, n) { | ||||
| 	if (typeof(pl[n]) == "undefined") | ||||
| 		return; | ||||
|  | ||||
| 	document.forms[0].elements[p + "_" + n].checked = pl[n]; | ||||
| } | ||||
|  | ||||
| function setStr(pl, p, n) { | ||||
| 	var f = document.forms[0], e = f.elements[(p != null ? p + "_" : '') + n]; | ||||
|  | ||||
| 	if (typeof(pl[n]) == "undefined") | ||||
| 		return; | ||||
|  | ||||
| 	if (e.type == "text") | ||||
| 		e.value = pl[n]; | ||||
| 	else | ||||
| 		selectByValue(f, (p != null ? p + "_" : '') + n, pl[n]); | ||||
| } | ||||
|  | ||||
| function getBool(p, n, d, tv, fv) { | ||||
| 	var v = document.forms[0].elements[p + "_" + n].checked; | ||||
|  | ||||
| 	tv = typeof(tv) == 'undefined' ? 'true' : "'" + jsEncode(tv) + "'"; | ||||
| 	fv = typeof(fv) == 'undefined' ? 'false' : "'" + jsEncode(fv) + "'"; | ||||
|  | ||||
| 	return (v == d) ? '' : n + (v ? ':' + tv + ',' : ':' + fv + ','); | ||||
| } | ||||
|  | ||||
| function getStr(p, n, d) { | ||||
| 	var e = document.forms[0].elements[(p != null ? p + "_" : "") + n]; | ||||
| 	var v = e.type == "text" ? e.value : e.options[e.selectedIndex].value; | ||||
|  | ||||
| 	if (n == 'src') | ||||
| 		v = tinyMCEPopup.editor.convertURL(v, 'src', null); | ||||
|  | ||||
| 	return ((n == d || v == '') ? '' : n + ":'" + jsEncode(v) + "',"); | ||||
| } | ||||
|  | ||||
| function getInt(p, n, d) { | ||||
| 	var e = document.forms[0].elements[(p != null ? p + "_" : "") + n]; | ||||
| 	var v = e.type == "text" ? e.value : e.options[e.selectedIndex].value; | ||||
|  | ||||
| 	return ((n == d || v == '') ? '' : n + ":" + v.replace(/[^0-9]+/g, '') + ","); | ||||
| } | ||||
|  | ||||
| function jsEncode(s) { | ||||
| 	s = s.replace(new RegExp('\\\\', 'g'), '\\\\'); | ||||
| 	s = s.replace(new RegExp('"', 'g'), '\\"'); | ||||
| 	s = s.replace(new RegExp("'", 'g'), "\\'"); | ||||
|  | ||||
| 	return s; | ||||
| } | ||||
|  | ||||
| function generatePreview(c) { | ||||
| 	var f = document.forms[0], p = document.getElementById('prev'), h = '', cls, pl, n, type, codebase, wp, hp, nw, nh; | ||||
|  | ||||
| 	p.innerHTML = '<!-- x --->'; | ||||
|  | ||||
| 	nw = parseInt(f.width.value); | ||||
| 	nh = parseInt(f.height.value); | ||||
|  | ||||
| 	if (f.width.value != "" && f.height.value != "") { | ||||
| 		if (f.constrain.checked) { | ||||
| 			if (c == 'width' && oldWidth != 0) { | ||||
| 				wp = nw / oldWidth; | ||||
| 				nh = Math.round(wp * nh); | ||||
| 				f.height.value = nh; | ||||
| 			} else if (c == 'height' && oldHeight != 0) { | ||||
| 				hp = nh / oldHeight; | ||||
| 				nw = Math.round(hp * nw); | ||||
| 				f.width.value = nw; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (f.width.value != "") | ||||
| 		oldWidth = nw; | ||||
|  | ||||
| 	if (f.height.value != "") | ||||
| 		oldHeight = nh; | ||||
|  | ||||
| 	// After constrain | ||||
| 	pl = serializeParameters(); | ||||
|  | ||||
| 	switch (f.media_type.options[f.media_type.selectedIndex].value) { | ||||
| 		case "flash": | ||||
| 			cls = 'clsid:D27CDB6E-AE6D-11cf-96B8-444553540000'; | ||||
| 			codebase = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0'; | ||||
| 			type = 'application/x-shockwave-flash'; | ||||
| 			break; | ||||
|  | ||||
| 		case "shockwave": | ||||
| 			cls = 'clsid:166B1BCA-3F9C-11CF-8075-444553540000'; | ||||
| 			codebase = 'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0'; | ||||
| 			type = 'application/x-director'; | ||||
| 			break; | ||||
|  | ||||
| 		case "qt": | ||||
| 			cls = 'clsid:02BF25D5-8C17-4B23-BC80-D3488ABDDC6B'; | ||||
| 			codebase = 'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0'; | ||||
| 			type = 'video/quicktime'; | ||||
| 			break; | ||||
|  | ||||
| 		case "wmp": | ||||
| 			cls = ed.getParam('media_wmp6_compatible') ? 'clsid:05589FA1-C356-11CE-BF01-00AA0055595A' : 'clsid:6BF52A52-394A-11D3-B153-00C04F79FAA6'; | ||||
| 			codebase = 'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701'; | ||||
| 			type = 'application/x-mplayer2'; | ||||
| 			break; | ||||
|  | ||||
| 		case "rmp": | ||||
| 			cls = 'clsid:CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA'; | ||||
| 			codebase = 'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701'; | ||||
| 			type = 'audio/x-pn-realaudio-plugin'; | ||||
| 			break; | ||||
| 	} | ||||
|  | ||||
| 	if (pl == '') { | ||||
| 		p.innerHTML = ''; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	pl = tinyMCEPopup.editor.plugins.media._parse(pl); | ||||
|  | ||||
| 	if (!pl.src) { | ||||
| 		p.innerHTML = ''; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	pl.src = tinyMCEPopup.editor.documentBaseURI.toAbsolute(pl.src); | ||||
| 	pl.width = !pl.width ? 100 : pl.width; | ||||
| 	pl.height = !pl.height ? 100 : pl.height; | ||||
| 	pl.id = !pl.id ? 'obj' : pl.id; | ||||
| 	pl.name = !pl.name ? 'eobj' : pl.name; | ||||
| 	pl.align = !pl.align ? '' : pl.align; | ||||
|  | ||||
| 	// Avoid annoying warning about insecure items | ||||
| 	if (!tinymce.isIE || document.location.protocol != 'https:') { | ||||
| 		h += '<object classid="clsid:' + cls + '" codebase="' + codebase + '" width="' + pl.width + '" height="' + pl.height + '" id="' + pl.id + '" name="' + pl.name + '" align="' + pl.align + '">'; | ||||
|  | ||||
| 		for (n in pl) { | ||||
| 			h += '<param name="' + n + '" value="' + pl[n] + '">'; | ||||
|  | ||||
| 			// Add extra url parameter if it's an absolute URL | ||||
| 			if (n == 'src' && pl[n].indexOf('://') != -1) | ||||
| 				h += '<param name="url" value="' + pl[n] + '" />'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	h += '<embed type="' + type + '" '; | ||||
|  | ||||
| 	for (n in pl) | ||||
| 		h += n + '="' + pl[n] + '" '; | ||||
|  | ||||
| 	h += '></embed>'; | ||||
|  | ||||
| 	// Avoid annoying warning about insecure items | ||||
| 	if (!tinymce.isIE || document.location.protocol != 'https:') | ||||
| 		h += '</object>'; | ||||
|  | ||||
| 	p.innerHTML = "<!-- x --->" + h; | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,103 @@ | ||||
| tinyMCE.addI18n('en.media_dlg',{ | ||||
| title:"Insert / edit embedded media", | ||||
| general:"General", | ||||
| advanced:"Advanced", | ||||
| file:"File/URL", | ||||
| list:"List", | ||||
| size:"Dimensions", | ||||
| preview:"Preview", | ||||
| constrain_proportions:"Constrain proportions", | ||||
| type:"Type", | ||||
| id:"Id", | ||||
| name:"Name", | ||||
| class_name:"Class", | ||||
| vspace:"V-Space", | ||||
| hspace:"H-Space", | ||||
| play:"Auto play", | ||||
| loop:"Loop", | ||||
| menu:"Show menu", | ||||
| quality:"Quality", | ||||
| scale:"Scale", | ||||
| align:"Align", | ||||
| salign:"SAlign", | ||||
| wmode:"WMode", | ||||
| bgcolor:"Background", | ||||
| base:"Base", | ||||
| flashvars:"Flashvars", | ||||
| liveconnect:"SWLiveConnect", | ||||
| autohref:"AutoHREF", | ||||
| cache:"Cache", | ||||
| hidden:"Hidden", | ||||
| controller:"Controller", | ||||
| kioskmode:"Kiosk mode", | ||||
| playeveryframe:"Play every frame", | ||||
| targetcache:"Target cache", | ||||
| correction:"No correction", | ||||
| enablejavascript:"Enable JavaScript", | ||||
| starttime:"Start time", | ||||
| endtime:"End time", | ||||
| href:"Href", | ||||
| qtsrcchokespeed:"Choke speed", | ||||
| target:"Target", | ||||
| volume:"Volume", | ||||
| autostart:"Auto start", | ||||
| enabled:"Enabled", | ||||
| fullscreen:"Fullscreen", | ||||
| invokeurls:"Invoke URLs", | ||||
| mute:"Mute", | ||||
| stretchtofit:"Stretch to fit", | ||||
| windowlessvideo:"Windowless video", | ||||
| balance:"Balance", | ||||
| baseurl:"Base URL", | ||||
| captioningid:"Captioning id", | ||||
| currentmarker:"Current marker", | ||||
| currentposition:"Current position", | ||||
| defaultframe:"Default frame", | ||||
| playcount:"Play count", | ||||
| rate:"Rate", | ||||
| uimode:"UI Mode", | ||||
| flash_options:"Flash options", | ||||
| qt_options:"Quicktime options", | ||||
| wmp_options:"Windows media player options", | ||||
| rmp_options:"Real media player options", | ||||
| shockwave_options:"Shockwave options", | ||||
| autogotourl:"Auto goto URL", | ||||
| center:"Center", | ||||
| imagestatus:"Image status", | ||||
| maintainaspect:"Maintain aspect", | ||||
| nojava:"No java", | ||||
| prefetch:"Prefetch", | ||||
| shuffle:"Shuffle", | ||||
| console:"Console", | ||||
| numloop:"Num loops", | ||||
| controls:"Controls", | ||||
| scriptcallbacks:"Script callbacks", | ||||
| swstretchstyle:"Stretch style", | ||||
| swstretchhalign:"Stretch H-Align", | ||||
| swstretchvalign:"Stretch V-Align", | ||||
| sound:"Sound", | ||||
| progress:"Progress", | ||||
| qtsrc:"QT Src", | ||||
| qt_stream_warn:"Streamed rtsp resources should be added to the QT Src field under the advanced tab.\nYou should also add a non streamed version to the Src field..", | ||||
| align_top:"Top", | ||||
| align_right:"Right", | ||||
| align_bottom:"Bottom", | ||||
| align_left:"Left", | ||||
| align_center:"Center", | ||||
| align_top_left:"Top left", | ||||
| align_top_right:"Top right", | ||||
| align_bottom_left:"Bottom left", | ||||
| align_bottom_right:"Bottom right", | ||||
| flv_options:"Flash video options", | ||||
| flv_scalemode:"Scale mode", | ||||
| flv_buffer:"Buffer", | ||||
| flv_startimage:"Start image", | ||||
| flv_starttime:"Start time", | ||||
| flv_defaultvolume:"Default volumne", | ||||
| flv_hiddengui:"Hidden GUI", | ||||
| flv_autostart:"Auto start", | ||||
| flv_loop:"Loop", | ||||
| flv_showscalemodes:"Show scale modes", | ||||
| flv_smoothvideo:"Smooth video", | ||||
| flv_jscallback:"JS Callback" | ||||
| }); | ||||
| @@ -0,0 +1,824 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#media_dlg.title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/media.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/validate.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||||
| 	<link href="css/media.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body style="display: none"> | ||||
|     <form onsubmit="insertMedia();return false;" action="#"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');generatePreview();" onmousedown="return false;">{#media_dlg.general}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#media_dlg.advanced}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#media_dlg.general}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 							<tr> | ||||
| 								<td><label for="media_type">{#media_dlg.type}</label></td> | ||||
| 								<td> | ||||
| 									<select id="media_type" name="media_type" onchange="changedType(this.value);generatePreview();"> | ||||
| 										<option value="flash">Flash</option> | ||||
| 										<!-- <option value="flv">Flash video (FLV)</option> --> | ||||
| 										<option value="qt">Quicktime</option> | ||||
| 										<option value="shockwave">Shockwave</option> | ||||
| 										<option value="wmp">Windows Media</option> | ||||
| 										<option value="rmp">Real Media</option> | ||||
| 									</select> | ||||
| 								</td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 							<td><label for="src">{#media_dlg.file}</label></td> | ||||
| 							  <td> | ||||
| 									<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 									  <tr> | ||||
| 										<td><input id="src" name="src" type="text" value="" class="mceFocus" onchange="switchType(this.value);generatePreview();" /></td> | ||||
| 										<td id="filebrowsercontainer"> </td> | ||||
| 									  </tr> | ||||
| 									</table> | ||||
| 								</td> | ||||
| 							</tr> | ||||
| 							<tr id="linklistrow"> | ||||
| 								<td><label for="linklist">{#media_dlg.list}</label></td> | ||||
| 								<td id="linklistcontainer"> </td> | ||||
| 							</tr> | ||||
| 							<tr> | ||||
| 								<td><label for="width">{#media_dlg.size}</label></td> | ||||
| 								<td> | ||||
| 									<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 										<tr> | ||||
| 											<td><input type="text" id="width" name="width" value="" class="size" onchange="generatePreview('width');" /> x <input type="text" id="height" name="height" value="" class="size"  onchange="generatePreview('height');" /></td> | ||||
| 											<td>  <input id="constrain" type="checkbox" name="constrain" class="checkbox" /></td> | ||||
| 											<td><label id="constrainlabel" for="constrain">{#media_dlg.constrain_proportions}</label></td> | ||||
| 										</tr> | ||||
| 									</table> | ||||
| 								</td> | ||||
| 							</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset> | ||||
| 					<legend>{#media_dlg.preview}</legend> | ||||
| 					<div id="prev"></div> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#media_dlg.advanced}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0" width="100%"> | ||||
| 						<tr> | ||||
| 							<td><label for="id">{#media_dlg.id}</label></td> | ||||
| 							<td><input type="text" id="id" name="id" onchange="generatePreview();" /></td> | ||||
| 							<td><label for="name">{#media_dlg.name}</label></td> | ||||
| 							<td><input type="text" id="name" name="name" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="align">{#media_dlg.align}</label></td> | ||||
| 							<td> | ||||
| 								<select id="align" name="align" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="top">{#media_dlg.align_top}</option> | ||||
| 									<option value="right">{#media_dlg.align_right}</option> | ||||
| 									<option value="bottom">{#media_dlg.align_bottom}</option> | ||||
| 									<option value="left">{#media_dlg.align_left}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="bgcolor">{#media_dlg.bgcolor}</label></td> | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');generatePreview();" /></td> | ||||
| 										<td id="bgcolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="vspace">{#media_dlg.vspace}</label></td> | ||||
| 							<td><input type="text" id="vspace" name="vspace" class="number" onchange="generatePreview();" /></td> | ||||
| 							<td><label for="hspace">{#media_dlg.hspace}</label></td> | ||||
| 							<td><input type="text" id="hspace" name="hspace" class="number" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="flash_options"> | ||||
| 					<legend>{#media_dlg.flash_options}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td><label for="flash_quality">{#media_dlg.quality}</label></td> | ||||
| 							<td> | ||||
| 								<select id="flash_quality" name="flash_quality" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="high">high</option> | ||||
| 									<option value="low">low</option> | ||||
| 									<option value="autolow">autolow</option> | ||||
| 									<option value="autohigh">autohigh</option> | ||||
| 									<option value="best">best</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="flash_scale">{#media_dlg.scale}</label></td> | ||||
| 							<td> | ||||
| 								<select id="flash_scale" name="flash_scale" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="showall">showall</option> | ||||
| 									<option value="noborder">noborder</option> | ||||
| 									<option value="exactfit">exactfit</option> | ||||
| 									<option value="noscale">noscale</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="flash_wmode">{#media_dlg.wmode}</label></td> | ||||
| 							<td> | ||||
| 								<select id="flash_wmode" name="flash_wmode" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="window">window</option> | ||||
| 									<option value="opaque">opaque</option> | ||||
| 									<option value="transparent">transparent</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="flash_salign">{#media_dlg.salign}</label></td> | ||||
| 							<td> | ||||
| 								<select id="flash_salign" name="flash_salign" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="l">{#media_dlg.align_left}</option> | ||||
| 									<option value="t">{#media_dlg.align_top}</option> | ||||
| 									<option value="r">{#media_dlg.align_right}</option> | ||||
| 									<option value="b">{#media_dlg.align_bottom}</option> | ||||
| 									<option value="tl">{#media_dlg.align_top_left}</option> | ||||
| 									<option value="tr">{#media_dlg.align_top_right}</option> | ||||
| 									<option value="bl">{#media_dlg.align_bottom_left}</option> | ||||
| 									<option value="br">{#media_dlg.align_bottom_right}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flash_play" name="flash_play" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flash_play">{#media_dlg.play}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flash_loop" name="flash_loop" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flash_loop">{#media_dlg.loop}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flash_menu" name="flash_menu" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flash_menu">{#media_dlg.menu}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flash_swliveconnect" name="flash_swliveconnect" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flash_swliveconnect">{#media_dlg.liveconnect}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
|  | ||||
| 					<table> | ||||
| 						<tr> | ||||
| 							<td><label for="flash_base">{#media_dlg.base}</label></td> | ||||
| 							<td><input type="text" id="flash_base" name="flash_base" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="flash_flashvars">{#media_dlg.flashvars}</label></td> | ||||
| 							<td><input type="text" id="flash_flashvars" name="flash_flashvars" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="flv_options"> | ||||
| 					<legend>{#media_dlg.flv_options}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td><label for="flv_scalemode">{#media_dlg.flv_scalemode}</label></td> | ||||
| 							<td> | ||||
| 								<select id="flv_scalemode" name="flv_scalemode" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="none">none</option> | ||||
| 									<option value="double">double</option> | ||||
| 									<option value="full">full</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="flv_buffer">{#media_dlg.flv_buffer}</label></td> | ||||
| 							<td><input type="text" id="flv_buffer" name="flv_buffer" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="flv_startimage">{#media_dlg.flv_startimage}</label></td> | ||||
| 							<td><input type="text" id="flv_startimage" name="flv_startimage" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="flv_starttime">{#media_dlg.flv_starttime}</label></td> | ||||
| 							<td><input type="text" id="flv_starttime" name="flv_starttime" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="flv_defaultvolume">{#media_dlg.flv_defaultvolume}</label></td> | ||||
| 							<td><input type="text" id="flv_defaultvolume" name="flv_defaultvolume" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="flv_starttime">{#media_dlg.flv_starttime}</label></td> | ||||
| 							<td><input type="text" id="flv_starttime" name="flv_starttime" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flv_hiddengui" name="flv_hiddengui" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flv_hiddengui">{#media_dlg.flv_hiddengui}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flv_autostart" name="flv_autostart" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flv_autostart">{#media_dlg.flv_autostart}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flv_loop" name="flv_loop" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flv_loop">{#media_dlg.flv_loop}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flv_showscalemodes" name="flv_showscalemodes" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flv_showscalemodes">{#media_dlg.flv_showscalemodes}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flv_smoothvideo" name="flash_flv_flv_smoothvideosmoothvideo" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flv_smoothvideo">{#media_dlg.flv_smoothvideo}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="flv_jscallback" name="flv_jscallback" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="flv_jscallback">{#media_dlg.flv_jscallback}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="qt_options"> | ||||
| 					<legend>{#media_dlg.qt_options}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_loop" name="qt_loop" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_loop">{#media_dlg.loop}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_autoplay" name="qt_autoplay" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_autoplay">{#media_dlg.play}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_cache" name="qt_cache" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_cache">{#media_dlg.cache}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_controller" name="qt_controller" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_controller">{#media_dlg.controller}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_correction" name="qt_correction" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_correction">{#media_dlg.correction}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_enablejavascript" name="qt_enablejavascript" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_enablejavascript">{#media_dlg.enablejavascript}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_kioskmode" name="qt_kioskmode" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_kioskmode">{#media_dlg.kioskmode}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_autohref" name="qt_autohref" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_autohref">{#media_dlg.autohref}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_playeveryframe" name="qt_playeveryframe" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_playeveryframe">{#media_dlg.playeveryframe}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="qt_targetcache" name="qt_targetcache" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="qt_targetcache">{#media_dlg.targetcache}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="qt_scale">{#media_dlg.scale}</label></td> | ||||
| 							<td><select id="qt_scale" name="qt_scale" class="mceEditableSelect" onchange="generatePreview();"> | ||||
| 									<option value="">{#not_set}</option>  | ||||
| 									<option value="tofit">tofit</option> | ||||
| 									<option value="aspect">aspect</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> </td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="qt_starttime">{#media_dlg.starttime}</label></td> | ||||
| 							<td><input type="text" id="qt_starttime" name="qt_starttime" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="qt_endtime">{#media_dlg.endtime}</label></td> | ||||
| 							<td><input type="text" id="qt_endtime" name="qt_endtime" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="qt_target">{#media_dlg.target}</label></td> | ||||
| 							<td><input type="text" id="qt_target" name="qt_target" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="qt_href">{#media_dlg.href}</label></td> | ||||
| 							<td><input type="text" id="qt_href" name="qt_href" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="qt_qtsrcchokespeed">{#media_dlg.qtsrcchokespeed}</label></td> | ||||
| 							<td><input type="text" id="qt_qtsrcchokespeed" name="qt_qtsrcchokespeed" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="qt_volume">{#media_dlg.volume}</label></td> | ||||
| 							<td><input type="text" id="qt_volume" name="qt_volume" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="qt_qtsrc">{#media_dlg.qtsrc}</label></td> | ||||
| 							<td colspan="4"> | ||||
| 							<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 								  <tr> | ||||
| 									<td><input type="text" id="qt_qtsrc" name="qt_qtsrc" onchange="generatePreview();" /></td> | ||||
| 									<td id="qtsrcfilebrowsercontainer"> </td> | ||||
| 								  </tr> | ||||
| 							</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="wmp_options"> | ||||
| 					<legend>{#media_dlg.wmp_options}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_autostart" name="wmp_autostart" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_autostart">{#media_dlg.autostart}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_enabled" name="wmp_enabled" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_enabled">{#media_dlg.enabled}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_enablecontextmenu" name="wmp_enablecontextmenu" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_enablecontextmenu">{#media_dlg.menu}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_fullscreen" name="wmp_fullscreen" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_fullscreen">{#media_dlg.fullscreen}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_invokeurls" name="wmp_invokeurls" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_invokeurls">{#media_dlg.invokeurls}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_mute" name="wmp_mute" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_mute">{#media_dlg.mute}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_stretchtofit" name="wmp_stretchtofit" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_stretchtofit">{#media_dlg.stretchtofit}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="wmp_windowlessvideo" name="wmp_windowlessvideo" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="wmp_windowlessvideo">{#media_dlg.windowlessvideo}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="wmp_balance">{#media_dlg.balance}</label></td> | ||||
| 							<td><input type="text" id="wmp_balance" name="wmp_balance" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="wmp_baseurl">{#media_dlg.baseurl}</label></td> | ||||
| 							<td><input type="text" id="wmp_baseurl" name="wmp_baseurl" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="wmp_captioningid">{#media_dlg.captioningid}</label></td> | ||||
| 							<td><input type="text" id="wmp_captioningid" name="wmp_captioningid" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="wmp_currentmarker">{#media_dlg.currentmarker}</label></td> | ||||
| 							<td><input type="text" id="wmp_currentmarker" name="wmp_currentmarker" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="wmp_currentposition">{#media_dlg.currentposition}</label></td> | ||||
| 							<td><input type="text" id="wmp_currentposition" name="wmp_currentposition" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="wmp_defaultframe">{#media_dlg.defaultframe}</label></td> | ||||
| 							<td><input type="text" id="wmp_defaultframe" name="wmp_defaultframe" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="wmp_playcount">{#media_dlg.playcount}</label></td> | ||||
| 							<td><input type="text" id="wmp_playcount" name="wmp_playcount" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="wmp_rate">{#media_dlg.rate}</label></td> | ||||
| 							<td><input type="text" id="wmp_rate" name="wmp_rate" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="wmp_uimode">{#media_dlg.uimode}</label></td> | ||||
| 							<td><input type="text" id="wmp_uimode" name="wmp_uimode" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="wmp_volume">{#media_dlg.volume}</label></td> | ||||
| 							<td><input type="text" id="wmp_volume" name="wmp_volume" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="rmp_options"> | ||||
| 					<legend>{#media_dlg.rmp_options}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_autostart" name="rmp_autostart" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_autostart">{#media_dlg.autostart}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_loop" name="rmp_loop" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_loop">{#media_dlg.loop}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_autogotourl" name="rmp_autogotourl" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_autogotourl">{#media_dlg.autogotourl}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_center" name="rmp_center" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_center">{#media_dlg.center}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_imagestatus" name="rmp_imagestatus" checked="checked" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_imagestatus">{#media_dlg.imagestatus}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_maintainaspect" name="rmp_maintainaspect" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_maintainaspect">{#media_dlg.maintainaspect}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_nojava" name="rmp_nojava" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_nojava">{#media_dlg.nojava}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_prefetch" name="rmp_prefetch" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_prefetch">{#media_dlg.prefetch}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="rmp_shuffle" name="rmp_shuffle" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="rmp_shuffle">{#media_dlg.shuffle}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								  | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="rmp_console">{#media_dlg.console}</label></td> | ||||
| 							<td><input type="text" id="rmp_console" name="rmp_console" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="rmp_controls">{#media_dlg.controls}</label></td> | ||||
| 							<td><input type="text" id="rmp_controls" name="rmp_controls" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="rmp_numloop">{#media_dlg.numloop}</label></td> | ||||
| 							<td><input type="text" id="rmp_numloop" name="rmp_numloop" onchange="generatePreview();" /></td> | ||||
|  | ||||
| 							<td><label for="rmp_scriptcallbacks">{#media_dlg.scriptcallbacks}</label></td> | ||||
| 							<td><input type="text" id="rmp_scriptcallbacks" name="rmp_scriptcallbacks" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
|  | ||||
| 				<fieldset id="shockwave_options"> | ||||
| 					<legend>{#media_dlg.shockwave_options}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td><label for="shockwave_swstretchstyle">{#media_dlg.swstretchstyle}</label></td> | ||||
| 							<td> | ||||
| 								<select id="shockwave_swstretchstyle" name="shockwave_swstretchstyle" onchange="generatePreview();"> | ||||
| 									<option value="none">{#not_set}</option> | ||||
| 									<option value="meet">Meet</option> | ||||
| 									<option value="fill">Fill</option> | ||||
| 									<option value="stage">Stage</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="shockwave_swvolume">{#media_dlg.volume}</label></td> | ||||
| 							<td><input type="text" id="shockwave_swvolume" name="shockwave_swvolume" onchange="generatePreview();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="shockwave_swstretchhalign">{#media_dlg.swstretchhalign}</label></td> | ||||
| 							<td> | ||||
| 								<select id="shockwave_swstretchhalign" name="shockwave_swstretchhalign" onchange="generatePreview();"> | ||||
| 									<option value="none">{#not_set}</option> | ||||
| 									<option value="left">{#media_dlg.align_left}</option> | ||||
| 									<option value="center">{#media_dlg.align_center}</option> | ||||
| 									<option value="right">{#media_dlg.align_right}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="shockwave_swstretchvalign">{#media_dlg.swstretchvalign}</label></td> | ||||
| 							<td> | ||||
| 								<select id="shockwave_swstretchvalign" name="shockwave_swstretchvalign" onchange="generatePreview();"> | ||||
| 									<option value="none">{#not_set}</option> | ||||
| 									<option value="meet">Meet</option> | ||||
| 									<option value="fill">Fill</option> | ||||
| 									<option value="stage">Stage</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="shockwave_autostart" name="shockwave_autostart" onchange="generatePreview();" checked="checked" /></td> | ||||
| 										<td><label for="shockwave_autostart">{#media_dlg.autostart}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="shockwave_sound" name="shockwave_sound" onchange="generatePreview();" checked="checked" /></td> | ||||
| 										<td><label for="shockwave_sound">{#media_dlg.sound}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
|  | ||||
| 						<tr> | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="shockwave_swliveconnect" name="shockwave_swliveconnect" onchange="generatePreview();" /></td> | ||||
| 										<td><label for="shockwave_swliveconnect">{#media_dlg.liveconnect}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
|  | ||||
| 							<td colspan="2"> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input type="checkbox" class="checkbox" id="shockwave_progress" name="shockwave_progress" onchange="generatePreview();" checked="checked" /></td> | ||||
| 										<td><label for="shockwave_progress">{#media_dlg.progress}</label></td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,22 @@ | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| <title>blank_page</title> | ||||
| <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> | ||||
| <link href="css/blank.css" rel="stylesheet" type="text/css" /> | ||||
| <base target="_self" /> | ||||
| <script type="text/javascript"> | ||||
| function init() { | ||||
| 	if (parent.tinymce.isIE) | ||||
| 		document.body.contentEditable = true; | ||||
| 	else | ||||
| 		document.designMode = 'on'; | ||||
|  | ||||
| 	parent.initIframe(document); | ||||
| 	window.focus(); | ||||
| } | ||||
| </script> | ||||
| </head> | ||||
| <body onload="init();"> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,389 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:27 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	var Event = tinymce.dom.Event; | ||||
|  | ||||
| 	tinymce.create('tinymce.plugins.PastePlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			var t = this; | ||||
|  | ||||
| 			t.editor = ed;  | ||||
|  | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mcePasteText', function(ui, v) { | ||||
| 				if (ui) { | ||||
| 					if ((ed.getParam('paste_use_dialog', true)) || (!tinymce.isIE)) { | ||||
| 						ed.windowManager.open({ | ||||
| 							file : url + '/pastetext.htm', | ||||
| 							width : 450, | ||||
| 							height : 400, | ||||
| 							inline : 1 | ||||
| 						}, { | ||||
| 							plugin_url : url | ||||
| 						}); | ||||
| 					} else | ||||
| 						t._insertText(clipboardData.getData("Text"), true); | ||||
| 				} else | ||||
| 					t._insertText(v.html, v.linebreaks); | ||||
| 			}); | ||||
|  | ||||
| 			ed.addCommand('mcePasteWord', function(ui, v) { | ||||
| 				if (ui) { | ||||
| 					if ((ed.getParam('paste_use_dialog', true)) || (!tinymce.isIE)) { | ||||
| 						ed.windowManager.open({ | ||||
| 							file : url + '/pasteword.htm', | ||||
| 							width : 450, | ||||
| 							height : 400, | ||||
| 							inline : 1 | ||||
| 						}, { | ||||
| 							plugin_url : url | ||||
| 						}); | ||||
| 					} else | ||||
| 						t._insertText(t._clipboardHTML()); | ||||
| 				} else | ||||
| 					t._insertWordContent(v); | ||||
| 			}); | ||||
|  | ||||
| 			ed.addCommand('mceSelectAll', function() { | ||||
| 				ed.execCommand('selectall');  | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('pastetext', {title : 'paste.paste_text_desc', cmd : 'mcePasteText', ui : true}); | ||||
| 			ed.addButton('pasteword', {title : 'paste.paste_word_desc', cmd : 'mcePasteWord', ui : true}); | ||||
| 			ed.addButton('selectall', {title : 'paste.selectall_desc', cmd : 'mceSelectAll'}); | ||||
|  | ||||
| 			if (ed.getParam("paste_auto_cleanup_on_paste", false)) { | ||||
| 				ed.onPaste.add(function(ed, e) { | ||||
| 					return t._handlePasteEvent(e) | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			if (!tinymce.isIE && ed.getParam("paste_auto_cleanup_on_paste", false)) { | ||||
| 				// Force paste dialog if non IE browser | ||||
| 				ed.onKeyDown.add(function(ed, e) { | ||||
| 					if (e.ctrlKey && e.keyCode == 86) { | ||||
| 						window.setTimeout(function() { | ||||
| 							ed.execCommand("mcePasteText", true); | ||||
| 						}, 1); | ||||
|  | ||||
| 						Event.cancel(e); | ||||
| 					} | ||||
| 				}); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Paste text/word', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/paste', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		// Private methods | ||||
|  | ||||
| 		_handlePasteEvent : function(e) { | ||||
| 			var html = this._clipboardHTML(), ed = this.editor, sel = ed.selection, r; | ||||
|  | ||||
| 			// Removes italic, strong etc, the if was needed due to bug #1437114 | ||||
| 			if (ed && (r = sel.getRng()) && r.text.length > 0) | ||||
| 				ed.execCommand('delete'); | ||||
|  | ||||
| 			if (html && html.length > 0) | ||||
| 				ed.execCommand('mcePasteWord', false, html); | ||||
|  | ||||
| 			return Event.cancel(e); | ||||
| 		}, | ||||
|  | ||||
| 		_insertText : function(content, bLinebreaks) { | ||||
| 			content = this.editor.dom.encode(content); | ||||
|  | ||||
| 			if (content && content.length > 0) { | ||||
| 				if (bLinebreaks) {  | ||||
| 					// Special paragraph treatment  | ||||
| 					if (this.editor.getParam("paste_create_paragraphs", true)) { | ||||
| 						var rl = this.editor.getParam("paste_replace_list", '\u2122,<sup>TM</sup>,\u2026,...,\u201c|\u201d,",\u2019,\',\u2013|\u2014|\u2015|\u2212,-').split(','); | ||||
| 						for (var i=0; i<rl.length; i+=2) | ||||
| 							content = content.replace(new RegExp(rl[i], 'gi'), rl[i+1]); | ||||
|  | ||||
| 						content = content.replace(/\r\n\r\n/g, '</p><p>'); | ||||
| 						content = content.replace(/\r\r/g, '</p><p>'); | ||||
| 						content = content.replace(/\n\n/g, '</p><p>'); | ||||
|  | ||||
| 						// Has paragraphs  | ||||
| 						if ((pos = content.indexOf('</p><p>')) != -1) {  | ||||
| 							this.editor.execCommand("Delete");  | ||||
|  | ||||
| 							var node = this.editor.selection.getNode();  | ||||
|  | ||||
| 							// Get list of elements to break  | ||||
| 							var breakElms = []; | ||||
|  | ||||
| 							do {  | ||||
| 								if (node.nodeType == 1) {  | ||||
| 									// Don't break tables and break at body  | ||||
| 									if (node.nodeName == "TD" || node.nodeName == "BODY")  | ||||
| 										break;  | ||||
| 			 | ||||
| 									breakElms[breakElms.length] = node;  | ||||
| 								}  | ||||
| 							} while(node = node.parentNode);  | ||||
|  | ||||
| 							var before = "", after = "</p>";  | ||||
| 							before += content.substring(0, pos);  | ||||
|  | ||||
| 							for (var i=0; i<breakElms.length; i++) {  | ||||
| 								before += "</" + breakElms[i].nodeName + ">";  | ||||
| 								after += "<" + breakElms[(breakElms.length-1)-i].nodeName + ">";  | ||||
| 							}  | ||||
|  | ||||
| 							before += "<p>";  | ||||
| 							content = before + content.substring(pos+7) + after;  | ||||
| 						}  | ||||
| 					}  | ||||
|  | ||||
| 					if (this.editor.getParam("paste_create_linebreaks", true)) { | ||||
| 						content = content.replace(/\r\n/g, '<br />'); | ||||
| 						content = content.replace(/\r/g, '<br />'); | ||||
| 						content = content.replace(/\n/g, '<br />'); | ||||
| 					} | ||||
| 				}  | ||||
|  | ||||
| 				this.editor.execCommand("mceInsertRawHTML", false, content);  | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_insertWordContent : function(content) {  | ||||
| 			var t = this, ed = t.editor; | ||||
|  | ||||
| 			if (content && content.length > 0) { | ||||
| 				// Cleanup Word content | ||||
| 				var bull = String.fromCharCode(8226); | ||||
| 				var middot = String.fromCharCode(183); | ||||
|  | ||||
| 				if (ed.getParam('paste_insert_word_content_callback')) | ||||
| 					content = ed.execCallback('paste_insert_word_content_callback', 'before', content); | ||||
|  | ||||
| 				var rl = ed.getParam("paste_replace_list", '\u2122,<sup>TM</sup>,\u2026,...,\u201c|\u201d,",\u2019,\',\u2013|\u2014|\u2015|\u2212,-').split(','); | ||||
| 				for (var i=0; i<rl.length; i+=2) | ||||
| 					content = content.replace(new RegExp(rl[i], 'gi'), rl[i+1]); | ||||
|  | ||||
| 				if (this.editor.getParam("paste_convert_headers_to_strong", false)) { | ||||
| 					content = content.replace(new RegExp('<p class=MsoHeading.*?>(.*?)<\/p>', 'gi'), '<p><b>$1</b></p>'); | ||||
| 				} | ||||
|  | ||||
| 				content = content.replace(new RegExp('tab-stops: list [0-9]+.0pt">', 'gi'), '">' + "--list--"); | ||||
| 				content = content.replace(new RegExp(bull + "(.*?)<BR>", "gi"), "<p>" + middot + "$1</p>"); | ||||
| 				content = content.replace(new RegExp('<SPAN style="mso-list: Ignore">', 'gi'), "<span>" + bull); // Covert to bull list | ||||
| 				content = content.replace(/<o:p><\/o:p>/gi, ""); | ||||
| 				content = content.replace(new RegExp('<br style="page-break-before: always;.*>', 'gi'), '-- page break --'); // Replace pagebreaks | ||||
| 				content = content.replace(new RegExp('<(!--)([^>]*)(--)>', 'g'), "");  // Word comments | ||||
|  | ||||
| 				if (this.editor.getParam("paste_remove_spans", true)) | ||||
| 					content = content.replace(/<\/?span[^>]*>/gi, ""); | ||||
|  | ||||
| 				if (this.editor.getParam("paste_remove_styles", true)) | ||||
| 					content = content.replace(new RegExp('<(\\w[^>]*) style="([^"]*)"([^>]*)', 'gi'), "<$1$3"); | ||||
|  | ||||
| 				content = content.replace(/<\/?font[^>]*>/gi, ""); | ||||
|  | ||||
| 				// Strips class attributes. | ||||
| 				switch (this.editor.getParam("paste_strip_class_attributes", "all")) { | ||||
| 					case "all": | ||||
| 						content = content.replace(/<(\w[^>]*) class=([^ |>]*)([^>]*)/gi, "<$1$3"); | ||||
| 						break; | ||||
|  | ||||
| 					case "mso": | ||||
| 						content = content.replace(new RegExp('<(\\w[^>]*) class="?mso([^ |>]*)([^>]*)', 'gi'), "<$1$3"); | ||||
| 						break; | ||||
| 				} | ||||
|  | ||||
| 				content = content.replace(new RegExp('href="?' + this._reEscape("" + document.location) + '', 'gi'), 'href="' + this.editor.documentBaseURI.getURI()); | ||||
| 				content = content.replace(/<(\w[^>]*) lang=([^ |>]*)([^>]*)/gi, "<$1$3"); | ||||
| 				content = content.replace(/<\\?\?xml[^>]*>/gi, ""); | ||||
| 				content = content.replace(/<\/?\w+:[^>]*>/gi, ""); | ||||
| 				content = content.replace(/-- page break --\s*<p> <\/p>/gi, ""); // Remove pagebreaks | ||||
| 				content = content.replace(/-- page break --/gi, ""); // Remove pagebreaks | ||||
|  | ||||
| 		//		content = content.replace(/\/? */gi, "");   | ||||
| 		//		content = content.replace(/<p> <\/p>/gi, ''); | ||||
|  | ||||
| 				if (!this.editor.getParam('force_p_newlines')) { | ||||
| 					content = content.replace('', '' ,'gi'); | ||||
| 					content = content.replace('</p>', '<br /><br />' ,'gi'); | ||||
| 				} | ||||
|  | ||||
| 				if (!tinymce.isIE && !this.editor.getParam('force_p_newlines')) { | ||||
| 					content = content.replace(/<\/?p[^>]*>/gi, ""); | ||||
| 				} | ||||
|  | ||||
| 				content = content.replace(/<\/?div[^>]*>/gi, ""); | ||||
|  | ||||
| 				// Convert all middlot lists to UL lists | ||||
| 				if (this.editor.getParam("paste_convert_middot_lists", true)) { | ||||
| 					var div = ed.dom.create("div", null, content); | ||||
|  | ||||
| 					// Convert all middot paragraphs to li elements | ||||
| 					var className = this.editor.getParam("paste_unindented_list_class", "unIndentedList"); | ||||
|  | ||||
| 					while (this._convertMiddots(div, "--list--")) ; // bull | ||||
| 					while (this._convertMiddots(div, middot, className)) ; // Middot | ||||
| 					while (this._convertMiddots(div, bull)) ; // bull | ||||
|  | ||||
| 					content = div.innerHTML; | ||||
| 				} | ||||
|  | ||||
| 				// Replace all headers with strong and fix some other issues | ||||
| 				if (this.editor.getParam("paste_convert_headers_to_strong", false)) { | ||||
| 					content = content.replace(/<h[1-6]> <\/h[1-6]>/gi, '<p>  </p>'); | ||||
| 					content = content.replace(/<h[1-6]>/gi, '<p><b>'); | ||||
| 					content = content.replace(/<\/h[1-6]>/gi, '</b></p>'); | ||||
| 					content = content.replace(/<b> <\/b>/gi, '<b>  </b>'); | ||||
| 					content = content.replace(/^( )*/gi, ''); | ||||
| 				} | ||||
|  | ||||
| 				content = content.replace(/--list--/gi, ""); // Remove --list-- | ||||
|  | ||||
| 				if (ed.getParam('paste_insert_word_content_callback')) | ||||
| 					content = ed.execCallback('paste_insert_word_content_callback', 'after', content); | ||||
|  | ||||
| 				// Insert cleaned content | ||||
| 				this.editor.execCommand("mceInsertContent", false, content); | ||||
|  | ||||
| 				if (this.editor.getParam('paste_force_cleanup_wordpaste', true)) { | ||||
| 					var ed = this.editor; | ||||
|  | ||||
| 					window.setTimeout(function() { | ||||
| 						ed.execCommand("mceCleanup"); | ||||
| 					}, 1); // Do normal cleanup detached from this thread | ||||
| 				} | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_reEscape : function(s) { | ||||
| 			var l = "?.\\*[](){}+^$:"; | ||||
| 			var o = ""; | ||||
|  | ||||
| 			for (var i=0; i<s.length; i++) { | ||||
| 				var c = s.charAt(i); | ||||
|  | ||||
| 				if (l.indexOf(c) != -1) | ||||
| 					o += '\\' + c; | ||||
| 				else | ||||
| 					o += c; | ||||
| 			} | ||||
|  | ||||
| 			return o; | ||||
| 		}, | ||||
|  | ||||
| 		_convertMiddots : function(div, search, class_name) { | ||||
| 			var ed = this.editor, mdot = String.fromCharCode(183), bull = String.fromCharCode(8226); | ||||
| 			var nodes, prevul, i, p, ul, li, np, cp, li; | ||||
|  | ||||
| 			nodes = div.getElementsByTagName("p"); | ||||
| 			for (i=0; i<nodes.length; i++) { | ||||
| 				p = nodes[i]; | ||||
|  | ||||
| 				// Is middot | ||||
| 				if (p.innerHTML.indexOf(search) == 0) { | ||||
| 					ul = ed.dom.create("ul"); | ||||
|  | ||||
| 					if (class_name) | ||||
| 						ul.className = class_name; | ||||
|  | ||||
| 					// Add the first one | ||||
| 					li = ed.dom.create("li"); | ||||
| 					li.innerHTML = p.innerHTML.replace(new RegExp('' + mdot + '|' + bull + '|--list--| ', "gi"), ''); | ||||
| 					ul.appendChild(li); | ||||
|  | ||||
| 					// Add the rest | ||||
| 					np = p.nextSibling; | ||||
| 					while (np) { | ||||
| 						// If the node is whitespace, then | ||||
| 						// ignore it and continue on. | ||||
| 						if (np.nodeType == 3 && new RegExp('^\\s$', 'm').test(np.nodeValue)) { | ||||
| 								np = np.nextSibling; | ||||
| 								continue; | ||||
| 						} | ||||
|  | ||||
| 						if (search == mdot) { | ||||
| 								if (np.nodeType == 1 && new RegExp('^o(\\s+| )').test(np.innerHTML)) { | ||||
| 										// Second level of nesting | ||||
| 										if (!prevul) { | ||||
| 												prevul = ul; | ||||
| 												ul = ed.dom.create("ul"); | ||||
| 												prevul.appendChild(ul); | ||||
| 										} | ||||
| 										np.innerHTML = np.innerHTML.replace(/^o/, ''); | ||||
| 								} else { | ||||
| 										// Pop the stack if we're going back up to the first level | ||||
| 										if (prevul) { | ||||
| 												ul = prevul; | ||||
| 												prevul = null; | ||||
| 										} | ||||
| 										// Not element or middot paragraph | ||||
| 										if (np.nodeType != 1 || np.innerHTML.indexOf(search) != 0) | ||||
| 												break; | ||||
| 								} | ||||
| 						} else { | ||||
| 								// Not element or middot paragraph | ||||
| 								if (np.nodeType != 1 || np.innerHTML.indexOf(search) != 0) | ||||
| 										break; | ||||
| 							} | ||||
|  | ||||
| 						cp = np.nextSibling; | ||||
| 						li = ed.dom.create("li"); | ||||
| 						li.innerHTML = np.innerHTML.replace(new RegExp('' + mdot + '|' + bull + '|--list--| ', "gi"), ''); | ||||
| 						np.parentNode.removeChild(np); | ||||
| 						ul.appendChild(li); | ||||
| 						np = cp; | ||||
| 					} | ||||
|  | ||||
| 					p.parentNode.replaceChild(ul, p); | ||||
|  | ||||
| 					return true; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			return false; | ||||
| 		}, | ||||
|  | ||||
| 		_clipboardHTML : function() { | ||||
| 			var div = document.getElementById('_TinyMCE_clipboardHTML'); | ||||
|  | ||||
| 			if (!div) { | ||||
| 				var div = document.createElement('DIV'); | ||||
| 				div.id = '_TinyMCE_clipboardHTML'; | ||||
|  | ||||
| 				with (div.style) { | ||||
| 					visibility = 'hidden'; | ||||
| 					overflow = 'hidden'; | ||||
| 					position = 'absolute'; | ||||
| 					width = 1; | ||||
| 					height = 1; | ||||
| 				} | ||||
|  | ||||
| 				document.body.appendChild(div); | ||||
| 			} | ||||
|  | ||||
| 			div.innerHTML = ''; | ||||
| 			var rng = document.body.createTextRange(); | ||||
| 			rng.moveToElementText(div); | ||||
| 			rng.execCommand('Paste'); | ||||
| 			var html = div.innerHTML; | ||||
| 			div.innerHTML = ''; | ||||
| 			return html; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('paste', tinymce.plugins.PastePlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,42 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| function saveContent() { | ||||
| 	if (document.forms[0].htmlSource.value == '') { | ||||
| 		tinyMCEPopup.close(); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	tinyMCEPopup.execCommand('mcePasteText', false, { | ||||
| 		html : document.forms[0].htmlSource.value, | ||||
| 		linebreaks : document.forms[0].linebreaks.checked | ||||
| 	}); | ||||
|  | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function onLoadInit() { | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	// Remove Gecko spellchecking | ||||
| 	if (tinymce.isGecko) | ||||
| 		document.body.spellcheck = tinyMCEPopup.getParam("gecko_spellcheck"); | ||||
|  | ||||
| 	resizeInputs(); | ||||
| } | ||||
|  | ||||
| var wHeight=0, wWidth=0, owHeight=0, owWidth=0; | ||||
|  | ||||
| function resizeInputs() { | ||||
| 	if (!tinymce.isIE) { | ||||
| 		wHeight = self.innerHeight-80; | ||||
| 		wWidth = self.innerWidth-17; | ||||
| 	} else { | ||||
| 		wHeight = document.body.clientHeight-80; | ||||
| 		wWidth = document.body.clientWidth-17; | ||||
| 	} | ||||
|  | ||||
| 	document.forms[0].htmlSource.style.height = Math.abs(wHeight) + 'px'; | ||||
| 	document.forms[0].htmlSource.style.width  = Math.abs(wWidth) + 'px'; | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(onLoadInit); | ||||
| @@ -0,0 +1,56 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| function saveContent() { | ||||
| 	var html = document.getElementById("frmData").contentWindow.document.body.innerHTML; | ||||
|  | ||||
| 	if (html == ''){ | ||||
| 		tinyMCEPopup.close(); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	tinyMCEPopup.execCommand('mcePasteWord', false, html); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function onLoadInit() { | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	// Fix for endless reloading in FF | ||||
| 	window.setTimeout(createIFrame, 10); | ||||
| } | ||||
|  | ||||
| function createIFrame() { | ||||
| 	document.getElementById('iframecontainer').innerHTML = '<iframe id="frmData" name="frmData" class="sourceIframe" src="blank.htm" height="280" width="400" frameborder="0" style="background-color:#FFFFFF; width:100%;" dir="ltr" wrap="soft"></iframe>'; | ||||
| } | ||||
|  | ||||
| var wHeight=0, wWidth=0, owHeight=0, owWidth=0; | ||||
|  | ||||
| function initIframe(doc) { | ||||
| 	var dir = tinyMCEPopup.editor.settings.directionality; | ||||
|  | ||||
| 	doc.body.dir = dir; | ||||
|  | ||||
| 	// Remove Gecko spellchecking | ||||
| 	if (tinymce.isGecko) | ||||
| 		doc.body.spellcheck = tinyMCEPopup.getParam("gecko_spellcheck"); | ||||
|  | ||||
| 	resizeInputs(); | ||||
| } | ||||
|  | ||||
| function resizeInputs() { | ||||
| 	if (!tinymce.isIE) { | ||||
| 		wHeight = self.innerHeight - 80; | ||||
| 		wWidth = self.innerWidth - 18; | ||||
| 	} else { | ||||
| 		wHeight = document.body.clientHeight - 80; | ||||
| 		wWidth = document.body.clientWidth - 18; | ||||
| 	} | ||||
|  | ||||
| 	var elm = document.getElementById('frmData'); | ||||
| 	if (elm) { | ||||
| 		elm.style.height = Math.abs(wHeight) + 'px'; | ||||
| 		elm.style.width  = Math.abs(wWidth) + 'px'; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(onLoadInit); | ||||
| @@ -0,0 +1,5 @@ | ||||
| tinyMCE.addI18n('en.paste_dlg',{ | ||||
| text_title:"Use CTRL+V on your keyboard to paste the text into the window.", | ||||
| text_linebreaks:"Keep linebreaks", | ||||
| word_title:"Use CTRL+V on your keyboard to paste the text into the window." | ||||
| }); | ||||
| @@ -0,0 +1,34 @@ | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#paste.paste_text_desc}</title> | ||||
| 	<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/pastetext.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body onresize="resizeInputs();" style="display:none; overflow:hidden;"> | ||||
| <form name="source" onsubmit="saveContent();return false;" action="#"> | ||||
| 	<div style="float: left" class="title">{#paste.paste_text_desc}</div> | ||||
|  | ||||
| 	<div style="float: right"> | ||||
| 		<input type="checkbox" name="linebreaks" id="linebreaks" class="wordWrapCode" checked="checked" /><label for="linebreaks">{#paste_dlg.text_linebreaks}</label> | ||||
| 	</div> | ||||
|  | ||||
| 	<br style="clear: both" /> | ||||
|  | ||||
| 	<div>{#paste_dlg.text_title}</div> | ||||
|  | ||||
| 	<textarea name="htmlSource" id="htmlSource" rows="15" cols="100" style="width: 100%; height: 100%; font-family: 'Courier New',Courier,mono; font-size: 12px;" dir="ltr" wrap="soft" class="mceFocus"></textarea> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" name="insert" value="{#insert}" id="insert" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right"> | ||||
| 			<input type="button" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" id="cancel" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body>  | ||||
| </html> | ||||
| @@ -0,0 +1,29 @@ | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> | ||||
| 	<title>{#paste.paste_word_desc}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/pasteword.js"></script> | ||||
| 	<link href="css/pasteword.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body onresize="resizeInputs();" style="display:none; overflow:hidden;"> | ||||
| 	<form name="source" onsubmit="saveContent();" action="#"> | ||||
| 		<div class="title">{#paste.paste_word_desc}</div> | ||||
|  | ||||
| 		<div>{#paste_dlg.word_title}</div> | ||||
|  | ||||
| 		<div id="iframecontainer"></div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="button" id="insert" name="insert" value="{#insert}" onclick="saveContent();" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.Preview',{init:function(ed,url){var t=this;t.editor=ed;ed.addCommand('mcePreview',t._preview,t);ed.addButton('preview',{title:'preview.preview_desc',cmd:'mcePreview'});},getInfo:function(){return{longname:'Preview',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/preview',version:tinymce.majorVersion+"."+tinymce.minorVersion};},_preview:function(){var ed=this.editor,win,html,c,pos,pos2,css,i,page=ed.getParam("plugin_preview_pageurl",null),w=ed.getParam("plugin_preview_width","550"),h=ed.getParam("plugin_preview_height","600");if(page){ed.windowManager.open({file:ed.getParam("plugin_preview_pageurl",null),width:w,height:h},{resizable:"yes",scrollbars:"yes",inline:1});}else{win=window.open("","mcePreview","menubar=no,toolbar=no,scrollbars=yes,resizable=yes,left=20,top=20,width="+w+",height="+h);html="";c=ed.getContent();pos=c.indexOf('<body');css=ed.getParam("content_css",'').split(',');tinymce.map(css,function(u){return ed.documentBaseURI.toAbsolute(u);});if(pos!=-1){pos=c.indexOf('>',pos);pos2=c.lastIndexOf('</body>');c=c.substring(pos+1,pos2);}html+=ed.getParam('doctype');html+='<html xmlns="http://www.w3.org/1999/xhtml">';html+='<head>';html+='<title>'+ed.getLang('preview.preview_desc')+'</title>';html+='<base href="'+ed.documentBaseURI.getURI()+'" />';html+='<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />';for(i=0;i<css.length;i++)html+='<link href="'+css[i]+'" rel="stylesheet" type="text/css" />';html+='</head>';html+='<body dir="'+ed.getParam("directionality")+'" onload="window.opener.tinymce.EditorManager.get(\''+ed.id+'\').plugins[\'preview\']._onLoad(window,document);">';html+=c;html+='</body>';html+='</html>';win.document.write(html);win.document.close();}},_onLoad:function(w,d){var t=this,nl,i,el=[],sv,ne;t._doc=d;w.writeFlash=t._writeFlash;w.writeShockWave=t._writeShockWave;w.writeQuickTime=t._writeQuickTime;w.writeRealMedia=t._writeRealMedia;w.writeWindowsMedia=t._writeWindowsMedia;w.writeEmbed=t._writeEmbed;nl=d.getElementsByTagName("script");for(i=0;i<nl.length;i++){sv=tinymce.isIE?nl[i].innerHTML:nl[i].firstChild.nodeValue;if(new RegExp('write(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)\\(.*','g').test(sv))el[el.length]=nl[i];}for(i=0;i<el.length;i++){ne=d.createElement("div");ne.innerHTML=d._embeds[i];el[i].parentNode.insertBefore(ne.firstChild,el[i]);}},_writeFlash:function(p){p.src=this.editor.documentBaseURI.toAbsolute(p.src);TinyMCE_PreviewPlugin._writeEmbed('D27CDB6E-AE6D-11cf-96B8-444553540000','http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0','application/x-shockwave-flash',p);},_writeShockWave:function(p){this.editor.documentBaseURI.toAbsolute(p.src);TinyMCE_PreviewPlugin._writeEmbed('166B1BCA-3F9C-11CF-8075-444553540000','http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0','application/x-director',p);},_writeQuickTime:function(p){this.editor.documentBaseURI.toAbsolute(p.src);TinyMCE_PreviewPlugin._writeEmbed('02BF25D5-8C17-4B23-BC80-D3488ABDDC6B','http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0','video/quicktime',p);},_writeRealMedia:function(p){this.editor.documentBaseURI.toAbsolute(p.src);TinyMCE_PreviewPlugin._writeEmbed('CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA','http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0','audio/x-pn-realaudio-plugin',p);},_writeWindowsMedia:function(p){this.editor.documentBaseURI.toAbsolute(p.src);p.url=p.src;TinyMCE_PreviewPlugin._writeEmbed('6BF52A52-394A-11D3-B153-00C04F79FAA6','http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701','application/x-mplayer2',p);},_writeEmbed:function(cls,cb,mt,p){var h='',n,d=t._doc,ne,c;h+='<object classid="clsid:'+cls+'" codebase="'+cb+'"';h+=typeof(p.id)!="undefined"?'id="'+p.id+'"':'';h+=typeof(p.name)!="undefined"?'name="'+p.name+'"':'';h+=typeof(p.width)!="undefined"?'width="'+p.width+'"':'';h+=typeof(p.height)!="undefined"?'height="'+p.height+'"':'';h+=typeof(p.align)!="undefined"?'align="'+p.align+'"':'';h+='>';for(n in p)h+='<param name="'+n+'" value="'+p[n]+'">';h+='<embed type="'+mt+'"';for(n in p)h+=n+'="'+p[n]+'" ';h+='></embed></object>';d._embeds[d._embeds.length]=h;}});tinymce.PluginManager.add('preview',tinymce.plugins.Preview);})(); | ||||
| @@ -0,0 +1,187 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:28 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.Preview', { | ||||
| 		init : function(ed, url) { | ||||
| 			var t = this; | ||||
|  | ||||
| 			t.editor = ed; | ||||
|  | ||||
| 			ed.addCommand('mcePreview', t._preview, t); | ||||
| 			ed.addButton('preview', {title : 'preview.preview_desc', cmd : 'mcePreview'}); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Preview', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/preview', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		// Private methods | ||||
|  | ||||
| 		_preview : function() { | ||||
| 			var ed = this.editor, win, html, c, pos, pos2, css, i, page = ed.getParam("plugin_preview_pageurl", null), w = ed.getParam("plugin_preview_width", "550"), h = ed.getParam("plugin_preview_height", "600"); | ||||
|  | ||||
| 			// Use a custom preview page | ||||
| 			if (page) { | ||||
| 				ed.windowManager.open({ | ||||
| 					file : ed.getParam("plugin_preview_pageurl", null), | ||||
| 					width : w, | ||||
| 					height : h | ||||
| 				}, { | ||||
| 					resizable : "yes", | ||||
| 					scrollbars : "yes", | ||||
| 					inline : 1 | ||||
| 				}); | ||||
| 			} else { | ||||
| 				win = window.open("", "mcePreview", "menubar=no,toolbar=no,scrollbars=yes,resizable=yes,left=20,top=20,width=" + w + ",height="  + h); | ||||
| 				html = ""; | ||||
| 				c = ed.getContent(); | ||||
| 				pos = c.indexOf('<body'); | ||||
| 				css = ed.getParam("content_css", '').split(','); | ||||
|  | ||||
| 				tinymce.map(css, function(u) { | ||||
| 					return ed.documentBaseURI.toAbsolute(u); | ||||
| 				}); | ||||
|  | ||||
| 				if (pos != -1) { | ||||
| 					pos = c.indexOf('>', pos); | ||||
| 					pos2 = c.lastIndexOf('</body>'); | ||||
| 					c = c.substring(pos + 1, pos2); | ||||
| 				} | ||||
|  | ||||
| 				html += ed.getParam('doctype'); | ||||
| 				html += '<html xmlns="http://www.w3.org/1999/xhtml">'; | ||||
| 				html += '<head>'; | ||||
| 				html += '<title>' + ed.getLang('preview.preview_desc') + '</title>'; | ||||
| 				html += '<base href="' + ed.documentBaseURI.getURI() + '" />'; | ||||
| 				html += '<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />'; | ||||
|  | ||||
| 				for (i=0; i<css.length; i++) | ||||
| 					html += '<link href="' + css[i] + '" rel="stylesheet" type="text/css" />'; | ||||
|  | ||||
| 				html += '</head>'; | ||||
| 				html += '<body dir="' + ed.getParam("directionality") + '" onload="window.opener.tinymce.EditorManager.get(\'' + ed.id + '\').plugins[\'preview\']._onLoad(window,document);">'; | ||||
| 				html += c; | ||||
| 				html += '</body>'; | ||||
| 				html += '</html>'; | ||||
|  | ||||
| 				win.document.write(html); | ||||
| 				win.document.close(); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_onLoad : function(w, d) { | ||||
| 			var t = this, nl, i, el = [], sv, ne; | ||||
|  | ||||
| 			t._doc = d; | ||||
| 			w.writeFlash = t._writeFlash; | ||||
| 			w.writeShockWave = t._writeShockWave; | ||||
| 			w.writeQuickTime = t._writeQuickTime; | ||||
| 			w.writeRealMedia = t._writeRealMedia; | ||||
| 			w.writeWindowsMedia = t._writeWindowsMedia; | ||||
| 			w.writeEmbed = t._writeEmbed; | ||||
|  | ||||
| 			nl = d.getElementsByTagName("script"); | ||||
| 			for (i=0; i<nl.length; i++) { | ||||
| 				sv = tinymce.isIE ? nl[i].innerHTML : nl[i].firstChild.nodeValue; | ||||
|  | ||||
| 				if (new RegExp('write(Flash|ShockWave|WindowsMedia|QuickTime|RealMedia)\\(.*', 'g').test(sv)) | ||||
| 					el[el.length] = nl[i]; | ||||
| 			} | ||||
|  | ||||
| 			for (i=0; i<el.length; i++) { | ||||
| 				ne = d.createElement("div"); | ||||
| 				ne.innerHTML = d._embeds[i]; | ||||
| 				el[i].parentNode.insertBefore(ne.firstChild, el[i]); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_writeFlash : function(p) { | ||||
| 			p.src = this.editor.documentBaseURI.toAbsolute(p.src); | ||||
| 			TinyMCE_PreviewPlugin._writeEmbed( | ||||
| 				'D27CDB6E-AE6D-11cf-96B8-444553540000', | ||||
| 				'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0', | ||||
| 				'application/x-shockwave-flash', | ||||
| 				p | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		_writeShockWave : function(p) { | ||||
| 			this.editor.documentBaseURI.toAbsolute(p.src); | ||||
| 			TinyMCE_PreviewPlugin._writeEmbed( | ||||
| 				'166B1BCA-3F9C-11CF-8075-444553540000', | ||||
| 				'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0', | ||||
| 				'application/x-director', | ||||
| 				p | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		_writeQuickTime : function(p) { | ||||
| 			this.editor.documentBaseURI.toAbsolute(p.src); | ||||
| 			TinyMCE_PreviewPlugin._writeEmbed( | ||||
| 				'02BF25D5-8C17-4B23-BC80-D3488ABDDC6B', | ||||
| 				'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0', | ||||
| 				'video/quicktime', | ||||
| 				p | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		_writeRealMedia : function(p) { | ||||
| 			this.editor.documentBaseURI.toAbsolute(p.src); | ||||
| 			TinyMCE_PreviewPlugin._writeEmbed( | ||||
| 				'CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA', | ||||
| 				'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0', | ||||
| 				'audio/x-pn-realaudio-plugin', | ||||
| 				p | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		_writeWindowsMedia : function(p) { | ||||
| 			this.editor.documentBaseURI.toAbsolute(p.src); | ||||
| 			p.url = p.src; | ||||
| 			TinyMCE_PreviewPlugin._writeEmbed( | ||||
| 				'6BF52A52-394A-11D3-B153-00C04F79FAA6', | ||||
| 				'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701', | ||||
| 				'application/x-mplayer2', | ||||
| 				p | ||||
| 			); | ||||
| 		}, | ||||
|  | ||||
| 		_writeEmbed : function(cls, cb, mt, p) { | ||||
| 			var h = '', n, d = t._doc, ne, c; | ||||
|  | ||||
| 			h += '<object classid="clsid:' + cls + '" codebase="' + cb + '"'; | ||||
| 			h += typeof(p.id) != "undefined" ? 'id="' + p.id + '"' : ''; | ||||
| 			h += typeof(p.name) != "undefined" ? 'name="' + p.name + '"' : ''; | ||||
| 			h += typeof(p.width) != "undefined" ? 'width="' + p.width + '"' : ''; | ||||
| 			h += typeof(p.height) != "undefined" ? 'height="' + p.height + '"' : ''; | ||||
| 			h += typeof(p.align) != "undefined" ? 'align="' + p.align + '"' : ''; | ||||
| 			h += '>'; | ||||
|  | ||||
| 			for (n in p) | ||||
| 				h += '<param name="' + n + '" value="' + p[n] + '">'; | ||||
|  | ||||
| 			h += '<embed type="' + mt + '"'; | ||||
|  | ||||
| 			for (n in p) | ||||
| 				h += n + '="' + p[n] + '" '; | ||||
|  | ||||
| 			h += '></embed></object>'; | ||||
|  | ||||
| 			d._embeds[d._embeds.length] = h; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('preview', tinymce.plugins.Preview); | ||||
| })(); | ||||
| @@ -0,0 +1,73 @@ | ||||
| /** | ||||
|  * This script contains embed functions for common plugins. This scripts are complety free to use for any purpose. | ||||
|  */ | ||||
|  | ||||
| function writeFlash(p) { | ||||
| 	writeEmbed( | ||||
| 		'D27CDB6E-AE6D-11cf-96B8-444553540000', | ||||
| 		'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0', | ||||
| 		'application/x-shockwave-flash', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeShockWave(p) { | ||||
| 	writeEmbed( | ||||
| 	'166B1BCA-3F9C-11CF-8075-444553540000', | ||||
| 	'http://download.macromedia.com/pub/shockwave/cabs/director/sw.cab#version=8,5,1,0', | ||||
| 	'application/x-director', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeQuickTime(p) { | ||||
| 	writeEmbed( | ||||
| 		'02BF25D5-8C17-4B23-BC80-D3488ABDDC6B', | ||||
| 		'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0', | ||||
| 		'video/quicktime', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeRealMedia(p) { | ||||
| 	writeEmbed( | ||||
| 		'CFCDAA03-8BE4-11cf-B84B-0020AFBBCCFA', | ||||
| 		'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0', | ||||
| 		'audio/x-pn-realaudio-plugin', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeWindowsMedia(p) { | ||||
| 	p.url = p.src; | ||||
| 	writeEmbed( | ||||
| 		'6BF52A52-394A-11D3-B153-00C04F79FAA6', | ||||
| 		'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701', | ||||
| 		'application/x-mplayer2', | ||||
| 		p | ||||
| 	); | ||||
| } | ||||
|  | ||||
| function writeEmbed(cls, cb, mt, p) { | ||||
| 	var h = '', n; | ||||
|  | ||||
| 	h += '<object classid="clsid:' + cls + '" codebase="' + cb + '"'; | ||||
| 	h += typeof(p.id) != "undefined" ? 'id="' + p.id + '"' : ''; | ||||
| 	h += typeof(p.name) != "undefined" ? 'name="' + p.name + '"' : ''; | ||||
| 	h += typeof(p.width) != "undefined" ? 'width="' + p.width + '"' : ''; | ||||
| 	h += typeof(p.height) != "undefined" ? 'height="' + p.height + '"' : ''; | ||||
| 	h += typeof(p.align) != "undefined" ? 'align="' + p.align + '"' : ''; | ||||
| 	h += '>'; | ||||
|  | ||||
| 	for (n in p) | ||||
| 		h += '<param name="' + n + '" value="' + p[n] + '">'; | ||||
|  | ||||
| 	h += '<embed type="' + mt + '"'; | ||||
|  | ||||
| 	for (n in p) | ||||
| 		h += n + '="' + p[n] + '" '; | ||||
|  | ||||
| 	h += '></embed></object>'; | ||||
|  | ||||
| 	document.write(h); | ||||
| } | ||||
| @@ -0,0 +1 @@ | ||||
| <!-- WebKit --> | ||||
| @@ -0,0 +1,460 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:28 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	var Event = tinymce.dom.Event, grep = tinymce.grep, each = tinymce.each, inArray = tinymce.inArray, isOldWebKit = tinymce.isOldWebKit; | ||||
|  | ||||
| 	tinymce.create('tinymce.plugins.Safari', { | ||||
| 		init : function(ed) { | ||||
| 			var t = this, dom; | ||||
|  | ||||
| 			// Ignore on non webkit | ||||
| 			if (!tinymce.isWebKit) | ||||
| 				return; | ||||
|  | ||||
| 			t.editor = ed; | ||||
| 			t.webKitFontSizes = ['x-small', 'small', 'medium', 'large', 'x-large', 'xx-large', '-webkit-xxx-large']; | ||||
| 			t.namedFontSizes = ['xx-small', 'x-small','small','medium','large','x-large', 'xx-large']; | ||||
|  | ||||
| 			// Safari will crash if the build in createlink command is used | ||||
| /*			ed.addCommand('CreateLink', function(u, v) { | ||||
| 				ed.execCommand("mceInsertContent", false, '<a href="' + dom.encode(v) + '">' + ed.selection.getContent() + '</a>'); | ||||
| 			});*/ | ||||
|  | ||||
| 			ed.onPaste.add(function(ed, e) { | ||||
| 				function removeStyles(e) { | ||||
| 					e = e.target; | ||||
|  | ||||
| 					if (e.nodeType == 1) { | ||||
| 						e.style.cssText = ''; | ||||
|  | ||||
| 						each(ed.dom.select('*', e), function(e) { | ||||
| 							e.style.cssText = ''; | ||||
| 						}); | ||||
| 					} | ||||
| 				}; | ||||
|  | ||||
| 				Event.add(ed.getDoc(), 'DOMNodeInserted', removeStyles); | ||||
|  | ||||
| 				window.setTimeout(function() { | ||||
| 					Event.remove(ed.getDoc(), 'DOMNodeInserted', removeStyles); | ||||
| 				}, 0); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onKeyUp.add(function(ed, e) { | ||||
| 				var h, b; | ||||
|  | ||||
| 				// If backspace or delete key | ||||
| 				if (e.keyCode == 46 || e.keyCode == 8) { | ||||
| 					b = ed.getBody(); | ||||
| 					h = b.innerHTML; | ||||
|  | ||||
| 					// If there is no text content or images or hr elements then remove everything | ||||
| 					if (b.childNodes.length == 1 && !/<(img|hr)/.test(h) && tinymce.trim(h.replace(/<[^>]+>/g, '')).length == 0) | ||||
| 						ed.setContent('', {format : 'raw'}); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			// Workaround for FormatBlock bug, http://bugs.webkit.org/show_bug.cgi?id=16004 | ||||
| 			ed.addCommand('FormatBlock', function(u, v) { | ||||
| 				var dom = ed.dom, e = dom.getParent(ed.selection.getNode(), dom.isBlock); | ||||
|  | ||||
| 				if (e) | ||||
| 					dom.replace(dom.create(v), e, 1); | ||||
| 				else | ||||
| 					ed.getDoc().execCommand("FormatBlock", false, v); | ||||
| 			}); | ||||
|  | ||||
| 			// Workaround for InsertHTML bug, http://bugs.webkit.org/show_bug.cgi?id=16382 | ||||
| 			ed.addCommand('mceInsertContent', function(u, v) { | ||||
| 				ed.getDoc().execCommand("InsertText", false, 'mce_marker'); | ||||
| 				ed.getBody().innerHTML = ed.getBody().innerHTML.replace(/mce_marker/g, v + '<span id="_mce_tmp">XX</span>'); | ||||
| 				ed.selection.select(ed.dom.get('_mce_tmp')); | ||||
| 				ed.getDoc().execCommand("Delete", false, ' '); | ||||
| 			}); | ||||
|  | ||||
| 			// Workaround for missing shift+enter support, http://bugs.webkit.org/show_bug.cgi?id=16973 | ||||
| 			ed.onKeyPress.add(function(ed, e) { | ||||
| 				if (e.keyCode == 13 && (e.shiftKey || ed.settings.force_br_newlines && ed.selection.getNode().nodeName != 'LI')) { | ||||
| 					t._insertBR(ed); | ||||
| 					Event.cancel(e); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			// Safari returns incorrect values | ||||
| 			ed.addQueryValueHandler('FontSize', function(u, v) { | ||||
| 				var e, v; | ||||
|  | ||||
| 				// Check for the real font size at the start of selection | ||||
| 				if ((e = ed.dom.getParent(ed.selection.getStart(), 'span')) && (v = e.style.fontSize)) | ||||
| 					return tinymce.inArray(t.namedFontSizes, v) + 1; | ||||
|  | ||||
| 				// Check for the real font size at the end of selection | ||||
| 				if ((e = ed.dom.getParent(ed.selection.getEnd(), 'span')) && (v = e.style.fontSize)) | ||||
| 					return tinymce.inArray(t.namedFontSizes, v) + 1; | ||||
|  | ||||
| 				// Return default value it's better than nothing right! | ||||
| 				return ed.getDoc().queryCommandValue('FontSize'); | ||||
| 			}); | ||||
|  | ||||
| 			// Safari returns incorrect values | ||||
| 			ed.addQueryValueHandler('FontName', function(u, v) { | ||||
| 				var e, v; | ||||
|  | ||||
| 				// Check for the real font name at the start of selection | ||||
| 				if ((e = ed.dom.getParent(ed.selection.getStart(), 'span')) && (v = e.style.fontFamily)) | ||||
| 					return v.replace(/, /g, ','); | ||||
|  | ||||
| 				// Check for the real font name at the end of selection | ||||
| 				if ((e = ed.dom.getParent(ed.selection.getEnd(), 'span')) && (v = e.style.fontFamily)) | ||||
| 					return v.replace(/, /g, ','); | ||||
|  | ||||
| 				// Return default value it's better than nothing right! | ||||
| 				return ed.getDoc().queryCommandValue('FontName'); | ||||
| 			}); | ||||
|  | ||||
| 			// Workaround for bug, http://bugs.webkit.org/show_bug.cgi?id=12250 | ||||
| 			ed.onClick.add(function(ed, e) { | ||||
| 				e = e.target; | ||||
|  | ||||
| 				if (e.nodeName == 'IMG') { | ||||
| 					t.selElm = e; | ||||
| 					ed.selection.select(e); | ||||
| 				} else | ||||
| 					t.selElm = null; | ||||
| 			}); | ||||
|  | ||||
| /*			ed.onBeforeExecCommand.add(function(ed, c, b) { | ||||
| 				var r = t.bookmarkRng; | ||||
|  | ||||
| 				// Restore selection | ||||
| 				if (r) { | ||||
| 					ed.selection.setRng(r); | ||||
| 					t.bookmarkRng = null; | ||||
| 					//console.debug('restore', r.startContainer, r.startOffset, r.endContainer, r.endOffset); | ||||
| 				} | ||||
| 			});*/ | ||||
|  | ||||
| 			ed.onInit.add(function() { | ||||
| 				t._fixWebKitSpans(); | ||||
|  | ||||
| /*				ed.windowManager.onOpen.add(function() { | ||||
| 					var r = ed.selection.getRng(); | ||||
|  | ||||
| 					// Store selection if valid | ||||
| 					if (r.startContainer != ed.getDoc()) { | ||||
| 						t.bookmarkRng = r.cloneRange(); | ||||
| 						//console.debug('store', r.startContainer, r.startOffset, r.endContainer, r.endOffset); | ||||
| 					} | ||||
| 				}); | ||||
|  | ||||
| 				ed.windowManager.onClose.add(function() { | ||||
| 					t.bookmarkRng = null; | ||||
| 				});*/ | ||||
|  | ||||
| 				if (isOldWebKit) | ||||
| 					t._patchSafari2x(ed); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onSetContent.add(function() { | ||||
| 				dom = ed.dom; | ||||
|  | ||||
| 				// Convert strong,b,em,u,strike to spans | ||||
| 				each(['strong','b','em','u','strike','sub','sup','a'], function(v) { | ||||
| 					each(grep(dom.select(v)).reverse(), function(n) { | ||||
| 						var nn = n.nodeName.toLowerCase(), st; | ||||
|  | ||||
| 						// Convert anchors into images | ||||
| 						if (nn == 'a') { | ||||
| 							if (n.name) | ||||
| 								dom.replace(dom.create('img', {mce_name : 'a', name : n.name, 'class' : 'mceItemAnchor'}), n); | ||||
|  | ||||
| 							return; | ||||
| 						} | ||||
|  | ||||
| 						switch (nn) { | ||||
| 							case 'b': | ||||
| 							case 'strong': | ||||
| 								if (nn == 'b') | ||||
| 									nn = 'strong'; | ||||
|  | ||||
| 								st = 'font-weight: bold;'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'em': | ||||
| 								st = 'font-style: italic;'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'u': | ||||
| 								st = 'text-decoration: underline;'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'sub': | ||||
| 								st = 'vertical-align: sub;'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'sup': | ||||
| 								st = 'vertical-align: super;'; | ||||
| 								break; | ||||
|  | ||||
| 							case 'strike': | ||||
| 								st = 'text-decoration: line-through;'; | ||||
| 								break; | ||||
| 						} | ||||
|  | ||||
| 						dom.replace(dom.create('span', {mce_name : nn, style : st, 'class' : 'Apple-style-span'}), n, 1); | ||||
| 					}); | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onPreProcess.add(function(ed, o) { | ||||
| 				dom = ed.dom; | ||||
|  | ||||
| 				each(grep(o.node.getElementsByTagName('span')).reverse(), function(n) { | ||||
| 					var v, bg; | ||||
|  | ||||
| 					if (o.get) { | ||||
| 						if (dom.hasClass(n, 'Apple-style-span')) { | ||||
| 							bg = n.style.backgroundColor; | ||||
|  | ||||
| 							switch (dom.getAttrib(n, 'mce_name')) { | ||||
| 								case 'font': | ||||
| 									if (!ed.settings.convert_fonts_to_spans) | ||||
| 										dom.setAttrib(n, 'style', ''); | ||||
| 									break; | ||||
|  | ||||
| 								case 'strong': | ||||
| 								case 'em': | ||||
| 								case 'sub': | ||||
| 								case 'sup': | ||||
| 									dom.setAttrib(n, 'style', ''); | ||||
| 									break; | ||||
|  | ||||
| 								case 'strike': | ||||
| 								case 'u': | ||||
| 									if (!ed.settings.inline_styles) | ||||
| 										dom.setAttrib(n, 'style', ''); | ||||
| 									else | ||||
| 										dom.setAttrib(n, 'mce_name', ''); | ||||
|  | ||||
| 									break; | ||||
|  | ||||
| 								default: | ||||
| 									if (!ed.settings.inline_styles) | ||||
| 										dom.setAttrib(n, 'style', ''); | ||||
| 							} | ||||
|  | ||||
|  | ||||
| 							if (bg) | ||||
| 								n.style.backgroundColor = bg; | ||||
| 						} | ||||
| 					} | ||||
|  | ||||
| 					if (dom.hasClass(n, 'mceItemRemoved')) | ||||
| 						dom.remove(n, 1); | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			ed.onPostProcess.add(function(ed, o) { | ||||
| 				// Safari adds BR at end of all block elements | ||||
| 				o.content = o.content.replace(/<br \/><\/(h[1-6]|div|p|address|pre)>/g, '</$1>'); | ||||
|  | ||||
| 				// Safari adds id="undefined" to HR elements | ||||
| 				o.content = o.content.replace(/ id=\"undefined\"/g, ''); | ||||
| 			}); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Safari compatibility', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/safari', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		// Internal methods | ||||
|  | ||||
| 		_fixWebKitSpans : function() { | ||||
| 			var t = this, ed = t.editor; | ||||
|  | ||||
| 			if (!isOldWebKit) { | ||||
| 				// Use mutator events on new WebKit | ||||
| 				Event.add(ed.getDoc(), 'DOMNodeInserted', function(e) { | ||||
| 					e = e.target; | ||||
|  | ||||
| 					if (e && e.nodeType == 1) | ||||
| 						t._fixAppleSpan(e); | ||||
| 				}); | ||||
| 			} else { | ||||
| 				// Do post command processing in old WebKit since the browser crashes on Mutator events :( | ||||
| 				ed.onExecCommand.add(function() { | ||||
| 					each(ed.dom.select('span'), function(n) { | ||||
| 						t._fixAppleSpan(n); | ||||
| 					}); | ||||
|  | ||||
| 					ed.nodeChanged(); | ||||
| 				}); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_fixAppleSpan : function(e) { | ||||
| 			var ed = this.editor, dom = ed.dom, fz = this.webKitFontSizes, fzn = this.namedFontSizes, s = ed.settings, st, p; | ||||
|  | ||||
| 			if (dom.getAttrib(e, 'mce_fixed')) | ||||
| 				return; | ||||
|  | ||||
| 			// Handle Apple style spans | ||||
| 			if (e.nodeName == 'SPAN' && e.className == 'Apple-style-span') { | ||||
| 				st = e.style; | ||||
|  | ||||
| 				if (!s.convert_fonts_to_spans) { | ||||
| 					if (st.fontSize) { | ||||
| 						dom.setAttrib(e, 'mce_name', 'font'); | ||||
| 						dom.setAttrib(e, 'size', inArray(fz, st.fontSize) + 1); | ||||
| 					} | ||||
|  | ||||
| 					if (st.fontFamily) { | ||||
| 						dom.setAttrib(e, 'mce_name', 'font'); | ||||
| 						dom.setAttrib(e, 'face', st.fontFamily); | ||||
| 					} | ||||
|  | ||||
| 					if (st.color) { | ||||
| 						dom.setAttrib(e, 'mce_name', 'font'); | ||||
| 						dom.setAttrib(e, 'color', dom.toHex(st.color)); | ||||
| 					} | ||||
|  | ||||
| 					if (st.backgroundColor) { | ||||
| 						dom.setAttrib(e, 'mce_name', 'font'); | ||||
| 						dom.setStyle(e, 'background-color', st.backgroundColor); | ||||
| 					} | ||||
| 				} else { | ||||
| 					if (st.fontSize) | ||||
| 						dom.setStyle(e, 'fontSize', fzn[inArray(fz, st.fontSize)]); | ||||
| 				} | ||||
|  | ||||
| 				if (st.fontWeight == 'bold') | ||||
| 					dom.setAttrib(e, 'mce_name', 'strong'); | ||||
|  | ||||
| 				if (st.fontStyle == 'italic') | ||||
| 					dom.setAttrib(e, 'mce_name', 'em'); | ||||
|  | ||||
| 				if (st.textDecoration == 'underline') | ||||
| 					dom.setAttrib(e, 'mce_name', 'u'); | ||||
|  | ||||
| 				if (st.textDecoration == 'line-through') | ||||
| 					dom.setAttrib(e, 'mce_name', 'strike'); | ||||
|  | ||||
| 				if (st.verticalAlign == 'super') | ||||
| 					dom.setAttrib(e, 'mce_name', 'sup'); | ||||
|  | ||||
| 				if (st.verticalAlign == 'sub') | ||||
| 					dom.setAttrib(e, 'mce_name', 'sub'); | ||||
|  | ||||
| 				dom.setAttrib(e, 'mce_fixed', '1'); | ||||
| 			} | ||||
| 		}, | ||||
|  | ||||
| 		_patchSafari2x : function(ed) { | ||||
| 			var t = this, setContent, getNode, dom = ed.dom, lr; | ||||
|  | ||||
| 			// Inline dialogs | ||||
| 			if (ed.windowManager.onBeforeOpen) { | ||||
| 				ed.windowManager.onBeforeOpen.add(function() { | ||||
| 					r = ed.selection.getRng(); | ||||
| 				}); | ||||
| 			} | ||||
|  | ||||
| 			// Fake select on 2.x | ||||
| 			ed.selection.select = function(n) { | ||||
| 				this.getSel().setBaseAndExtent(n, 0, n, 1); | ||||
| 			}; | ||||
|  | ||||
| 			getNode = ed.selection.getNode; | ||||
| 			ed.selection.getNode = function() { | ||||
| 				return t.selElm || getNode.call(this); | ||||
| 			}; | ||||
|  | ||||
| 			// Fake range on Safari 2.x | ||||
| 			ed.selection.getRng = function() { | ||||
| 				var t = this, s = t.getSel(), d = ed.getDoc(), r, rb, ra, di; | ||||
|  | ||||
| 				// Fake range on Safari 2.x | ||||
| 				if (s.anchorNode) { | ||||
| 					r = d.createRange(); | ||||
|  | ||||
| 					try { | ||||
| 						// Setup before range | ||||
| 						rb = d.createRange(); | ||||
| 						rb.setStart(s.anchorNode, s.anchorOffset); | ||||
| 						rb.collapse(1); | ||||
|  | ||||
| 						// Setup after range | ||||
| 						ra = d.createRange(); | ||||
| 						ra.setStart(s.focusNode, s.focusOffset); | ||||
| 						ra.collapse(1); | ||||
|  | ||||
| 						// Setup start/end points by comparing locations | ||||
| 						di = rb.compareBoundaryPoints(rb.START_TO_END, ra) < 0; | ||||
| 						r.setStart(di ? s.anchorNode : s.focusNode, di ? s.anchorOffset : s.focusOffset); | ||||
| 						r.setEnd(di ? s.focusNode : s.anchorNode, di ? s.focusOffset : s.anchorOffset); | ||||
|  | ||||
| 						lr = r; | ||||
| 					} catch (ex) { | ||||
| 						// Sometimes fails, at least we tried to do it by the book. I hope Safari 2.x will go disappear soooon!!! | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				return r || lr; | ||||
| 			}; | ||||
|  | ||||
| 			// Fix setContent so it works | ||||
| 			setContent = ed.selection.setContent; | ||||
| 			ed.selection.setContent = function(h, s) { | ||||
| 				var r = this.getRng(), b; | ||||
|  | ||||
| 				try { | ||||
| 					setContent.call(this, h, s); | ||||
| 				} catch (ex) { | ||||
| 					// Workaround for Safari 2.x | ||||
| 					b = dom.create('body'); | ||||
| 					b.innerHTML = h; | ||||
|  | ||||
| 					each(b.childNodes, function(n) { | ||||
| 						r.insertNode(n.cloneNode(true)); | ||||
| 					}); | ||||
| 				} | ||||
| 			}; | ||||
| 		}, | ||||
|  | ||||
| 		_insertBR : function(ed) { | ||||
| 			var dom = ed.dom, s = ed.selection, r = s.getRng(), br; | ||||
|  | ||||
| 			// Insert BR element | ||||
| 			r.insertNode(br = dom.create('br')); | ||||
|  | ||||
| 			// Place caret after BR | ||||
| 			r.setStartAfter(br); | ||||
| 			r.setEndAfter(br); | ||||
| 			s.setRng(r); | ||||
|  | ||||
| 			// Could not place caret after BR then insert an nbsp entity and move the caret | ||||
| 			if (s.getSel().focusNode == br.previousSibling) { | ||||
| 				s.select(dom.insertAfter(dom.doc.createTextNode('\u00a0'), br)); | ||||
| 				s.collapse(1); | ||||
| 			} | ||||
|  | ||||
| 			// Scroll to new position, scrollIntoView can't be used due to bug: http://bugs.webkit.org/show_bug.cgi?id=16117 | ||||
| 			ed.getWin().scrollTo(0, dom.getPos(s.getRng().startContainer).y); | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('safari', tinymce.plugins.Safari); | ||||
| })(); | ||||
|  | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.SearchReplacePlugin',{init:function(ed,url){function open(m){ed.windowManager.open({file:url+'/searchreplace.htm',width:420+parseInt(ed.getLang('searchreplace.delta_width',0)),height:160+parseInt(ed.getLang('searchreplace.delta_height',0)),inline:1,auto_focus:0},{mode:m,search_string:ed.selection.getContent({format:'text'}),plugin_url:url});};ed.addCommand('mceSearch',function(){open('search');});ed.addCommand('mceReplace',function(){open('replace');});ed.addButton('search',{title:'searchreplace.search_desc',cmd:'mceSearch'});ed.addButton('replace',{title:'searchreplace.replace_desc',cmd:'mceReplace'});ed.addShortcut('ctrl+f','searchreplace.search_desc','mceSearch');},getInfo:function(){return{longname:'Search/Replace',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/searchreplace',version:tinymce.majorVersion+"."+tinymce.minorVersion};}});tinymce.PluginManager.add('searchreplace',tinymce.plugins.SearchReplacePlugin);})(); | ||||
| @@ -0,0 +1,54 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:28 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.SearchReplacePlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			function open(m) { | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/searchreplace.htm', | ||||
| 					width : 420 + parseInt(ed.getLang('searchreplace.delta_width', 0)), | ||||
| 					height : 160 + parseInt(ed.getLang('searchreplace.delta_height', 0)), | ||||
| 					inline : 1, | ||||
| 					auto_focus : 0 | ||||
| 				}, { | ||||
| 					mode : m, | ||||
| 					search_string : ed.selection.getContent({format : 'text'}), | ||||
| 					plugin_url : url | ||||
| 				}); | ||||
| 			}; | ||||
|  | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceSearch', function() { | ||||
| 				open('search'); | ||||
| 			}); | ||||
|  | ||||
| 			ed.addCommand('mceReplace', function() { | ||||
| 				open('replace'); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('search', {title : 'searchreplace.search_desc', cmd : 'mceSearch'}); | ||||
| 			ed.addButton('replace', {title : 'searchreplace.replace_desc', cmd : 'mceReplace'}); | ||||
|  | ||||
| 			ed.addShortcut('ctrl+f', 'searchreplace.search_desc', 'mceSearch'); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Search/Replace', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/searchreplace', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('searchreplace', tinymce.plugins.SearchReplacePlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,117 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var SearchReplaceDialog = { | ||||
| 	init : function(ed) { | ||||
| 		var f = document.forms[0], m = tinyMCEPopup.getWindowArg("mode"); | ||||
|  | ||||
| 		this.switchMode(m); | ||||
|  | ||||
| 		f[m + '_panel_searchstring'].value = tinyMCEPopup.getWindowArg("search_string"); | ||||
|  | ||||
| 		// Focus input field | ||||
| 		f[m + '_panel_searchstring'].focus(); | ||||
| 	}, | ||||
|  | ||||
| 	switchMode : function(m) { | ||||
| 		var f, lm = this.lastMode; | ||||
|  | ||||
| 		if (lm != m) { | ||||
| 			f = document.forms[0]; | ||||
|  | ||||
| 			if (lm) { | ||||
| 				f[m + '_panel_searchstring'].value = f[lm + '_panel_searchstring'].value; | ||||
| 				f[m + '_panel_backwardsu'].checked = f[lm + '_panel_backwardsu'].checked; | ||||
| 				f[m + '_panel_backwardsd'].checked = f[lm + '_panel_backwardsd'].checked; | ||||
| 				f[m + '_panel_casesensitivebox'].checked = f[lm + '_panel_casesensitivebox'].checked; | ||||
| 			} | ||||
|  | ||||
| 			mcTabs.displayTab(m + '_tab',  m + '_panel'); | ||||
| 			document.getElementById("replaceBtn").style.display = (m == "replace") ? "inline" : "none"; | ||||
| 			document.getElementById("replaceAllBtn").style.display = (m == "replace") ? "inline" : "none"; | ||||
| 			this.lastMode = m; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	searchNext : function(a) { | ||||
| 		var ed = tinyMCEPopup.editor, se = ed.selection, r = se.getRng(), f, m = this.lastMode, s, b, fl = 0, w = ed.getWin(), wm = ed.windowManager, fo = 0; | ||||
|  | ||||
| 		// Get input | ||||
| 		f = document.forms[0]; | ||||
| 		s = f[m + '_panel_searchstring'].value; | ||||
| 		b = f[m + '_panel_backwardsu'].checked; | ||||
| 		ca = f[m + '_panel_casesensitivebox'].checked; | ||||
| 		rs = f['replace_panel_replacestring'].value; | ||||
|  | ||||
| 		function fix() { | ||||
| 			// Correct Firefox graphics glitches | ||||
| 			r = se.getRng().cloneRange(); | ||||
| 			ed.getDoc().execCommand('SelectAll', false, null); | ||||
| 			se.setRng(r); | ||||
| 		}; | ||||
|  | ||||
| 		function replace() { | ||||
| 			if (tinymce.isIE) | ||||
| 				ed.selection.getRng().duplicate().pasteHTML(rs); // Needs to be duplicated due to selection bug in IE | ||||
| 			else | ||||
| 				ed.getDoc().execCommand('InsertHTML', false, rs); | ||||
| 		}; | ||||
|  | ||||
| 		// IE flags | ||||
| 		if (ca) | ||||
| 			fl = fl | 4; | ||||
|  | ||||
| 		switch (a) { | ||||
| 			case 'all': | ||||
| 				if (tinymce.isIE) { | ||||
| 					while (r.findText(s, b ? -1 : 1, fl)) { | ||||
| 						r.scrollIntoView(); | ||||
| 						r.select(); | ||||
| 						replace(); | ||||
| 						fo = 1; | ||||
| 					} | ||||
|  | ||||
| 					tinyMCEPopup.storeSelection(); | ||||
| 				} else { | ||||
| 					while (w.find(s, ca, b, false, false, false, false)) { | ||||
| 						replace(); | ||||
| 						fo = 1; | ||||
| 					} | ||||
| 				} | ||||
|  | ||||
| 				if (fo) | ||||
| 					wm.alert(ed.getLang('searchreplace_dlg.allreplaced')); | ||||
| 				else | ||||
| 					wm.alert(ed.getLang('searchreplace_dlg.notfound')); | ||||
|  | ||||
| 				return; | ||||
|  | ||||
| 			case 'current': | ||||
| 				replace(); | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		se.collapse(b); | ||||
| 		r = se.getRng(); | ||||
|  | ||||
| 		// Whats the point | ||||
| 		if (!s) | ||||
| 			return; | ||||
|  | ||||
| 		if (tinymce.isIE) { | ||||
| 			if (r.findText(s, b ? -1 : 1, fl)) { | ||||
| 				r.scrollIntoView(); | ||||
| 				r.select(); | ||||
| 			} else | ||||
| 				wm.alert(ed.getLang('searchreplace_dlg.notfound')); | ||||
|  | ||||
| 			tinyMCEPopup.storeSelection(); | ||||
| 		} else { | ||||
| 			if (!w.find(s, ca, b, false, false, false, false)) | ||||
| 				wm.alert(ed.getLang('searchreplace_dlg.notfound')); | ||||
| 			else | ||||
| 				fix(); | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| tinyMCEPopup.onInit.add(SearchReplaceDialog.init, SearchReplaceDialog); | ||||
| @@ -0,0 +1,16 @@ | ||||
| tinyMCE.addI18n('en.searchreplace_dlg',{ | ||||
| searchnext_desc:"Find again", | ||||
| notfound:"The search has been completed. The search string could not be found.", | ||||
| search_title:"Find", | ||||
| replace_title:"Find/Replace", | ||||
| allreplaced:"All occurrences of the search string were replaced.", | ||||
| findwhat:"Find what", | ||||
| replacewith:"Replace with", | ||||
| direction:"Direction", | ||||
| up:"Up", | ||||
| down:"Down", | ||||
| mcase:"Match case", | ||||
| findnext:"Find next", | ||||
| replace:"Replace", | ||||
| replaceall:"Replace all" | ||||
| }); | ||||
| @@ -0,0 +1,105 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#searchreplace_dlg.replace_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="js/searchreplace.js"></script> | ||||
| 	<link rel="stylesheet" type="text/css" href="css/searchreplace.css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body style="display:none;"> | ||||
| <form onsubmit="SearchReplaceDialog.searchNext('none');return false;" action="#"> | ||||
| 	<div class="tabs"> | ||||
| 		<ul> | ||||
| 			<li id="search_tab"><span><a href="javascript:SearchReplaceDialog.switchMode('search');" onmousedown="return false;">{#searchreplace.search_desc}</a></span></li> | ||||
| 			<li id="replace_tab"><span><a href="javascript:SearchReplaceDialog.switchMode('replace');" onmousedown="return false;">{#searchreplace_dlg.replace}</a></span></li> | ||||
| 		</ul> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="panel_wrapper"> | ||||
| 		<div id="search_panel" class="panel"> | ||||
| 			<table border="0" cellspacing="0" cellpadding="2"> | ||||
| 				<tr> | ||||
| 					<td><label for="search_panel_searchstring">{#searchreplace_dlg.findwhat}</label></td> | ||||
| 					<td><input type="text" id="search_panel_searchstring" name="search_panel_searchstring" style="width: 200px" /></td> | ||||
| 				</tr> | ||||
| 				<tr> | ||||
| 					<td colspan="2"> | ||||
| 						<table border="0" cellspacing="0" cellpadding="0" class="direction"> | ||||
| 							<tr> | ||||
| 								<td><label>{#searchreplace_dlg.direction}</label></td> | ||||
| 								<td><input id="search_panel_backwardsu" name="search_panel_backwards" class="radio" type="radio" /></td> | ||||
| 								<td><label for="search_panel_backwardsu">{#searchreplace_dlg.up}</label></td> | ||||
| 								<td><input id="search_panel_backwardsd" name="search_panel_backwards" class="radio" type="radio" checked="checked" /></td> | ||||
| 								<td><label for="search_panel_backwardsd">{#searchreplace_dlg.down}</label></td> | ||||
| 							</tr> | ||||
| 						</table> | ||||
| 					</td> | ||||
| 				</tr> | ||||
| 				<tr> | ||||
| 					<td colspan="2"> | ||||
| 						<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 							<tr> | ||||
| 								<td><input id="search_panel_casesensitivebox" name="search_panel_casesensitivebox" class="checkbox" type="checkbox" /></td> | ||||
| 								<td><label for="search_panel_casesensitivebox">{#searchreplace_dlg.mcase}</label></td> | ||||
| 							</tr> | ||||
| 						</table> | ||||
| 					</td> | ||||
| 				</tr> | ||||
| 			</table> | ||||
| 		</div> | ||||
|  | ||||
| 		<div id="replace_panel" class="panel"> | ||||
| 			<table border="0" cellspacing="0" cellpadding="2"> | ||||
| 				<tr> | ||||
| 					<td><label for="replace_panel_searchstring">{#searchreplace_dlg.findwhat}</label></td> | ||||
| 					<td><input type="text" id="replace_panel_searchstring" name="replace_panel_searchstring" style="width: 200px" /></td> | ||||
| 				</tr> | ||||
| 				<tr> | ||||
| 					<td><label for="replace_panel_replacestring">{#searchreplace_dlg.replacewith}</label></td> | ||||
| 					<td><input type="text" id="replace_panel_replacestring" name="replace_panel_replacestring" style="width: 200px" /></td> | ||||
| 				</tr> | ||||
| 				<tr> | ||||
| 					<td colspan="2"> | ||||
| 						<table border="0" cellspacing="0" cellpadding="0" class="direction"> | ||||
| 							<tr> | ||||
| 								<td><label>{#searchreplace_dlg.direction}</label></td> | ||||
| 								<td><input id="replace_panel_backwardsu" name="replace_panel_backwards" class="radio" type="radio" /></td> | ||||
| 								<td><label for="replace_panel_backwardsu">{#searchreplace_dlg.up}</label></td> | ||||
| 								<td><input id="replace_panel_backwardsd" name="replace_panel_backwards" class="radio" type="radio" checked="checked" /></td> | ||||
| 								<td><label for="replace_panel_backwardsd">{#searchreplace_dlg.down}</label></td> | ||||
| 							</tr> | ||||
| 						</table> | ||||
| 					</td> | ||||
| 				</tr> | ||||
| 				<tr> | ||||
| 					<td colspan="2"> | ||||
| 						<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 							<tr> | ||||
| 								<td><input id="replace_panel_casesensitivebox" name="replace_panel_casesensitivebox" class="checkbox" type="checkbox" /></td> | ||||
| 								<td><label for="replace_panel_casesensitivebox">{#searchreplace_dlg.mcase}</label></td> | ||||
| 							</tr> | ||||
| 						</table> | ||||
| 					</td> | ||||
| 				</tr> | ||||
| 			</table> | ||||
| 		</div> | ||||
|  | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#searchreplace_dlg.findnext}" /> | ||||
| 			<input type="button" class="button" id="replaceBtn" name="replaceBtn" value="{#searchreplace_dlg.replace}" onclick="SearchReplaceDialog.searchNext('current');" /> | ||||
| 			<input type="button" class="button" id="replaceAllBtn" name="replaceAllBtn" value="{#searchreplace_dlg.replaceall}" onclick="SearchReplaceDialog.searchNext('all');" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right">	 | ||||
| 			<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1 @@ | ||||
| (function(){tinymce.create('tinymce.plugins.StylePlugin',{init:function(ed,url){ed.addCommand('mceStyleProps',function(){ed.windowManager.open({file:url+'/props.htm',width:480+parseInt(ed.getLang('style.delta_width',0)),height:320+parseInt(ed.getLang('style.delta_height',0)),inline:1},{plugin_url:url,style_text:ed.selection.getNode().style.cssText});});ed.addCommand('mceSetElementStyle',function(ui,v){if(e=ed.selection.getNode()){ed.dom.setAttrib(e,'style',v);ed.execCommand('mceRepaint');}});ed.onNodeChange.add(function(ed,cm,n){cm.setDisabled('styleprops',n.nodeName==='BODY');});ed.addButton('styleprops',{title:'style.desc',cmd:'mceStyleProps'});},getInfo:function(){return{longname:'Style',author:'Moxiecode Systems AB',authorurl:'http://tinymce.moxiecode.com',infourl:'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/style',version:tinymce.majorVersion+"."+tinymce.minorVersion};}});tinymce.PluginManager.add('style',tinymce.plugins.StylePlugin);})(); | ||||
| @@ -0,0 +1,52 @@ | ||||
| /** | ||||
|  * $Id: editor_plugin_src.js,v 1.1 2008/07/28 21:57:28 bao Exp $ | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| (function() { | ||||
| 	tinymce.create('tinymce.plugins.StylePlugin', { | ||||
| 		init : function(ed, url) { | ||||
| 			// Register commands | ||||
| 			ed.addCommand('mceStyleProps', function() { | ||||
| 				ed.windowManager.open({ | ||||
| 					file : url + '/props.htm', | ||||
| 					width : 480 + parseInt(ed.getLang('style.delta_width', 0)), | ||||
| 					height : 320 + parseInt(ed.getLang('style.delta_height', 0)), | ||||
| 					inline : 1 | ||||
| 				}, { | ||||
| 					plugin_url : url, | ||||
| 					style_text : ed.selection.getNode().style.cssText | ||||
| 				}); | ||||
| 			}); | ||||
|  | ||||
| 			ed.addCommand('mceSetElementStyle', function(ui, v) { | ||||
| 				if (e = ed.selection.getNode()) { | ||||
| 					ed.dom.setAttrib(e, 'style', v); | ||||
| 					ed.execCommand('mceRepaint'); | ||||
| 				} | ||||
| 			}); | ||||
|  | ||||
| 			ed.onNodeChange.add(function(ed, cm, n) { | ||||
| 				cm.setDisabled('styleprops', n.nodeName === 'BODY'); | ||||
| 			}); | ||||
|  | ||||
| 			// Register buttons | ||||
| 			ed.addButton('styleprops', {title : 'style.desc', cmd : 'mceStyleProps'}); | ||||
| 		}, | ||||
|  | ||||
| 		getInfo : function() { | ||||
| 			return { | ||||
| 				longname : 'Style', | ||||
| 				author : 'Moxiecode Systems AB', | ||||
| 				authorurl : 'http://tinymce.moxiecode.com', | ||||
| 				infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/style', | ||||
| 				version : tinymce.majorVersion + "." + tinymce.minorVersion | ||||
| 			}; | ||||
| 		} | ||||
| 	}); | ||||
|  | ||||
| 	// Register plugin | ||||
| 	tinymce.PluginManager.add('style', tinymce.plugins.StylePlugin); | ||||
| })(); | ||||
| @@ -0,0 +1,641 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var defaultFonts = "" +  | ||||
| 	"Arial, Helvetica, sans-serif=Arial, Helvetica, sans-serif;" +  | ||||
| 	"Times New Roman, Times, serif=Times New Roman, Times, serif;" +  | ||||
| 	"Courier New, Courier, mono=Courier New, Courier, mono;" +  | ||||
| 	"Times New Roman, Times, serif=Times New Roman, Times, serif;" +  | ||||
| 	"Georgia, Times New Roman, Times, serif=Georgia, Times New Roman, Times, serif;" +  | ||||
| 	"Verdana, Arial, Helvetica, sans-serif=Verdana, Arial, Helvetica, sans-serif;" +  | ||||
| 	"Geneva, Arial, Helvetica, sans-serif=Geneva, Arial, Helvetica, sans-serif"; | ||||
|  | ||||
| var defaultSizes = "9;10;12;14;16;18;24;xx-small;x-small;small;medium;large;x-large;xx-large;smaller;larger"; | ||||
| var defaultMeasurement = "+pixels=px;points=pt;em;in;cm;mm;picas;ems;exs;%"; | ||||
| var defaultSpacingMeasurement = "pixels=px;points=pt;in;cm;mm;picas;+ems;exs;%"; | ||||
| var defaultIndentMeasurement = "pixels=px;+points=pt;in;cm;mm;picas;ems;exs;%"; | ||||
| var defaultWeight = "normal;bold;bolder;lighter;100;200;300;400;500;600;700;800;900"; | ||||
| var defaultTextStyle = "normal;italic;oblique"; | ||||
| var defaultVariant = "normal;small-caps"; | ||||
| var defaultLineHeight = "normal"; | ||||
| var defaultAttachment = "fixed;scroll"; | ||||
| var defaultRepeat = "no-repeat;repeat;repeat-x;repeat-y"; | ||||
| var defaultPosH = "left;center;right"; | ||||
| var defaultPosV = "top;center;bottom"; | ||||
| var defaultVAlign = "baseline;sub;super;top;text-top;middle;bottom;text-bottom"; | ||||
| var defaultDisplay = "inline;block;list-item;run-in;compact;marker;table;inline-table;table-row-group;table-header-group;table-footer-group;table-row;table-column-group;table-column;table-cell;table-caption;none"; | ||||
| var defaultBorderStyle = "none;solid;dashed;dotted;double;groove;ridge;inset;outset"; | ||||
| var defaultBorderWidth = "thin;medium;thick"; | ||||
| var defaultListType = "disc;circle;square;decimal;lower-roman;upper-roman;lower-alpha;upper-alpha;none"; | ||||
|  | ||||
| function init() { | ||||
| 	var ce = document.getElementById('container'), h; | ||||
|  | ||||
| 	ce.style.cssText = tinyMCEPopup.getWindowArg('style_text'); | ||||
|  | ||||
| 	h = getBrowserHTML('background_image_browser','background_image','image','advimage'); | ||||
| 	document.getElementById("background_image_browser").innerHTML = h; | ||||
|  | ||||
| 	document.getElementById('text_color_pickcontainer').innerHTML = getColorPickerHTML('text_color_pick','text_color'); | ||||
| 	document.getElementById('background_color_pickcontainer').innerHTML = getColorPickerHTML('background_color_pick','background_color'); | ||||
| 	document.getElementById('border_color_top_pickcontainer').innerHTML = getColorPickerHTML('border_color_top_pick','border_color_top'); | ||||
| 	document.getElementById('border_color_right_pickcontainer').innerHTML = getColorPickerHTML('border_color_right_pick','border_color_right'); | ||||
| 	document.getElementById('border_color_bottom_pickcontainer').innerHTML = getColorPickerHTML('border_color_bottom_pick','border_color_bottom'); | ||||
| 	document.getElementById('border_color_left_pickcontainer').innerHTML = getColorPickerHTML('border_color_left_pick','border_color_left'); | ||||
|  | ||||
| 	fillSelect(0, 'text_font', 'style_font', defaultFonts, ';', true); | ||||
| 	fillSelect(0, 'text_size', 'style_font_size', defaultSizes, ';', true); | ||||
| 	fillSelect(0, 'text_size_measurement', 'style_font_size_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'text_case', 'style_text_case', "capitalize;uppercase;lowercase", ';', true); | ||||
| 	fillSelect(0, 'text_weight', 'style_font_weight', defaultWeight, ';', true); | ||||
| 	fillSelect(0, 'text_style', 'style_font_style', defaultTextStyle, ';', true); | ||||
| 	fillSelect(0, 'text_variant', 'style_font_variant', defaultVariant, ';', true); | ||||
| 	fillSelect(0, 'text_lineheight', 'style_font_line_height', defaultLineHeight, ';', true); | ||||
| 	fillSelect(0, 'text_lineheight_measurement', 'style_font_line_height_measurement', defaultMeasurement, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'background_attachment', 'style_background_attachment', defaultAttachment, ';', true); | ||||
| 	fillSelect(0, 'background_repeat', 'style_background_repeat', defaultRepeat, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'background_hpos_measurement', 'style_background_hpos_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'background_vpos_measurement', 'style_background_vpos_measurement', defaultMeasurement, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'background_hpos', 'style_background_hpos', defaultPosH, ';', true); | ||||
| 	fillSelect(0, 'background_vpos', 'style_background_vpos', defaultPosV, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'block_wordspacing', 'style_wordspacing', 'normal', ';', true); | ||||
| 	fillSelect(0, 'block_wordspacing_measurement', 'style_wordspacing_measurement', defaultSpacingMeasurement, ';', true); | ||||
| 	fillSelect(0, 'block_letterspacing', 'style_letterspacing', 'normal', ';', true); | ||||
| 	fillSelect(0, 'block_letterspacing_measurement', 'style_letterspacing_measurement', defaultSpacingMeasurement, ';', true); | ||||
| 	fillSelect(0, 'block_vertical_alignment', 'style_vertical_alignment', defaultVAlign, ';', true); | ||||
| 	fillSelect(0, 'block_text_align', 'style_text_align', "left;right;center;justify", ';', true); | ||||
| 	fillSelect(0, 'block_whitespace', 'style_whitespace', "normal;pre;nowrap", ';', true); | ||||
| 	fillSelect(0, 'block_display', 'style_display', defaultDisplay, ';', true); | ||||
| 	fillSelect(0, 'block_text_indent_measurement', 'style_text_indent_measurement', defaultIndentMeasurement, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'box_width_measurement', 'style_box_width_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_height_measurement', 'style_box_height_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_float', 'style_float', 'left;right;none', ';', true); | ||||
| 	fillSelect(0, 'box_clear', 'style_clear', 'left;right;both;none', ';', true); | ||||
| 	fillSelect(0, 'box_padding_left_measurement', 'style_padding_left_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_padding_top_measurement', 'style_padding_top_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_padding_bottom_measurement', 'style_padding_bottom_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_padding_right_measurement', 'style_padding_right_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_margin_left_measurement', 'style_margin_left_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_margin_top_measurement', 'style_margin_top_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_margin_bottom_measurement', 'style_margin_bottom_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'box_margin_right_measurement', 'style_margin_right_measurement', defaultMeasurement, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'border_style_top', 'style_border_style_top', defaultBorderStyle, ';', true); | ||||
| 	fillSelect(0, 'border_style_right', 'style_border_style_right', defaultBorderStyle, ';', true); | ||||
| 	fillSelect(0, 'border_style_bottom', 'style_border_style_bottom', defaultBorderStyle, ';', true); | ||||
| 	fillSelect(0, 'border_style_left', 'style_border_style_left', defaultBorderStyle, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'border_width_top', 'style_border_width_top', defaultBorderWidth, ';', true); | ||||
| 	fillSelect(0, 'border_width_right', 'style_border_width_right', defaultBorderWidth, ';', true); | ||||
| 	fillSelect(0, 'border_width_bottom', 'style_border_width_bottom', defaultBorderWidth, ';', true); | ||||
| 	fillSelect(0, 'border_width_left', 'style_border_width_left', defaultBorderWidth, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'border_width_top_measurement', 'style_border_width_top_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'border_width_right_measurement', 'style_border_width_right_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'border_width_bottom_measurement', 'style_border_width_bottom_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'border_width_left_measurement', 'style_border_width_left_measurement', defaultMeasurement, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'list_type', 'style_list_type', defaultListType, ';', true); | ||||
| 	fillSelect(0, 'list_position', 'style_list_position', "inside;outside", ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'positioning_type', 'style_positioning_type', "absolute;relative;static", ';', true); | ||||
| 	fillSelect(0, 'positioning_visibility', 'style_positioning_visibility', "inherit;visible;hidden", ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'positioning_width_measurement', 'style_positioning_width_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_height_measurement', 'style_positioning_height_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_overflow', 'style_positioning_overflow', "visible;hidden;scroll;auto", ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'positioning_placement_top_measurement', 'style_positioning_placement_top_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_placement_right_measurement', 'style_positioning_placement_right_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_placement_bottom_measurement', 'style_positioning_placement_bottom_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_placement_left_measurement', 'style_positioning_placement_left_measurement', defaultMeasurement, ';', true); | ||||
|  | ||||
| 	fillSelect(0, 'positioning_clip_top_measurement', 'style_positioning_clip_top_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_clip_right_measurement', 'style_positioning_clip_right_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_clip_bottom_measurement', 'style_positioning_clip_bottom_measurement', defaultMeasurement, ';', true); | ||||
| 	fillSelect(0, 'positioning_clip_left_measurement', 'style_positioning_clip_left_measurement', defaultMeasurement, ';', true); | ||||
|  | ||||
| 	TinyMCE_EditableSelects.init(); | ||||
| 	setupFormData(); | ||||
| 	showDisabledControls(); | ||||
| } | ||||
|  | ||||
| function setupFormData() { | ||||
| 	var ce = document.getElementById('container'), f = document.forms[0], s, b, i; | ||||
|  | ||||
| 	// Setup text fields | ||||
|  | ||||
| 	selectByValue(f, 'text_font', ce.style.fontFamily, true, true); | ||||
| 	selectByValue(f, 'text_size', getNum(ce.style.fontSize), true, true); | ||||
| 	selectByValue(f, 'text_size_measurement', getMeasurement(ce.style.fontSize)); | ||||
| 	selectByValue(f, 'text_weight', ce.style.fontWeight, true, true); | ||||
| 	selectByValue(f, 'text_style', ce.style.fontStyle, true, true); | ||||
| 	selectByValue(f, 'text_lineheight', getNum(ce.style.lineHeight), true, true); | ||||
| 	selectByValue(f, 'text_lineheight_measurement', getMeasurement(ce.style.lineHeight)); | ||||
| 	selectByValue(f, 'text_case', ce.style.textTransform, true, true); | ||||
| 	selectByValue(f, 'text_variant', ce.style.fontVariant, true, true); | ||||
| 	f.text_color.value = tinyMCEPopup.editor.dom.toHex(ce.style.color); | ||||
| 	updateColor('text_color_pick', 'text_color'); | ||||
| 	f.text_underline.checked = inStr(ce.style.textDecoration, 'underline'); | ||||
| 	f.text_overline.checked = inStr(ce.style.textDecoration, 'overline'); | ||||
| 	f.text_linethrough.checked = inStr(ce.style.textDecoration, 'line-through'); | ||||
| 	f.text_blink.checked = inStr(ce.style.textDecoration, 'blink'); | ||||
|  | ||||
| 	// Setup background fields | ||||
|  | ||||
| 	f.background_color.value = tinyMCEPopup.editor.dom.toHex(ce.style.backgroundColor); | ||||
| 	updateColor('background_color_pick', 'background_color'); | ||||
| 	f.background_image.value = ce.style.backgroundImage.replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
| 	selectByValue(f, 'background_repeat', ce.style.backgroundRepeat, true, true); | ||||
| 	selectByValue(f, 'background_attachment', ce.style.backgroundAttachment, true, true); | ||||
| 	selectByValue(f, 'background_hpos', getNum(getVal(ce.style.backgroundPosition, 0)), true, true); | ||||
| 	selectByValue(f, 'background_hpos_measurement', getMeasurement(getVal(ce.style.backgroundPosition, 0))); | ||||
| 	selectByValue(f, 'background_vpos', getNum(getVal(ce.style.backgroundPosition, 1)), true, true); | ||||
| 	selectByValue(f, 'background_vpos_measurement', getMeasurement(getVal(ce.style.backgroundPosition, 1))); | ||||
|  | ||||
| 	// Setup block fields | ||||
|  | ||||
| 	selectByValue(f, 'block_wordspacing', getNum(ce.style.wordSpacing), true, true); | ||||
| 	selectByValue(f, 'block_wordspacing_measurement', getMeasurement(ce.style.wordSpacing)); | ||||
| 	selectByValue(f, 'block_letterspacing', getNum(ce.style.letterSpacing), true, true); | ||||
| 	selectByValue(f, 'block_letterspacing_measurement', getMeasurement(ce.style.letterSpacing)); | ||||
| 	selectByValue(f, 'block_vertical_alignment', ce.style.verticalAlign, true, true); | ||||
| 	selectByValue(f, 'block_text_align', ce.style.textAlign, true, true); | ||||
| 	f.block_text_indent.value = getNum(ce.style.textIndent); | ||||
| 	selectByValue(f, 'block_text_indent_measurement', getMeasurement(ce.style.textIndent)); | ||||
| 	selectByValue(f, 'block_whitespace', ce.style.whiteSpace, true, true); | ||||
| 	selectByValue(f, 'block_display', ce.style.display, true, true); | ||||
|  | ||||
| 	// Setup box fields | ||||
|  | ||||
| 	f.box_width.value = getNum(ce.style.width); | ||||
| 	selectByValue(f, 'box_width_measurement', getMeasurement(ce.style.width)); | ||||
|  | ||||
| 	f.box_height.value = getNum(ce.style.height); | ||||
| 	selectByValue(f, 'box_height_measurement', getMeasurement(ce.style.height)); | ||||
|  | ||||
| 	if (tinymce.isGecko) | ||||
| 		selectByValue(f, 'box_float', ce.style.cssFloat, true, true); | ||||
| 	else | ||||
| 		selectByValue(f, 'box_float', ce.style.styleFloat, true, true); | ||||
|  | ||||
| 	selectByValue(f, 'box_clear', ce.style.clear, true, true); | ||||
|  | ||||
| 	setupBox(f, ce, 'box_padding', 'padding', ''); | ||||
| 	setupBox(f, ce, 'box_margin', 'margin', ''); | ||||
|  | ||||
| 	// Setup border fields | ||||
|  | ||||
| 	setupBox(f, ce, 'border_style', 'border', 'Style'); | ||||
| 	setupBox(f, ce, 'border_width', 'border', 'Width'); | ||||
| 	setupBox(f, ce, 'border_color', 'border', 'Color'); | ||||
|  | ||||
| 	updateColor('border_color_top_pick', 'border_color_top'); | ||||
| 	updateColor('border_color_right_pick', 'border_color_right'); | ||||
| 	updateColor('border_color_bottom_pick', 'border_color_bottom'); | ||||
| 	updateColor('border_color_left_pick', 'border_color_left'); | ||||
|  | ||||
| 	f.elements.border_color_top.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_top.value); | ||||
| 	f.elements.border_color_right.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_right.value); | ||||
| 	f.elements.border_color_bottom.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_bottom.value); | ||||
| 	f.elements.border_color_left.value = tinyMCEPopup.editor.dom.toHex(f.elements.border_color_left.value); | ||||
|  | ||||
| 	// Setup list fields | ||||
|  | ||||
| 	selectByValue(f, 'list_type', ce.style.listStyleType, true, true); | ||||
| 	selectByValue(f, 'list_position', ce.style.listStylePosition, true, true); | ||||
| 	f.list_bullet_image.value = ce.style.listStyleImage.replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
|  | ||||
| 	// Setup box fields | ||||
|  | ||||
| 	selectByValue(f, 'positioning_type', ce.style.position, true, true); | ||||
| 	selectByValue(f, 'positioning_visibility', ce.style.visibility, true, true); | ||||
| 	selectByValue(f, 'positioning_overflow', ce.style.overflow, true, true); | ||||
| 	f.positioning_zindex.value = ce.style.zIndex ? ce.style.zIndex : ""; | ||||
|  | ||||
| 	f.positioning_width.value = getNum(ce.style.width); | ||||
| 	selectByValue(f, 'positioning_width_measurement', getMeasurement(ce.style.width)); | ||||
|  | ||||
| 	f.positioning_height.value = getNum(ce.style.height); | ||||
| 	selectByValue(f, 'positioning_height_measurement', getMeasurement(ce.style.height)); | ||||
|  | ||||
| 	setupBox(f, ce, 'positioning_placement', '', '', ['top', 'right', 'bottom', 'left']); | ||||
|  | ||||
| 	s = ce.style.clip.replace(new RegExp("rect\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
| 	s = s.replace(/,/g, ' '); | ||||
|  | ||||
| 	if (!hasEqualValues([getVal(s, 0), getVal(s, 1), getVal(s, 2), getVal(s, 3)])) { | ||||
| 		f.positioning_clip_top.value = getNum(getVal(s, 0)); | ||||
| 		selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0))); | ||||
| 		f.positioning_clip_right.value = getNum(getVal(s, 1)); | ||||
| 		selectByValue(f, 'positioning_clip_right_measurement', getMeasurement(getVal(s, 1))); | ||||
| 		f.positioning_clip_bottom.value = getNum(getVal(s, 2)); | ||||
| 		selectByValue(f, 'positioning_clip_bottom_measurement', getMeasurement(getVal(s, 2))); | ||||
| 		f.positioning_clip_left.value = getNum(getVal(s, 3)); | ||||
| 		selectByValue(f, 'positioning_clip_left_measurement', getMeasurement(getVal(s, 3))); | ||||
| 	} else { | ||||
| 		f.positioning_clip_top.value = getNum(getVal(s, 0)); | ||||
| 		selectByValue(f, 'positioning_clip_top_measurement', getMeasurement(getVal(s, 0))); | ||||
| 		f.positioning_clip_right.value = f.positioning_clip_bottom.value = f.positioning_clip_left.value; | ||||
| 	} | ||||
|  | ||||
| //	setupBox(f, ce, '', 'border', 'Color'); | ||||
| } | ||||
|  | ||||
| function getMeasurement(s) { | ||||
| 	return s.replace(/^([0-9]+)(.*)$/, "$2"); | ||||
| } | ||||
|  | ||||
| function getNum(s) { | ||||
| 	if (new RegExp('^[0-9]+[a-z%]+$', 'gi').test(s)) | ||||
| 		return s.replace(/[^0-9]/g, ''); | ||||
|  | ||||
| 	return s; | ||||
| } | ||||
|  | ||||
| function inStr(s, n) { | ||||
| 	return new RegExp(n, 'gi').test(s); | ||||
| } | ||||
|  | ||||
| function getVal(s, i) { | ||||
| 	var a = s.split(' '); | ||||
|  | ||||
| 	if (a.length > 1) | ||||
| 		return a[i]; | ||||
|  | ||||
| 	return ""; | ||||
| } | ||||
|  | ||||
| function setValue(f, n, v) { | ||||
| 	if (f.elements[n].type == "text") | ||||
| 		f.elements[n].value = v; | ||||
| 	else | ||||
| 		selectByValue(f, n, v, true, true); | ||||
| } | ||||
|  | ||||
| function setupBox(f, ce, fp, pr, sf, b) { | ||||
| 	if (typeof(b) == "undefined") | ||||
| 		b = ['Top', 'Right', 'Bottom', 'Left']; | ||||
|  | ||||
| 	if (isSame(ce, pr, sf, b)) { | ||||
| 		f.elements[fp + "_same"].checked = true; | ||||
|  | ||||
| 		setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf])); | ||||
| 		f.elements[fp + "_top"].disabled = false; | ||||
|  | ||||
| 		f.elements[fp + "_right"].value = ""; | ||||
| 		f.elements[fp + "_right"].disabled = true; | ||||
| 		f.elements[fp + "_bottom"].value = ""; | ||||
| 		f.elements[fp + "_bottom"].disabled = true; | ||||
| 		f.elements[fp + "_left"].value = ""; | ||||
| 		f.elements[fp + "_left"].disabled = true; | ||||
|  | ||||
| 		if (f.elements[fp + "_top_measurement"]) { | ||||
| 			selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf])); | ||||
| 			f.elements[fp + "_left_measurement"].disabled = true; | ||||
| 			f.elements[fp + "_bottom_measurement"].disabled = true; | ||||
| 			f.elements[fp + "_right_measurement"].disabled = true; | ||||
| 		} | ||||
| 	} else { | ||||
| 		f.elements[fp + "_same"].checked = false; | ||||
|  | ||||
| 		setValue(f, fp + "_top", getNum(ce.style[pr + b[0] + sf])); | ||||
| 		f.elements[fp + "_top"].disabled = false; | ||||
|  | ||||
| 		setValue(f, fp + "_right", getNum(ce.style[pr + b[1] + sf])); | ||||
| 		f.elements[fp + "_right"].disabled = false; | ||||
|  | ||||
| 		setValue(f, fp + "_bottom", getNum(ce.style[pr + b[2] + sf])); | ||||
| 		f.elements[fp + "_bottom"].disabled = false; | ||||
|  | ||||
| 		setValue(f, fp + "_left", getNum(ce.style[pr + b[3] + sf])); | ||||
| 		f.elements[fp + "_left"].disabled = false; | ||||
|  | ||||
| 		if (f.elements[fp + "_top_measurement"]) { | ||||
| 			selectByValue(f, fp + '_top_measurement', getMeasurement(ce.style[pr + b[0] + sf])); | ||||
| 			selectByValue(f, fp + '_right_measurement', getMeasurement(ce.style[pr + b[1] + sf])); | ||||
| 			selectByValue(f, fp + '_bottom_measurement', getMeasurement(ce.style[pr + b[2] + sf])); | ||||
| 			selectByValue(f, fp + '_left_measurement', getMeasurement(ce.style[pr + b[3] + sf])); | ||||
| 			f.elements[fp + "_left_measurement"].disabled = false; | ||||
| 			f.elements[fp + "_bottom_measurement"].disabled = false; | ||||
| 			f.elements[fp + "_right_measurement"].disabled = false; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function isSame(e, pr, sf, b) { | ||||
| 	var a = [], i, x; | ||||
|  | ||||
| 	if (typeof(b) == "undefined") | ||||
| 		b = ['Top', 'Right', 'Bottom', 'Left']; | ||||
|  | ||||
| 	if (typeof(sf) == "undefined" || sf == null) | ||||
| 		sf = ""; | ||||
|  | ||||
| 	a[0] = e.style[pr + b[0] + sf]; | ||||
| 	a[1] = e.style[pr + b[1] + sf]; | ||||
| 	a[2] = e.style[pr + b[2] + sf]; | ||||
| 	a[3] = e.style[pr + b[3] + sf]; | ||||
|  | ||||
| 	for (i=0; i<a.length; i++) { | ||||
| 		if (a[i] == null) | ||||
| 			return false; | ||||
|  | ||||
| 		for (x=0; x<a.length; x++) { | ||||
| 			if (a[x] != a[i]) | ||||
| 				return false; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return true; | ||||
| }; | ||||
|  | ||||
| function hasEqualValues(a) { | ||||
| 	var i, x; | ||||
|  | ||||
| 	for (i=0; i<a.length; i++) { | ||||
| 		if (a[i] == null) | ||||
| 			return false; | ||||
|  | ||||
| 		for (x=0; x<a.length; x++) { | ||||
| 			if (a[x] != a[i]) | ||||
| 				return false; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return true; | ||||
| } | ||||
|  | ||||
| function applyAction() { | ||||
| 	var ce = document.getElementById('container'), ed = tinyMCEPopup.editor; | ||||
|  | ||||
| 	generateCSS(); | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
| 	ed.dom.setAttrib(ed.selection.getNode(), 'style', tinyMCEPopup.editor.dom.serializeStyle(tinyMCEPopup.editor.dom.parseStyle(ce.style.cssText))); | ||||
| } | ||||
|  | ||||
| function updateAction() { | ||||
| 	applyAction(); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function generateCSS() { | ||||
| 	var ce = document.getElementById('container'), f = document.forms[0], num = new RegExp('[0-9]+', 'g'), s, t; | ||||
|  | ||||
| 	ce.style.cssText = ""; | ||||
|  | ||||
| 	// Build text styles | ||||
| 	ce.style.fontFamily = f.text_font.value; | ||||
| 	ce.style.fontSize = f.text_size.value + (isNum(f.text_size.value) ? (f.text_size_measurement.value || 'px') : ""); | ||||
| 	ce.style.fontStyle = f.text_style.value; | ||||
| 	ce.style.lineHeight = f.text_lineheight.value + (isNum(f.text_lineheight.value) ? f.text_lineheight_measurement.value : ""); | ||||
| 	ce.style.textTransform = f.text_case.value; | ||||
| 	ce.style.fontWeight = f.text_weight.value; | ||||
| 	ce.style.fontVariant = f.text_variant.value; | ||||
| 	ce.style.color = f.text_color.value; | ||||
|  | ||||
| 	s = ""; | ||||
| 	s += f.text_underline.checked ? " underline" : ""; | ||||
| 	s += f.text_overline.checked ? " overline" : ""; | ||||
| 	s += f.text_linethrough.checked ? " line-through" : ""; | ||||
| 	s += f.text_blink.checked ? " blink" : ""; | ||||
| 	s = s.length > 0 ? s.substring(1) : s; | ||||
|  | ||||
| 	if (f.text_none.checked) | ||||
| 		s = "none"; | ||||
|  | ||||
| 	ce.style.textDecoration = s; | ||||
|  | ||||
| 	// Build background styles | ||||
|  | ||||
| 	ce.style.backgroundColor = f.background_color.value; | ||||
| 	ce.style.backgroundImage = f.background_image.value != "" ? "url(" + f.background_image.value + ")" : ""; | ||||
| 	ce.style.backgroundRepeat = f.background_repeat.value; | ||||
| 	ce.style.backgroundAttachment = f.background_attachment.value; | ||||
|  | ||||
| 	if (f.background_hpos.value != "") { | ||||
| 		s = ""; | ||||
| 		s += f.background_hpos.value + (isNum(f.background_hpos.value) ? f.background_hpos_measurement.value : "") + " "; | ||||
| 		s += f.background_vpos.value + (isNum(f.background_vpos.value) ? f.background_vpos_measurement.value : ""); | ||||
| 		ce.style.backgroundPosition = s; | ||||
| 	} | ||||
|  | ||||
| 	// Build block styles | ||||
|  | ||||
| 	ce.style.wordSpacing = f.block_wordspacing.value + (isNum(f.block_wordspacing.value) ? f.block_wordspacing_measurement.value : ""); | ||||
| 	ce.style.letterSpacing = f.block_letterspacing.value + (isNum(f.block_letterspacing.value) ? f.block_letterspacing_measurement.value : ""); | ||||
| 	ce.style.verticalAlign = f.block_vertical_alignment.value; | ||||
| 	ce.style.textAlign = f.block_text_align.value; | ||||
| 	ce.style.textIndent = f.block_text_indent.value + (isNum(f.block_text_indent.value) ? f.block_text_indent_measurement.value : ""); | ||||
| 	ce.style.whiteSpace = f.block_whitespace.value; | ||||
| 	ce.style.display = f.block_display.value; | ||||
|  | ||||
| 	// Build box styles | ||||
|  | ||||
| 	ce.style.width = f.box_width.value + (isNum(f.box_width.value) ? f.box_width_measurement.value : ""); | ||||
| 	ce.style.height = f.box_height.value + (isNum(f.box_height.value) ? f.box_height_measurement.value : ""); | ||||
| 	ce.style.styleFloat = f.box_float.value; | ||||
|  | ||||
| 	if (tinymce.isGecko) | ||||
| 		ce.style.cssFloat = f.box_float.value; | ||||
|  | ||||
| 	ce.style.clear = f.box_clear.value; | ||||
|  | ||||
| 	if (!f.box_padding_same.checked) { | ||||
| 		ce.style.paddingTop = f.box_padding_top.value + (isNum(f.box_padding_top.value) ? f.box_padding_top_measurement.value : ""); | ||||
| 		ce.style.paddingRight = f.box_padding_right.value + (isNum(f.box_padding_right.value) ? f.box_padding_right_measurement.value : ""); | ||||
| 		ce.style.paddingBottom = f.box_padding_bottom.value + (isNum(f.box_padding_bottom.value) ? f.box_padding_bottom_measurement.value : ""); | ||||
| 		ce.style.paddingLeft = f.box_padding_left.value + (isNum(f.box_padding_left.value) ? f.box_padding_left_measurement.value : ""); | ||||
| 	} else | ||||
| 		ce.style.padding = f.box_padding_top.value + (isNum(f.box_padding_top.value) ? f.box_padding_top_measurement.value : "");		 | ||||
|  | ||||
| 	if (!f.box_margin_same.checked) { | ||||
| 		ce.style.marginTop = f.box_margin_top.value + (isNum(f.box_margin_top.value) ? f.box_margin_top_measurement.value : ""); | ||||
| 		ce.style.marginRight = f.box_margin_right.value + (isNum(f.box_margin_right.value) ? f.box_margin_right_measurement.value : ""); | ||||
| 		ce.style.marginBottom = f.box_margin_bottom.value + (isNum(f.box_margin_bottom.value) ? f.box_margin_bottom_measurement.value : ""); | ||||
| 		ce.style.marginLeft = f.box_margin_left.value + (isNum(f.box_margin_left.value) ? f.box_margin_left_measurement.value : ""); | ||||
| 	} else | ||||
| 		ce.style.margin = f.box_margin_top.value + (isNum(f.box_margin_top.value) ? f.box_margin_top_measurement.value : "");		 | ||||
|  | ||||
| 	// Build border styles | ||||
|  | ||||
| 	if (!f.border_style_same.checked) { | ||||
| 		ce.style.borderTopStyle = f.border_style_top.value; | ||||
| 		ce.style.borderRightStyle = f.border_style_right.value; | ||||
| 		ce.style.borderBottomStyle = f.border_style_bottom.value; | ||||
| 		ce.style.borderLeftStyle = f.border_style_left.value; | ||||
| 	} else | ||||
| 		ce.style.borderStyle = f.border_style_top.value; | ||||
|  | ||||
| 	if (!f.border_width_same.checked) { | ||||
| 		ce.style.borderTopWidth = f.border_width_top.value + (isNum(f.border_width_top.value) ? f.border_width_top_measurement.value : ""); | ||||
| 		ce.style.borderRightWidth = f.border_width_right.value + (isNum(f.border_width_right.value) ? f.border_width_right_measurement.value : ""); | ||||
| 		ce.style.borderBottomWidth = f.border_width_bottom.value + (isNum(f.border_width_bottom.value) ? f.border_width_bottom_measurement.value : ""); | ||||
| 		ce.style.borderLeftWidth = f.border_width_left.value + (isNum(f.border_width_left.value) ? f.border_width_left_measurement.value : ""); | ||||
| 	} else | ||||
| 		ce.style.borderWidth = f.border_width_top.value; | ||||
|  | ||||
| 	if (!f.border_color_same.checked) { | ||||
| 		ce.style.borderTopColor = f.border_color_top.value; | ||||
| 		ce.style.borderRightColor = f.border_color_right.value; | ||||
| 		ce.style.borderBottomColor = f.border_color_bottom.value; | ||||
| 		ce.style.borderLeftColor = f.border_color_left.value; | ||||
| 	} else | ||||
| 		ce.style.borderColor = f.border_color_top.value; | ||||
|  | ||||
| 	// Build list styles | ||||
|  | ||||
| 	ce.style.listStyleType = f.list_type.value; | ||||
| 	ce.style.listStylePosition = f.list_position.value; | ||||
| 	ce.style.listStyleImage = f.list_bullet_image.value != "" ? "url(" + f.list_bullet_image.value + ")" : ""; | ||||
|  | ||||
| 	// Build positioning styles | ||||
|  | ||||
| 	ce.style.position = f.positioning_type.value; | ||||
| 	ce.style.visibility = f.positioning_visibility.value; | ||||
|  | ||||
| 	if (ce.style.width == "") | ||||
| 		ce.style.width = f.positioning_width.value + (isNum(f.positioning_width.value) ? f.positioning_width_measurement.value : ""); | ||||
|  | ||||
| 	if (ce.style.height == "") | ||||
| 		ce.style.height = f.positioning_height.value + (isNum(f.positioning_height.value) ? f.positioning_height_measurement.value : ""); | ||||
|  | ||||
| 	ce.style.zIndex = f.positioning_zindex.value; | ||||
| 	ce.style.overflow = f.positioning_overflow.value; | ||||
|  | ||||
| 	if (!f.positioning_placement_same.checked) { | ||||
| 		ce.style.top = f.positioning_placement_top.value + (isNum(f.positioning_placement_top.value) ? f.positioning_placement_top_measurement.value : ""); | ||||
| 		ce.style.right = f.positioning_placement_right.value + (isNum(f.positioning_placement_right.value) ? f.positioning_placement_right_measurement.value : ""); | ||||
| 		ce.style.bottom = f.positioning_placement_bottom.value + (isNum(f.positioning_placement_bottom.value) ? f.positioning_placement_bottom_measurement.value : ""); | ||||
| 		ce.style.left = f.positioning_placement_left.value + (isNum(f.positioning_placement_left.value) ? f.positioning_placement_left_measurement.value : ""); | ||||
| 	} else { | ||||
| 		s = f.positioning_placement_top.value + (isNum(f.positioning_placement_top.value) ? f.positioning_placement_top_measurement.value : ""); | ||||
| 		ce.style.top = s; | ||||
| 		ce.style.right = s; | ||||
| 		ce.style.bottom = s; | ||||
| 		ce.style.left = s; | ||||
| 	} | ||||
|  | ||||
| 	if (!f.positioning_clip_same.checked) { | ||||
| 		s = "rect("; | ||||
| 		s += (isNum(f.positioning_clip_top.value) ? f.positioning_clip_top.value + f.positioning_clip_top_measurement.value : "auto") + " "; | ||||
| 		s += (isNum(f.positioning_clip_right.value) ? f.positioning_clip_right.value + f.positioning_clip_right_measurement.value : "auto") + " "; | ||||
| 		s += (isNum(f.positioning_clip_bottom.value) ? f.positioning_clip_bottom.value + f.positioning_clip_bottom_measurement.value : "auto") + " "; | ||||
| 		s += (isNum(f.positioning_clip_left.value) ? f.positioning_clip_left.value + f.positioning_clip_left_measurement.value : "auto"); | ||||
| 		s += ")"; | ||||
|  | ||||
| 		if (s != "rect(auto auto auto auto)") | ||||
| 			ce.style.clip = s; | ||||
| 	} else { | ||||
| 		s = "rect("; | ||||
| 		t = isNum(f.positioning_clip_top.value) ? f.positioning_clip_top.value + f.positioning_clip_top_measurement.value : "auto"; | ||||
| 		s += t + " "; | ||||
| 		s += t + " "; | ||||
| 		s += t + " "; | ||||
| 		s += t + ")"; | ||||
|  | ||||
| 		if (s != "rect(auto auto auto auto)") | ||||
| 			ce.style.clip = s; | ||||
| 	} | ||||
|  | ||||
| 	ce.style.cssText = ce.style.cssText; | ||||
| } | ||||
|  | ||||
| function isNum(s) { | ||||
| 	return new RegExp('[0-9]+', 'g').test(s); | ||||
| } | ||||
|  | ||||
| function showDisabledControls() { | ||||
| 	var f = document.forms, i, a; | ||||
|  | ||||
| 	for (i=0; i<f.length; i++) { | ||||
| 		for (a=0; a<f[i].elements.length; a++) { | ||||
| 			if (f[i].elements[a].disabled) | ||||
| 				tinyMCEPopup.editor.dom.addClass(f[i].elements[a], "disabled"); | ||||
| 			else | ||||
| 				tinyMCEPopup.editor.dom.removeClass(f[i].elements[a], "disabled"); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function fillSelect(f, s, param, dval, sep, em) { | ||||
| 	var i, ar, p, se; | ||||
|  | ||||
| 	f = document.forms[f]; | ||||
| 	sep = typeof(sep) == "undefined" ? ";" : sep; | ||||
|  | ||||
| 	if (em) | ||||
| 		addSelectValue(f, s, "", ""); | ||||
|  | ||||
| 	ar = tinyMCEPopup.getParam(param, dval).split(sep); | ||||
| 	for (i=0; i<ar.length; i++) { | ||||
| 		se = false; | ||||
|  | ||||
| 		if (ar[i].charAt(0) == '+') { | ||||
| 			ar[i] = ar[i].substring(1); | ||||
| 			se = true; | ||||
| 		} | ||||
|  | ||||
| 		p = ar[i].split('='); | ||||
|  | ||||
| 		if (p.length > 1) { | ||||
| 			addSelectValue(f, s, p[0], p[1]); | ||||
|  | ||||
| 			if (se) | ||||
| 				selectByValue(f, s, p[1]); | ||||
| 		} else { | ||||
| 			addSelectValue(f, s, p[0], p[0]); | ||||
|  | ||||
| 			if (se) | ||||
| 				selectByValue(f, s, p[0]); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function toggleSame(ce, pre) { | ||||
| 	var el = document.forms[0].elements, i; | ||||
|  | ||||
| 	if (ce.checked) { | ||||
| 		el[pre + "_top"].disabled = false; | ||||
| 		el[pre + "_right"].disabled = true; | ||||
| 		el[pre + "_bottom"].disabled = true; | ||||
| 		el[pre + "_left"].disabled = true; | ||||
|  | ||||
| 		if (el[pre + "_top_measurement"]) { | ||||
| 			el[pre + "_top_measurement"].disabled = false; | ||||
| 			el[pre + "_right_measurement"].disabled = true; | ||||
| 			el[pre + "_bottom_measurement"].disabled = true; | ||||
| 			el[pre + "_left_measurement"].disabled = true; | ||||
| 		} | ||||
| 	} else { | ||||
| 		el[pre + "_top"].disabled = false; | ||||
| 		el[pre + "_right"].disabled = false; | ||||
| 		el[pre + "_bottom"].disabled = false; | ||||
| 		el[pre + "_left"].disabled = false; | ||||
|  | ||||
| 		if (el[pre + "_top_measurement"]) { | ||||
| 			el[pre + "_top_measurement"].disabled = false; | ||||
| 			el[pre + "_right_measurement"].disabled = false; | ||||
| 			el[pre + "_bottom_measurement"].disabled = false; | ||||
| 			el[pre + "_left_measurement"].disabled = false; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	showDisabledControls(); | ||||
| } | ||||
|  | ||||
| function synch(fr, to) { | ||||
| 	var f = document.forms[0]; | ||||
|  | ||||
| 	f.elements[to].value = f.elements[fr].value; | ||||
|  | ||||
| 	if (f.elements[fr + "_measurement"]) | ||||
| 		selectByValue(f, to + "_measurement", f.elements[fr + "_measurement"].value); | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,63 @@ | ||||
| tinyMCE.addI18n('en.style_dlg',{ | ||||
| title:"Edit CSS Style", | ||||
| apply:"Apply", | ||||
| text_tab:"Text", | ||||
| background_tab:"Background", | ||||
| block_tab:"Block", | ||||
| box_tab:"Box", | ||||
| border_tab:"Border", | ||||
| list_tab:"List", | ||||
| positioning_tab:"Positioning", | ||||
| text_props:"Text", | ||||
| text_font:"Font", | ||||
| text_size:"Size", | ||||
| text_weight:"Weight", | ||||
| text_style:"Style", | ||||
| text_variant:"Variant", | ||||
| text_lineheight:"Line height", | ||||
| text_case:"Case", | ||||
| text_color:"Color", | ||||
| text_decoration:"Decoration", | ||||
| text_overline:"overline", | ||||
| text_underline:"underline", | ||||
| text_striketrough:"strikethrough", | ||||
| text_blink:"blink", | ||||
| text_none:"none", | ||||
| background_color:"Background color", | ||||
| background_image:"Background image", | ||||
| background_repeat:"Repeat", | ||||
| background_attachment:"Attachment", | ||||
| background_hpos:"Horizontal position", | ||||
| background_vpos:"Vertical position", | ||||
| block_wordspacing:"Word spacing", | ||||
| block_letterspacing:"Letter spacing", | ||||
| block_vertical_alignment:"Vertical alignment", | ||||
| block_text_align:"Text align", | ||||
| block_text_indent:"Text indent", | ||||
| block_whitespace:"Whitespace", | ||||
| block_display:"Display", | ||||
| box_width:"Width", | ||||
| box_height:"Height", | ||||
| box_float:"Float", | ||||
| box_clear:"Clear", | ||||
| padding:"Padding", | ||||
| same:"Same for all", | ||||
| top:"Top", | ||||
| right:"Right", | ||||
| bottom:"Bottom", | ||||
| left:"Left", | ||||
| margin:"Margin", | ||||
| style:"Style", | ||||
| width:"Width", | ||||
| height:"Height", | ||||
| color:"Color", | ||||
| list_type:"Type", | ||||
| bullet_image:"Bullet image", | ||||
| position:"Position", | ||||
| positioning_type:"Type", | ||||
| visibility:"Visibility", | ||||
| zindex:"Z-index", | ||||
| overflow:"Overflow", | ||||
| placement:"Placement", | ||||
| clip:"Clip" | ||||
| }); | ||||
| @@ -0,0 +1,731 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#style_dlg.title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="js/props.js"></script> | ||||
| 	<link href="css/props.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
|  | ||||
| <body id="styleprops" style="display: none"> | ||||
| <form onsubmit="updateAction();return false;" action="#"> | ||||
| <div class="tabs"> | ||||
| 	<ul> | ||||
| 		<li id="text_tab" class="current"><span><a href="javascript:mcTabs.displayTab('text_tab','text_panel');" onMouseDown="return false;">{#style_dlg.text_tab}</a></span></li> | ||||
| 		<li id="background_tab"><span><a href="javascript:mcTabs.displayTab('background_tab','background_panel');" onMouseDown="return false;">{#style_dlg.background_tab}</a></span></li> | ||||
| 		<li id="block_tab"><span><a href="javascript:mcTabs.displayTab('block_tab','block_panel');" onMouseDown="return false;">{#style_dlg.block_tab}</a></span></li> | ||||
| 		<li id="box_tab"><span><a href="javascript:mcTabs.displayTab('box_tab','box_panel');" onMouseDown="return false;">{#style_dlg.box_tab}</a></span></li> | ||||
| 		<li id="border_tab"><span><a href="javascript:mcTabs.displayTab('border_tab','border_panel');" onMouseDown="return false;">{#style_dlg.border_tab}</a></span></li> | ||||
| 		<li id="list_tab"><span><a href="javascript:mcTabs.displayTab('list_tab','list_panel');" onMouseDown="return false;">{#style_dlg.list_tab}</a></span></li> | ||||
| 		<li id="positioning_tab"><span><a href="javascript:mcTabs.displayTab('positioning_tab','positioning_panel');" onMouseDown="return false;">{#style_dlg.positioning_tab}</a></span></li> | ||||
| 	</ul> | ||||
| </div> | ||||
|  | ||||
| <div class="panel_wrapper"> | ||||
| <div id="text_panel" class="panel current"> | ||||
| 	<table border="0" width="100%"> | ||||
| 		<tr> | ||||
| 			<td><label for="text_font">{#style_dlg.text_font}</label></td> | ||||
| 			<td colspan="3"> | ||||
| 				<select id="text_font" name="text_font" class="mceEditableSelect mceFocus"></select> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 		<tr> | ||||
| 			<td><label for="text_size">{#style_dlg.text_size}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><select id="text_size" name="text_size" class="mceEditableSelect"></select></td> | ||||
| 						<td> </td> | ||||
|       <td><select id="text_size_measurement" name="text_size_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 			<td><label for="text_weight">{#style_dlg.text_weight}</label></td> | ||||
| 			<td> | ||||
| 				<select id="text_weight" name="text_weight"></select> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 		<tr> | ||||
| 			<td><label for="text_style">{#style_dlg.text_style}</label></td> | ||||
| 			<td> | ||||
| 				<select id="text_style" name="text_style" class="mceEditableSelect"></select> | ||||
| 			</td> | ||||
| 			<td><label for="text_variant">{#style_dlg.text_variant}</label></td> | ||||
| 			<td> | ||||
| 				<select id="text_variant" name="text_variant"></select> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 		<tr> | ||||
| 			<td><label for="text_lineheight">{#style_dlg.text_lineheight}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td> | ||||
| 							<select id="text_lineheight" name="text_lineheight" class="mceEditableSelect"></select> | ||||
| 						</td> | ||||
| 						<td> </td> | ||||
| 						<td><select id="text_lineheight_measurement" name="text_lineheight_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 			<td><label for="text_case">{#style_dlg.text_case}</label></td> | ||||
| 			<td> | ||||
| 				<select id="text_case" name="text_case"></select> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 		<tr> | ||||
| 			<td><label for="text_color">{#style_dlg.text_color}</label></td> | ||||
| 			<td colspan="2"> | ||||
| 				<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 					<tr> | ||||
| 						<td><input id="text_color" name="text_color" type="text" value="" size="9" onChange="updateColor('text_color_pick','text_color');" /></td> | ||||
| 						<td id="text_color_pickcontainer"> </td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 		<tr> | ||||
| 			<td valign="top" style="vertical-align: top; padding-top: 3px;">{#style_dlg.text_decoration}</td> | ||||
| 			<td colspan="2"> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><input id="text_underline" name="text_underline" class="checkbox" type="checkbox" /></td> | ||||
| 						<td><label for="text_underline">{#style_dlg.text_underline}</label></td> | ||||
| 					</tr> | ||||
| 					<tr> | ||||
| 						<td><input id="text_overline" name="text_overline" class="checkbox" type="checkbox" /></td> | ||||
| 						<td><label for="text_overline">{#style_dlg.text_overline}</label></td> | ||||
| 					</tr> | ||||
| 					<tr> | ||||
| 						<td><input id="text_linethrough" name="text_linethrough" class="checkbox" type="checkbox" /></td> | ||||
| 						<td><label for="text_linethrough">{#style_dlg.text_striketrough}</label></td> | ||||
| 					</tr> | ||||
| 					<tr> | ||||
| 						<td><input id="text_blink" name="text_blink" class="checkbox" type="checkbox" /></td> | ||||
| 						<td><label for="text_blink">{#style_dlg.text_blink}</label></td> | ||||
| 					</tr> | ||||
| 					<tr> | ||||
| 						<td><input id="text_none" name="text_none" class="checkbox" type="checkbox" /></td> | ||||
| 						<td><label for="text_none">{#style_dlg.text_none}</label></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 	</table> | ||||
| </div> | ||||
|  | ||||
| <div id="background_panel" class="panel"> | ||||
| 	<table border="0"> | ||||
| 		<tr> | ||||
| 			<td><label for="background_color">{#style_dlg.background_color}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 					<tr> | ||||
| 						<td><input id="background_color" name="background_color" type="text" value="" size="9" onChange="updateColor('background_color_pick','background_color');" /></td> | ||||
| 						<td id="background_color_pickcontainer"> </td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="background_image">{#style_dlg.background_image}</label></td> | ||||
| 			<td><table border="0" cellspacing="0" cellpadding="0"> | ||||
| 				<tr>  | ||||
| 				  <td><input id="background_image" name="background_image" type="text" /></td>  | ||||
| 				  <td id="background_image_browser"> </td> | ||||
| 				</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="background_repeat">{#style_dlg.background_repeat}</label></td> | ||||
| 			<td><select id="background_repeat" name="background_repeat" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="background_attachment">{#style_dlg.background_attachment}</label></td> | ||||
| 			<td><select id="background_attachment" name="background_attachment" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="background_hpos">{#style_dlg.background_hpos}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><select id="background_hpos" name="background_hpos" class="mceEditableSelect"></select></td> | ||||
| 						<td> </td> | ||||
| 						<td><select id="background_hpos_measurement" name="background_hpos_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="background_vpos">{#style_dlg.background_vpos}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><select id="background_vpos" name="background_vpos" class="mceEditableSelect"></select></td> | ||||
| 						<td> </td> | ||||
| 						<td><select id="background_vpos_measurement" name="background_vpos_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
| 	</table> | ||||
| </div> | ||||
|  | ||||
| <div id="block_panel" class="panel"> | ||||
| 	<table border="0"> | ||||
| 		<tr> | ||||
| 			<td><label for="block_wordspacing">{#style_dlg.block_wordspacing}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><select id="block_wordspacing" name="block_wordspacing" class="mceEditableSelect"></select></td> | ||||
| 						<td> </td> | ||||
| 						<td><select id="block_wordspacing_measurement" name="block_wordspacing_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="block_letterspacing">{#style_dlg.block_letterspacing}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><select id="block_letterspacing" name="block_letterspacing" class="mceEditableSelect"></select></td> | ||||
| 						<td> </td> | ||||
| 						<td><select id="block_letterspacing_measurement" name="block_letterspacing_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="block_vertical_alignment">{#style_dlg.block_vertical_alignment}</label></td> | ||||
| 			<td><select id="block_vertical_alignment" name="block_vertical_alignment" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="block_text_align">{#style_dlg.block_text_align}</label></td> | ||||
| 			<td><select id="block_text_align" name="block_text_align" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="block_text_indent">{#style_dlg.block_text_indent}</label></td> | ||||
| 			<td> | ||||
| 				<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 					<tr> | ||||
| 						<td><input type="text" id="block_text_indent" name="block_text_indent" /></td> | ||||
| 						<td> </td> | ||||
| 						<td><select id="block_text_indent_measurement" name="block_text_indent_measurement"></select></td> | ||||
| 					</tr> | ||||
| 				</table> | ||||
| 			</td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="block_whitespace">{#style_dlg.block_whitespace}</label></td> | ||||
| 			<td><select id="block_whitespace" name="block_whitespace" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="block_display">{#style_dlg.block_display}</label></td> | ||||
| 			<td><select id="block_display" name="block_display" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
| 	</table> | ||||
| </div> | ||||
|  | ||||
| <div id="box_panel" class="panel"> | ||||
| <table border="0"> | ||||
| 	<tr> | ||||
| 		<td><label for="box_width">{#style_dlg.box_width}</label></td> | ||||
| 		<td> | ||||
| 			<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 				<tr> | ||||
| 					<td><input type="text" id="box_width" name="box_width" class="mceEditableSelect" onChange="synch('box_width','positioning_width');" /></td> | ||||
| 					<td> </td> | ||||
| 					<td><select id="box_width_measurement" name="box_width_measurement"></select></td> | ||||
| 				</tr> | ||||
| 			</table> | ||||
| 		</td> | ||||
| 		<td>   <label for="box_float">{#style_dlg.box_float}</label></td> | ||||
| 		<td><select id="box_float" name="box_float" class="mceEditableSelect"></select></td> | ||||
| 	</tr> | ||||
|  | ||||
| 	<tr> | ||||
| 		<td><label for="box_height">{#style_dlg.box_height}</label></td> | ||||
| 		<td> | ||||
| 			<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 				<tr> | ||||
| 					<td><input type="text" id="box_height" name="box_height" class="mceEditableSelect" onChange="synch('box_height','positioning_height');" /></td> | ||||
| 					<td> </td> | ||||
| 					<td><select id="box_height_measurement" name="box_height_measurement"></select></td> | ||||
| 				</tr> | ||||
| 			</table> | ||||
| 		</td> | ||||
| 		<td>   <label for="box_clear">{#style_dlg.box_clear}</label></td> | ||||
| 		<td><select id="box_clear" name="box_clear" class="mceEditableSelect"></select></td> | ||||
| 	</tr> | ||||
| </table> | ||||
| <div style="float: left; width: 49%"> | ||||
| 	<fieldset> | ||||
| 		<legend>{#style_dlg.padding}</legend> | ||||
|  | ||||
| 		<table border="0"> | ||||
| 			<tr> | ||||
| 				<td> </td> | ||||
| 				<td><input type="checkbox" id="box_padding_same" name="box_padding_same" class="checkbox" checked="checked" onClick="toggleSame(this,'box_padding');" /> <label for="box_padding_same">{#style_dlg.same}</label></td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_padding_top">{#style_dlg.top}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_padding_top" name="box_padding_top" class="mceEditableSelect" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_padding_top_measurement" name="box_padding_top_measurement"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_padding_right">{#style_dlg.right}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_padding_right" name="box_padding_right" class="mceEditableSelect" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_padding_right_measurement" name="box_padding_right_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_padding_bottom">{#style_dlg.bottom}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_padding_bottom" name="box_padding_bottom" class="mceEditableSelect" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_padding_bottom_measurement" name="box_padding_bottom_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_padding_left">{#style_dlg.left}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_padding_left" name="box_padding_left" class="mceEditableSelect" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_padding_left_measurement" name="box_padding_left_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</fieldset> | ||||
| </div> | ||||
|  | ||||
| <div style="float: right; width: 49%"> | ||||
| 	<fieldset> | ||||
| 		<legend>{#style_dlg.margin}</legend> | ||||
|  | ||||
| 		<table border="0"> | ||||
| 			<tr> | ||||
| 				<td> </td> | ||||
| 				<td><input type="checkbox" id="box_margin_same" name="box_margin_same" class="checkbox" checked="checked" onClick="toggleSame(this,'box_margin');" /> <label for="box_margin_same">{#style_dlg.same}</label></td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_margin_top">{#style_dlg.top}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_margin_top" name="box_margin_top" class="mceEditableSelect" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_margin_top_measurement" name="box_margin_top_measurement"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_margin_right">{#style_dlg.right}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_margin_right" name="box_margin_right" class="mceEditableSelect" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_margin_right_measurement" name="box_margin_right_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_margin_bottom">{#style_dlg.bottom}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_margin_bottom" name="box_margin_bottom" class="mceEditableSelect" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_margin_bottom_measurement" name="box_margin_bottom_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td><label for="box_margin_left">{#style_dlg.left}</label></td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="box_margin_left" name="box_margin_left" class="mceEditableSelect" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="box_margin_left_measurement" name="box_margin_left_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</fieldset> | ||||
| </div> | ||||
| <br style="clear: both" /> | ||||
| </div> | ||||
|  | ||||
| <div id="border_panel" class="panel"> | ||||
| <table border="0" cellspacing="0" cellpadding="0" width="100%"> | ||||
| <tr> | ||||
| 	<td class="tdelim"> </td> | ||||
| 	<td class="tdelim delim"> </td> | ||||
| 	<td class="tdelim">{#style_dlg.style}</td> | ||||
| 	<td class="tdelim delim"> </td> | ||||
| 	<td class="tdelim">{#style_dlg.width}</td> | ||||
| 	<td class="tdelim delim"> </td> | ||||
| 	<td class="tdelim">{#style_dlg.color}</td> | ||||
| </tr> | ||||
|  | ||||
| <tr> | ||||
| 	<td> </td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><input type="checkbox" id="border_style_same" name="border_style_same" class="checkbox" checked="checked" onClick="toggleSame(this,'border_style');" /> <label for="border_style_same">{#style_dlg.same}</label></td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><input type="checkbox" id="border_width_same" name="border_width_same" class="checkbox" checked="checked" onClick="toggleSame(this,'border_width');" /> <label for="border_width_same">{#style_dlg.same}</label></td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><input type="checkbox" id="border_color_same" name="border_color_same" class="checkbox" checked="checked" onClick="toggleSame(this,'border_color');" /> <label for="border_color_same">{#style_dlg.same}</label></td> | ||||
| </tr> | ||||
|  | ||||
| <tr> | ||||
| 	<td>{#style_dlg.top}</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><select id="border_style_top" name="border_style_top" class="mceEditableSelect"></select></td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 			<tr> | ||||
| 				<td><select id="border_width_top" name="border_width_top" class="mceEditableSelect"></select></td> | ||||
| 				<td> </td> | ||||
| 				<td><select id="border_width_top_measurement" name="border_width_top_measurement"></select></td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 			<tr> | ||||
| 				<td><input id="border_color_top" name="border_color_top" type="text" value="" size="9" onChange="updateColor('border_color_top_pick','border_color_top');" /></td> | ||||
| 				<td id="border_color_top_pickcontainer"> </td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| </tr> | ||||
|  | ||||
| <tr> | ||||
| 	<td>{#style_dlg.right}</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><select id="border_style_right" name="border_style_right" class="mceEditableSelect" disabled="disabled"></select></td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 			<tr> | ||||
| 				<td><select id="border_width_right" name="border_width_right" class="mceEditableSelect" disabled="disabled"></select></td> | ||||
| 				<td> </td> | ||||
| 				<td><select id="border_width_right_measurement" name="border_width_right_measurement" disabled="disabled"></select></td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 			<tr> | ||||
| 				<td><input id="border_color_right" name="border_color_right" type="text" value="" size="9" onChange="updateColor('border_color_right_pick','border_color_right');" disabled="disabled" /></td> | ||||
| 				<td id="border_color_right_pickcontainer"> </td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| </tr> | ||||
|  | ||||
| <tr> | ||||
| 	<td>{#style_dlg.bottom}</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><select id="border_style_bottom" name="border_style_bottom" class="mceEditableSelect" disabled="disabled"></select></td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 			<tr> | ||||
| 				<td><select id="border_width_bottom" name="border_width_bottom" class="mceEditableSelect" disabled="disabled"></select></td> | ||||
| 				<td> </td> | ||||
| 				<td><select id="border_width_bottom_measurement" name="border_width_bottom_measurement" disabled="disabled"></select></td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 			<tr> | ||||
| 				<td><input id="border_color_bottom" name="border_color_bottom" type="text" value="" size="9" onChange="updateColor('border_color_bottom_pick','border_color_bottom');" disabled="disabled" /></td> | ||||
| 				<td id="border_color_bottom_pickcontainer"> </td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| </tr> | ||||
|  | ||||
| <tr> | ||||
| 	<td>{#style_dlg.left}</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td><select id="border_style_left" name="border_style_left" class="mceEditableSelect" disabled="disabled"></select></td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 			<tr> | ||||
| 				<td><select id="border_width_left" name="border_width_left" class="mceEditableSelect" disabled="disabled"></select></td> | ||||
| 				<td> </td> | ||||
| 				<td><select id="border_width_left_measurement" name="border_width_left_measurement" disabled="disabled"></select></td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| 	<td class="delim"> </td> | ||||
| 	<td> | ||||
| 		<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 			<tr> | ||||
| 				<td><input id="border_color_left" name="border_color_left" type="text" value="" size="9" onChange="updateColor('border_color_left_pick','border_color_left');" disabled="disabled" /></td> | ||||
| 				<td id="border_color_left_pickcontainer"> </td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</td> | ||||
| </tr> | ||||
| </table> | ||||
| </div> | ||||
|  | ||||
| <div id="list_panel" class="panel"> | ||||
| 	<table border="0"> | ||||
| 		<tr> | ||||
| 			<td><label for="list_type">{#style_dlg.list_type}</label></td> | ||||
| 			<td><select id="list_type" name="list_type" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="list_bullet_image">{#style_dlg.bullet_image}</label></td> | ||||
| 			<td><input id="list_bullet_image" name="list_bullet_image" type="text" /></td> | ||||
| 		</tr> | ||||
|  | ||||
| 		<tr> | ||||
| 			<td><label for="list_position">{#style_dlg.position}</label></td> | ||||
| 			<td><select id="list_position" name="list_position" class="mceEditableSelect"></select></td> | ||||
| 		</tr> | ||||
| 	</table> | ||||
| </div> | ||||
|  | ||||
| <div id="positioning_panel" class="panel"> | ||||
| <table border="0"> | ||||
| 	<tr> | ||||
| 		<td><label for="positioning_type">{#style_dlg.positioning_type}</label></td> | ||||
| 		<td><select id="positioning_type" name="positioning_type" class="mceEditableSelect"></select></td> | ||||
| 		<td>   <label for="positioning_visibility">{#style_dlg.visibility}</label></td> | ||||
| 		<td><select id="positioning_visibility" name="positioning_visibility" class="mceEditableSelect"></select></td> | ||||
| 	</tr> | ||||
|  | ||||
| 	<tr> | ||||
| 		<td><label for="positioning_width">{#style_dlg.width}</label></td> | ||||
| 		<td> | ||||
| 			<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 				<tr> | ||||
| 					<td><input type="text" id="positioning_width" name="positioning_width" onChange="synch('positioning_width','box_width');" /></td> | ||||
| 					<td> </td> | ||||
| 					<td><select id="positioning_width_measurement" name="positioning_width_measurement"></select></td> | ||||
| 				</tr> | ||||
| 			</table> | ||||
| 		</td> | ||||
| 		<td>   <label for="positioning_zindex">{#style_dlg.zindex}</label></td> | ||||
| 		<td><input type="text" id="positioning_zindex" name="positioning_zindex" /></td> | ||||
| 	</tr> | ||||
|  | ||||
| 	<tr> | ||||
| 		<td><label for="positioning_height">{#style_dlg.height}</label></td> | ||||
| 		<td> | ||||
| 			<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 				<tr> | ||||
| 					<td><input type="text" id="positioning_height" name="positioning_height" onChange="synch('positioning_height','box_height');" /></td> | ||||
| 					<td> </td> | ||||
| 					<td><select id="positioning_height_measurement" name="positioning_height_measurement"></select></td> | ||||
| 				</tr> | ||||
| 			</table> | ||||
| 		</td> | ||||
| 		<td>   <label for="positioning_overflow">{#style_dlg.overflow}</label></td> | ||||
| 		<td><select id="positioning_overflow" name="positioning_overflow" class="mceEditableSelect"></select></td> | ||||
| 	</tr> | ||||
| </table> | ||||
|  | ||||
| <div style="float: left; width: 49%"> | ||||
| 	<fieldset> | ||||
| 		<legend>{#style_dlg.placement}</legend> | ||||
|  | ||||
| 		<table border="0"> | ||||
| 			<tr> | ||||
| 				<td> </td> | ||||
| 				<td><input type="checkbox" id="positioning_placement_same" name="positioning_placement_same" class="checkbox" checked="checked" onClick="toggleSame(this,'positioning_placement');" /> <label for="positioning_placement_same">{#style_dlg.same}</label></td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.top}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_placement_top" name="positioning_placement_top" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_placement_top_measurement" name="positioning_placement_top_measurement"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.right}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_placement_right" name="positioning_placement_right" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_placement_right_measurement" name="positioning_placement_right_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.bottom}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_placement_bottom" name="positioning_placement_bottom" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_placement_bottom_measurement" name="positioning_placement_bottom_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.left}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_placement_left" name="positioning_placement_left" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_placement_left_measurement" name="positioning_placement_left_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</fieldset> | ||||
| </div> | ||||
|  | ||||
| <div style="float: right; width: 49%"> | ||||
| 	<fieldset> | ||||
| 		<legend>{#style_dlg.clip}</legend> | ||||
|  | ||||
| 		<table border="0"> | ||||
| 			<tr> | ||||
| 				<td> </td> | ||||
| 				<td><input type="checkbox" id="positioning_clip_same" name="positioning_clip_same" class="checkbox" checked="checked" onClick="toggleSame(this,'positioning_clip');" /> <label for="positioning_clip_same">{#style_dlg.same}</label></td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.top}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_clip_top" name="positioning_clip_top" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_clip_top_measurement" name="positioning_clip_top_measurement"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.right}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_clip_right" name="positioning_clip_right" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_clip_right_measurement" name="positioning_clip_right_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.bottom}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_clip_bottom" name="positioning_clip_bottom" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_clip_bottom_measurement" name="positioning_clip_bottom_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 			<tr> | ||||
| 				<td>{#style_dlg.left}</td> | ||||
| 				<td> | ||||
| 					<table border="0" cellspacing="0" cellpadding="0"> | ||||
| 						<tr> | ||||
| 							<td><input type="text" id="positioning_clip_left" name="positioning_clip_left" disabled="disabled" /></td> | ||||
| 							<td> </td> | ||||
| 							<td><select id="positioning_clip_left_measurement" name="positioning_clip_left_measurement" disabled="disabled"></select></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</td> | ||||
| 			</tr> | ||||
| 		</table> | ||||
| 	</fieldset> | ||||
| </div> | ||||
| <br style="clear: both" /> | ||||
| </div> | ||||
| </div> | ||||
|  | ||||
| <div class="mceActionPanel"> | ||||
| 	<div style="float: left"> | ||||
| 		<div style="float: left"><input type="submit" id="insert" name="insert" value="{#update}" /></div> | ||||
|  | ||||
| 		<div style="float: left"> <input type="button" class="button" id="apply" name="apply" value="{#style_dlg.apply}" onClick="applyAction();" /></div> | ||||
| 		<br style="clear: both" /> | ||||
| 	</div> | ||||
|  | ||||
| 	<div style="float: right"> | ||||
| 		<input type="button" id="cancel" name="cancel" value="{#cancel}" onClick="tinyMCEPopup.close();" /> | ||||
| 	</div> | ||||
| </div> | ||||
| </form> | ||||
|  | ||||
| <div style="display: none"> | ||||
| 	<div id="container"></div> | ||||
| </div> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,184 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#table_dlg.cell_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||||
| 	<script type="text/javascript" src="js/cell.js"></script> | ||||
| 	<link href="css/cell.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="tablecell" style="display: none"> | ||||
| 	<form onsubmit="updateAction();return false;" action="#"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#table_dlg.general_tab}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#table_dlg.advanced_tab}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#table_dlg.general_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td><label for="align">{#table_dlg.align}</label></td> | ||||
| 							<td> | ||||
| 								<select id="align" name="align" class="mceFocus"> | ||||
| 									<option value="">{#not_set}</option> | ||||
| 									<option value="center">{#table_dlg.align_middle}</option> | ||||
| 									<option value="left">{#table_dlg.align_left}</option> | ||||
| 									<option value="right">{#table_dlg.align_right}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 		 | ||||
| 							<td><label for="celltype">{#table_dlg.cell_type}</label></td> | ||||
| 							<td> | ||||
| 								<select id="celltype" name="celltype"> | ||||
| 									<option value="td">{#table_dlg.td}</option> | ||||
| 									<option value="th">{#table_dlg.th}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="valign">{#table_dlg.valign}</label></td> | ||||
| 							<td> | ||||
| 								<select id="valign" name="valign"> | ||||
| 									<option value="">{#not_set}</option> | ||||
| 									<option value="top">{#table_dlg.align_top}</option> | ||||
| 									<option value="middle">{#table_dlg.align_middle}</option> | ||||
| 									<option value="bottom">{#table_dlg.align_bottom}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 							<td><label for="scope">{#table_dlg.scope}</label></td> | ||||
| 							<td> | ||||
| 								<select id="scope" name="scope"> | ||||
| 									<option value="">{#not_set}</option> | ||||
| 									<option value="col">{#table.col}</option> | ||||
| 									<option value="row">{#table.row}</option> | ||||
| 									<option value="rowgroup">{#table_dlg.rowgroup}</option> | ||||
| 									<option value="colgroup">{#table_dlg.colgroup}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
|  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="width">{#table_dlg.width}</label></td> | ||||
| 							<td><input id="width" name="width" type="text" value="" size="4" maxlength="4" onchange="changedSize();" /></td> | ||||
|  | ||||
| 							<td><label for="height">{#table_dlg.height}</label></td> | ||||
| 							<td><input id="height" name="height" type="text" value="" size="4" maxlength="4" onchange="changedSize();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr id="styleSelectRow"> | ||||
| 							<td><label for="class">{#class_name}</label></td> | ||||
| 							<td colspan="3"> | ||||
| 								<select id="class" name="class" class="mceEditableSelect"> | ||||
| 									<option value="" selected="selected">{#not_set}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#table_dlg.advanced_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="id">{#table_dlg.id}</label></td>  | ||||
| 							<td><input id="id" name="id" type="text" value="" style="width: 200px" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="style">{#table_dlg.style}</label></td> | ||||
| 							<td><input type="text" id="style" name="style" value="" style="width: 200px;" onchange="changedStyle();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="dir">{#table_dlg.langdir}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="dir" name="dir" style="width: 200px">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="ltr">{#table_dlg.ltr}</option>  | ||||
| 										<option value="rtl">{#table_dlg.rtl}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="lang">{#table_dlg.langcode}</label></td>  | ||||
| 							<td> | ||||
| 								<input id="lang" name="lang" type="text" value="" style="width: 200px" /> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="backgroundimage">{#table_dlg.bgimage}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="backgroundimage" name="backgroundimage" type="text" value="" style="width: 200px" onchange="changedBackgroundImage();" /></td> | ||||
| 										<td id="backgroundimagebrowsercontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bordercolor">{#table_dlg.bordercolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bordercolor" name="bordercolor" type="text" value="" size="9" onchange="updateColor('bordercolor_pick','bordercolor');changedColor();" /></td> | ||||
| 										<td id="bordercolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bgcolor">{#table_dlg.bgcolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedColor();" /></td> | ||||
| 										<td id="bgcolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div> | ||||
| 				<select id="action" name="action"> | ||||
| 					<option value="cell">{#table_dlg.cell_cell}</option> | ||||
| 					<option value="row">{#table_dlg.cell_row}</option> | ||||
| 					<option value="all">{#table_dlg.cell_all}</option> | ||||
| 				</select> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: left"> | ||||
| 				<div><input type="submit" id="insert" name="insert" value="{#update}" /></div> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,259 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var ed; | ||||
|  | ||||
| function init() { | ||||
| 	ed = tinyMCEPopup.editor; | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||||
| 	document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor'); | ||||
| 	document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor') | ||||
|  | ||||
| 	var inst = ed; | ||||
| 	var tdElm = ed.dom.getParent(ed.selection.getNode(), "td,th"); | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = ed.dom.parseStyle(ed.dom.getAttrib(tdElm, "style")); | ||||
|  | ||||
| 	// Get table cell data | ||||
| 	var celltype = tdElm.nodeName.toLowerCase(); | ||||
| 	var align = ed.dom.getAttrib(tdElm, 'align'); | ||||
| 	var valign = ed.dom.getAttrib(tdElm, 'valign'); | ||||
| 	var width = trimSize(getStyle(tdElm, 'width', 'width')); | ||||
| 	var height = trimSize(getStyle(tdElm, 'height', 'height')); | ||||
| 	var bordercolor = convertRGBToHex(getStyle(tdElm, 'bordercolor', 'borderLeftColor')); | ||||
| 	var bgcolor = convertRGBToHex(getStyle(tdElm, 'bgcolor', 'backgroundColor')); | ||||
| 	var className = ed.dom.getAttrib(tdElm, 'class'); | ||||
| 	var backgroundimage = getStyle(tdElm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");; | ||||
| 	var id = ed.dom.getAttrib(tdElm, 'id'); | ||||
| 	var lang = ed.dom.getAttrib(tdElm, 'lang'); | ||||
| 	var dir = ed.dom.getAttrib(tdElm, 'dir'); | ||||
| 	var scope = ed.dom.getAttrib(tdElm, 'scope'); | ||||
|  | ||||
| 	// Setup form | ||||
| 	addClassesToList('class', 'table_cell_styles'); | ||||
| 	TinyMCE_EditableSelects.init(); | ||||
|  | ||||
| 	formObj.bordercolor.value = bordercolor; | ||||
| 	formObj.bgcolor.value = bgcolor; | ||||
| 	formObj.backgroundimage.value = backgroundimage; | ||||
| 	formObj.width.value = width; | ||||
| 	formObj.height.value = height; | ||||
| 	formObj.id.value = id; | ||||
| 	formObj.lang.value = lang; | ||||
| 	formObj.style.value = ed.dom.serializeStyle(st); | ||||
| 	selectByValue(formObj, 'align', align); | ||||
| 	selectByValue(formObj, 'valign', valign); | ||||
| 	selectByValue(formObj, 'class', className, true, true); | ||||
| 	selectByValue(formObj, 'celltype', celltype); | ||||
| 	selectByValue(formObj, 'dir', dir); | ||||
| 	selectByValue(formObj, 'scope', scope); | ||||
|  | ||||
| 	// Resize some elements | ||||
| 	if (isVisible('backgroundimagebrowser')) | ||||
| 		document.getElementById('backgroundimage').style.width = '180px'; | ||||
|  | ||||
| 	updateColor('bordercolor_pick', 'bordercolor'); | ||||
| 	updateColor('bgcolor_pick', 'bgcolor'); | ||||
| } | ||||
|  | ||||
| function updateAction() { | ||||
| 	var el, inst = ed, tdElm, trElm, tableElm, formObj = document.forms[0]; | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
| 	el = ed.selection.getNode(); | ||||
| 	tdElm = ed.dom.getParent(el, "td,th"); | ||||
| 	trElm = ed.dom.getParent(el, "tr"); | ||||
| 	tableElm = ed.dom.getParent(el, "table"); | ||||
|  | ||||
| 	ed.execCommand('mceBeginUndoLevel'); | ||||
|  | ||||
| 	switch (getSelectValue(formObj, 'action')) { | ||||
| 		case "cell": | ||||
| 			var celltype = getSelectValue(formObj, 'celltype'); | ||||
| 			var scope = getSelectValue(formObj, 'scope'); | ||||
|  | ||||
| 			if (ed.getParam("accessibility_warnings")) { | ||||
| 				if (celltype == "th" && scope == "") | ||||
| 					var answer = confirm(ed.getLang('table_dlg.missing_scope', '', true)); | ||||
| 				else | ||||
| 					var answer = true; | ||||
|  | ||||
| 				if (!answer) | ||||
| 					return; | ||||
| 			} | ||||
|  | ||||
| 			updateCell(tdElm); | ||||
| 			break; | ||||
|  | ||||
| 		case "row": | ||||
| 			var cell = trElm.firstChild; | ||||
|  | ||||
| 			if (cell.nodeName != "TD" && cell.nodeName != "TH") | ||||
| 				cell = nextCell(cell); | ||||
|  | ||||
| 			do { | ||||
| 				cell = updateCell(cell, true); | ||||
| 			} while ((cell = nextCell(cell)) != null); | ||||
|  | ||||
| 			break; | ||||
|  | ||||
| 		case "all": | ||||
| 			var rows = tableElm.getElementsByTagName("tr"); | ||||
|  | ||||
| 			for (var i=0; i<rows.length; i++) { | ||||
| 				var cell = rows[i].firstChild; | ||||
|  | ||||
| 				if (cell.nodeName != "TD" && cell.nodeName != "TH") | ||||
| 					cell = nextCell(cell); | ||||
|  | ||||
| 				do { | ||||
| 					cell = updateCell(cell, true); | ||||
| 				} while ((cell = nextCell(cell)) != null); | ||||
| 			} | ||||
|  | ||||
| 			break; | ||||
| 	} | ||||
|  | ||||
| 	ed.addVisual(); | ||||
| 	ed.nodeChanged(); | ||||
| 	inst.execCommand('mceEndUndoLevel'); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function nextCell(elm) { | ||||
| 	while ((elm = elm.nextSibling) != null) { | ||||
| 		if (elm.nodeName == "TD" || elm.nodeName == "TH") | ||||
| 			return elm; | ||||
| 	} | ||||
|  | ||||
| 	return null; | ||||
| } | ||||
|  | ||||
| function updateCell(td, skip_id) { | ||||
| 	var inst = ed; | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var curCellType = td.nodeName.toLowerCase(); | ||||
| 	var celltype = getSelectValue(formObj, 'celltype'); | ||||
| 	var doc = inst.getDoc(); | ||||
| 	var dom = ed.dom; | ||||
|  | ||||
| 	if (!skip_id) | ||||
| 		td.setAttribute('id', formObj.id.value); | ||||
|  | ||||
| 	td.setAttribute('align', formObj.align.value); | ||||
| 	td.setAttribute('vAlign', formObj.valign.value); | ||||
| 	td.setAttribute('lang', formObj.lang.value); | ||||
| 	td.setAttribute('dir', getSelectValue(formObj, 'dir')); | ||||
| 	td.setAttribute('style', ed.dom.serializeStyle(ed.dom.parseStyle(formObj.style.value))); | ||||
| 	td.setAttribute('scope', formObj.scope.value); | ||||
| 	ed.dom.setAttrib(td, 'class', getSelectValue(formObj, 'class')); | ||||
|  | ||||
| 	// Clear deprecated attributes | ||||
| 	ed.dom.setAttrib(td, 'width', ''); | ||||
| 	ed.dom.setAttrib(td, 'height', ''); | ||||
| 	ed.dom.setAttrib(td, 'bgColor', ''); | ||||
| 	ed.dom.setAttrib(td, 'borderColor', ''); | ||||
| 	ed.dom.setAttrib(td, 'background', ''); | ||||
|  | ||||
| 	// Set styles | ||||
| 	td.style.width = getCSSSize(formObj.width.value); | ||||
| 	td.style.height = getCSSSize(formObj.height.value); | ||||
| 	if (formObj.bordercolor.value != "") { | ||||
| 		td.style.borderColor = formObj.bordercolor.value; | ||||
| 		td.style.borderStyle = td.style.borderStyle == "" ? "solid" : td.style.borderStyle; | ||||
| 		td.style.borderWidth = td.style.borderWidth == "" ? "1px" : td.style.borderWidth; | ||||
| 	} else | ||||
| 		td.style.borderColor = ''; | ||||
|  | ||||
| 	td.style.backgroundColor = formObj.bgcolor.value; | ||||
|  | ||||
| 	if (formObj.backgroundimage.value != "") | ||||
| 		td.style.backgroundImage = "url('" + formObj.backgroundimage.value + "')"; | ||||
| 	else | ||||
| 		td.style.backgroundImage = ''; | ||||
|  | ||||
| 	if (curCellType != celltype) { | ||||
| 		// changing to a different node type | ||||
| 		var newCell = doc.createElement(celltype); | ||||
|  | ||||
| 		for (var c=0; c<td.childNodes.length; c++) | ||||
| 			newCell.appendChild(td.childNodes[c].cloneNode(1)); | ||||
|  | ||||
| 		for (var a=0; a<td.attributes.length; a++) | ||||
| 			ed.dom.setAttrib(newCell, td.attributes[a].name, ed.dom.getAttrib(td, td.attributes[a].name)); | ||||
|  | ||||
| 		td.parentNode.replaceChild(newCell, td); | ||||
| 		td = newCell; | ||||
| 	} | ||||
|  | ||||
| 	dom.setAttrib(td, 'style', dom.serializeStyle(dom.parseStyle(td.style.cssText))); | ||||
|  | ||||
| 	return td; | ||||
| } | ||||
|  | ||||
| function changedBackgroundImage() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = ed.dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	st['background-image'] = "url('" + formObj.backgroundimage.value + "')"; | ||||
|  | ||||
| 	formObj.style.value = ed.dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedSize() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = ed.dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	var width = formObj.width.value; | ||||
| 	if (width != "") | ||||
| 		st['width'] = getCSSSize(width); | ||||
| 	else | ||||
| 		st['width'] = ""; | ||||
|  | ||||
| 	var height = formObj.height.value; | ||||
| 	if (height != "") | ||||
| 		st['height'] = getCSSSize(height); | ||||
| 	else | ||||
| 		st['height'] = ""; | ||||
|  | ||||
| 	formObj.style.value = ed.dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedColor() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = ed.dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	st['background-color'] = formObj.bgcolor.value; | ||||
| 	st['border-color'] = formObj.bordercolor.value; | ||||
|  | ||||
| 	formObj.style.value = ed.dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedStyle() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = ed.dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	if (st['background-image']) | ||||
| 		formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
| 	else | ||||
| 		formObj.backgroundimage.value = ''; | ||||
|  | ||||
| 	if (st['width']) | ||||
| 		formObj.width.value = trimSize(st['width']); | ||||
|  | ||||
| 	if (st['height']) | ||||
| 		formObj.height.value = trimSize(st['height']); | ||||
|  | ||||
| 	if (st['background-color']) { | ||||
| 		formObj.bgcolor.value = st['background-color']; | ||||
| 		updateColor('bgcolor_pick','bgcolor'); | ||||
| 	} | ||||
|  | ||||
| 	if (st['border-color']) { | ||||
| 		formObj.bordercolor.value = st['border-color']; | ||||
| 		updateColor('bordercolor_pick','bordercolor'); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,29 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| function init() { | ||||
| 	var f = document.forms[0], v; | ||||
|  | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	f.numcols.value = tinyMCEPopup.getWindowArg('numcols', 1); | ||||
| 	f.numrows.value = tinyMCEPopup.getWindowArg('numrows', 1); | ||||
| } | ||||
|  | ||||
| function mergeCells() { | ||||
| 	var args = [], f = document.forms[0]; | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 	if (!AutoValidator.validate(f)) { | ||||
| 		alert(tinyMCEPopup.getLang('invalid_data')); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	args["numcols"] = f.numcols.value; | ||||
| 	args["numrows"] = f.numrows.value; | ||||
|  | ||||
| 	tinyMCEPopup.execCommand("mceTableMergeCells", false, args); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,212 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| function init() { | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||||
| 	document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor'); | ||||
|  | ||||
| 	var inst = tinyMCEPopup.editor; | ||||
| 	var dom = inst.dom; | ||||
| 	var trElm = dom.getParent(inst.selection.getNode(), "tr"); | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = dom.parseStyle(dom.getAttrib(trElm, "style")); | ||||
|  | ||||
| 	// Get table row data | ||||
| 	var rowtype = trElm.parentNode.nodeName.toLowerCase(); | ||||
| 	var align = dom.getAttrib(trElm, 'align'); | ||||
| 	var valign = dom.getAttrib(trElm, 'valign'); | ||||
| 	var height = trimSize(getStyle(trElm, 'height', 'height')); | ||||
| 	var className = dom.getAttrib(trElm, 'class'); | ||||
| 	var bgcolor = convertRGBToHex(getStyle(trElm, 'bgcolor', 'backgroundColor')); | ||||
| 	var backgroundimage = getStyle(trElm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");; | ||||
| 	var id = dom.getAttrib(trElm, 'id'); | ||||
| 	var lang = dom.getAttrib(trElm, 'lang'); | ||||
| 	var dir = dom.getAttrib(trElm, 'dir'); | ||||
|  | ||||
| 	// Setup form | ||||
| 	addClassesToList('class', 'table_row_styles'); | ||||
| 	TinyMCE_EditableSelects.init(); | ||||
|  | ||||
| 	formObj.bgcolor.value = bgcolor; | ||||
| 	formObj.backgroundimage.value = backgroundimage; | ||||
| 	formObj.height.value = height; | ||||
| 	formObj.id.value = id; | ||||
| 	formObj.lang.value = lang; | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| 	selectByValue(formObj, 'align', align); | ||||
| 	selectByValue(formObj, 'valign', valign); | ||||
| 	selectByValue(formObj, 'class', className, true, true); | ||||
| 	selectByValue(formObj, 'rowtype', rowtype); | ||||
| 	selectByValue(formObj, 'dir', dir); | ||||
|  | ||||
| 	// Resize some elements | ||||
| 	if (isVisible('backgroundimagebrowser')) | ||||
| 		document.getElementById('backgroundimage').style.width = '180px'; | ||||
|  | ||||
| 	updateColor('bgcolor_pick', 'bgcolor'); | ||||
| } | ||||
|  | ||||
| function updateAction() { | ||||
| 	var inst = tinyMCEPopup.editor, dom = inst.dom, trElm, tableElm, formObj = document.forms[0]; | ||||
| 	var action = getSelectValue(formObj, 'action'); | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
| 	trElm = dom.getParent(inst.selection.getNode(), "tr"); | ||||
| 	tableElm = dom.getParent(inst.selection.getNode(), "table"); | ||||
|  | ||||
| 	inst.execCommand('mceBeginUndoLevel'); | ||||
|  | ||||
| 	switch (action) { | ||||
| 		case "row": | ||||
| 			updateRow(trElm); | ||||
| 			break; | ||||
|  | ||||
| 		case "all": | ||||
| 			var rows = tableElm.getElementsByTagName("tr"); | ||||
|  | ||||
| 			for (var i=0; i<rows.length; i++) | ||||
| 				updateRow(rows[i], true); | ||||
|  | ||||
| 			break; | ||||
|  | ||||
| 		case "odd": | ||||
| 		case "even": | ||||
| 			var rows = tableElm.getElementsByTagName("tr"); | ||||
|  | ||||
| 			for (var i=0; i<rows.length; i++) { | ||||
| 				if ((i % 2 == 0 && action == "odd") || (i % 2 != 0 && action == "even")) | ||||
| 					updateRow(rows[i], true, true); | ||||
| 			} | ||||
|  | ||||
| 			break; | ||||
| 	} | ||||
|  | ||||
| 	inst.addVisual(); | ||||
| 	inst.nodeChanged(); | ||||
| 	inst.execCommand('mceEndUndoLevel'); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function updateRow(tr_elm, skip_id, skip_parent) { | ||||
| 	var inst = tinyMCEPopup.editor; | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var dom = inst.dom; | ||||
| 	var curRowType = tr_elm.parentNode.nodeName.toLowerCase(); | ||||
| 	var rowtype = getSelectValue(formObj, 'rowtype'); | ||||
| 	var doc = inst.getDoc(); | ||||
|  | ||||
| 	// Update row element | ||||
| 	if (!skip_id) | ||||
| 		tr_elm.setAttribute('id', formObj.id.value); | ||||
|  | ||||
| 	tr_elm.setAttribute('align', getSelectValue(formObj, 'align')); | ||||
| 	tr_elm.setAttribute('vAlign', getSelectValue(formObj, 'valign')); | ||||
| 	tr_elm.setAttribute('lang', formObj.lang.value); | ||||
| 	tr_elm.setAttribute('dir', getSelectValue(formObj, 'dir')); | ||||
| 	tr_elm.setAttribute('style', dom.serializeStyle(dom.parseStyle(formObj.style.value))); | ||||
| 	dom.setAttrib(tr_elm, 'class', getSelectValue(formObj, 'class')); | ||||
|  | ||||
| 	// Clear deprecated attributes | ||||
| 	tr_elm.setAttribute('background', ''); | ||||
| 	tr_elm.setAttribute('bgColor', ''); | ||||
| 	tr_elm.setAttribute('height', ''); | ||||
|  | ||||
| 	// Set styles | ||||
| 	tr_elm.style.height = getCSSSize(formObj.height.value); | ||||
| 	tr_elm.style.backgroundColor = formObj.bgcolor.value; | ||||
|  | ||||
| 	if (formObj.backgroundimage.value != "") | ||||
| 		tr_elm.style.backgroundImage = "url('" + formObj.backgroundimage.value + "')"; | ||||
| 	else | ||||
| 		tr_elm.style.backgroundImage = ''; | ||||
|  | ||||
| 	// Setup new rowtype | ||||
| 	if (curRowType != rowtype && !skip_parent) { | ||||
| 		// first, clone the node we are working on | ||||
| 		var newRow = tr_elm.cloneNode(1); | ||||
|  | ||||
| 		// next, find the parent of its new destination (creating it if necessary) | ||||
| 		var theTable = dom.getParent(tr_elm, "table"); | ||||
| 		var dest = rowtype; | ||||
| 		var newParent = null; | ||||
| 		for (var i = 0; i < theTable.childNodes.length; i++) { | ||||
| 			if (theTable.childNodes[i].nodeName.toLowerCase() == dest) | ||||
| 				newParent = theTable.childNodes[i]; | ||||
| 		} | ||||
|  | ||||
| 		if (newParent == null) { | ||||
| 			newParent = doc.createElement(dest); | ||||
|  | ||||
| 			if (dest == "thead") { | ||||
| 				if (theTable.firstChild.nodeName == 'CAPTION') | ||||
| 					inst.dom.insertAfter(newParent, theTable.firstChild); | ||||
| 				else | ||||
| 					theTable.insertBefore(newParent, theTable.firstChild); | ||||
| 			} else | ||||
| 				theTable.appendChild(newParent); | ||||
| 		} | ||||
|  | ||||
| 		// append the row to the new parent | ||||
| 		newParent.appendChild(newRow); | ||||
|  | ||||
| 		// remove the original | ||||
| 		tr_elm.parentNode.removeChild(tr_elm); | ||||
|  | ||||
| 		// set tr_elm to the new node | ||||
| 		tr_elm = newRow; | ||||
| 	} | ||||
|  | ||||
| 	dom.setAttrib(tr_elm, 'style', dom.serializeStyle(dom.parseStyle(tr_elm.style.cssText))); | ||||
| } | ||||
|  | ||||
| function changedBackgroundImage() { | ||||
| 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	st['background-image'] = "url('" + formObj.backgroundimage.value + "')"; | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedStyle() { | ||||
| 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	if (st['background-image']) | ||||
| 		formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
| 	else | ||||
| 		formObj.backgroundimage.value = ''; | ||||
|  | ||||
| 	if (st['height']) | ||||
| 		formObj.height.value = trimSize(st['height']); | ||||
|  | ||||
| 	if (st['background-color']) { | ||||
| 		formObj.bgcolor.value = st['background-color']; | ||||
| 		updateColor('bgcolor_pick','bgcolor'); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function changedSize() { | ||||
| 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	var height = formObj.height.value; | ||||
| 	if (height != "") | ||||
| 		st['height'] = getCSSSize(height); | ||||
| 	else | ||||
| 		st['height'] = ""; | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedColor() { | ||||
| 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	st['background-color'] = formObj.bgcolor.value; | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,410 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var action, orgTableWidth, orgTableHeight, dom = tinyMCEPopup.editor.dom; | ||||
|  | ||||
| function insertTable() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var inst = tinyMCEPopup.editor, dom = inst.dom; | ||||
| 	var cols = 2, rows = 2, border = 0, cellpadding = -1, cellspacing = -1, align, width, height, className, caption, frame, rules; | ||||
| 	var html = '', capEl, elm; | ||||
| 	var cellLimit, rowLimit, colLimit; | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 	if (!AutoValidator.validate(formObj)) { | ||||
| 		alert(inst.getLang('invalid_data')); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	elm = dom.getParent(inst.selection.getNode(), 'table'); | ||||
|  | ||||
| 	// Get form data | ||||
| 	cols = formObj.elements['cols'].value; | ||||
| 	rows = formObj.elements['rows'].value; | ||||
| 	border = formObj.elements['border'].value != "" ? formObj.elements['border'].value  : 0; | ||||
| 	cellpadding = formObj.elements['cellpadding'].value != "" ? formObj.elements['cellpadding'].value : ""; | ||||
| 	cellspacing = formObj.elements['cellspacing'].value != "" ? formObj.elements['cellspacing'].value : ""; | ||||
| 	align = formObj.elements['align'].options[formObj.elements['align'].selectedIndex].value; | ||||
| 	frame = formObj.elements['frame'].options[formObj.elements['frame'].selectedIndex].value; | ||||
| 	rules = formObj.elements['rules'].options[formObj.elements['rules'].selectedIndex].value; | ||||
| 	width = formObj.elements['width'].value; | ||||
| 	height = formObj.elements['height'].value; | ||||
| 	bordercolor = formObj.elements['bordercolor'].value; | ||||
| 	bgcolor = formObj.elements['bgcolor'].value; | ||||
| 	className = formObj.elements['class'].options[formObj.elements['class'].selectedIndex].value; | ||||
| 	id = formObj.elements['id'].value; | ||||
| 	summary = formObj.elements['summary'].value; | ||||
| 	style = formObj.elements['style'].value; | ||||
| 	dir = formObj.elements['dir'].value; | ||||
| 	lang = formObj.elements['lang'].value; | ||||
| 	background = formObj.elements['backgroundimage'].value; | ||||
| 	caption = formObj.elements['caption'].checked; | ||||
|  | ||||
| 	cellLimit = tinyMCEPopup.getParam('table_cell_limit', false); | ||||
| 	rowLimit = tinyMCEPopup.getParam('table_row_limit', false); | ||||
| 	colLimit = tinyMCEPopup.getParam('table_col_limit', false); | ||||
|  | ||||
| 	// Validate table size | ||||
| 	if (colLimit && cols > colLimit) { | ||||
| 		inst.windowManager.alert(inst.getLang('table_dlg.col_limit').replace(/\{\$cols\}/g, colLimit)); | ||||
| 		return false; | ||||
| 	} else if (rowLimit && rows > rowLimit) { | ||||
| 		inst.windowManager.alert(inst.getLang('table_dlg.row_limit').replace(/\{\$rows\}/g, rowLimit)); | ||||
| 		return false; | ||||
| 	} else if (cellLimit && cols * rows > cellLimit) { | ||||
| 		inst.windowManager.alert(inst.getLang('table_dlg.cell_limit').replace(/\{\$cells\}/g, cellLimit)); | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	// Update table | ||||
| 	if (action == "update") { | ||||
| 		inst.execCommand('mceBeginUndoLevel'); | ||||
|  | ||||
| 		dom.setAttrib(elm, 'cellPadding', cellpadding, true); | ||||
| 		dom.setAttrib(elm, 'cellSpacing', cellspacing, true); | ||||
| 		dom.setAttrib(elm, 'border', border); | ||||
| 		dom.setAttrib(elm, 'align', align); | ||||
| 		dom.setAttrib(elm, 'frame', frame); | ||||
| 		dom.setAttrib(elm, 'rules', rules); | ||||
| 		dom.setAttrib(elm, 'class', className); | ||||
| 		dom.setAttrib(elm, 'style', style); | ||||
| 		dom.setAttrib(elm, 'id', id); | ||||
| 		dom.setAttrib(elm, 'summary', summary); | ||||
| 		dom.setAttrib(elm, 'dir', dir); | ||||
| 		dom.setAttrib(elm, 'lang', lang); | ||||
|  | ||||
| 		capEl = inst.dom.select('caption', elm)[0]; | ||||
|  | ||||
| 		if (capEl && !caption) | ||||
| 			capEl.parentNode.removeChild(capEl); | ||||
|  | ||||
| 		if (!capEl && caption) { | ||||
| 			capEl = elm.ownerDocument.createElement('caption'); | ||||
|  | ||||
| 			if (!tinymce.isIE) | ||||
| 				capEl.innerHTML = '<br mce_bogus="1"/>'; | ||||
|  | ||||
| 			elm.insertBefore(capEl, elm.firstChild); | ||||
| 		} | ||||
|  | ||||
| 		if (width && /(pt|em|cm)$/.test(width)) { | ||||
| 			dom.setStyle(elm, 'width', width); | ||||
| 			dom.setAttrib(elm, 'width', ''); | ||||
| 		} else { | ||||
| 			dom.setAttrib(elm, 'width', width, true); | ||||
| 			dom.setStyle(elm, 'width', ''); | ||||
| 		} | ||||
|  | ||||
| 		// Remove these since they are not valid XHTML | ||||
| 		dom.setAttrib(elm, 'borderColor', ''); | ||||
| 		dom.setAttrib(elm, 'bgColor', ''); | ||||
| 		dom.setAttrib(elm, 'background', ''); | ||||
|  | ||||
| 		if (height) { | ||||
| 			dom.setStyle(elm, 'height', height); | ||||
| 			dom.setAttrib(elm, 'height', ''); | ||||
| 		} | ||||
|  | ||||
| 		if (background != '') | ||||
| 			elm.style.backgroundImage = "url('" + background + "')"; | ||||
| 		else | ||||
| 			elm.style.backgroundImage = ''; | ||||
|  | ||||
| /*		if (tinyMCEPopup.getParam("inline_styles")) { | ||||
| 			if (width != '') | ||||
| 				elm.style.width = getCSSSize(width); | ||||
| 		}*/ | ||||
|  | ||||
| 		if (bordercolor != "") { | ||||
| 			elm.style.borderColor = bordercolor; | ||||
| 			elm.style.borderStyle = elm.style.borderStyle == "" ? "solid" : elm.style.borderStyle; | ||||
| 			elm.style.borderWidth = border == "" ? "1px" : border; | ||||
| 		} else | ||||
| 			elm.style.borderColor = ''; | ||||
|  | ||||
| 		elm.style.backgroundColor = bgcolor; | ||||
| 		elm.style.height = getCSSSize(height); | ||||
|  | ||||
| 		inst.addVisual(); | ||||
|  | ||||
| 		// Fix for stange MSIE align bug | ||||
| 		//elm.outerHTML = elm.outerHTML; | ||||
|  | ||||
| 		inst.nodeChanged(); | ||||
| 		inst.execCommand('mceEndUndoLevel'); | ||||
|  | ||||
| 		// Repaint if dimensions changed | ||||
| 		if (formObj.width.value != orgTableWidth || formObj.height.value != orgTableHeight) | ||||
| 			inst.execCommand('mceRepaint'); | ||||
|  | ||||
| 		tinyMCEPopup.close(); | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	// Create new table | ||||
| 	html += '<table'; | ||||
|  | ||||
| 	html += makeAttrib('id', id); | ||||
| 	html += makeAttrib('border', border); | ||||
| 	html += makeAttrib('cellpadding', cellpadding); | ||||
| 	html += makeAttrib('cellspacing', cellspacing); | ||||
|  | ||||
| 	if (width && /(pt|em|cm)$/.test(width)) { | ||||
| 		if (style) | ||||
| 			style += '; '; | ||||
|  | ||||
| 		style += 'width: ' + width; | ||||
| 	} else | ||||
| 		html += makeAttrib('width', width); | ||||
|  | ||||
| /*	if (height) { | ||||
| 		if (style) | ||||
| 			style += '; '; | ||||
|  | ||||
| 		style += 'height: ' + height; | ||||
| 	}*/ | ||||
|  | ||||
| 	//html += makeAttrib('height', height); | ||||
| 	//html += makeAttrib('bordercolor', bordercolor); | ||||
| 	//html += makeAttrib('bgcolor', bgcolor); | ||||
| 	html += makeAttrib('align', align); | ||||
| 	html += makeAttrib('frame', frame); | ||||
| 	html += makeAttrib('rules', rules); | ||||
| 	html += makeAttrib('class', className); | ||||
| 	html += makeAttrib('style', style); | ||||
| 	html += makeAttrib('summary', summary); | ||||
| 	html += makeAttrib('dir', dir); | ||||
| 	html += makeAttrib('lang', lang); | ||||
| 	html += '>'; | ||||
|  | ||||
| 	if (caption) { | ||||
| 		if (!tinymce.isIE) | ||||
| 			html += '<caption><br mce_bogus="1"/></caption>'; | ||||
| 		else | ||||
| 			html += '<caption></caption>'; | ||||
| 	} | ||||
|  | ||||
| 	for (var y=0; y<rows; y++) { | ||||
| 		html += "<tr>"; | ||||
|  | ||||
| 		for (var x=0; x<cols; x++) { | ||||
| 			if (!tinymce.isIE) | ||||
| 				html += '<td><br mce_bogus="1"/></td>'; | ||||
| 			else | ||||
| 				html += '<td></td>'; | ||||
| 		} | ||||
|  | ||||
| 		html += "</tr>"; | ||||
| 	} | ||||
|  | ||||
| 	html += "</table>"; | ||||
|  | ||||
| 	inst.execCommand('mceBeginUndoLevel'); | ||||
| 	inst.execCommand('mceInsertContent', false, html); | ||||
| 	inst.addVisual(); | ||||
| 	inst.execCommand('mceEndUndoLevel'); | ||||
|  | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function makeAttrib(attrib, value) { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var valueElm = formObj.elements[attrib]; | ||||
|  | ||||
| 	if (typeof(value) == "undefined" || value == null) { | ||||
| 		value = ""; | ||||
|  | ||||
| 		if (valueElm) | ||||
| 			value = valueElm.value; | ||||
| 	} | ||||
|  | ||||
| 	if (value == "") | ||||
| 		return ""; | ||||
|  | ||||
| 	// XML encode it | ||||
| 	value = value.replace(/&/g, '&'); | ||||
| 	value = value.replace(/\"/g, '"'); | ||||
| 	value = value.replace(/</g, '<'); | ||||
| 	value = value.replace(/>/g, '>'); | ||||
|  | ||||
| 	return ' ' + attrib + '="' + value + '"'; | ||||
| } | ||||
|  | ||||
| function init() { | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||||
| 	document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table'); | ||||
| 	document.getElementById('bordercolor_pickcontainer').innerHTML = getColorPickerHTML('bordercolor_pick','bordercolor'); | ||||
| 	document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor'); | ||||
|  | ||||
| 	var cols = 2, rows = 2, border = tinyMCEPopup.getParam('table_default_border', '0'), cellpadding = tinyMCEPopup.getParam('table_default_cellpadding', ''), cellspacing = tinyMCEPopup.getParam('table_default_cellspacing', ''); | ||||
| 	var align = "", width = "", height = "", bordercolor = "", bgcolor = "", className = ""; | ||||
| 	var id = "", summary = "", style = "", dir = "", lang = "", background = "", bgcolor = "", bordercolor = "", rules, frame; | ||||
| 	var inst = tinyMCEPopup.editor, dom = inst.dom; | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var elm = dom.getParent(inst.selection.getNode(), "table"); | ||||
|  | ||||
| 	action = tinyMCEPopup.getWindowArg('action'); | ||||
|  | ||||
| 	if (!action) | ||||
| 		action = elm ? "update" : "insert"; | ||||
|  | ||||
| 	if (elm && action != "insert") { | ||||
| 		var rowsAr = elm.rows; | ||||
| 		var cols = 0; | ||||
| 		for (var i=0; i<rowsAr.length; i++) | ||||
| 			if (rowsAr[i].cells.length > cols) | ||||
| 				cols = rowsAr[i].cells.length; | ||||
|  | ||||
| 		cols = cols; | ||||
| 		rows = rowsAr.length; | ||||
|  | ||||
| 		st = dom.parseStyle(dom.getAttrib(elm, "style")); | ||||
| 		border = trimSize(getStyle(elm, 'border', 'borderWidth')); | ||||
| 		cellpadding = dom.getAttrib(elm, 'cellpadding', ""); | ||||
| 		cellspacing = dom.getAttrib(elm, 'cellspacing', ""); | ||||
| 		width = trimSize(getStyle(elm, 'width', 'width')); | ||||
| 		height = trimSize(getStyle(elm, 'height', 'height')); | ||||
| 		bordercolor = convertRGBToHex(getStyle(elm, 'bordercolor', 'borderLeftColor')); | ||||
| 		bgcolor = convertRGBToHex(getStyle(elm, 'bgcolor', 'backgroundColor')); | ||||
| 		align = dom.getAttrib(elm, 'align', align); | ||||
| 		frame = dom.getAttrib(elm, 'frame'); | ||||
| 		rules = dom.getAttrib(elm, 'rules'); | ||||
| 		className = tinymce.trim(dom.getAttrib(elm, 'class').replace(/mceItem.+/g, '')); | ||||
| 		id = dom.getAttrib(elm, 'id'); | ||||
| 		summary = dom.getAttrib(elm, 'summary'); | ||||
| 		style = dom.serializeStyle(st); | ||||
| 		dir = dom.getAttrib(elm, 'dir'); | ||||
| 		lang = dom.getAttrib(elm, 'lang'); | ||||
| 		background = getStyle(elm, 'background', 'backgroundImage').replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
| 		formObj.caption.checked = elm.getElementsByTagName('caption').length > 0; | ||||
|  | ||||
| 		orgTableWidth = width; | ||||
| 		orgTableHeight = height; | ||||
|  | ||||
| 		action = "update"; | ||||
| 		formObj.insert.value = inst.getLang('update'); | ||||
| 	} | ||||
|  | ||||
| 	addClassesToList('class', "table_styles"); | ||||
| 	TinyMCE_EditableSelects.init(); | ||||
|  | ||||
| 	// Update form | ||||
| 	selectByValue(formObj, 'align', align); | ||||
| 	selectByValue(formObj, 'frame', frame); | ||||
| 	selectByValue(formObj, 'rules', rules); | ||||
| 	selectByValue(formObj, 'class', className, true, true); | ||||
| 	formObj.cols.value = cols; | ||||
| 	formObj.rows.value = rows; | ||||
| 	formObj.border.value = border; | ||||
| 	formObj.cellpadding.value = cellpadding; | ||||
| 	formObj.cellspacing.value = cellspacing; | ||||
| 	formObj.width.value = width; | ||||
| 	formObj.height.value = height; | ||||
| 	formObj.bordercolor.value = bordercolor; | ||||
| 	formObj.bgcolor.value = bgcolor; | ||||
| 	formObj.id.value = id; | ||||
| 	formObj.summary.value = summary; | ||||
| 	formObj.style.value = style; | ||||
| 	formObj.dir.value = dir; | ||||
| 	formObj.lang.value = lang; | ||||
| 	formObj.backgroundimage.value = background; | ||||
|  | ||||
| 	updateColor('bordercolor_pick', 'bordercolor'); | ||||
| 	updateColor('bgcolor_pick', 'bgcolor'); | ||||
|  | ||||
| 	// Resize some elements | ||||
| 	if (isVisible('backgroundimagebrowser')) | ||||
| 		document.getElementById('backgroundimage').style.width = '180px'; | ||||
|  | ||||
| 	// Disable some fields in update mode | ||||
| 	if (action == "update") { | ||||
| 		formObj.cols.disabled = true; | ||||
| 		formObj.rows.disabled = true; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function changedSize() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| /*	var width = formObj.width.value; | ||||
| 	if (width != "") | ||||
| 		st['width'] = tinyMCEPopup.getParam("inline_styles") ? getCSSSize(width) : ""; | ||||
| 	else | ||||
| 		st['width'] = "";*/ | ||||
|  | ||||
| 	var height = formObj.height.value; | ||||
| 	if (height != "") | ||||
| 		st['height'] = getCSSSize(height); | ||||
| 	else | ||||
| 		st['height'] = ""; | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedBackgroundImage() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	st['background-image'] = "url('" + formObj.backgroundimage.value + "')"; | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedBorder() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	// Update border width if the element has a color | ||||
| 	if (formObj.border.value != "" && formObj.bordercolor.value != "") | ||||
| 		st['border-width'] = formObj.border.value + "px"; | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedColor() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	st['background-color'] = formObj.bgcolor.value; | ||||
|  | ||||
| 	if (formObj.bordercolor.value != "") { | ||||
| 		st['border-color'] = formObj.bordercolor.value; | ||||
|  | ||||
| 		// Add border-width if it's missing | ||||
| 		if (!st['border-width']) | ||||
| 			st['border-width'] = formObj.border.value == "" ? "1px" : formObj.border.value + "px"; | ||||
| 	} | ||||
|  | ||||
| 	formObj.style.value = dom.serializeStyle(st); | ||||
| } | ||||
|  | ||||
| function changedStyle() { | ||||
| 	var formObj = document.forms[0]; | ||||
| 	var st = dom.parseStyle(formObj.style.value); | ||||
|  | ||||
| 	if (st['background-image']) | ||||
| 		formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1"); | ||||
| 	else | ||||
| 		formObj.backgroundimage.value = ''; | ||||
|  | ||||
| 	if (st['width']) | ||||
| 		formObj.width.value = trimSize(st['width']); | ||||
|  | ||||
| 	if (st['height']) | ||||
| 		formObj.height.value = trimSize(st['height']); | ||||
|  | ||||
| 	if (st['background-color']) { | ||||
| 		formObj.bgcolor.value = st['background-color']; | ||||
| 		updateColor('bgcolor_pick','bgcolor'); | ||||
| 	} | ||||
|  | ||||
| 	if (st['border-color']) { | ||||
| 		formObj.bordercolor.value = st['border-color']; | ||||
| 		updateColor('bordercolor_pick','bordercolor'); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,74 @@ | ||||
| tinyMCE.addI18n('en.table_dlg',{ | ||||
| general_tab:"General", | ||||
| advanced_tab:"Advanced", | ||||
| general_props:"General properties", | ||||
| advanced_props:"Advanced properties", | ||||
| rowtype:"Row in table part", | ||||
| title:"Insert/Modify table", | ||||
| width:"Width", | ||||
| height:"Height", | ||||
| cols:"Cols", | ||||
| rows:"Rows", | ||||
| cellspacing:"Cellspacing", | ||||
| cellpadding:"Cellpadding", | ||||
| border:"Border", | ||||
| align:"Alignment", | ||||
| align_default:"Default", | ||||
| align_left:"Left", | ||||
| align_right:"Right", | ||||
| align_middle:"Center", | ||||
| row_title:"Table row properties", | ||||
| cell_title:"Table cell properties", | ||||
| cell_type:"Cell type", | ||||
| valign:"Vertical alignment", | ||||
| align_top:"Top", | ||||
| align_bottom:"Bottom", | ||||
| bordercolor:"Border color", | ||||
| bgcolor:"Background color", | ||||
| merge_cells_title:"Merge table cells", | ||||
| id:"Id", | ||||
| style:"Style", | ||||
| langdir:"Language direction", | ||||
| langcode:"Language code", | ||||
| mime:"Target MIME type", | ||||
| ltr:"Left to right", | ||||
| rtl:"Right to left", | ||||
| bgimage:"Background image", | ||||
| summary:"Summary", | ||||
| td:"Data", | ||||
| th:"Header", | ||||
| cell_cell:"Update current cell", | ||||
| cell_row:"Update all cells in row", | ||||
| cell_all:"Update all cells in table", | ||||
| row_row:"Update current row", | ||||
| row_odd:"Update odd rows in table", | ||||
| row_even:"Update even rows in table", | ||||
| row_all:"Update all rows in table", | ||||
| thead:"Table Head", | ||||
| tbody:"Table Body", | ||||
| tfoot:"Table Foot", | ||||
| scope:"Scope", | ||||
| rowgroup:"Row Group", | ||||
| colgroup:"Col Group", | ||||
| col_limit:"You've exceeded the maximum number of columns of {$cols}.", | ||||
| row_limit:"You've exceeded the maximum number of rows of {$rows}.", | ||||
| cell_limit:"You've exceeded the maximum number of cells of {$cells}.", | ||||
| missing_scope:"Are you sure you want to continue without specifying a scope for this table header cell. Without it, it may be difficult for some users with disabilities to understand the content or data displayed of the table.", | ||||
| caption:"Table caption", | ||||
| frame:"Frame", | ||||
| frame_none:"none", | ||||
| frame_groups:"groups", | ||||
| frame_rows:"rows", | ||||
| frame_cols:"cols", | ||||
| frame_all:"all", | ||||
| rules:"Rules", | ||||
| rules_void:"void", | ||||
| rules_above:"above", | ||||
| rules_below:"below", | ||||
| rules_hsides:"hsides", | ||||
| rules_lhs:"lhs", | ||||
| rules_rhs:"rhs", | ||||
| rules_vsides:"vsides", | ||||
| rules_box:"box", | ||||
| rules_border:"border" | ||||
| }); | ||||
| @@ -0,0 +1,38 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#table_dlg.merge_cells_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/validate.js"></script> | ||||
| 	<script type="text/javascript" src="js/merge_cells.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body style="margin: 8px" style="display: none"> | ||||
| <form onsubmit="mergeCells();return false;" action="#"> | ||||
| 	<fieldset> | ||||
| 		<legend>{#table_dlg.merge_cells_title}</legend> | ||||
| 		  <table border="0" cellpadding="0" cellspacing="3" width="100%"> | ||||
| 			  <tr> | ||||
| 				<td>{#table_dlg.cols}:</td> | ||||
| 				<td align="right"><input type="text" name="numcols" value="" class="number min1 mceFocus" style="width: 30px" /></td> | ||||
| 			  </tr> | ||||
| 			  <tr> | ||||
| 				<td>{#table_dlg.rows}:</td> | ||||
| 				<td align="right"><input type="text" name="numrows" value="" class="number min1" style="width: 30px" /></td> | ||||
| 			  </tr> | ||||
| 		  </table> | ||||
| 	</fieldset> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#update}" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right"> | ||||
| 			<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,161 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#table_dlg.row_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||||
| 	<script type="text/javascript" src="js/row.js"></script> | ||||
| 	<link href="css/row.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="tablerow" style="display: none"> | ||||
| 	<form onsubmit="updateAction();return false;"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#table_dlg.general_tab}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#table_dlg.advanced_tab}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#table_dlg.general_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 						<tr> | ||||
| 							<td><label for="rowtype">{#table_dlg.rowtype}</label></td> | ||||
| 							<td class="col2"> | ||||
| 								<select id="rowtype" name="rowtype" class="mceFocus"> | ||||
| 									<option value="thead">{#table_dlg.thead}</option> | ||||
| 									<option value="tbody">{#table_dlg.tbody}</option> | ||||
| 									<option value="tfoot">{#table_dlg.tfoot}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="align">{#table_dlg.align}</label></td> | ||||
| 							<td class="col2"> | ||||
| 								<select id="align" name="align"> | ||||
| 									<option value="">{#not_set}</option> | ||||
| 									<option value="center">{#table_dlg.align_middle}</option> | ||||
| 									<option value="left">{#table_dlg.align_left}</option> | ||||
| 									<option value="right">{#table_dlg.align_right}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="valign">{#table_dlg.valign}</label></td> | ||||
| 							<td class="col2"> | ||||
| 								<select id="valign" name="valign"> | ||||
| 									<option value="">{#not_set}</option> | ||||
| 									<option value="top">{#table_dlg.align_top}</option> | ||||
| 									<option value="middle">{#table_dlg.align_middle}</option> | ||||
| 									<option value="bottom">{#table_dlg.align_bottom}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr id="styleSelectRow"> | ||||
| 							<td><label for="class">{#class_name}</label></td> | ||||
| 							<td class="col2"> | ||||
| 								<select id="class" name="class" class="mceEditableSelect"> | ||||
| 									<option value="" selected="selected">{#not_set}</option> | ||||
| 								</select> | ||||
| 							</td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="height">{#table_dlg.height}</label></td> | ||||
| 							<td class="col2"><input name="height" type="text" id="height" value="" size="4" maxlength="4" onchange="changedSize();" /></td> | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#table_dlg.advanced_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="id">{#table_dlg.id}</label></td>  | ||||
| 							<td><input id="id" name="id" type="text" value="" style="width: 200px" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="style">{#table_dlg.style}</label></td> | ||||
| 							<td><input type="text" id="style" name="style" value="" style="width: 200px;" onchange="changedStyle();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="dir">{#table_dlg.langdir}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="dir" name="dir" style="width: 200px">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="ltr">{#table_dlg.ltr}</option>  | ||||
| 										<option value="rtl">{#table_dlg.rtl}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="lang">{#table_dlg.langcode}</label></td>  | ||||
| 							<td> | ||||
| 								<input id="lang" name="lang" type="text" value="" style="width: 200px" /> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="backgroundimage">{#table_dlg.bgimage}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="backgroundimage" name="backgroundimage" type="text" value="" style="width: 200px" onchange="changedBackgroundImage();" /></td> | ||||
| 										<td id="backgroundimagebrowsercontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bgcolor">{#table_dlg.bgcolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedColor();" /></td> | ||||
| 										<td id="bgcolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div> | ||||
| 				<select id="action" name="action"> | ||||
| 					<option value="row">{#table_dlg.row_row}</option> | ||||
| 					<option value="odd">{#table_dlg.row_odd}</option> | ||||
| 					<option value="even">{#table_dlg.row_even}</option> | ||||
| 					<option value="all">{#table_dlg.row_all}</option> | ||||
| 				</select> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: left"> | ||||
| 				<div><input type="submit" id="insert" name="insert" value="{#update}" /></div> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,193 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#table_dlg.title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/validate.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/editable_selects.js"></script> | ||||
| 	<script type="text/javascript" src="js/table.js"></script> | ||||
| 	<link href="css/table.css" rel="stylesheet" type="text/css" /> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="table" style="display: none"> | ||||
| 	<form onsubmit="insertTable();return false;" action="#"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#table_dlg.general_tab}</a></span></li> | ||||
| 				<li id="advanced_tab"><span><a href="javascript:mcTabs.displayTab('advanced_tab','advanced_panel');" onmousedown="return false;">{#table_dlg.advanced_tab}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#table_dlg.general_props}</legend> | ||||
| 					  <table border="0" cellpadding="4" cellspacing="0" width="100%"> | ||||
| 							  <tr> | ||||
| 								<td><label id="colslabel" for="cols">{#table_dlg.cols}</label></td> | ||||
| 								<td><input id="cols" name="cols" type="text" value="" size="3" maxlength="3" class="required number min1 mceFocus" /></td> | ||||
| 								<td><label id="rowslabel" for="rows">{#table_dlg.rows}</label></td> | ||||
| 								<td><input id="rows" name="rows" type="text" value="" size="3" maxlength="3" class="required number min1" /></td> | ||||
| 							  </tr> | ||||
| 							  <tr> | ||||
| 								<td><label id="cellpaddinglabel" for="cellpadding">{#table_dlg.cellpadding}</label></td> | ||||
| 								<td><input id="cellpadding" name="cellpadding" type="text" value="" size="3" maxlength="3" class="number" /></td> | ||||
| 								<td><label id="cellspacinglabel" for="cellspacing">{#table_dlg.cellspacing}</label></td> | ||||
| 								<td><input id="cellspacing" name="cellspacing" type="text" value="" size="3" maxlength="3" class="number" /></td> | ||||
| 							  </tr> | ||||
| 							  <tr> | ||||
| 								<td><label id="alignlabel" for="align">{#table_dlg.align}</label></td> | ||||
| 								<td><select id="align" name="align"> | ||||
| 									<option value="">{#not_set}</option> | ||||
| 									<option value="center">{#table_dlg.align_middle}</option> | ||||
| 									<option value="left">{#table_dlg.align_left}</option> | ||||
| 									<option value="right">{#table_dlg.align_right}</option> | ||||
| 								  </select></td> | ||||
| 								<td><label id="borderlabel" for="border">{#table_dlg.border}</label></td> | ||||
| 								<td><input id="border" name="border" type="text" value="" size="3" maxlength="3" onchange="changedBorder();" class="number" /></td> | ||||
| 							  </tr> | ||||
| 							  <tr id="width_row"> | ||||
| 								<td><label id="widthlabel" for="width">{#table_dlg.width}</label></td> | ||||
| 								<td><input name="width" type="text" id="width" value="" size="4" maxlength="4" onchange="changedSize();" class="size" /></td> | ||||
| 								<td><label id="heightlabel" for="height">{#table_dlg.height}</label></td> | ||||
| 								<td><input name="height" type="text" id="height" value="" size="4" maxlength="4" onchange="changedSize();" class="size" /></td> | ||||
| 							  </tr> | ||||
| 							  <tr id="styleSelectRow"> | ||||
| 								<td><label id="classlabel" for="class">{#class_name}</label></td> | ||||
| 								<td colspan="3"> | ||||
| 								 <select id="class" name="class" class="mceEditableSelect"> | ||||
| 									<option value="" selected>{#not_set}</option> | ||||
| 								 </select></td> | ||||
| 							  </tr> | ||||
| 							  <tr> | ||||
| 								<td class="column1"><label for="caption">{#table_dlg.caption}</label></td>  | ||||
| 								<td><input id="caption" name="caption" type="checkbox" class="checkbox" value="true" /></td>  | ||||
| 							  </tr> | ||||
| 							</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="advanced_panel" class="panel"> | ||||
| 				<fieldset> | ||||
| 					<legend>{#table_dlg.advanced_props}</legend> | ||||
|  | ||||
| 					<table border="0" cellpadding="0" cellspacing="4"> | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="id">{#table_dlg.id}</label></td>  | ||||
| 							<td><input id="id" name="id" type="text" value="" class="advfield" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="summary">{#table_dlg.summary}</label></td>  | ||||
| 							<td><input id="summary" name="summary" type="text" value="" class="advfield" /></td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td><label for="style">{#table_dlg.style}</label></td> | ||||
| 							<td><input type="text" id="style" name="style" value="" class="advfield" onchange="changedStyle();" /></td> | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label id="langlabel" for="lang">{#table_dlg.langcode}</label></td>  | ||||
| 							<td> | ||||
| 								<input id="lang" name="lang" type="text" value="" class="advfield" /> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="backgroundimage">{#table_dlg.bgimage}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="backgroundimage" name="backgroundimage" type="text" value="" class="advfield" onchange="changedBackgroundImage();" /></td> | ||||
| 										<td id="backgroundimagebrowsercontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="frame">{#table_dlg.frame}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="frame" name="frame" class="advfield">  | ||||
| 										<option value="">{#not_set}</option> | ||||
| 										<option value="void">{#table_dlg.rules_void}</option> | ||||
| 										<option value="above">{#table_dlg.rules_above}</option>  | ||||
| 										<option value="below">{#table_dlg.rules_below}</option>  | ||||
| 										<option value="hsides">{#table_dlg.rules_hsides}</option>  | ||||
| 										<option value="lhs">{#table_dlg.rules_lhs}</option>  | ||||
| 										<option value="rhs">{#table_dlg.rules_rhs}</option>  | ||||
| 										<option value="vsides">{#table_dlg.rules_vsides}</option>  | ||||
| 										<option value="box">{#table_dlg.rules_box}</option>  | ||||
| 										<option value="border">{#table_dlg.rules_border}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="rules">{#table_dlg.rules}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="rules" name="rules" class="advfield">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="none">{#table_dlg.frame_none}</option> | ||||
| 										<option value="groups">{#table_dlg.frame_groups}</option> | ||||
| 										<option value="rows">{#table_dlg.frame_rows}</option> | ||||
| 										<option value="cols">{#table_dlg.frame_cols}</option> | ||||
| 										<option value="all">{#table_dlg.frame_all}</option> | ||||
| 									</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="dir">{#table_dlg.langdir}</label></td>  | ||||
| 							<td> | ||||
| 								<select id="dir" name="dir" class="advfield">  | ||||
| 										<option value="">{#not_set}</option>  | ||||
| 										<option value="ltr">{#table_dlg.ltr}</option>  | ||||
| 										<option value="rtl">{#table_dlg.rtl}</option>  | ||||
| 								</select> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bordercolor">{#table_dlg.bordercolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bordercolor" name="bordercolor" type="text" value="" size="9" onchange="updateColor('bordercolor_pick','bordercolor');changedColor();" /></td> | ||||
| 										<td id="bordercolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
|  | ||||
| 						<tr> | ||||
| 							<td class="column1"><label for="bgcolor">{#table_dlg.bgcolor}</label></td>  | ||||
| 							<td> | ||||
| 								<table border="0" cellpadding="0" cellspacing="0"> | ||||
| 									<tr> | ||||
| 										<td><input id="bgcolor" name="bgcolor" type="text" value="" size="9" onchange="updateColor('bgcolor_pick','bgcolor');changedColor();" /></td> | ||||
| 										<td id="bgcolor_pickcontainer"> </td> | ||||
| 									</tr> | ||||
| 								</table> | ||||
| 							</td>  | ||||
| 						</tr> | ||||
| 					</table> | ||||
| 				</fieldset> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,56 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advanced_dlg.about_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="js/about.js"></script> | ||||
| </head> | ||||
| <body id="about" style="display: none"> | ||||
| 		<div class="tabs"> | ||||
| 			<ul> | ||||
| 				<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#advanced_dlg.about_general}</a></span></li> | ||||
| 				<li id="help_tab" style="display:none"><span><a href="javascript:mcTabs.displayTab('help_tab','help_panel');" onmousedown="return false;">{#advanced_dlg.about_help}</a></span></li> | ||||
| 				<li id="plugins_tab"><span><a href="javascript:mcTabs.displayTab('plugins_tab','plugins_panel');" onmousedown="return false;">{#advanced_dlg.about_plugins}</a></span></li> | ||||
| 			</ul> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="panel_wrapper"> | ||||
| 			<div id="general_panel" class="panel current"> | ||||
| 				<h3>{#advanced_dlg.about_title}</h3> | ||||
| 				<p>Version: <span id="version"></span> (<span id="date"></span>)</p> | ||||
| 				<p>TinyMCE is a platform independent web based Javascript HTML WYSIWYG editor control released as Open Source under <a href="../../license.txt" target="_blank">LGPL</a> | ||||
| 				by Moxiecode Systems AB. It has the ability to convert HTML TEXTAREA fields or other HTML elements to editor instances.</p> | ||||
| 				<p>Copyright © 2003-2008, <a href="http://www.moxiecode.com" target="_blank">Moxiecode Systems AB</a>, All rights reserved.</p> | ||||
| 				<p>For more information about this software visit the <a href="http://tinymce.moxiecode.com" target="_blank">TinyMCE website</a>.</p> | ||||
|  | ||||
| 				<div id="buttoncontainer"> | ||||
| 					<a href="http://www.moxiecode.com" target="_blank"><img src="http://tinymce.moxiecode.com/images/gotmoxie.png" alt="Got Moxie?" border="0" /></a> | ||||
| 					<a href="http://sourceforge.net/projects/tinymce/" target="_blank"><img src="http://sourceforge.net/sflogo.php?group_id=103281" alt="Hosted By Sourceforge" border="0" /></a> | ||||
| 					<a href="http://www.freshmeat.net/projects/tinymce" target="_blank"><img src="http://tinymce.moxiecode.com/images/fm.gif" alt="Also on freshmeat" border="0" /></a> | ||||
| 				</div> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="plugins_panel" class="panel"> | ||||
| 				<div id="pluginscontainer"> | ||||
| 					<h3>{#advanced_dlg.about_loaded}</h3> | ||||
|  | ||||
| 					<div id="plugintablecontainer"> | ||||
| 					</div> | ||||
|  | ||||
| 					<p> </p> | ||||
| 				</div> | ||||
| 			</div> | ||||
|  | ||||
| 			<div id="help_panel" class="panel noscroll" style="overflow: visible;"> | ||||
| 				<div id="iframecontainer"></div> | ||||
| 			</div> | ||||
| 		</div> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" id="cancel" name="cancel" value="{#close}" onclick="tinyMCEPopup.close();" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,32 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advanced_dlg.anchor_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/anchor.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body style="display: none"> | ||||
| <form onsubmit="AnchorDialog.update();return false;" action="#"> | ||||
| 	<table border="0" cellpadding="4" cellspacing="0"> | ||||
| 		<tr> | ||||
| 			<td colspan="2" class="title">{#advanced_dlg.anchor_title}</td> | ||||
| 		</tr> | ||||
| 		<tr> | ||||
| 			<td nowrap="nowrap">{#advanced_dlg.anchor_name}:</td> | ||||
| 			<td><input name="anchorName" type="text" class="mceFocus" id="anchorName" value="" style="width: 200px" /></td> | ||||
| 		</tr> | ||||
| 	</table> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#update}" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right"> | ||||
| 			<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,54 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advanced_dlg.charmap_title}</title> | ||||
| 	<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1" /> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/charmap.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="charmap" style="display:none"> | ||||
| <table align="center" border="0" cellspacing="0" cellpadding="2"> | ||||
|     <tr> | ||||
|         <td colspan="2" class="title">{#advanced_dlg.charmap_title}</td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td id="charmapView" rowspan="2" align="left" valign="top"> | ||||
| 			<!-- Chars will be rendered here --> | ||||
|         </td> | ||||
|         <td width="100" align="center" valign="top"> | ||||
|             <table border="0" cellpadding="0" cellspacing="0" width="100" style="height:100px"> | ||||
|                 <tr> | ||||
|                     <td id="codeV"> </td> | ||||
|                 </tr> | ||||
|                 <tr> | ||||
|                     <td id="codeN"> </td> | ||||
|                 </tr> | ||||
|             </table> | ||||
|         </td> | ||||
|     </tr> | ||||
|     <tr> | ||||
|         <td valign="bottom" style="padding-bottom: 3px;"> | ||||
|             <table width="100" align="center" border="0" cellpadding="2" cellspacing="0"> | ||||
|                 <tr> | ||||
|                     <td align="center" style="border-left: 1px solid #666699; border-top: 1px solid #666699; border-right: 1px solid #666699;">HTML-Code</td> | ||||
|                 </tr> | ||||
|                 <tr> | ||||
|                     <td style="font-size: 16px; font-weight: bold; border-left: 1px solid #666699; border-bottom: 1px solid #666699; border-right: 1px solid #666699;" id="codeA" align="center"> </td> | ||||
|                 </tr> | ||||
|                 <tr> | ||||
|                     <td style="font-size: 1px;"> </td> | ||||
|                 </tr> | ||||
|                 <tr> | ||||
|                     <td align="center" style="border-left: 1px solid #666699; border-top: 1px solid #666699; border-right: 1px solid #666699;">NUM-Code</td> | ||||
|                 </tr> | ||||
|                 <tr> | ||||
|                     <td style="font-size: 16px; font-weight: bold; border-left: 1px solid #666699; border-bottom: 1px solid #666699; border-right: 1px solid #666699;" id="codeB" align="center"> </td> | ||||
|                 </tr> | ||||
|             </table> | ||||
|         </td> | ||||
|     </tr> | ||||
| </table> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,76 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advanced_dlg.colorpicker_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="js/color_picker.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="colorpicker" style="display: none"> | ||||
| <form onsubmit="insertAction();return false" action="#"> | ||||
| 	<div class="tabs"> | ||||
| 		<ul> | ||||
| 			<li id="picker_tab" class="current"><span><a href="javascript:mcTabs.displayTab('picker_tab','picker_panel');" onmousedown="return false;">{#advanced_dlg.colorpicker_picker_tab}</a></span></li> | ||||
| 			<li id="rgb_tab"><span><a href="javascript:;" onclick="generateWebColors();mcTabs.displayTab('rgb_tab','rgb_panel');" onmousedown="return false;">{#advanced_dlg.colorpicker_palette_tab}</a></span></li> | ||||
| 			<li id="named_tab"><span><a  href="javascript:;" onclick="generateNamedColors();javascript:mcTabs.displayTab('named_tab','named_panel');" onmousedown="return false;">{#advanced_dlg.colorpicker_named_tab}</a></span></li> | ||||
| 		</ul> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="panel_wrapper"> | ||||
| 		<div id="picker_panel" class="panel current"> | ||||
| 			<fieldset> | ||||
| 				<legend>{#advanced_dlg.colorpicker_picker_title}</legend> | ||||
| 				<div id="picker"> | ||||
| 					<img id="colors" src="img/colorpicker.jpg" onclick="computeColor(event)" onmousedown="isMouseDown = true;return false;" onmouseup="isMouseDown = false;" onmousemove="if (isMouseDown && isMouseOver) computeColor(event); return false;" onmouseover="isMouseOver=true;" onmouseout="isMouseOver=false;" /> | ||||
|  | ||||
| 					<div id="light"> | ||||
| 						<!-- Will be filled with divs --> | ||||
| 					</div> | ||||
|  | ||||
| 					<br style="clear: both" /> | ||||
| 				</div> | ||||
| 			</fieldset> | ||||
| 		</div> | ||||
|  | ||||
| 		<div id="rgb_panel" class="panel"> | ||||
| 			<fieldset> | ||||
| 				<legend>{#advanced_dlg.colorpicker_palette_title}</legend> | ||||
| 				<div id="webcolors"> | ||||
| 					<!-- Gets filled with web safe colors--> | ||||
| 				</div> | ||||
|  | ||||
| 				<br style="clear: both" /> | ||||
| 			</fieldset> | ||||
| 		</div> | ||||
|  | ||||
| 		<div id="named_panel" class="panel"> | ||||
| 			<fieldset> | ||||
| 				<legend>{#advanced_dlg.colorpicker_named_title}</legend> | ||||
| 				<div id="namedcolors"> | ||||
| 					<!-- Gets filled with named colors--> | ||||
| 				</div> | ||||
|  | ||||
| 				<br style="clear: both" /> | ||||
|  | ||||
| 				<div id="colornamecontainer"> | ||||
| 					{#advanced_dlg.colorpicker_name} <span id="colorname"></span> | ||||
| 				</div> | ||||
| 			</fieldset> | ||||
| 		</div> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#apply}" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div id="preview"></div> | ||||
|  | ||||
| 		<div id="previewblock"> | ||||
| 			<label for="color">{#advanced_dlg.colorpicker_color}</label> <input id="color" type="text" size="8" maxlength="8" class="text mceFocus" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| @@ -0,0 +1,86 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advanced_dlg.image_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="js/image.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="image" style="display: none"> | ||||
| <form onsubmit="ImageDialog.update();return false;" action="#"> | ||||
| 	<div class="tabs"> | ||||
| 		<ul> | ||||
| 			<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#advanced_dlg.image_title}</a></span></li> | ||||
| 		</ul> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="panel_wrapper"> | ||||
| 		<div id="general_panel" class="panel current"> | ||||
|      <table border="0" cellpadding="4" cellspacing="0"> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="src">{#advanced_dlg.image_src}</label></td> | ||||
|             <td><table border="0" cellspacing="0" cellpadding="0"> | ||||
|                 <tr> | ||||
|                   <td><input id="src" name="src" type="text" class="mceFocus" value="" style="width: 200px" onchange="ImageDialog.getImageData();" /></td> | ||||
|                   <td id="srcbrowsercontainer"> </td> | ||||
|                 </tr> | ||||
|               </table></td> | ||||
|           </tr> | ||||
| 		  <tr> | ||||
| 			<td><label for="image_list">{#advanced_dlg.image_list}</label></td> | ||||
| 			<td><select id="image_list" name="image_list" onchange="document.getElementById('src').value=this.options[this.selectedIndex].value;document.getElementById('alt').value=this.options[this.selectedIndex].text;"></select></td> | ||||
| 		  </tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="alt">{#advanced_dlg.image_alt}</label></td> | ||||
|             <td><input id="alt" name="alt" type="text" value="" style="width: 200px" /></td> | ||||
|           </tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="align">{#advanced_dlg.image_align}</label></td> | ||||
|             <td><select id="align" name="align" onchange="ImageDialog.updateStyle();"> | ||||
|                 <option value="">{#not_set}</option> | ||||
|                 <option value="baseline">{#advanced_dlg.image_align_baseline}</option> | ||||
|                 <option value="top">{#advanced_dlg.image_align_top}</option> | ||||
|                 <option value="middle">{#advanced_dlg.image_align_middle}</option> | ||||
|                 <option value="bottom">{#advanced_dlg.image_align_bottom}</option> | ||||
|                 <option value="text-top">{#advanced_dlg.image_align_texttop}</option> | ||||
|                 <option value="text-bottom">{#advanced_dlg.image_align_textbottom}</option> | ||||
|                 <option value="left">{#advanced_dlg.image_align_left}</option> | ||||
|                 <option value="right">{#advanced_dlg.image_align_right}</option> | ||||
|               </select></td> | ||||
|           </tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="width">{#advanced_dlg.image_dimensions}</label></td> | ||||
|             <td><input id="width" name="width" type="text" value="" size="3" maxlength="5" /> | ||||
|               x | ||||
|               <input id="height" name="height" type="text" value="" size="3" maxlength="5" /></td> | ||||
|           </tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="border">{#advanced_dlg.image_border}</label></td> | ||||
|             <td><input id="border" name="border" type="text" value="" size="3" maxlength="3" onchange="ImageDialog.updateStyle();" /></td> | ||||
|           </tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="vspace">{#advanced_dlg.image_vspace}</label></td> | ||||
|             <td><input id="vspace" name="vspace" type="text" value="" size="3" maxlength="3" onchange="ImageDialog.updateStyle();" /></td> | ||||
|           </tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="hspace">{#advanced_dlg.image_hspace}</label></td> | ||||
|             <td><input id="hspace" name="hspace" type="text" value="" size="3" maxlength="3" onchange="ImageDialog.updateStyle();" /></td> | ||||
|           </tr> | ||||
|         </table> | ||||
| 		</div> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right"> | ||||
| 			<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| After Width: | Height: | Size: 3.1 KiB | 
| After Width: | Height: | Size: 11 KiB | 
| @@ -0,0 +1,72 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| function init() { | ||||
| 	var ed, tcont; | ||||
|  | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
| 	ed = tinyMCEPopup.editor; | ||||
|  | ||||
| 	// Give FF some time | ||||
| 	window.setTimeout('insertHelpIFrame();', 10); | ||||
|  | ||||
| 	tcont = document.getElementById('plugintablecontainer'); | ||||
| 	document.getElementById('plugins_tab').style.display = 'none'; | ||||
|  | ||||
| 	var html = ""; | ||||
| 	html += '<table id="plugintable">'; | ||||
| 	html += '<thead>'; | ||||
| 	html += '<tr>'; | ||||
| 	html += '<td>' + ed.getLang('advanced_dlg.about_plugin') + '</td>'; | ||||
| 	html += '<td>' + ed.getLang('advanced_dlg.about_author') + '</td>'; | ||||
| 	html += '<td>' + ed.getLang('advanced_dlg.about_version') + '</td>'; | ||||
| 	html += '</tr>'; | ||||
| 	html += '</thead>'; | ||||
| 	html += '<tbody>'; | ||||
|  | ||||
| 	tinymce.each(ed.plugins, function(p, n) { | ||||
| 		var info; | ||||
|  | ||||
| 		if (!p.getInfo) | ||||
| 			return; | ||||
|  | ||||
| 		html += '<tr>'; | ||||
|  | ||||
| 		info = p.getInfo(); | ||||
|  | ||||
| 		if (info.infourl != null && info.infourl != '') | ||||
| 			html += '<td width="50%" title="' + n + '"><a href="' + info.infourl + '" target="_blank">' + info.longname + '</a></td>'; | ||||
| 		else | ||||
| 			html += '<td width="50%" title="' + n + '">' + info.longname + '</td>'; | ||||
|  | ||||
| 		if (info.authorurl != null && info.authorurl != '') | ||||
| 			html += '<td width="35%"><a href="' + info.authorurl + '" target="_blank">' + info.author + '</a></td>'; | ||||
| 		else | ||||
| 			html += '<td width="35%">' + info.author + '</td>'; | ||||
|  | ||||
| 		html += '<td width="15%">' + info.version + '</td>'; | ||||
| 		html += '</tr>'; | ||||
|  | ||||
| 		document.getElementById('plugins_tab').style.display = ''; | ||||
|  | ||||
| 	}); | ||||
|  | ||||
| 	html += '</tbody>'; | ||||
| 	html += '</table>'; | ||||
|  | ||||
| 	tcont.innerHTML = html; | ||||
|  | ||||
| 	tinyMCEPopup.dom.get('version').innerHTML = tinymce.majorVersion + "." + tinymce.minorVersion; | ||||
| 	tinyMCEPopup.dom.get('date').innerHTML = tinymce.releaseDate; | ||||
| } | ||||
|  | ||||
| function insertHelpIFrame() { | ||||
| 	var html; | ||||
|  | ||||
| 	if (tinyMCEPopup.getParam('docs_url')) { | ||||
| 		html = '<iframe width="100%" height="300" src="' + tinyMCEPopup.editor.baseURI.toAbsolute(tinyMCEPopup.getParam('docs_url')) + '"></iframe>'; | ||||
| 		document.getElementById('iframecontainer').innerHTML = html; | ||||
| 		document.getElementById('help_tab').style.display = 'block'; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,37 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var AnchorDialog = { | ||||
| 	init : function(ed) { | ||||
| 		var action, elm, f = document.forms[0]; | ||||
|  | ||||
| 		this.editor = ed; | ||||
| 		elm = ed.dom.getParent(ed.selection.getNode(), 'A,IMG'); | ||||
| 		v = ed.dom.getAttrib(elm, 'name'); | ||||
|  | ||||
| 		if (v) { | ||||
| 			this.action = 'update'; | ||||
| 			f.anchorName.value = v; | ||||
| 		} | ||||
|  | ||||
| 		f.insert.value = ed.getLang(elm ? 'update' : 'insert'); | ||||
| 	}, | ||||
|  | ||||
| 	update : function() { | ||||
| 		var ed = this.editor; | ||||
| 		 | ||||
| 		tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 		if (this.action != 'update') | ||||
| 			ed.selection.collapse(1); | ||||
|  | ||||
| 		// Webkit acts weird if empty inline element is inserted so we need to use a image instead | ||||
| 		if (tinymce.isWebKit) | ||||
| 			ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('img', {mce_name : 'a', name : document.forms[0].anchorName.value, 'class' : 'mceItemAnchor'})); | ||||
| 		else | ||||
| 			ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('a', {name : document.forms[0].anchorName.value, 'class' : 'mceItemAnchor'}, '')); | ||||
|  | ||||
| 		tinyMCEPopup.close(); | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| tinyMCEPopup.onInit.add(AnchorDialog.init, AnchorDialog); | ||||
| @@ -0,0 +1,325 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var charmap = [ | ||||
| 	[' ',    ' ',  true, 'no-break space'], | ||||
| 	['&',     '&',   true, 'ampersand'], | ||||
| 	['"',    '"',   true, 'quotation mark'], | ||||
| // finance | ||||
| 	['¢',    '¢',  true, 'cent sign'], | ||||
| 	['€',    '€', true, 'euro sign'], | ||||
| 	['£',   '£',  true, 'pound sign'], | ||||
| 	['¥',     '¥',  true, 'yen sign'], | ||||
| // signs | ||||
| 	['©',    '©',  true, 'copyright sign'], | ||||
| 	['®',     '®',  true, 'registered sign'], | ||||
| 	['™',   '™', true, 'trade mark sign'], | ||||
| 	['‰',  '‰', true, 'per mille sign'], | ||||
| 	['µ',   'µ',  true, 'micro sign'], | ||||
| 	['·',  '·',  true, 'middle dot'], | ||||
| 	['•',    '•', true, 'bullet'], | ||||
| 	['…',  '…', true, 'three dot leader'], | ||||
| 	['′',   '′', true, 'minutes / feet'], | ||||
| 	['″',   '″', true, 'seconds / inches'], | ||||
| 	['§',    '§',  true, 'section sign'], | ||||
| 	['¶',    '¶',  true, 'paragraph sign'], | ||||
| 	['ß',   'ß',  true, 'sharp s / ess-zed'], | ||||
| // quotations | ||||
| 	['‹',  '‹', true, 'single left-pointing angle quotation mark'], | ||||
| 	['›',  '›', true, 'single right-pointing angle quotation mark'], | ||||
| 	['«',   '«',  true, 'left pointing guillemet'], | ||||
| 	['»',   '»',  true, 'right pointing guillemet'], | ||||
| 	['‘',   '‘', true, 'left single quotation mark'], | ||||
| 	['’',   '’', true, 'right single quotation mark'], | ||||
| 	['“',   '“', true, 'left double quotation mark'], | ||||
| 	['”',   '”', true, 'right double quotation mark'], | ||||
| 	['‚',   '‚', true, 'single low-9 quotation mark'], | ||||
| 	['„',   '„', true, 'double low-9 quotation mark'], | ||||
| 	['<',      '<',   true, 'less-than sign'], | ||||
| 	['>',      '>',   true, 'greater-than sign'], | ||||
| 	['≤',      '≤', true, 'less-than or equal to'], | ||||
| 	['≥',      '≥', true, 'greater-than or equal to'], | ||||
| 	['–',   '–', true, 'en dash'], | ||||
| 	['—',   '—', true, 'em dash'], | ||||
| 	['¯',    '¯',  true, 'macron'], | ||||
| 	['‾',   '‾', true, 'overline'], | ||||
| 	['¤',  '¤',  true, 'currency sign'], | ||||
| 	['¦',  '¦',  true, 'broken bar'], | ||||
| 	['¨',     '¨',  true, 'diaeresis'], | ||||
| 	['¡',   '¡',  true, 'inverted exclamation mark'], | ||||
| 	['¿',  '¿',  true, 'turned question mark'], | ||||
| 	['ˆ',    'ˆ',  true, 'circumflex accent'], | ||||
| 	['˜',   '˜',  true, 'small tilde'], | ||||
| 	['°',     '°',  true, 'degree sign'], | ||||
| 	['−',   '−', true, 'minus sign'], | ||||
| 	['±',  '±',  true, 'plus-minus sign'], | ||||
| 	['÷',  '÷',  true, 'division sign'], | ||||
| 	['⁄',   '⁄', true, 'fraction slash'], | ||||
| 	['×',   '×',  true, 'multiplication sign'], | ||||
| 	['¹',    '¹',  true, 'superscript one'], | ||||
| 	['²',    '²',  true, 'superscript two'], | ||||
| 	['³',    '³',  true, 'superscript three'], | ||||
| 	['¼',  '¼',  true, 'fraction one quarter'], | ||||
| 	['½',  '½',  true, 'fraction one half'], | ||||
| 	['¾',  '¾',  true, 'fraction three quarters'], | ||||
| // math / logical | ||||
| 	['ƒ',    'ƒ',  true, 'function / florin'], | ||||
| 	['∫',     '∫', true, 'integral'], | ||||
| 	['∑',     '∑', true, 'n-ary sumation'], | ||||
| 	['∞',   '∞', true, 'infinity'], | ||||
| 	['√',   '√', true, 'square root'], | ||||
| 	['∼',     '∼', false,'similar to'], | ||||
| 	['≅',    '≅', false,'approximately equal to'], | ||||
| 	['≈',   '≈', true, 'almost equal to'], | ||||
| 	['≠',      '≠', true, 'not equal to'], | ||||
| 	['≡',   '≡', true, 'identical to'], | ||||
| 	['∈',    '∈', false,'element of'], | ||||
| 	['∉',   '∉', false,'not an element of'], | ||||
| 	['∋',      '∋', false,'contains as member'], | ||||
| 	['∏',    '∏', true, 'n-ary product'], | ||||
| 	['∧',     '∧', false,'logical and'], | ||||
| 	['∨',      '∨', false,'logical or'], | ||||
| 	['¬',     '¬',  true, 'not sign'], | ||||
| 	['∩',     '∩', true, 'intersection'], | ||||
| 	['∪',     '∪', false,'union'], | ||||
| 	['∂',    '∂', true, 'partial differential'], | ||||
| 	['∀',  '∀', false,'for all'], | ||||
| 	['∃',   '∃', false,'there exists'], | ||||
| 	['∅',   '∅', false,'diameter'], | ||||
| 	['∇',   '∇', false,'backward difference'], | ||||
| 	['∗',  '∗', false,'asterisk operator'], | ||||
| 	['∝',    '∝', false,'proportional to'], | ||||
| 	['∠',     '∠', false,'angle'], | ||||
| // undefined | ||||
| 	['´',   '´',  true, 'acute accent'], | ||||
| 	['¸',   '¸',  true, 'cedilla'], | ||||
| 	['ª',    'ª',  true, 'feminine ordinal indicator'], | ||||
| 	['º',    'º',  true, 'masculine ordinal indicator'], | ||||
| 	['†',  '†', true, 'dagger'], | ||||
| 	['‡',  '‡', true, 'double dagger'], | ||||
| // alphabetical special chars | ||||
| 	['À',  'À',  true, 'A - grave'], | ||||
| 	['Á',  'Á',  true, 'A - acute'], | ||||
| 	['Â',   'Â',  true, 'A - circumflex'], | ||||
| 	['Ã',  'Ã',  true, 'A - tilde'], | ||||
| 	['Ä',    'Ä',  true, 'A - diaeresis'], | ||||
| 	['Å',   'Å',  true, 'A - ring above'], | ||||
| 	['Æ',   'Æ',  true, 'ligature AE'], | ||||
| 	['Ç',  'Ç',  true, 'C - cedilla'], | ||||
| 	['È',  'È',  true, 'E - grave'], | ||||
| 	['É',  'É',  true, 'E - acute'], | ||||
| 	['Ê',   'Ê',  true, 'E - circumflex'], | ||||
| 	['Ë',    'Ë',  true, 'E - diaeresis'], | ||||
| 	['Ì',  'Ì',  true, 'I - grave'], | ||||
| 	['Í',  'Í',  true, 'I - acute'], | ||||
| 	['Î',   'Î',  true, 'I - circumflex'], | ||||
| 	['Ï',    'Ï',  true, 'I - diaeresis'], | ||||
| 	['Ð',     'Ð',  true, 'ETH'], | ||||
| 	['Ñ',  'Ñ',  true, 'N - tilde'], | ||||
| 	['Ò',  'Ò',  true, 'O - grave'], | ||||
| 	['Ó',  'Ó',  true, 'O - acute'], | ||||
| 	['Ô',   'Ô',  true, 'O - circumflex'], | ||||
| 	['Õ',  'Õ',  true, 'O - tilde'], | ||||
| 	['Ö',    'Ö',  true, 'O - diaeresis'], | ||||
| 	['Ø',  'Ø',  true, 'O - slash'], | ||||
| 	['Œ',   'Œ',  true, 'ligature OE'], | ||||
| 	['Š',  'Š',  true, 'S - caron'], | ||||
| 	['Ù',  'Ù',  true, 'U - grave'], | ||||
| 	['Ú',  'Ú',  true, 'U - acute'], | ||||
| 	['Û',   'Û',  true, 'U - circumflex'], | ||||
| 	['Ü',    'Ü',  true, 'U - diaeresis'], | ||||
| 	['Ý',  'Ý',  true, 'Y - acute'], | ||||
| 	['Ÿ',    'Ÿ',  true, 'Y - diaeresis'], | ||||
| 	['Þ',   'Þ',  true, 'THORN'], | ||||
| 	['à',  'à',  true, 'a - grave'], | ||||
| 	['á',  'á',  true, 'a - acute'], | ||||
| 	['â',   'â',  true, 'a - circumflex'], | ||||
| 	['ã',  'ã',  true, 'a - tilde'], | ||||
| 	['ä',    'ä',  true, 'a - diaeresis'], | ||||
| 	['å',   'å',  true, 'a - ring above'], | ||||
| 	['æ',   'æ',  true, 'ligature ae'], | ||||
| 	['ç',  'ç',  true, 'c - cedilla'], | ||||
| 	['è',  'è',  true, 'e - grave'], | ||||
| 	['é',  'é',  true, 'e - acute'], | ||||
| 	['ê',   'ê',  true, 'e - circumflex'], | ||||
| 	['ë',    'ë',  true, 'e - diaeresis'], | ||||
| 	['ì',  'ì',  true, 'i - grave'], | ||||
| 	['í',  'í',  true, 'i - acute'], | ||||
| 	['î',   'î',  true, 'i - circumflex'], | ||||
| 	['ï',    'ï',  true, 'i - diaeresis'], | ||||
| 	['ð',     'ð',  true, 'eth'], | ||||
| 	['ñ',  'ñ',  true, 'n - tilde'], | ||||
| 	['ò',  'ò',  true, 'o - grave'], | ||||
| 	['ó',  'ó',  true, 'o - acute'], | ||||
| 	['ô',   'ô',  true, 'o - circumflex'], | ||||
| 	['õ',  'õ',  true, 'o - tilde'], | ||||
| 	['ö',    'ö',  true, 'o - diaeresis'], | ||||
| 	['ø',  'ø',  true, 'o slash'], | ||||
| 	['œ',   'œ',  true, 'ligature oe'], | ||||
| 	['š',  'š',  true, 's - caron'], | ||||
| 	['ù',  'ù',  true, 'u - grave'], | ||||
| 	['ú',  'ú',  true, 'u - acute'], | ||||
| 	['û',   'û',  true, 'u - circumflex'], | ||||
| 	['ü',    'ü',  true, 'u - diaeresis'], | ||||
| 	['ý',  'ý',  true, 'y - acute'], | ||||
| 	['þ',   'þ',  true, 'thorn'], | ||||
| 	['ÿ',    'ÿ',  true, 'y - diaeresis'], | ||||
|     ['Α',   'Α',  true, 'Alpha'], | ||||
| 	['Β',    'Β',  true, 'Beta'], | ||||
| 	['Γ',   'Γ',  true, 'Gamma'], | ||||
| 	['Δ',   'Δ',  true, 'Delta'], | ||||
| 	['Ε', 'Ε',  true, 'Epsilon'], | ||||
| 	['Ζ',    'Ζ',  true, 'Zeta'], | ||||
| 	['Η',     'Η',  true, 'Eta'], | ||||
| 	['Θ',   'Θ',  true, 'Theta'], | ||||
| 	['Ι',    'Ι',  true, 'Iota'], | ||||
| 	['Κ',   'Κ',  true, 'Kappa'], | ||||
| 	['Λ',  'Λ',  true, 'Lambda'], | ||||
| 	['Μ',      'Μ',  true, 'Mu'], | ||||
| 	['Ν',      'Ν',  true, 'Nu'], | ||||
| 	['Ξ',      'Ξ',  true, 'Xi'], | ||||
| 	['Ο', 'Ο',  true, 'Omicron'], | ||||
| 	['Π',      'Π',  true, 'Pi'], | ||||
| 	['Ρ',     'Ρ',  true, 'Rho'], | ||||
| 	['Σ',   'Σ',  true, 'Sigma'], | ||||
| 	['Τ',     'Τ',  true, 'Tau'], | ||||
| 	['Υ', 'Υ',  true, 'Upsilon'], | ||||
| 	['Φ',     'Φ',  true, 'Phi'], | ||||
| 	['Χ',     'Χ',  true, 'Chi'], | ||||
| 	['Ψ',     'Ψ',  true, 'Psi'], | ||||
| 	['Ω',   'Ω',  true, 'Omega'], | ||||
| 	['α',   'α',  true, 'alpha'], | ||||
| 	['β',    'β',  true, 'beta'], | ||||
| 	['γ',   'γ',  true, 'gamma'], | ||||
| 	['δ',   'δ',  true, 'delta'], | ||||
| 	['ε', 'ε',  true, 'epsilon'], | ||||
| 	['ζ',    'ζ',  true, 'zeta'], | ||||
| 	['η',     'η',  true, 'eta'], | ||||
| 	['θ',   'θ',  true, 'theta'], | ||||
| 	['ι',    'ι',  true, 'iota'], | ||||
| 	['κ',   'κ',  true, 'kappa'], | ||||
| 	['λ',  'λ',  true, 'lambda'], | ||||
| 	['μ',      'μ',  true, 'mu'], | ||||
| 	['ν',      'ν',  true, 'nu'], | ||||
| 	['ξ',      'ξ',  true, 'xi'], | ||||
| 	['ο', 'ο',  true, 'omicron'], | ||||
| 	['π',      'π',  true, 'pi'], | ||||
| 	['ρ',     'ρ',  true, 'rho'], | ||||
| 	['ς',  'ς',  true, 'final sigma'], | ||||
| 	['σ',   'σ',  true, 'sigma'], | ||||
| 	['τ',     'τ',  true, 'tau'], | ||||
| 	['υ', 'υ',  true, 'upsilon'], | ||||
| 	['φ',     'φ',  true, 'phi'], | ||||
| 	['χ',     'χ',  true, 'chi'], | ||||
| 	['ψ',     'ψ',  true, 'psi'], | ||||
| 	['ω',   'ω',  true, 'omega'], | ||||
| // symbols | ||||
| 	['ℵ', 'ℵ', false,'alef symbol'], | ||||
| 	['ϖ',     'ϖ',  false,'pi symbol'], | ||||
| 	['ℜ',    'ℜ', false,'real part symbol'], | ||||
| 	['ϑ','ϑ',  false,'theta symbol'], | ||||
| 	['ϒ',   'ϒ',  false,'upsilon - hook symbol'], | ||||
| 	['℘',  '℘', false,'Weierstrass p'], | ||||
| 	['ℑ',   'ℑ', false,'imaginary part'], | ||||
| // arrows | ||||
| 	['←',    '←', true, 'leftwards arrow'], | ||||
| 	['↑',    '↑', true, 'upwards arrow'], | ||||
| 	['→',    '→', true, 'rightwards arrow'], | ||||
| 	['↓',    '↓', true, 'downwards arrow'], | ||||
| 	['↔',    '↔', true, 'left right arrow'], | ||||
| 	['↵',   '↵', false,'carriage return'], | ||||
| 	['⇐',    '⇐', false,'leftwards double arrow'], | ||||
| 	['⇑',    '⇑', false,'upwards double arrow'], | ||||
| 	['⇒',    '⇒', false,'rightwards double arrow'], | ||||
| 	['⇓',    '⇓', false,'downwards double arrow'], | ||||
| 	['⇔',    '⇔', false,'left right double arrow'], | ||||
| 	['∴',  '∴', false,'therefore'], | ||||
| 	['⊂',     '⊂', false,'subset of'], | ||||
| 	['⊃',     '⊃', false,'superset of'], | ||||
| 	['⊄',    '⊄', false,'not a subset of'], | ||||
| 	['⊆',    '⊆', false,'subset of or equal to'], | ||||
| 	['⊇',    '⊇', false,'superset of or equal to'], | ||||
| 	['⊕',   '⊕', false,'circled plus'], | ||||
| 	['⊗',  '⊗', false,'circled times'], | ||||
| 	['⊥',    '⊥', false,'perpendicular'], | ||||
| 	['⋅',    '⋅', false,'dot operator'], | ||||
| 	['⌈',   '⌈', false,'left ceiling'], | ||||
| 	['⌉',   '⌉', false,'right ceiling'], | ||||
| 	['⌊',  '⌊', false,'left floor'], | ||||
| 	['⌋',  '⌋', false,'right floor'], | ||||
| 	['⟨',    '〈', false,'left-pointing angle bracket'], | ||||
| 	['⟩',    '〉', false,'right-pointing angle bracket'], | ||||
| 	['◊',     '◊', true,'lozenge'], | ||||
| 	['♠',  '♠', false,'black spade suit'], | ||||
| 	['♣',   '♣', true, 'black club suit'], | ||||
| 	['♥',  '♥', true, 'black heart suit'], | ||||
| 	['♦',   '♦', true, 'black diamond suit'], | ||||
| 	[' ',    ' ', false,'en space'], | ||||
| 	[' ',    ' ', false,'em space'], | ||||
| 	[' ',  ' ', false,'thin space'], | ||||
| 	['‌',    '‌', false,'zero width non-joiner'], | ||||
| 	['‍',     '‍', false,'zero width joiner'], | ||||
| 	['‎',     '‎', false,'left-to-right mark'], | ||||
| 	['‏',     '‏', false,'right-to-left mark'], | ||||
| 	['­',     '­',  false,'soft hyphen'] | ||||
| ]; | ||||
|  | ||||
| tinyMCEPopup.onInit.add(function() { | ||||
| 	tinyMCEPopup.dom.setHTML('charmapView', renderCharMapHTML()); | ||||
| }); | ||||
|  | ||||
| function renderCharMapHTML() { | ||||
| 	var charsPerRow = 20, tdWidth=20, tdHeight=20, i; | ||||
| 	var html = '<table border="0" cellspacing="1" cellpadding="0" width="' + (tdWidth*charsPerRow) + '"><tr height="' + tdHeight + '">'; | ||||
| 	var cols=-1; | ||||
|  | ||||
| 	for (i=0; i<charmap.length; i++) { | ||||
| 		if (charmap[i][2]==true) { | ||||
| 			cols++; | ||||
| 			html += '' | ||||
| 				+ '<td class="charmap">' | ||||
| 				+ '<a onmouseover="previewChar(\'' + charmap[i][1].substring(1,charmap[i][1].length) + '\',\'' + charmap[i][0].substring(1,charmap[i][0].length) + '\',\'' + charmap[i][3] + '\');" onfocus="previewChar(\'' + charmap[i][1].substring(1,charmap[i][1].length) + '\',\'' + charmap[i][0].substring(1,charmap[i][0].length) + '\',\'' + charmap[i][3] + '\');" href="javascript:void(0)" onclick="insertChar(\'' + charmap[i][1].substring(2,charmap[i][1].length-1) + '\');" onclick="return false;" onmousedown="return false;" title="' + charmap[i][3] + '">' | ||||
| 				+ charmap[i][1] | ||||
| 				+ '</a></td>'; | ||||
| 			if ((cols+1) % charsPerRow == 0) | ||||
| 				html += '</tr><tr height="' + tdHeight + '">'; | ||||
| 		} | ||||
| 	 } | ||||
|  | ||||
| 	if (cols % charsPerRow > 0) { | ||||
| 		var padd = charsPerRow - (cols % charsPerRow); | ||||
| 		for (var i=0; i<padd-1; i++) | ||||
| 			html += '<td width="' + tdWidth + '" height="' + tdHeight + '" class="charmap"> </td>'; | ||||
| 	} | ||||
|  | ||||
| 	html += '</tr></table>'; | ||||
|  | ||||
| 	return html; | ||||
| } | ||||
|  | ||||
| function insertChar(chr) { | ||||
| 	tinyMCEPopup.execCommand('mceInsertContent', false, '&#' + chr + ';'); | ||||
|  | ||||
| 	// Refocus in window | ||||
| 	if (tinyMCEPopup.isWindow) | ||||
| 		window.focus(); | ||||
|  | ||||
| 	tinyMCEPopup.editor.focus(); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function previewChar(codeA, codeB, codeN) { | ||||
| 	var elmA = document.getElementById('codeA'); | ||||
| 	var elmB = document.getElementById('codeB'); | ||||
| 	var elmV = document.getElementById('codeV'); | ||||
| 	var elmN = document.getElementById('codeN'); | ||||
|  | ||||
| 	if (codeA=='#160;') { | ||||
| 		elmV.innerHTML = '__'; | ||||
| 	} else { | ||||
| 		elmV.innerHTML = '&' + codeA; | ||||
| 	} | ||||
|  | ||||
| 	elmB.innerHTML = '&' + codeA; | ||||
| 	elmA.innerHTML = '&' + codeB; | ||||
| 	elmN.innerHTML = codeN; | ||||
| } | ||||
| @@ -0,0 +1,253 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var detail = 50, strhex = "0123456789abcdef", i, isMouseDown = false, isMouseOver = false; | ||||
|  | ||||
| var colors = [ | ||||
| 	"#000000","#000033","#000066","#000099","#0000cc","#0000ff","#330000","#330033", | ||||
| 	"#330066","#330099","#3300cc","#3300ff","#660000","#660033","#660066","#660099", | ||||
| 	"#6600cc","#6600ff","#990000","#990033","#990066","#990099","#9900cc","#9900ff", | ||||
| 	"#cc0000","#cc0033","#cc0066","#cc0099","#cc00cc","#cc00ff","#ff0000","#ff0033", | ||||
| 	"#ff0066","#ff0099","#ff00cc","#ff00ff","#003300","#003333","#003366","#003399", | ||||
| 	"#0033cc","#0033ff","#333300","#333333","#333366","#333399","#3333cc","#3333ff", | ||||
| 	"#663300","#663333","#663366","#663399","#6633cc","#6633ff","#993300","#993333", | ||||
| 	"#993366","#993399","#9933cc","#9933ff","#cc3300","#cc3333","#cc3366","#cc3399", | ||||
| 	"#cc33cc","#cc33ff","#ff3300","#ff3333","#ff3366","#ff3399","#ff33cc","#ff33ff", | ||||
| 	"#006600","#006633","#006666","#006699","#0066cc","#0066ff","#336600","#336633", | ||||
| 	"#336666","#336699","#3366cc","#3366ff","#666600","#666633","#666666","#666699", | ||||
| 	"#6666cc","#6666ff","#996600","#996633","#996666","#996699","#9966cc","#9966ff", | ||||
| 	"#cc6600","#cc6633","#cc6666","#cc6699","#cc66cc","#cc66ff","#ff6600","#ff6633", | ||||
| 	"#ff6666","#ff6699","#ff66cc","#ff66ff","#009900","#009933","#009966","#009999", | ||||
| 	"#0099cc","#0099ff","#339900","#339933","#339966","#339999","#3399cc","#3399ff", | ||||
| 	"#669900","#669933","#669966","#669999","#6699cc","#6699ff","#999900","#999933", | ||||
| 	"#999966","#999999","#9999cc","#9999ff","#cc9900","#cc9933","#cc9966","#cc9999", | ||||
| 	"#cc99cc","#cc99ff","#ff9900","#ff9933","#ff9966","#ff9999","#ff99cc","#ff99ff", | ||||
| 	"#00cc00","#00cc33","#00cc66","#00cc99","#00cccc","#00ccff","#33cc00","#33cc33", | ||||
| 	"#33cc66","#33cc99","#33cccc","#33ccff","#66cc00","#66cc33","#66cc66","#66cc99", | ||||
| 	"#66cccc","#66ccff","#99cc00","#99cc33","#99cc66","#99cc99","#99cccc","#99ccff", | ||||
| 	"#cccc00","#cccc33","#cccc66","#cccc99","#cccccc","#ccccff","#ffcc00","#ffcc33", | ||||
| 	"#ffcc66","#ffcc99","#ffcccc","#ffccff","#00ff00","#00ff33","#00ff66","#00ff99", | ||||
| 	"#00ffcc","#00ffff","#33ff00","#33ff33","#33ff66","#33ff99","#33ffcc","#33ffff", | ||||
| 	"#66ff00","#66ff33","#66ff66","#66ff99","#66ffcc","#66ffff","#99ff00","#99ff33", | ||||
| 	"#99ff66","#99ff99","#99ffcc","#99ffff","#ccff00","#ccff33","#ccff66","#ccff99", | ||||
| 	"#ccffcc","#ccffff","#ffff00","#ffff33","#ffff66","#ffff99","#ffffcc","#ffffff" | ||||
| ]; | ||||
|  | ||||
| var named = { | ||||
| 	'#F0F8FF':'AliceBlue','#FAEBD7':'AntiqueWhite','#00FFFF':'Aqua','#7FFFD4':'Aquamarine','#F0FFFF':'Azure','#F5F5DC':'Beige', | ||||
| 	'#FFE4C4':'Bisque','#000000':'Black','#FFEBCD':'BlanchedAlmond','#0000FF':'Blue','#8A2BE2':'BlueViolet','#A52A2A':'Brown', | ||||
| 	'#DEB887':'BurlyWood','#5F9EA0':'CadetBlue','#7FFF00':'Chartreuse','#D2691E':'Chocolate','#FF7F50':'Coral','#6495ED':'CornflowerBlue', | ||||
| 	'#FFF8DC':'Cornsilk','#DC143C':'Crimson','#00FFFF':'Cyan','#00008B':'DarkBlue','#008B8B':'DarkCyan','#B8860B':'DarkGoldenRod', | ||||
| 	'#A9A9A9':'DarkGray','#A9A9A9':'DarkGrey','#006400':'DarkGreen','#BDB76B':'DarkKhaki','#8B008B':'DarkMagenta','#556B2F':'DarkOliveGreen', | ||||
| 	'#FF8C00':'Darkorange','#9932CC':'DarkOrchid','#8B0000':'DarkRed','#E9967A':'DarkSalmon','#8FBC8F':'DarkSeaGreen','#483D8B':'DarkSlateBlue', | ||||
| 	'#2F4F4F':'DarkSlateGray','#2F4F4F':'DarkSlateGrey','#00CED1':'DarkTurquoise','#9400D3':'DarkViolet','#FF1493':'DeepPink','#00BFFF':'DeepSkyBlue', | ||||
| 	'#696969':'DimGray','#696969':'DimGrey','#1E90FF':'DodgerBlue','#B22222':'FireBrick','#FFFAF0':'FloralWhite','#228B22':'ForestGreen', | ||||
| 	'#FF00FF':'Fuchsia','#DCDCDC':'Gainsboro','#F8F8FF':'GhostWhite','#FFD700':'Gold','#DAA520':'GoldenRod','#808080':'Gray','#808080':'Grey', | ||||
| 	'#008000':'Green','#ADFF2F':'GreenYellow','#F0FFF0':'HoneyDew','#FF69B4':'HotPink','#CD5C5C':'IndianRed','#4B0082':'Indigo','#FFFFF0':'Ivory', | ||||
| 	'#F0E68C':'Khaki','#E6E6FA':'Lavender','#FFF0F5':'LavenderBlush','#7CFC00':'LawnGreen','#FFFACD':'LemonChiffon','#ADD8E6':'LightBlue', | ||||
| 	'#F08080':'LightCoral','#E0FFFF':'LightCyan','#FAFAD2':'LightGoldenRodYellow','#D3D3D3':'LightGray','#D3D3D3':'LightGrey','#90EE90':'LightGreen', | ||||
| 	'#FFB6C1':'LightPink','#FFA07A':'LightSalmon','#20B2AA':'LightSeaGreen','#87CEFA':'LightSkyBlue','#778899':'LightSlateGray','#778899':'LightSlateGrey', | ||||
| 	'#B0C4DE':'LightSteelBlue','#FFFFE0':'LightYellow','#00FF00':'Lime','#32CD32':'LimeGreen','#FAF0E6':'Linen','#FF00FF':'Magenta','#800000':'Maroon', | ||||
| 	'#66CDAA':'MediumAquaMarine','#0000CD':'MediumBlue','#BA55D3':'MediumOrchid','#9370D8':'MediumPurple','#3CB371':'MediumSeaGreen','#7B68EE':'MediumSlateBlue', | ||||
| 	'#00FA9A':'MediumSpringGreen','#48D1CC':'MediumTurquoise','#C71585':'MediumVioletRed','#191970':'MidnightBlue','#F5FFFA':'MintCream','#FFE4E1':'MistyRose','#FFE4B5':'Moccasin', | ||||
| 	'#FFDEAD':'NavajoWhite','#000080':'Navy','#FDF5E6':'OldLace','#808000':'Olive','#6B8E23':'OliveDrab','#FFA500':'Orange','#FF4500':'OrangeRed','#DA70D6':'Orchid', | ||||
| 	'#EEE8AA':'PaleGoldenRod','#98FB98':'PaleGreen','#AFEEEE':'PaleTurquoise','#D87093':'PaleVioletRed','#FFEFD5':'PapayaWhip','#FFDAB9':'PeachPuff', | ||||
| 	'#CD853F':'Peru','#FFC0CB':'Pink','#DDA0DD':'Plum','#B0E0E6':'PowderBlue','#800080':'Purple','#FF0000':'Red','#BC8F8F':'RosyBrown','#4169E1':'RoyalBlue', | ||||
| 	'#8B4513':'SaddleBrown','#FA8072':'Salmon','#F4A460':'SandyBrown','#2E8B57':'SeaGreen','#FFF5EE':'SeaShell','#A0522D':'Sienna','#C0C0C0':'Silver', | ||||
| 	'#87CEEB':'SkyBlue','#6A5ACD':'SlateBlue','#708090':'SlateGray','#708090':'SlateGrey','#FFFAFA':'Snow','#00FF7F':'SpringGreen', | ||||
| 	'#4682B4':'SteelBlue','#D2B48C':'Tan','#008080':'Teal','#D8BFD8':'Thistle','#FF6347':'Tomato','#40E0D0':'Turquoise','#EE82EE':'Violet', | ||||
| 	'#F5DEB3':'Wheat','#FFFFFF':'White','#F5F5F5':'WhiteSmoke','#FFFF00':'Yellow','#9ACD32':'YellowGreen' | ||||
| }; | ||||
|  | ||||
| function init() { | ||||
| 	var inputColor = convertRGBToHex(tinyMCEPopup.getWindowArg('input_color')); | ||||
|  | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	generatePicker(); | ||||
|  | ||||
| 	if (inputColor) { | ||||
| 		changeFinalColor(inputColor); | ||||
|  | ||||
| 		col = convertHexToRGB(inputColor); | ||||
|  | ||||
| 		if (col) | ||||
| 			updateLight(col.r, col.g, col.b); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function insertAction() { | ||||
| 	var color = document.getElementById("color").value, f = tinyMCEPopup.getWindowArg('func'); | ||||
|  | ||||
| 	tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 	if (f) | ||||
| 		f(color); | ||||
|  | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function showColor(color, name) { | ||||
| 	if (name) | ||||
| 		document.getElementById("colorname").innerHTML = name; | ||||
|  | ||||
| 	document.getElementById("preview").style.backgroundColor = color; | ||||
| 	document.getElementById("color").value = color.toLowerCase(); | ||||
| } | ||||
|  | ||||
| function convertRGBToHex(col) { | ||||
| 	var re = new RegExp("rgb\\s*\\(\\s*([0-9]+).*,\\s*([0-9]+).*,\\s*([0-9]+).*\\)", "gi"); | ||||
|  | ||||
| 	if (!col) | ||||
| 		return col; | ||||
|  | ||||
| 	var rgb = col.replace(re, "$1,$2,$3").split(','); | ||||
| 	if (rgb.length == 3) { | ||||
| 		r = parseInt(rgb[0]).toString(16); | ||||
| 		g = parseInt(rgb[1]).toString(16); | ||||
| 		b = parseInt(rgb[2]).toString(16); | ||||
|  | ||||
| 		r = r.length == 1 ? '0' + r : r; | ||||
| 		g = g.length == 1 ? '0' + g : g; | ||||
| 		b = b.length == 1 ? '0' + b : b; | ||||
|  | ||||
| 		return "#" + r + g + b; | ||||
| 	} | ||||
|  | ||||
| 	return col; | ||||
| } | ||||
|  | ||||
| function convertHexToRGB(col) { | ||||
| 	if (col.indexOf('#') != -1) { | ||||
| 		col = col.replace(new RegExp('[^0-9A-F]', 'gi'), ''); | ||||
|  | ||||
| 		r = parseInt(col.substring(0, 2), 16); | ||||
| 		g = parseInt(col.substring(2, 4), 16); | ||||
| 		b = parseInt(col.substring(4, 6), 16); | ||||
|  | ||||
| 		return {r : r, g : g, b : b}; | ||||
| 	} | ||||
|  | ||||
| 	return null; | ||||
| } | ||||
|  | ||||
| function generatePicker() { | ||||
| 	var el = document.getElementById('light'), h = '', i; | ||||
|  | ||||
| 	for (i = 0; i < detail; i++){ | ||||
| 		h += '<div id="gs'+i+'" style="background-color:#000000; width:15px; height:3px; border-style:none; border-width:0px;"' | ||||
| 		+ ' onclick="changeFinalColor(this.style.backgroundColor)"' | ||||
| 		+ ' onmousedown="isMouseDown = true; return false;"' | ||||
| 		+ ' onmouseup="isMouseDown = false;"' | ||||
| 		+ ' onmousemove="if (isMouseDown && isMouseOver) changeFinalColor(this.style.backgroundColor); return false;"' | ||||
| 		+ ' onmouseover="isMouseOver = true;"' | ||||
| 		+ ' onmouseout="isMouseOver = false;"' | ||||
| 		+ '></div>'; | ||||
| 	} | ||||
|  | ||||
| 	el.innerHTML = h; | ||||
| } | ||||
|  | ||||
| function generateWebColors() { | ||||
| 	var el = document.getElementById('webcolors'), h = '', i; | ||||
|  | ||||
| 	if (el.className == 'generated') | ||||
| 		return; | ||||
|  | ||||
| 	h += '<table border="0" cellspacing="1" cellpadding="0">' | ||||
| 		+ '<tr>'; | ||||
|  | ||||
| 	for (i=0; i<colors.length; i++) { | ||||
| 		h += '<td bgcolor="' + colors[i] + '" width="10" height="10">' | ||||
| 			+ '<a href="javascript:insertAction();" onfocus="showColor(\'' + colors[i] +  '\');" onmouseover="showColor(\'' + colors[i] +  '\');" style="display:block;width:10px;height:10px;overflow:hidden;">' | ||||
| 			+ '</a></td>'; | ||||
| 		if ((i+1) % 18 == 0) | ||||
| 			h += '</tr><tr>'; | ||||
| 	} | ||||
|  | ||||
| 	h += '</table>'; | ||||
|  | ||||
| 	el.innerHTML = h; | ||||
| 	el.className = 'generated'; | ||||
| } | ||||
|  | ||||
| function generateNamedColors() { | ||||
| 	var el = document.getElementById('namedcolors'), h = '', n, v, i = 0; | ||||
|  | ||||
| 	if (el.className == 'generated') | ||||
| 		return; | ||||
|  | ||||
| 	for (n in named) { | ||||
| 		v = named[n]; | ||||
| 		h += '<a href="javascript:insertAction();" onmouseover="showColor(\'' + n +  '\',\'' + v + '\');" style="background-color: ' + n + '"><!-- IE --></a>' | ||||
| 	} | ||||
|  | ||||
| 	el.innerHTML = h; | ||||
| 	el.className = 'generated'; | ||||
| } | ||||
|  | ||||
| function dechex(n) { | ||||
| 	return strhex.charAt(Math.floor(n / 16)) + strhex.charAt(n % 16); | ||||
| } | ||||
|  | ||||
| function computeColor(e) { | ||||
| 	var x, y, partWidth, partDetail, imHeight, r, g, b, coef, i, finalCoef, finalR, finalG, finalB; | ||||
|  | ||||
| 	x = e.offsetX ? e.offsetX : (e.target ? e.clientX - e.target.x : 0); | ||||
| 	y = e.offsetY ? e.offsetY : (e.target ? e.clientY - e.target.y : 0); | ||||
|  | ||||
| 	partWidth = document.getElementById('colors').width / 6; | ||||
| 	partDetail = detail / 2; | ||||
| 	imHeight = document.getElementById('colors').height; | ||||
|  | ||||
| 	r = (x >= 0)*(x < partWidth)*255 + (x >= partWidth)*(x < 2*partWidth)*(2*255 - x * 255 / partWidth) + (x >= 4*partWidth)*(x < 5*partWidth)*(-4*255 + x * 255 / partWidth) + (x >= 5*partWidth)*(x < 6*partWidth)*255; | ||||
| 	g = (x >= 0)*(x < partWidth)*(x * 255 / partWidth) + (x >= partWidth)*(x < 3*partWidth)*255	+ (x >= 3*partWidth)*(x < 4*partWidth)*(4*255 - x * 255 / partWidth); | ||||
| 	b = (x >= 2*partWidth)*(x < 3*partWidth)*(-2*255 + x * 255 / partWidth) + (x >= 3*partWidth)*(x < 5*partWidth)*255 + (x >= 5*partWidth)*(x < 6*partWidth)*(6*255 - x * 255 / partWidth); | ||||
|  | ||||
| 	coef = (imHeight - y) / imHeight; | ||||
| 	r = 128 + (r - 128) * coef; | ||||
| 	g = 128 + (g - 128) * coef; | ||||
| 	b = 128 + (b - 128) * coef; | ||||
|  | ||||
| 	changeFinalColor('#' + dechex(r) + dechex(g) + dechex(b)); | ||||
| 	updateLight(r, g, b); | ||||
| } | ||||
|  | ||||
| function updateLight(r, g, b) { | ||||
| 	var i, partDetail = detail / 2, finalCoef, finalR, finalG, finalB, color; | ||||
|  | ||||
| 	for (i=0; i<detail; i++) { | ||||
| 		if ((i>=0) && (i<partDetail)) { | ||||
| 			finalCoef = i / partDetail; | ||||
| 			finalR = dechex(255 - (255 - r) * finalCoef); | ||||
| 			finalG = dechex(255 - (255 - g) * finalCoef); | ||||
| 			finalB = dechex(255 - (255 - b) * finalCoef); | ||||
| 		} else { | ||||
| 			finalCoef = 2 - i / partDetail; | ||||
| 			finalR = dechex(r * finalCoef); | ||||
| 			finalG = dechex(g * finalCoef); | ||||
| 			finalB = dechex(b * finalCoef); | ||||
| 		} | ||||
|  | ||||
| 		color = finalR + finalG + finalB; | ||||
|  | ||||
| 		setCol('gs' + i, '#'+color); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function changeFinalColor(color) { | ||||
| 	if (color.indexOf('#') == -1) | ||||
| 		color = convertRGBToHex(color); | ||||
|  | ||||
| 	setCol('preview', color); | ||||
| 	document.getElementById('color').value = color; | ||||
| } | ||||
|  | ||||
| function setCol(e, c) { | ||||
| 	try { | ||||
| 		document.getElementById(e).style.backgroundColor = c; | ||||
| 	} catch (ex) { | ||||
| 		// Ignore IE warning | ||||
| 	} | ||||
| } | ||||
|  | ||||
| tinyMCEPopup.onInit.add(init); | ||||
| @@ -0,0 +1,245 @@ | ||||
| var ImageDialog = { | ||||
| 	preInit : function() { | ||||
| 		var url; | ||||
|  | ||||
| 		tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| 		if (url = tinyMCEPopup.getParam("external_image_list_url")) | ||||
| 			document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>'); | ||||
| 	}, | ||||
|  | ||||
| 	init : function() { | ||||
| 		var f = document.forms[0], ed = tinyMCEPopup.editor; | ||||
|  | ||||
| 		// Setup browse button | ||||
| 		document.getElementById('srcbrowsercontainer').innerHTML = getBrowserHTML('srcbrowser','src','image','theme_advanced_image'); | ||||
| 		if (isVisible('srcbrowser')) | ||||
| 			document.getElementById('src').style.width = '180px'; | ||||
|  | ||||
| 		e = ed.selection.getNode(); | ||||
|  | ||||
| 		this.fillFileList('image_list', 'tinyMCEImageList'); | ||||
|  | ||||
| 		if (e.nodeName == 'IMG') { | ||||
| 			f.src.value = ed.dom.getAttrib(e, 'src'); | ||||
| 			f.alt.value = ed.dom.getAttrib(e, 'alt'); | ||||
| 			f.border.value = this.getAttrib(e, 'border'); | ||||
| 			f.vspace.value = this.getAttrib(e, 'vspace'); | ||||
| 			f.hspace.value = this.getAttrib(e, 'hspace'); | ||||
| 			f.width.value = ed.dom.getAttrib(e, 'width'); | ||||
| 			f.height.value = ed.dom.getAttrib(e, 'height'); | ||||
| 			f.insert.value = ed.getLang('update'); | ||||
| 			this.styleVal = ed.dom.getAttrib(e, 'style'); | ||||
| 			selectByValue(f, 'image_list', f.src.value); | ||||
| 			selectByValue(f, 'align', this.getAttrib(e, 'align')); | ||||
| 			this.updateStyle(); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	fillFileList : function(id, l) { | ||||
| 		var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl; | ||||
|  | ||||
| 		l = window[l]; | ||||
|  | ||||
| 		if (l && l.length > 0) { | ||||
| 			lst.options[lst.options.length] = new Option('', ''); | ||||
|  | ||||
| 			tinymce.each(l, function(o) { | ||||
| 				lst.options[lst.options.length] = new Option(o[0], o[1]); | ||||
| 			}); | ||||
| 		} else | ||||
| 			dom.remove(dom.getParent(id, 'tr')); | ||||
| 	}, | ||||
|  | ||||
| 	update : function() { | ||||
| 		var f = document.forms[0], nl = f.elements, ed = tinyMCEPopup.editor, args = {}, el; | ||||
|  | ||||
| 		tinyMCEPopup.restoreSelection(); | ||||
|  | ||||
| 		if (f.src.value === '') { | ||||
| 			if (ed.selection.getNode().nodeName == 'IMG') { | ||||
| 				ed.dom.remove(ed.selection.getNode()); | ||||
| 				ed.execCommand('mceRepaint'); | ||||
| 			} | ||||
|  | ||||
| 			tinyMCEPopup.close(); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (!ed.settings.inline_styles) { | ||||
| 			args = tinymce.extend(args, { | ||||
| 				vspace : nl.vspace.value, | ||||
| 				hspace : nl.hspace.value, | ||||
| 				border : nl.border.value, | ||||
| 				align : getSelectValue(f, 'align') | ||||
| 			}); | ||||
| 		} else | ||||
| 			args.style = this.styleVal; | ||||
|  | ||||
| 		tinymce.extend(args, { | ||||
| 			src : f.src.value, | ||||
| 			alt : f.alt.value, | ||||
| 			width : f.width.value, | ||||
| 			height : f.height.value | ||||
| 		}); | ||||
|  | ||||
| 		el = ed.selection.getNode(); | ||||
|  | ||||
| 		if (el && el.nodeName == 'IMG') { | ||||
| 			ed.dom.setAttribs(el, args); | ||||
| 		} else { | ||||
| 			ed.execCommand('mceInsertContent', false, '<img id="__mce_tmp" />', {skip_undo : 1}); | ||||
| 			ed.dom.setAttribs('__mce_tmp', args); | ||||
| 			ed.dom.setAttrib('__mce_tmp', 'id', ''); | ||||
| 			ed.undoManager.add(); | ||||
| 		} | ||||
|  | ||||
| 		tinyMCEPopup.close(); | ||||
| 	}, | ||||
|  | ||||
| 	updateStyle : function() { | ||||
| 		var dom = tinyMCEPopup.dom, st, v, f = document.forms[0]; | ||||
|  | ||||
| 		if (tinyMCEPopup.editor.settings.inline_styles) { | ||||
| 			st = tinyMCEPopup.dom.parseStyle(this.styleVal); | ||||
|  | ||||
| 			// Handle align | ||||
| 			v = getSelectValue(f, 'align'); | ||||
| 			if (v) { | ||||
| 				if (v == 'left' || v == 'right') { | ||||
| 					st['float'] = v; | ||||
| 					delete st['vertical-align']; | ||||
| 				} else { | ||||
| 					st['vertical-align'] = v; | ||||
| 					delete st['float']; | ||||
| 				} | ||||
| 			} else { | ||||
| 				delete st['float']; | ||||
| 				delete st['vertical-align']; | ||||
| 			} | ||||
|  | ||||
| 			// Handle border | ||||
| 			v = f.border.value; | ||||
| 			if (v || v == '0') { | ||||
| 				if (v == '0') | ||||
| 					st['border'] = '0'; | ||||
| 				else | ||||
| 					st['border'] = v + 'px solid black'; | ||||
| 			} else | ||||
| 				delete st['border']; | ||||
|  | ||||
| 			// Handle hspace | ||||
| 			v = f.hspace.value; | ||||
| 			if (v) { | ||||
| 				delete st['margin']; | ||||
| 				st['margin-left'] = v + 'px'; | ||||
| 				st['margin-right'] = v + 'px'; | ||||
| 			} else { | ||||
| 				delete st['margin-left']; | ||||
| 				delete st['margin-right']; | ||||
| 			} | ||||
|  | ||||
| 			// Handle vspace | ||||
| 			v = f.vspace.value; | ||||
| 			if (v) { | ||||
| 				delete st['margin']; | ||||
| 				st['margin-top'] = v + 'px'; | ||||
| 				st['margin-bottom'] = v + 'px'; | ||||
| 			} else { | ||||
| 				delete st['margin-top']; | ||||
| 				delete st['margin-bottom']; | ||||
| 			} | ||||
|  | ||||
| 			// Merge | ||||
| 			st = tinyMCEPopup.dom.parseStyle(dom.serializeStyle(st)); | ||||
| 			this.styleVal = dom.serializeStyle(st); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	getAttrib : function(e, at) { | ||||
| 		var ed = tinyMCEPopup.editor, dom = ed.dom, v, v2; | ||||
|  | ||||
| 		if (ed.settings.inline_styles) { | ||||
| 			switch (at) { | ||||
| 				case 'align': | ||||
| 					if (v = dom.getStyle(e, 'float')) | ||||
| 						return v; | ||||
|  | ||||
| 					if (v = dom.getStyle(e, 'vertical-align')) | ||||
| 						return v; | ||||
|  | ||||
| 					break; | ||||
|  | ||||
| 				case 'hspace': | ||||
| 					v = dom.getStyle(e, 'margin-left') | ||||
| 					v2 = dom.getStyle(e, 'margin-right'); | ||||
| 					if (v && v == v2) | ||||
| 						return parseInt(v.replace(/[^0-9]/g, '')); | ||||
|  | ||||
| 					break; | ||||
|  | ||||
| 				case 'vspace': | ||||
| 					v = dom.getStyle(e, 'margin-top') | ||||
| 					v2 = dom.getStyle(e, 'margin-bottom'); | ||||
| 					if (v && v == v2) | ||||
| 						return parseInt(v.replace(/[^0-9]/g, '')); | ||||
|  | ||||
| 					break; | ||||
|  | ||||
| 				case 'border': | ||||
| 					v = 0; | ||||
|  | ||||
| 					tinymce.each(['top', 'right', 'bottom', 'left'], function(sv) { | ||||
| 						sv = dom.getStyle(e, 'border-' + sv + '-width'); | ||||
|  | ||||
| 						// False or not the same as prev | ||||
| 						if (!sv || (sv != v && v !== 0)) { | ||||
| 							v = 0; | ||||
| 							return false; | ||||
| 						} | ||||
|  | ||||
| 						if (sv) | ||||
| 							v = sv; | ||||
| 					}); | ||||
|  | ||||
| 					if (v) | ||||
| 						return parseInt(v.replace(/[^0-9]/g, '')); | ||||
|  | ||||
| 					break; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if (v = dom.getAttrib(e, at)) | ||||
| 			return v; | ||||
|  | ||||
| 		return ''; | ||||
| 	}, | ||||
|  | ||||
| 	resetImageData : function() { | ||||
| 		var f = document.forms[0]; | ||||
|  | ||||
| 		f.width.value = f.height.value = "";	 | ||||
| 	}, | ||||
|  | ||||
| 	updateImageData : function() { | ||||
| 		var f = document.forms[0], t = ImageDialog; | ||||
|  | ||||
| 		if (f.width.value == "") | ||||
| 			f.width.value = t.preloadImg.width; | ||||
|  | ||||
| 		if (f.height.value == "") | ||||
| 			f.height.value = t.preloadImg.height; | ||||
| 	}, | ||||
|  | ||||
| 	getImageData : function() { | ||||
| 		var f = document.forms[0]; | ||||
|  | ||||
| 		this.preloadImg = new Image(); | ||||
| 		this.preloadImg.onload = this.updateImageData; | ||||
| 		this.preloadImg.onerror = this.resetImageData; | ||||
| 		this.preloadImg.src = tinyMCEPopup.editor.documentBaseURI.toAbsolute(f.src.value); | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| ImageDialog.preInit(); | ||||
| tinyMCEPopup.onInit.add(ImageDialog.init, ImageDialog); | ||||
| @@ -0,0 +1,155 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
|  | ||||
| var LinkDialog = { | ||||
| 	preInit : function() { | ||||
| 		var url; | ||||
|  | ||||
| 		if (url = tinyMCEPopup.getParam("external_link_list_url")) | ||||
| 			document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>'); | ||||
| 	}, | ||||
|  | ||||
| 	init : function() { | ||||
| 		var f = document.forms[0], ed = tinyMCEPopup.editor; | ||||
|  | ||||
| 		// Setup browse button | ||||
| 		document.getElementById('hrefbrowsercontainer').innerHTML = getBrowserHTML('hrefbrowser', 'href', 'file', 'theme_advanced_link'); | ||||
| 		if (isVisible('hrefbrowser')) | ||||
| 			document.getElementById('href').style.width = '180px'; | ||||
|  | ||||
| 		this.fillClassList('class_list'); | ||||
| 		this.fillFileList('link_list', 'tinyMCELinkList'); | ||||
| 		this.fillTargetList('target_list'); | ||||
|  | ||||
| 		if (e = ed.dom.getParent(ed.selection.getNode(), 'A')) { | ||||
| 			f.href.value = ed.dom.getAttrib(e, 'href'); | ||||
| 			f.linktitle.value = ed.dom.getAttrib(e, 'title'); | ||||
| 			f.insert.value = ed.getLang('update'); | ||||
| 			selectByValue(f, 'link_list', f.href.value); | ||||
| 			selectByValue(f, 'target_list', ed.dom.getAttrib(e, 'target')); | ||||
| 			selectByValue(f, 'class_list', ed.dom.getAttrib(e, 'class')); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	update : function() { | ||||
| 		var f = document.forms[0], ed = tinyMCEPopup.editor, e, b; | ||||
|  | ||||
| 		tinyMCEPopup.restoreSelection(); | ||||
| 		e = ed.dom.getParent(ed.selection.getNode(), 'A'); | ||||
|  | ||||
| 		// Remove element if there is no href | ||||
| 		if (!f.href.value) { | ||||
| 			if (e) { | ||||
| 				tinyMCEPopup.execCommand("mceBeginUndoLevel"); | ||||
| 				b = ed.selection.getBookmark(); | ||||
| 				ed.dom.remove(e, 1); | ||||
| 				ed.selection.moveToBookmark(b); | ||||
| 				tinyMCEPopup.execCommand("mceEndUndoLevel"); | ||||
| 				tinyMCEPopup.close(); | ||||
| 				return; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		tinyMCEPopup.execCommand("mceBeginUndoLevel"); | ||||
|  | ||||
| 		// Create new anchor elements | ||||
| 		if (e == null) { | ||||
| 			tinyMCEPopup.execCommand("CreateLink", false, "#mce_temp_url#", {skip_undo : 1}); | ||||
|  | ||||
| 			tinymce.each(ed.dom.select("a"), function(n) { | ||||
| 				if (ed.dom.getAttrib(n, 'href') == '#mce_temp_url#') { | ||||
| 					e = n; | ||||
|  | ||||
| 					ed.dom.setAttribs(e, { | ||||
| 						href : f.href.value, | ||||
| 						title : f.linktitle.value, | ||||
| 						target : f.target_list ? f.target_list.options[f.target_list.selectedIndex].value : null, | ||||
| 						'class' : f.class_list ? f.class_list.options[f.class_list.selectedIndex].value : null | ||||
| 					}); | ||||
| 				} | ||||
| 			}); | ||||
| 		} else { | ||||
| 			ed.dom.setAttribs(e, { | ||||
| 				href : f.href.value, | ||||
| 				title : f.linktitle.value, | ||||
| 				target : f.target_list ? f.target_list.options[f.target_list.selectedIndex].value : null, | ||||
| 				'class' : f.class_list ? f.class_list.options[f.class_list.selectedIndex].value : null | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		// Don't move caret if selection was image | ||||
| 		if (e.childNodes.length != 1 || e.firstChild.nodeName != 'IMG') { | ||||
| 			ed.focus(); | ||||
| 			ed.selection.select(e); | ||||
| 			ed.selection.collapse(0); | ||||
| 			tinyMCEPopup.storeSelection(); | ||||
| 		} | ||||
|  | ||||
| 		tinyMCEPopup.execCommand("mceEndUndoLevel"); | ||||
| 		tinyMCEPopup.close(); | ||||
| 	}, | ||||
|  | ||||
| 	checkPrefix : function(n) { | ||||
| 		if (n.value && Validator.isEmail(n) && !/^\s*mailto:/i.test(n.value) && confirm(tinyMCEPopup.getLang('advanced_dlg.link_is_email'))) | ||||
| 			n.value = 'mailto:' + n.value; | ||||
|  | ||||
| 		if (/^\s*www./i.test(n.value) && confirm(tinyMCEPopup.getLang('advanced_dlg.link_is_external'))) | ||||
| 			n.value = 'http://' + n.value; | ||||
| 	}, | ||||
|  | ||||
| 	fillFileList : function(id, l) { | ||||
| 		var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl; | ||||
|  | ||||
| 		l = window[l]; | ||||
|  | ||||
| 		if (l && l.length > 0) { | ||||
| 			lst.options[lst.options.length] = new Option('', ''); | ||||
|  | ||||
| 			tinymce.each(l, function(o) { | ||||
| 				lst.options[lst.options.length] = new Option(o[0], o[1]); | ||||
| 			}); | ||||
| 		} else | ||||
| 			dom.remove(dom.getParent(id, 'tr')); | ||||
| 	}, | ||||
|  | ||||
| 	fillClassList : function(id) { | ||||
| 		var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl; | ||||
|  | ||||
| 		if (v = tinyMCEPopup.getParam('theme_advanced_styles')) { | ||||
| 			cl = []; | ||||
|  | ||||
| 			tinymce.each(v.split(';'), function(v) { | ||||
| 				var p = v.split('='); | ||||
|  | ||||
| 				cl.push({'title' : p[0], 'class' : p[1]}); | ||||
| 			}); | ||||
| 		} else | ||||
| 			cl = tinyMCEPopup.editor.dom.getClasses(); | ||||
|  | ||||
| 		if (cl.length > 0) { | ||||
| 			lst.options[lst.options.length] = new Option(tinyMCEPopup.getLang('not_set'), ''); | ||||
|  | ||||
| 			tinymce.each(cl, function(o) { | ||||
| 				lst.options[lst.options.length] = new Option(o.title || o['class'], o['class']); | ||||
| 			}); | ||||
| 		} else | ||||
| 			dom.remove(dom.getParent(id, 'tr')); | ||||
| 	}, | ||||
|  | ||||
| 	fillTargetList : function(id) { | ||||
| 		var dom = tinyMCEPopup.dom, lst = dom.get(id), v; | ||||
|  | ||||
| 		lst.options[lst.options.length] = new Option(tinyMCEPopup.getLang('not_set'), ''); | ||||
| 		lst.options[lst.options.length] = new Option(tinyMCEPopup.getLang('advanced_dlg.link_target_same'), '_self'); | ||||
| 		lst.options[lst.options.length] = new Option(tinyMCEPopup.getLang('advanced_dlg.link_target_blank'), '_blank'); | ||||
|  | ||||
| 		if (v = tinyMCEPopup.getParam('theme_advanced_link_targets')) { | ||||
| 			tinymce.each(v.split(','), function(v) { | ||||
| 				v = v.split('='); | ||||
| 				lst.options[lst.options.length] = new Option(v[0], v[1]); | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| LinkDialog.preInit(); | ||||
| tinyMCEPopup.onInit.add(LinkDialog.init, LinkDialog); | ||||
| @@ -0,0 +1,62 @@ | ||||
| tinyMCEPopup.requireLangPack(); | ||||
| tinyMCEPopup.onInit.add(onLoadInit); | ||||
|  | ||||
| function saveContent() { | ||||
| 	tinyMCEPopup.editor.setContent(document.getElementById('htmlSource').value); | ||||
| 	tinyMCEPopup.close(); | ||||
| } | ||||
|  | ||||
| function onLoadInit() { | ||||
| 	tinyMCEPopup.resizeToInnerSize(); | ||||
|  | ||||
| 	// Remove Gecko spellchecking | ||||
| 	if (tinymce.isGecko) | ||||
| 		document.body.spellcheck = tinyMCEPopup.editor.getParam("gecko_spellcheck"); | ||||
|  | ||||
| 	document.getElementById('htmlSource').value = tinyMCEPopup.editor.getContent(); | ||||
|  | ||||
| 	if (tinyMCEPopup.editor.getParam("theme_advanced_source_editor_wrap", true)) { | ||||
| 		setWrap('soft'); | ||||
| 		document.getElementById('wraped').checked = true; | ||||
| 	} | ||||
|  | ||||
| 	resizeInputs(); | ||||
| } | ||||
|  | ||||
| function setWrap(val) { | ||||
| 	var v, n, s = document.getElementById('htmlSource'); | ||||
|  | ||||
| 	s.wrap = val; | ||||
|  | ||||
| 	if (!tinymce.isIE) { | ||||
| 		v = s.value; | ||||
| 		n = s.cloneNode(false); | ||||
| 		n.setAttribute("wrap", val); | ||||
| 		s.parentNode.replaceChild(n, s); | ||||
| 		n.value = v; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function toggleWordWrap(elm) { | ||||
| 	if (elm.checked) | ||||
| 		setWrap('soft'); | ||||
| 	else | ||||
| 		setWrap('off'); | ||||
| } | ||||
|  | ||||
| var wHeight=0, wWidth=0, owHeight=0, owWidth=0; | ||||
|  | ||||
| function resizeInputs() { | ||||
| 	var el = document.getElementById('htmlSource'); | ||||
|  | ||||
| 	if (!tinymce.isIE) { | ||||
| 		 wHeight = self.innerHeight - 65; | ||||
| 		 wWidth = self.innerWidth - 16; | ||||
| 	} else { | ||||
| 		 wHeight = document.body.clientHeight - 70; | ||||
| 		 wWidth = document.body.clientWidth - 16; | ||||
| 	} | ||||
|  | ||||
| 	el.style.height = Math.abs(wHeight) + 'px'; | ||||
| 	el.style.width  = Math.abs(wWidth) + 'px'; | ||||
| } | ||||
| @@ -0,0 +1,62 @@ | ||||
| tinyMCE.addI18n('en.advanced',{ | ||||
| style_select:"Styles", | ||||
| font_size:"Font size", | ||||
| fontdefault:"Font family", | ||||
| block:"Format", | ||||
| paragraph:"Paragraph", | ||||
| div:"Div", | ||||
| address:"Address", | ||||
| pre:"Preformatted", | ||||
| h1:"Heading 1", | ||||
| h2:"Heading 2", | ||||
| h3:"Heading 3", | ||||
| h4:"Heading 4", | ||||
| h5:"Heading 5", | ||||
| h6:"Heading 6", | ||||
| blockquote:"Blockquote", | ||||
| code:"Code", | ||||
| samp:"Code sample", | ||||
| dt:"Definition term ", | ||||
| dd:"Definition description", | ||||
| bold_desc:"Bold (Ctrl+B)", | ||||
| italic_desc:"Italic (Ctrl+I)", | ||||
| underline_desc:"Underline (Ctrl+U)", | ||||
| striketrough_desc:"Strikethrough", | ||||
| justifyleft_desc:"Align left", | ||||
| justifycenter_desc:"Align center", | ||||
| justifyright_desc:"Align right", | ||||
| justifyfull_desc:"Align full", | ||||
| bullist_desc:"Unordered list", | ||||
| numlist_desc:"Ordered list", | ||||
| outdent_desc:"Outdent", | ||||
| indent_desc:"Indent", | ||||
| undo_desc:"Undo (Ctrl+Z)", | ||||
| redo_desc:"Redo (Ctrl+Y)", | ||||
| link_desc:"Insert/edit link", | ||||
| unlink_desc:"Unlink", | ||||
| image_desc:"Insert/edit image", | ||||
| cleanup_desc:"Cleanup messy code", | ||||
| code_desc:"Edit HTML Source", | ||||
| sub_desc:"Subscript", | ||||
| sup_desc:"Superscript", | ||||
| hr_desc:"Insert horizontal ruler", | ||||
| removeformat_desc:"Remove formatting", | ||||
| custom1_desc:"Your custom description here", | ||||
| forecolor_desc:"Select text color", | ||||
| backcolor_desc:"Select background color", | ||||
| charmap_desc:"Insert custom character", | ||||
| visualaid_desc:"Toggle guidelines/invisible elements", | ||||
| anchor_desc:"Insert/edit anchor", | ||||
| cut_desc:"Cut", | ||||
| copy_desc:"Copy", | ||||
| paste_desc:"Paste", | ||||
| image_props_desc:"Image properties", | ||||
| newdocument_desc:"New document", | ||||
| help_desc:"Help", | ||||
| blockquote_desc:"Blockquote", | ||||
| clipboard_msg:"Copy/Cut/Paste is not available in Mozilla and Firefox.\r\nDo you want more information about this issue?", | ||||
| path:"Path", | ||||
| newdocument:"Are you sure you want clear all contents?", | ||||
| toolbar_focus:"Jump to tool buttons - Alt+Q, Jump to editor - Alt-Z, Jump to element path - Alt-X", | ||||
| more_colors:"More colors" | ||||
| }); | ||||
| @@ -0,0 +1,51 @@ | ||||
| tinyMCE.addI18n('en.advanced_dlg',{ | ||||
| about_title:"About TinyMCE", | ||||
| about_general:"About", | ||||
| about_help:"Help", | ||||
| about_license:"License", | ||||
| about_plugins:"Plugins", | ||||
| about_plugin:"Plugin", | ||||
| about_author:"Author", | ||||
| about_version:"Version", | ||||
| about_loaded:"Loaded plugins", | ||||
| anchor_title:"Insert/edit anchor", | ||||
| anchor_name:"Anchor name", | ||||
| code_title:"HTML Source Editor", | ||||
| code_wordwrap:"Word wrap", | ||||
| colorpicker_title:"Select a color", | ||||
| colorpicker_picker_tab:"Picker", | ||||
| colorpicker_picker_title:"Color picker", | ||||
| colorpicker_palette_tab:"Palette", | ||||
| colorpicker_palette_title:"Palette colors", | ||||
| colorpicker_named_tab:"Named", | ||||
| colorpicker_named_title:"Named colors", | ||||
| colorpicker_color:"Color:", | ||||
| colorpicker_name:"Name:", | ||||
| charmap_title:"Select custom character", | ||||
| image_title:"Insert/edit image", | ||||
| image_src:"Image URL", | ||||
| image_alt:"Image description", | ||||
| image_list:"Image list", | ||||
| image_border:"Border", | ||||
| image_dimensions:"Dimensions", | ||||
| image_vspace:"Vertical space", | ||||
| image_hspace:"Horizontal space", | ||||
| image_align:"Alignment", | ||||
| image_align_baseline:"Baseline", | ||||
| image_align_top:"Top", | ||||
| image_align_middle:"Middle", | ||||
| image_align_bottom:"Bottom", | ||||
| image_align_texttop:"Text top", | ||||
| image_align_textbottom:"Text bottom", | ||||
| image_align_left:"Left", | ||||
| image_align_right:"Right", | ||||
| link_title:"Insert/edit link", | ||||
| link_url:"Link URL", | ||||
| link_target:"Target", | ||||
| link_target_same:"Open link in the same window", | ||||
| link_target_blank:"Open link in a new window", | ||||
| link_titlefield:"Title", | ||||
| link_is_email:"The URL you entered seems to be an email address, do you want to add the required mailto: prefix?", | ||||
| link_is_external:"The URL you entered seems to external link, do you want to add the required http:// prefix?", | ||||
| link_list:"Link list" | ||||
| }); | ||||
| @@ -0,0 +1,64 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<title>{#advanced_dlg.link_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/mctabs.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/form_utils.js"></script> | ||||
| 	<script type="text/javascript" src="../../utils/validate.js"></script> | ||||
| 	<script type="text/javascript" src="js/link.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body id="link" style="display: none"> | ||||
| <form onsubmit="LinkDialog.update();return false;" action="#"> | ||||
| 	<div class="tabs"> | ||||
| 		<ul> | ||||
| 			<li id="general_tab" class="current"><span><a href="javascript:mcTabs.displayTab('general_tab','general_panel');" onmousedown="return false;">{#advanced_dlg.link_title}</a></span></li> | ||||
| 		</ul> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="panel_wrapper"> | ||||
| 		<div id="general_panel" class="panel current"> | ||||
|  | ||||
| 		<table border="0" cellpadding="4" cellspacing="0"> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="href">{#advanced_dlg.link_url}</label></td> | ||||
|             <td><table border="0" cellspacing="0" cellpadding="0">  | ||||
| 				  <tr>  | ||||
| 					<td><input id="href" name="href" type="text" class="mceFocus" value="" style="width: 200px" onchange="LinkDialog.checkPrefix(this);" /></td>  | ||||
| 					<td id="hrefbrowsercontainer"> </td> | ||||
| 				  </tr>  | ||||
| 				</table></td> | ||||
|           </tr> | ||||
| 		  <tr> | ||||
| 			<td><label for="link_list">{#advanced_dlg.link_list}</label></td> | ||||
| 			<td><select id="link_list" name="link_list" onchange="document.getElementById('href').value=this.options[this.selectedIndex].value;"></select></td> | ||||
| 		  </tr> | ||||
| 		<tr> | ||||
| 			<td><label id="targetlistlabel" for="targetlist">{#advanced_dlg.link_target}</label></td> | ||||
| 			<td><select id="target_list" name="target_list"></select></td> | ||||
| 		</tr> | ||||
|           <tr> | ||||
|             <td nowrap="nowrap"><label for="linktitle">{#advanced_dlg.link_titlefield}</label></td> | ||||
|             <td><input id="linktitle" name="linktitle" type="text" value="" style="width: 200px" /></td> | ||||
|           </tr> | ||||
| 			<tr> | ||||
| 				<td><label for="class_list">{#class_name}</label></td> | ||||
| 				<td><select id="class_list" name="class_list"></select></td> | ||||
| 			</tr> | ||||
|         </table> | ||||
| 		</div> | ||||
| 	</div> | ||||
|  | ||||
| 	<div class="mceActionPanel"> | ||||
| 		<div style="float: left"> | ||||
| 			<input type="submit" id="insert" name="insert" value="{#insert}" /> | ||||
| 		</div> | ||||
|  | ||||
| 		<div style="float: right"> | ||||
| 			<input type="button" id="cancel" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" /> | ||||
| 		</div> | ||||
| 	</div> | ||||
| </form> | ||||
| </body> | ||||
| </html> | ||||
| After Width: | Height: | Size: 3.2 KiB | 
| After Width: | Height: | Size: 70 B | 
| After Width: | Height: | Size: 68 B | 
| After Width: | Height: | Size: 70 B | 
| After Width: | Height: | Size: 1.7 KiB | 
| After Width: | Height: | Size: 1.3 KiB | 
| @@ -0,0 +1,32 @@ | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| 	<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> | ||||
| 	<title>{#advanced_dlg.code_title}</title> | ||||
| 	<script type="text/javascript" src="../../tiny_mce_popup.js"></script> | ||||
| 	<script type="text/javascript" src="js/source_editor.js"></script> | ||||
| 	<base target="_self" /> | ||||
| </head> | ||||
| <body onresize="resizeInputs();" style="display:none; overflow:hidden;"> | ||||
| 	<form name="source" onsubmit="saveContent();return false;" action="#"> | ||||
| 		<div style="float: left" class="title">{#advanced_dlg.code_title}</div> | ||||
|  | ||||
| 		<div id="wrapline" style="float: right"> | ||||
| 			<input type="checkbox" name="wraped" id="wraped" onclick="toggleWordWrap(this);" class="wordWrapCode" /><label for="wraped">{#advanced_dlg.code_wordwrap}</label> | ||||
| 		</div> | ||||
|  | ||||
| 		<br style="clear: both" /> | ||||
|  | ||||
| 		<textarea name="htmlSource" id="htmlSource" rows="15" cols="100" style="width: 100%; height: 100%; font-family: 'Courier New',Courier,monospace; font-size: 12px;" dir="ltr" wrap="off" class="mceFocus"></textarea> | ||||
|  | ||||
| 		<div class="mceActionPanel"> | ||||
| 			<div style="float: left"> | ||||
| 				<input type="submit" name="insert" value="{#update}" id="insert" /> | ||||
| 			</div> | ||||
|  | ||||
| 			<div style="float: right"> | ||||
| 				<input type="button" name="cancel" value="{#cancel}" onclick="tinyMCEPopup.close();" id="cancel" /> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</form> | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										1
									
								
								site/forum.slowtwitch.com/www/static/fileman/tinymce/tiny_mce.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										275
									
								
								site/forum.slowtwitch.com/www/static/fileman/tinymce/tiny_mce_popup.js
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,275 @@ | ||||
| // Some global instances | ||||
| var tinymce = null, tinyMCEPopup, tinyMCE; | ||||
|  | ||||
| tinyMCEPopup = { | ||||
| 	init : function() { | ||||
| 		var t = this, w, ti, li, q, i, it; | ||||
|  | ||||
| 		li = ('' + document.location.search).replace(/^\?/, '').split('&'); | ||||
| 		q = {}; | ||||
| 		for (i=0; i<li.length; i++) { | ||||
| 			it = li[i].split('='); | ||||
| 			q[unescape(it[0])] = unescape(it[1]); | ||||
| 		} | ||||
|  | ||||
| 		if (q.mce_rdomain) | ||||
| 			document.domain = q.mce_rdomain; | ||||
|  | ||||
| 		// Find window & API | ||||
| 		w = t.getWin(); | ||||
| 		tinymce = w.tinymce; | ||||
| 		tinyMCE = w.tinyMCE; | ||||
| 		t.editor = tinymce.EditorManager.activeEditor; | ||||
| 		t.params = t.editor.windowManager.params; | ||||
|  | ||||
| 		// Setup local DOM | ||||
| 		t.dom = t.editor.windowManager.createInstance('tinymce.dom.DOMUtils', document); | ||||
| 		t.dom.loadCSS(t.editor.settings.popup_css); | ||||
|  | ||||
| 		// Setup on init listeners | ||||
| 		t.listeners = []; | ||||
| 		t.onInit = { | ||||
| 			add : function(f, s) { | ||||
| 				t.listeners.push({func : f, scope : s}); | ||||
| 			} | ||||
| 		}; | ||||
|  | ||||
| 		t.isWindow = !t.getWindowArg('mce_inline'); | ||||
| 		t.id = t.getWindowArg('mce_window_id'); | ||||
| 		t.editor.windowManager.onOpen.dispatch(t.editor.windowManager, window); | ||||
| 	}, | ||||
|  | ||||
| 	getWin : function() { | ||||
| 		return window.dialogArguments || opener || parent || top; | ||||
| 	}, | ||||
|  | ||||
| 	getWindowArg : function(n, dv) { | ||||
| 		var v = this.params[n]; | ||||
|  | ||||
| 		return tinymce.is(v) ? v : dv; | ||||
| 	}, | ||||
|  | ||||
| 	getParam : function(n, dv) { | ||||
| 		return this.editor.getParam(n, dv); | ||||
| 	}, | ||||
|  | ||||
| 	getLang : function(n, dv) { | ||||
| 		return this.editor.getLang(n, dv); | ||||
| 	}, | ||||
|  | ||||
| 	execCommand : function(cmd, ui, val, a) { | ||||
| 		a = a || {}; | ||||
| 		a.skip_focus = 1; | ||||
|  | ||||
| 		this.restoreSelection(); | ||||
| 		return this.editor.execCommand(cmd, ui, val, a); | ||||
| 	}, | ||||
|  | ||||
| 	resizeToInnerSize : function() { | ||||
| 		var t = this, n, b = document.body, vp = t.dom.getViewPort(window), dw, dh; | ||||
|  | ||||
| 		dw = t.getWindowArg('mce_width') - vp.w; | ||||
| 		dh = t.getWindowArg('mce_height') - vp.h; | ||||
|  | ||||
| 		if (t.isWindow) | ||||
| 			window.resizeBy(dw, dh); | ||||
| 		else | ||||
| 			t.editor.windowManager.resizeBy(dw, dh, t.id); | ||||
| 	}, | ||||
|  | ||||
| 	executeOnLoad : function(s) { | ||||
| 		this.onInit.add(function() { | ||||
| 			eval(s); | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	storeSelection : function() { | ||||
| 		this.editor.windowManager.bookmark = tinyMCEPopup.editor.selection.getBookmark('simple'); | ||||
| 	}, | ||||
|  | ||||
| 	restoreSelection : function() { | ||||
| 		var t = tinyMCEPopup; | ||||
|  | ||||
| 		if (!t.isWindow && tinymce.isIE) | ||||
| 			t.editor.selection.moveToBookmark(t.editor.windowManager.bookmark); | ||||
| 	}, | ||||
|  | ||||
| 	requireLangPack : function() { | ||||
| 		var u = this.getWindowArg('plugin_url') || this.getWindowArg('theme_url'); | ||||
|  | ||||
| 		if (u && this.editor.settings.language) { | ||||
| 			u += '/langs/' + this.editor.settings.language + '_dlg.js'; | ||||
|  | ||||
| 			if (!tinymce.ScriptLoader.isDone(u)) { | ||||
| 				document.write('<script type="text/javascript" src="' + tinymce._addVer(u) + '"></script>'); | ||||
| 				tinymce.ScriptLoader.markDone(u); | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	pickColor : function(e, element_id) { | ||||
| 		this.execCommand('mceColorPicker', true, { | ||||
| 			color : document.getElementById(element_id).value, | ||||
| 			func : function(c) { | ||||
| 				document.getElementById(element_id).value = c; | ||||
|  | ||||
| 				try { | ||||
| 					document.getElementById(element_id).onchange(); | ||||
| 				} catch (ex) { | ||||
| 					// Try fire event, ignore errors | ||||
| 				} | ||||
| 			} | ||||
| 		}); | ||||
| 	}, | ||||
|  | ||||
| 	openBrowser : function(element_id, type, option) { | ||||
| 		tinyMCEPopup.restoreSelection(); | ||||
| 		this.editor.execCallback('file_browser_callback', element_id, document.getElementById(element_id).value, type, window); | ||||
| 	}, | ||||
|  | ||||
| 	close : function() { | ||||
| 		var t = this; | ||||
|  | ||||
| 		// To avoid domain relaxing issue in Opera | ||||
| 		function close() { | ||||
| 			t.editor.windowManager.close(window); | ||||
| 			tinymce = tinyMCE = t.editor = t.params = t.dom = t.dom.doc = null; // Cleanup | ||||
| 		}; | ||||
|  | ||||
| 		if (tinymce.isOpera) | ||||
| 			t.getWin().setTimeout(close, 0); | ||||
| 		else | ||||
| 			close(); | ||||
| 	}, | ||||
|  | ||||
| 	// Internal functions	 | ||||
|  | ||||
| 	_restoreSelection : function() { | ||||
| 		var e = window.event.srcElement; | ||||
|  | ||||
| 		if (e.nodeName == 'INPUT' && (e.type == 'submit' || e.type == 'button')) | ||||
| 			tinyMCEPopup.restoreSelection(); | ||||
| 	}, | ||||
|  | ||||
| /*	_restoreSelection : function() { | ||||
| 		var e = window.event.srcElement; | ||||
|  | ||||
| 		// If user focus a non text input or textarea | ||||
| 		if ((e.nodeName != 'INPUT' && e.nodeName != 'TEXTAREA') || e.type != 'text') | ||||
| 			tinyMCEPopup.restoreSelection(); | ||||
| 	},*/ | ||||
|  | ||||
| 	_onDOMLoaded : function() { | ||||
| 		var t = this, ti = document.title, bm, h; | ||||
|  | ||||
| 		// Translate page | ||||
| 		h = document.body.innerHTML; | ||||
|  | ||||
| 		// Replace a=x with a="x" in IE | ||||
| 		if (tinymce.isIE) | ||||
| 			h = h.replace(/ (value|title|alt)=([^"][^\s>]+)/gi, ' $1="$2"') | ||||
|  | ||||
| 		document.dir = t.editor.getParam('directionality',''); | ||||
| 		document.body.innerHTML = t.editor.translate(h); | ||||
| 		document.title = ti = t.editor.translate(ti); | ||||
| 		document.body.style.display = ''; | ||||
|  | ||||
| 		// Restore selection in IE when focus is placed on a non textarea or input element of the type text | ||||
| 		if (tinymce.isIE) | ||||
| 			document.attachEvent('onmouseup', tinyMCEPopup._restoreSelection); | ||||
|  | ||||
| 		t.restoreSelection(); | ||||
| 		t.resizeToInnerSize(); | ||||
|  | ||||
| 		// Set inline title | ||||
| 		if (!t.isWindow) | ||||
| 			t.editor.windowManager.setTitle(window, ti); | ||||
| 		else | ||||
| 			window.focus(); | ||||
|  | ||||
| 		if (!tinymce.isIE && !t.isWindow) { | ||||
| 			tinymce.dom.Event._add(document, 'focus', function() { | ||||
| 				t.editor.windowManager.focus(t.id) | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		// Patch for accessibility | ||||
| 		tinymce.each(t.dom.select('select'), function(e) { | ||||
| 			e.onkeydown = tinyMCEPopup._accessHandler; | ||||
| 		}); | ||||
|  | ||||
| 		// Call onInit | ||||
| 		// Init must be called before focus so the selection won't get lost by the focus call | ||||
| 		tinymce.each(t.listeners, function(o) { | ||||
| 			o.func.call(o.scope, t.editor); | ||||
| 		}); | ||||
|  | ||||
| 		// Move focus to window | ||||
| 		if (t.getWindowArg('mce_auto_focus', true)) { | ||||
| 			window.focus(); | ||||
|  | ||||
| 			// Focus element with mceFocus class | ||||
| 			tinymce.each(document.forms, function(f) { | ||||
| 				tinymce.each(f.elements, function(e) { | ||||
| 					if (t.dom.hasClass(e, 'mceFocus') && !e.disabled) { | ||||
| 						e.focus(); | ||||
| 						return false; // Break loop | ||||
| 					} | ||||
| 				}); | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		document.onkeyup = tinyMCEPopup._closeWinKeyHandler; | ||||
| 	}, | ||||
|  | ||||
| 	_accessHandler : function(e) { | ||||
| 		e = e || window.event; | ||||
|  | ||||
| 		if (e.keyCode == 13 || e.keyCode == 32) { | ||||
| 			e = e.target || e.srcElement; | ||||
|  | ||||
| 			if (e.onchange) | ||||
| 				e.onchange(); | ||||
|  | ||||
| 			return tinymce.dom.Event.cancel(e); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	_closeWinKeyHandler : function(e) { | ||||
| 		e = e || window.event; | ||||
|  | ||||
| 		if (e.keyCode == 27) | ||||
| 			tinyMCEPopup.close(); | ||||
| 	}, | ||||
|  | ||||
| 	_wait : function() { | ||||
| 		var t = this, ti; | ||||
|  | ||||
| 		if (tinymce.isIE && document.location.protocol != 'https:') { | ||||
| 			// Fake DOMContentLoaded on IE | ||||
| 			document.write('<script id=__ie_onload defer src=\'javascript:""\';><\/script>'); | ||||
| 			document.getElementById("__ie_onload").onreadystatechange = function() { | ||||
| 				if (this.readyState == "complete") { | ||||
| 					t._onDOMLoaded(); | ||||
| 					document.getElementById("__ie_onload").onreadystatechange = null; // Prevent leak | ||||
| 				} | ||||
| 			}; | ||||
| 		} else { | ||||
| 			if (tinymce.isIE || tinymce.isWebKit) { | ||||
| 				ti = setInterval(function() { | ||||
| 					if (/loaded|complete/.test(document.readyState)) { | ||||
| 						clearInterval(ti); | ||||
| 						t._onDOMLoaded(); | ||||
| 					} | ||||
| 				}, 10); | ||||
| 			} else { | ||||
| 				window.addEventListener('DOMContentLoaded', function() { | ||||
| 					t._onDOMLoaded(); | ||||
| 				}, false); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| tinyMCEPopup.init(); | ||||
| tinyMCEPopup._wait(); // Wait for DOM Content Loaded | ||||
| @@ -0,0 +1,69 @@ | ||||
| /** | ||||
|  * $Id: editable_selects.js,v 1.1 2008/07/28 21:59:08 bao Exp $ | ||||
|  * | ||||
|  * Makes select boxes editable. | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| var TinyMCE_EditableSelects = { | ||||
| 	editSelectElm : null, | ||||
|  | ||||
| 	init : function() { | ||||
| 		var nl = document.getElementsByTagName("select"), i, d = document, o; | ||||
|  | ||||
| 		for (i=0; i<nl.length; i++) { | ||||
| 			if (nl[i].className.indexOf('mceEditableSelect') != -1) { | ||||
| 				o = new Option('(value)', '__mce_add_custom__'); | ||||
|  | ||||
| 				o.className = 'mceAddSelectValue'; | ||||
|  | ||||
| 				nl[i].options[nl[i].options.length] = o; | ||||
| 				nl[i].onchange = TinyMCE_EditableSelects.onChangeEditableSelect; | ||||
| 			} | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	onChangeEditableSelect : function(e) { | ||||
| 		var d = document, ne, se = window.event ? window.event.srcElement : e.target; | ||||
|  | ||||
| 		if (se.options[se.selectedIndex].value == '__mce_add_custom__') { | ||||
| 			ne = d.createElement("input"); | ||||
| 			ne.id = se.id + "_custom"; | ||||
| 			ne.name = se.name + "_custom"; | ||||
| 			ne.type = "text"; | ||||
|  | ||||
| 			ne.style.width = se.offsetWidth + 'px'; | ||||
| 			se.parentNode.insertBefore(ne, se); | ||||
| 			se.style.display = 'none'; | ||||
| 			ne.focus(); | ||||
| 			ne.onblur = TinyMCE_EditableSelects.onBlurEditableSelectInput; | ||||
| 			ne.onkeydown = TinyMCE_EditableSelects.onKeyDown; | ||||
| 			TinyMCE_EditableSelects.editSelectElm = se; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	onBlurEditableSelectInput : function() { | ||||
| 		var se = TinyMCE_EditableSelects.editSelectElm; | ||||
|  | ||||
| 		if (se) { | ||||
| 			if (se.previousSibling.value != '') { | ||||
| 				addSelectValue(document.forms[0], se.id, se.previousSibling.value, se.previousSibling.value); | ||||
| 				selectByValue(document.forms[0], se.id, se.previousSibling.value); | ||||
| 			} else | ||||
| 				selectByValue(document.forms[0], se.id, ''); | ||||
|  | ||||
| 			se.style.display = 'inline'; | ||||
| 			se.parentNode.removeChild(se.previousSibling); | ||||
| 			TinyMCE_EditableSelects.editSelectElm = null; | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
| 	onKeyDown : function(e) { | ||||
| 		e = e || window.event; | ||||
|  | ||||
| 		if (e.keyCode == 13) | ||||
| 			TinyMCE_EditableSelects.onBlurEditableSelectInput(); | ||||
| 	} | ||||
| }; | ||||
| @@ -0,0 +1,199 @@ | ||||
| /** | ||||
|  * $Id: form_utils.js,v 1.1 2008/07/28 21:59:08 bao Exp $ | ||||
|  * | ||||
|  * Various form utilitiy functions. | ||||
|  * | ||||
|  * @author Moxiecode | ||||
|  * @copyright Copyright <20> 2004-2008, Moxiecode Systems AB, All rights reserved. | ||||
|  */ | ||||
|  | ||||
| var themeBaseURL = tinyMCEPopup.editor.baseURI.toAbsolute('themes/' + tinyMCEPopup.getParam("theme")); | ||||
|  | ||||
| function getColorPickerHTML(id, target_form_element) { | ||||
| 	var h = ""; | ||||
|  | ||||
| 	h += '<a id="' + id + '_link" href="javascript:;" onclick="tinyMCEPopup.pickColor(event,\'' + target_form_element +'\');" onmousedown="return false;" class="pickcolor">'; | ||||
| 	h += '<span id="' + id + '" title="' + tinyMCEPopup.getLang('browse') + '"></span></a>'; | ||||
|  | ||||
| 	return h; | ||||
| } | ||||
|  | ||||
| function updateColor(img_id, form_element_id) { | ||||
| 	document.getElementById(img_id).style.backgroundColor = document.forms[0].elements[form_element_id].value; | ||||
| } | ||||
|  | ||||
| function setBrowserDisabled(id, state) { | ||||
| 	var img = document.getElementById(id); | ||||
| 	var lnk = document.getElementById(id + "_link"); | ||||
|  | ||||
| 	if (lnk) { | ||||
| 		if (state) { | ||||
| 			lnk.setAttribute("realhref", lnk.getAttribute("href")); | ||||
| 			lnk.removeAttribute("href"); | ||||
| 			tinyMCEPopup.dom.addClass(img, 'disabled'); | ||||
| 		} else { | ||||
| 			if (lnk.getAttribute("realhref")) | ||||
| 				lnk.setAttribute("href", lnk.getAttribute("realhref")); | ||||
|  | ||||
| 			tinyMCEPopup.dom.removeClass(img, 'disabled'); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function getBrowserHTML(id, target_form_element, type, prefix) { | ||||
| 	var option = prefix + "_" + type + "_browser_callback", cb, html; | ||||
|  | ||||
| 	cb = tinyMCEPopup.getParam(option, tinyMCEPopup.getParam("file_browser_callback")); | ||||
|  | ||||
| 	if (!cb) | ||||
| 		return ""; | ||||
|  | ||||
| 	html = ""; | ||||
| 	html += '<a id="' + id + '_link" href="javascript:openBrowser(\'' + id + '\',\'' + target_form_element + '\', \'' + type + '\',\'' + option + '\');" onmousedown="return false;" class="browse">'; | ||||
| 	html += '<span id="' + id + '" title="' + tinyMCEPopup.getLang('browse') + '"></span></a>'; | ||||
|  | ||||
| 	return html; | ||||
| } | ||||
|  | ||||
| function openBrowser(img_id, target_form_element, type, option) { | ||||
| 	var img = document.getElementById(img_id); | ||||
|  | ||||
| 	if (img.className != "mceButtonDisabled") | ||||
| 		tinyMCEPopup.openBrowser(target_form_element, type, option); | ||||
| } | ||||
|  | ||||
| function selectByValue(form_obj, field_name, value, add_custom, ignore_case) { | ||||
| 	if (!form_obj || !form_obj.elements[field_name]) | ||||
| 		return; | ||||
|  | ||||
| 	var sel = form_obj.elements[field_name]; | ||||
|  | ||||
| 	var found = false; | ||||
| 	for (var i=0; i<sel.options.length; i++) { | ||||
| 		var option = sel.options[i]; | ||||
|  | ||||
| 		if (option.value == value || (ignore_case && option.value.toLowerCase() == value.toLowerCase())) { | ||||
| 			option.selected = true; | ||||
| 			found = true; | ||||
| 		} else | ||||
| 			option.selected = false; | ||||
| 	} | ||||
|  | ||||
| 	if (!found && add_custom && value != '') { | ||||
| 		var option = new Option(value, value); | ||||
| 		option.selected = true; | ||||
| 		sel.options[sel.options.length] = option; | ||||
| 		sel.selectedIndex = sel.options.length - 1; | ||||
| 	} | ||||
|  | ||||
| 	return found; | ||||
| } | ||||
|  | ||||
| function getSelectValue(form_obj, field_name) { | ||||
| 	var elm = form_obj.elements[field_name]; | ||||
|  | ||||
| 	if (elm == null || elm.options == null) | ||||
| 		return ""; | ||||
|  | ||||
| 	return elm.options[elm.selectedIndex].value; | ||||
| } | ||||
|  | ||||
| function addSelectValue(form_obj, field_name, name, value) { | ||||
| 	var s = form_obj.elements[field_name]; | ||||
| 	var o = new Option(name, value); | ||||
| 	s.options[s.options.length] = o; | ||||
| } | ||||
|  | ||||
| function addClassesToList(list_id, specific_option) { | ||||
| 	// Setup class droplist | ||||
| 	var styleSelectElm = document.getElementById(list_id); | ||||
| 	var styles = tinyMCEPopup.getParam('theme_advanced_styles', false); | ||||
| 	styles = tinyMCEPopup.getParam(specific_option, styles); | ||||
|  | ||||
| 	if (styles) { | ||||
| 		var stylesAr = styles.split(';'); | ||||
|  | ||||
| 		for (var i=0; i<stylesAr.length; i++) { | ||||
| 			if (stylesAr != "") { | ||||
| 				var key, value; | ||||
|  | ||||
| 				key = stylesAr[i].split('=')[0]; | ||||
| 				value = stylesAr[i].split('=')[1]; | ||||
|  | ||||
| 				styleSelectElm.options[styleSelectElm.length] = new Option(key, value); | ||||
| 			} | ||||
| 		} | ||||
| 	} else { | ||||
| 		tinymce.each(tinyMCEPopup.editor.dom.getClasses(), function(o) { | ||||
| 			styleSelectElm.options[styleSelectElm.length] = new Option(o.title || o['class'], o['class']); | ||||
| 		}); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| function isVisible(element_id) { | ||||
| 	var elm = document.getElementById(element_id); | ||||
|  | ||||
| 	return elm && elm.style.display != "none"; | ||||
| } | ||||
|  | ||||
| function convertRGBToHex(col) { | ||||
| 	var re = new RegExp("rgb\\s*\\(\\s*([0-9]+).*,\\s*([0-9]+).*,\\s*([0-9]+).*\\)", "gi"); | ||||
|  | ||||
| 	var rgb = col.replace(re, "$1,$2,$3").split(','); | ||||
| 	if (rgb.length == 3) { | ||||
| 		r = parseInt(rgb[0]).toString(16); | ||||
| 		g = parseInt(rgb[1]).toString(16); | ||||
| 		b = parseInt(rgb[2]).toString(16); | ||||
|  | ||||
| 		r = r.length == 1 ? '0' + r : r; | ||||
| 		g = g.length == 1 ? '0' + g : g; | ||||
| 		b = b.length == 1 ? '0' + b : b; | ||||
|  | ||||
| 		return "#" + r + g + b; | ||||
| 	} | ||||
|  | ||||
| 	return col; | ||||
| } | ||||
|  | ||||
| function convertHexToRGB(col) { | ||||
| 	if (col.indexOf('#') != -1) { | ||||
| 		col = col.replace(new RegExp('[^0-9A-F]', 'gi'), ''); | ||||
|  | ||||
| 		r = parseInt(col.substring(0, 2), 16); | ||||
| 		g = parseInt(col.substring(2, 4), 16); | ||||
| 		b = parseInt(col.substring(4, 6), 16); | ||||
|  | ||||
| 		return "rgb(" + r + "," + g + "," + b + ")"; | ||||
| 	} | ||||
|  | ||||
| 	return col; | ||||
| } | ||||
|  | ||||
| function trimSize(size) { | ||||
| 	return size.replace(/([0-9\.]+)px|(%|in|cm|mm|em|ex|pt|pc)/, '$1$2'); | ||||
| } | ||||
|  | ||||
| function getCSSSize(size) { | ||||
| 	size = trimSize(size); | ||||
|  | ||||
| 	if (size == "") | ||||
| 		return ""; | ||||
|  | ||||
| 	// Add px | ||||
| 	if (/^[0-9]+$/.test(size)) | ||||
| 		size += 'px'; | ||||
|  | ||||
| 	return size; | ||||
| } | ||||
|  | ||||
| function getStyle(elm, attrib, style) { | ||||
| 	var val = tinyMCEPopup.dom.getAttrib(elm, attrib); | ||||
|  | ||||
| 	if (val != '') | ||||
| 		return '' + val; | ||||
|  | ||||
| 	if (typeof(style) == 'undefined') | ||||
| 		style = attrib; | ||||
|  | ||||
| 	return tinyMCEPopup.dom.getStyle(elm, style); | ||||
| } | ||||
 dsainty
					dsainty