bgneal@312: tinyMCEPopup.requireLangPack();
bgneal@312: 
bgneal@312: function init() {
bgneal@312: 	tinyMCEPopup.resizeToInnerSize();
bgneal@312: 
bgneal@312: 	document.getElementById('backgroundimagebrowsercontainer').innerHTML = getBrowserHTML('backgroundimagebrowser','backgroundimage','image','table');
bgneal@312: 	document.getElementById('bgcolor_pickcontainer').innerHTML = getColorPickerHTML('bgcolor_pick','bgcolor');
bgneal@312: 
bgneal@312: 	var inst = tinyMCEPopup.editor;
bgneal@312: 	var dom = inst.dom;
bgneal@312: 	var trElm = dom.getParent(inst.selection.getStart(), "tr");
bgneal@312: 	var formObj = document.forms[0];
bgneal@312: 	var st = dom.parseStyle(dom.getAttrib(trElm, "style"));
bgneal@312: 
bgneal@312: 	// Get table row data
bgneal@312: 	var rowtype = trElm.parentNode.nodeName.toLowerCase();
bgneal@312: 	var align = dom.getAttrib(trElm, 'align');
bgneal@312: 	var valign = dom.getAttrib(trElm, 'valign');
bgneal@312: 	var height = trimSize(getStyle(trElm, 'height', 'height'));
bgneal@312: 	var className = dom.getAttrib(trElm, 'class');
bgneal@312: 	var bgcolor = convertRGBToHex(getStyle(trElm, 'bgcolor', 'backgroundColor'));
bgneal@312: 	var backgroundimage = getStyle(trElm, 'background', 'backgroundImage').replace(new RegExp("url\\(['\"]?([^'\"]*)['\"]?\\)", 'gi'), "$1");
bgneal@312: 	var id = dom.getAttrib(trElm, 'id');
bgneal@312: 	var lang = dom.getAttrib(trElm, 'lang');
bgneal@312: 	var dir = dom.getAttrib(trElm, 'dir');
bgneal@312: 
bgneal@312: 	selectByValue(formObj, 'rowtype', rowtype);
bgneal@312: 
bgneal@312: 	// Any cells selected
bgneal@312: 	if (dom.select('td.mceSelected,th.mceSelected', trElm).length == 0) {
bgneal@312: 		// Setup form
bgneal@312: 		addClassesToList('class', 'table_row_styles');
bgneal@312: 		TinyMCE_EditableSelects.init();
bgneal@312: 
bgneal@312: 		formObj.bgcolor.value = bgcolor;
bgneal@312: 		formObj.backgroundimage.value = backgroundimage;
bgneal@312: 		formObj.height.value = height;
bgneal@312: 		formObj.id.value = id;
bgneal@312: 		formObj.lang.value = lang;
bgneal@312: 		formObj.style.value = dom.serializeStyle(st);
bgneal@312: 		selectByValue(formObj, 'align', align);
bgneal@312: 		selectByValue(formObj, 'valign', valign);
bgneal@312: 		selectByValue(formObj, 'class', className, true, true);
bgneal@312: 		selectByValue(formObj, 'dir', dir);
bgneal@312: 
bgneal@312: 		// Resize some elements
bgneal@312: 		if (isVisible('backgroundimagebrowser'))
bgneal@312: 			document.getElementById('backgroundimage').style.width = '180px';
bgneal@312: 
bgneal@312: 		updateColor('bgcolor_pick', 'bgcolor');
bgneal@312: 	} else
bgneal@312: 		tinyMCEPopup.dom.hide('action');
bgneal@312: }
bgneal@312: 
bgneal@312: function updateAction() {
bgneal@312: 	var inst = tinyMCEPopup.editor, dom = inst.dom, trElm, tableElm, formObj = document.forms[0];
bgneal@312: 	var action = getSelectValue(formObj, 'action');
bgneal@312: 
bgneal@312: 	tinyMCEPopup.restoreSelection();
bgneal@312: 	trElm = dom.getParent(inst.selection.getStart(), "tr");
bgneal@312: 	tableElm = dom.getParent(inst.selection.getStart(), "table");
bgneal@312: 
bgneal@312: 	// Update all selected rows
bgneal@312: 	if (dom.select('td.mceSelected,th.mceSelected', trElm).length > 0) {
bgneal@312: 		tinymce.each(tableElm.rows, function(tr) {
bgneal@312: 			var i;
bgneal@312: 
bgneal@312: 			for (i = 0; i < tr.cells.length; i++) {
bgneal@312: 				if (dom.hasClass(tr.cells[i], 'mceSelected')) {
bgneal@312: 					updateRow(tr, true);
bgneal@312: 					return;
bgneal@312: 				}
bgneal@312: 			}
bgneal@312: 		});
bgneal@312: 
bgneal@312: 		inst.addVisual();
bgneal@312: 		inst.nodeChanged();
bgneal@312: 		inst.execCommand('mceEndUndoLevel');
bgneal@312: 		tinyMCEPopup.close();
bgneal@312: 		return;
bgneal@312: 	}
bgneal@312: 
bgneal@312: 	switch (action) {
bgneal@312: 		case "row":
bgneal@312: 			updateRow(trElm);
bgneal@312: 			break;
bgneal@312: 
bgneal@312: 		case "all":
bgneal@312: 			var rows = tableElm.getElementsByTagName("tr");
bgneal@312: 
bgneal@312: 			for (var i=0; i<rows.length; i++)
bgneal@312: 				updateRow(rows[i], true);
bgneal@312: 
bgneal@312: 			break;
bgneal@312: 
bgneal@312: 		case "odd":
bgneal@312: 		case "even":
bgneal@312: 			var rows = tableElm.getElementsByTagName("tr");
bgneal@312: 
bgneal@312: 			for (var i=0; i<rows.length; i++) {
bgneal@312: 				if ((i % 2 == 0 && action == "odd") || (i % 2 != 0 && action == "even"))
bgneal@312: 					updateRow(rows[i], true, true);
bgneal@312: 			}
bgneal@312: 
bgneal@312: 			break;
bgneal@312: 	}
bgneal@312: 
bgneal@312: 	inst.addVisual();
bgneal@312: 	inst.nodeChanged();
bgneal@312: 	inst.execCommand('mceEndUndoLevel');
bgneal@312: 	tinyMCEPopup.close();
bgneal@312: }
bgneal@312: 
bgneal@312: function updateRow(tr_elm, skip_id, skip_parent) {
bgneal@312: 	var inst = tinyMCEPopup.editor;
bgneal@312: 	var formObj = document.forms[0];
bgneal@312: 	var dom = inst.dom;
bgneal@312: 	var curRowType = tr_elm.parentNode.nodeName.toLowerCase();
bgneal@312: 	var rowtype = getSelectValue(formObj, 'rowtype');
bgneal@312: 	var doc = inst.getDoc();
bgneal@312: 
bgneal@312: 	// Update row element
bgneal@312: 	if (!skip_id)
bgneal@442: 		dom.setAttrib(tr_elm, 'id', formObj.id.value);
bgneal@312: 
bgneal@442: 	dom.setAttrib(tr_elm, 'align', getSelectValue(formObj, 'align'));
bgneal@442: 	dom.setAttrib(tr_elm, 'vAlign', getSelectValue(formObj, 'valign'));
bgneal@442: 	dom.setAttrib(tr_elm, 'lang', formObj.lang.value);
bgneal@442: 	dom.setAttrib(tr_elm, 'dir', getSelectValue(formObj, 'dir'));
bgneal@442: 	dom.setAttrib(tr_elm, 'style', dom.serializeStyle(dom.parseStyle(formObj.style.value)));
bgneal@312: 	dom.setAttrib(tr_elm, 'class', getSelectValue(formObj, 'class'));
bgneal@312: 
bgneal@312: 	// Clear deprecated attributes
bgneal@442: 	dom.setAttrib(tr_elm, 'background', '');
bgneal@442: 	dom.setAttrib(tr_elm, 'bgColor', '');
bgneal@442: 	dom.setAttrib(tr_elm, 'height', '');
bgneal@312: 
bgneal@312: 	// Set styles
bgneal@312: 	tr_elm.style.height = getCSSSize(formObj.height.value);
bgneal@312: 	tr_elm.style.backgroundColor = formObj.bgcolor.value;
bgneal@312: 
bgneal@312: 	if (formObj.backgroundimage.value != "")
bgneal@312: 		tr_elm.style.backgroundImage = "url('" + formObj.backgroundimage.value + "')";
bgneal@312: 	else
bgneal@312: 		tr_elm.style.backgroundImage = '';
bgneal@312: 
bgneal@312: 	// Setup new rowtype
bgneal@312: 	if (curRowType != rowtype && !skip_parent) {
bgneal@312: 		// first, clone the node we are working on
bgneal@312: 		var newRow = tr_elm.cloneNode(1);
bgneal@312: 
bgneal@312: 		// next, find the parent of its new destination (creating it if necessary)
bgneal@312: 		var theTable = dom.getParent(tr_elm, "table");
bgneal@312: 		var dest = rowtype;
bgneal@312: 		var newParent = null;
bgneal@312: 		for (var i = 0; i < theTable.childNodes.length; i++) {
bgneal@312: 			if (theTable.childNodes[i].nodeName.toLowerCase() == dest)
bgneal@312: 				newParent = theTable.childNodes[i];
bgneal@312: 		}
bgneal@312: 
bgneal@312: 		if (newParent == null) {
bgneal@312: 			newParent = doc.createElement(dest);
bgneal@312: 
bgneal@442: 			if (theTable.firstChild.nodeName == 'CAPTION')
bgneal@442: 				inst.dom.insertAfter(newParent, theTable.firstChild);
bgneal@442: 			else
bgneal@442: 				theTable.insertBefore(newParent, theTable.firstChild);
bgneal@312: 		}
bgneal@312: 
bgneal@312: 		// append the row to the new parent
bgneal@312: 		newParent.appendChild(newRow);
bgneal@312: 
bgneal@312: 		// remove the original
bgneal@312: 		tr_elm.parentNode.removeChild(tr_elm);
bgneal@312: 
bgneal@312: 		// set tr_elm to the new node
bgneal@312: 		tr_elm = newRow;
bgneal@312: 	}
bgneal@312: 
bgneal@312: 	dom.setAttrib(tr_elm, 'style', dom.serializeStyle(dom.parseStyle(tr_elm.style.cssText)));
bgneal@312: }
bgneal@312: 
bgneal@312: function changedBackgroundImage() {
bgneal@312: 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom;
bgneal@312: 	var st = dom.parseStyle(formObj.style.value);
bgneal@312: 
bgneal@312: 	st['background-image'] = "url('" + formObj.backgroundimage.value + "')";
bgneal@312: 
bgneal@312: 	formObj.style.value = dom.serializeStyle(st);
bgneal@312: }
bgneal@312: 
bgneal@312: function changedStyle() {
bgneal@312: 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom;
bgneal@312: 	var st = dom.parseStyle(formObj.style.value);
bgneal@312: 
bgneal@312: 	if (st['background-image'])
bgneal@312: 		formObj.backgroundimage.value = st['background-image'].replace(new RegExp("url\\('?([^']*)'?\\)", 'gi'), "$1");
bgneal@312: 	else
bgneal@312: 		formObj.backgroundimage.value = '';
bgneal@312: 
bgneal@312: 	if (st['height'])
bgneal@312: 		formObj.height.value = trimSize(st['height']);
bgneal@312: 
bgneal@312: 	if (st['background-color']) {
bgneal@312: 		formObj.bgcolor.value = st['background-color'];
bgneal@312: 		updateColor('bgcolor_pick','bgcolor');
bgneal@312: 	}
bgneal@312: }
bgneal@312: 
bgneal@312: function changedSize() {
bgneal@312: 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom;
bgneal@312: 	var st = dom.parseStyle(formObj.style.value);
bgneal@312: 
bgneal@312: 	var height = formObj.height.value;
bgneal@312: 	if (height != "")
bgneal@312: 		st['height'] = getCSSSize(height);
bgneal@312: 	else
bgneal@312: 		st['height'] = "";
bgneal@312: 
bgneal@312: 	formObj.style.value = dom.serializeStyle(st);
bgneal@312: }
bgneal@312: 
bgneal@312: function changedColor() {
bgneal@312: 	var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom;
bgneal@312: 	var st = dom.parseStyle(formObj.style.value);
bgneal@312: 
bgneal@312: 	st['background-color'] = formObj.bgcolor.value;
bgneal@312: 
bgneal@312: 	formObj.style.value = dom.serializeStyle(st);
bgneal@312: }
bgneal@312: 
bgneal@312: tinyMCEPopup.onInit.add(init);