2004-04-18 14:21:17 +00:00
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
2002-01-15 15:49:46 +00:00
|
|
|
*
|
2004-04-18 14:21:17 +00:00
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
2002-01-15 15:49:46 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Editor Image Properties Overlay.
|
|
|
|
*
|
2004-04-18 14:21:17 +00:00
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 1998-1999
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
2002-01-15 15:49:46 +00:00
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Pete Collins
|
|
|
|
* Brian King
|
|
|
|
* Ben Goodger
|
|
|
|
* Neil Rashbrook <neil@parkwaycc.co.uk> (Separated from EdImageProps.js)
|
2004-04-18 14:21:17 +00:00
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
|
|
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
2002-01-15 15:49:46 +00:00
|
|
|
|
2002-01-24 15:41:20 +00:00
|
|
|
/*
|
|
|
|
Note: We encourage non-empty alt text for images inserted into a page.
|
|
|
|
When there's no alt text, we always write 'alt=""' as the attribute, since "alt" is a required attribute.
|
|
|
|
We allow users to not have alt text by checking a "Don't use alterate text" radio button,
|
|
|
|
and we don't accept spaces as valid alt text. A space used to be required to avoid the error message
|
2004-11-10 07:27:11 +00:00
|
|
|
if user didn't enter alt text, but is unnecessary now that we no longer annoy the user
|
2002-01-24 15:41:20 +00:00
|
|
|
with the error dialog if alt="" is present on an img element.
|
|
|
|
We trim all spaces at the beginning and end of user's alt text
|
|
|
|
*/
|
|
|
|
|
2002-01-15 15:49:46 +00:00
|
|
|
var gInsertNewImage = true;
|
|
|
|
var gInsertNewIMap = true;
|
2002-01-24 15:41:20 +00:00
|
|
|
var gDoAltTextError = false;
|
2002-01-15 15:49:46 +00:00
|
|
|
var gConstrainOn = false;
|
|
|
|
// Note used in current version, but these are set correctly
|
|
|
|
// and could be used to reset width and height used for constrain ratio
|
|
|
|
var gConstrainWidth = 0;
|
|
|
|
var gConstrainHeight = 0;
|
|
|
|
var imageElement;
|
|
|
|
var gImageMap = 0;
|
|
|
|
var gCanRemoveImageMap = false;
|
|
|
|
var gRemoveImageMap = false;
|
|
|
|
var gImageMapDisabled = false;
|
2002-02-08 22:40:59 +00:00
|
|
|
var gActualWidth = "";
|
|
|
|
var gActualHeight = "";
|
2002-01-15 15:49:46 +00:00
|
|
|
var gOriginalSrc = "";
|
|
|
|
var gHaveDocumentUrl = false;
|
|
|
|
var gTimerID;
|
|
|
|
var gValidateTab;
|
|
|
|
|
|
|
|
// These must correspond to values in EditorDialog.css for each theme
|
|
|
|
// (unfortunately, setting "style" attribute here doesn't work!)
|
|
|
|
var gPreviewImageWidth = 80;
|
|
|
|
var gPreviewImageHeight = 50;
|
|
|
|
|
|
|
|
// dialog initialization code
|
|
|
|
|
|
|
|
function ImageStartup()
|
|
|
|
{
|
|
|
|
gDialog.tabBox = document.getElementById( "TabBox" );
|
|
|
|
gDialog.tabLocation = document.getElementById( "imageLocationTab" );
|
|
|
|
gDialog.tabDimensions = document.getElementById( "imageDimensionsTab" );
|
|
|
|
gDialog.tabBorder = document.getElementById( "imageBorderTab" );
|
|
|
|
gDialog.srcInput = document.getElementById( "srcInput" );
|
2002-09-03 23:37:58 +00:00
|
|
|
gDialog.titleInput = document.getElementById( "titleInput" );
|
2002-01-15 15:49:46 +00:00
|
|
|
gDialog.altTextInput = document.getElementById( "altTextInput" );
|
2002-01-24 15:41:20 +00:00
|
|
|
gDialog.altTextRadioGroup = document.getElementById( "altTextRadioGroup" );
|
|
|
|
gDialog.altTextRadio = document.getElementById( "altTextRadio" );
|
|
|
|
gDialog.noAltTextRadio = document.getElementById( "noAltTextRadio" );
|
2002-01-15 15:49:46 +00:00
|
|
|
gDialog.customSizeRadio = document.getElementById( "customSizeRadio" );
|
|
|
|
gDialog.actualSizeRadio = document.getElementById( "actualSizeRadio" );
|
|
|
|
gDialog.constrainCheckbox = document.getElementById( "constrainCheckbox" );
|
|
|
|
gDialog.widthInput = document.getElementById( "widthInput" );
|
|
|
|
gDialog.heightInput = document.getElementById( "heightInput" );
|
|
|
|
gDialog.widthUnitsMenulist = document.getElementById( "widthUnitsMenulist" );
|
|
|
|
gDialog.heightUnitsMenulist = document.getElementById( "heightUnitsMenulist" );
|
|
|
|
gDialog.imagelrInput = document.getElementById( "imageleftrightInput" );
|
|
|
|
gDialog.imagetbInput = document.getElementById( "imagetopbottomInput" );
|
|
|
|
gDialog.border = document.getElementById( "border" );
|
|
|
|
gDialog.alignTypeSelect = document.getElementById( "alignTypeSelect" );
|
|
|
|
gDialog.ImageHolder = document.getElementById( "preview-image-holder" );
|
|
|
|
gDialog.PreviewWidth = document.getElementById( "PreviewWidth" );
|
|
|
|
gDialog.PreviewHeight = document.getElementById( "PreviewHeight" );
|
|
|
|
gDialog.PreviewSize = document.getElementById( "PreviewSize" );
|
|
|
|
gDialog.PreviewImage = null;
|
|
|
|
gDialog.OkButton = document.documentElement.getButton("accept");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set dialog widgets with attribute data
|
|
|
|
// We get them from globalElement copy so this can be used
|
|
|
|
// by AdvancedEdit(), which is shared by all property dialogs
|
|
|
|
function InitImage()
|
|
|
|
{
|
|
|
|
// Set the controls to the image's attributes
|
|
|
|
gDialog.srcInput.value = globalElement.getAttribute("src");
|
|
|
|
|
|
|
|
// Set "Relativize" checkbox according to current URL state
|
|
|
|
SetRelativeCheckbox();
|
|
|
|
|
|
|
|
// Force loading of image from its source and show preview image
|
|
|
|
LoadPreviewImage();
|
|
|
|
|
2002-09-03 23:37:58 +00:00
|
|
|
if (globalElement.hasAttribute("title"))
|
|
|
|
gDialog.titleInput.value = globalElement.getAttribute("title");
|
|
|
|
|
2002-01-24 15:41:20 +00:00
|
|
|
var hasAltText = globalElement.hasAttribute("alt");
|
2002-08-15 20:51:24 +00:00
|
|
|
var altText;
|
2002-01-24 15:41:20 +00:00
|
|
|
if (hasAltText)
|
|
|
|
{
|
2002-08-15 20:51:24 +00:00
|
|
|
altText = globalElement.getAttribute("alt");
|
|
|
|
gDialog.altTextInput.value = altText;
|
2002-01-24 15:41:20 +00:00
|
|
|
}
|
2002-08-15 20:51:24 +00:00
|
|
|
|
|
|
|
// Initialize altText widgets during dialog startup
|
|
|
|
// or if user enterred altText in Advanced Edit dialog
|
|
|
|
// (this preserves "Don't use alt text" radio button state)
|
|
|
|
if (!gDialog.altTextRadioGroup.selectedItem || altText)
|
2002-01-24 15:41:20 +00:00
|
|
|
{
|
2002-08-15 20:51:24 +00:00
|
|
|
if (gInsertNewImage || !hasAltText || (hasAltText && gDialog.altTextInput.value))
|
|
|
|
{
|
|
|
|
SetAltTextDisabled(false);
|
|
|
|
gDialog.altTextRadioGroup.selectedItem = gDialog.altTextRadio;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
SetAltTextDisabled(true);
|
|
|
|
gDialog.altTextRadioGroup.selectedItem = gDialog.noAltTextRadio;
|
|
|
|
}
|
2002-01-24 15:41:20 +00:00
|
|
|
}
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
// setup the height and width widgets
|
|
|
|
var width = InitPixelOrPercentMenulist(globalElement,
|
|
|
|
gInsertNewImage ? null : imageElement,
|
|
|
|
"width", "widthUnitsMenulist", gPixel);
|
|
|
|
var height = InitPixelOrPercentMenulist(globalElement,
|
|
|
|
gInsertNewImage ? null : imageElement,
|
|
|
|
"height", "heightUnitsMenulist", gPixel);
|
|
|
|
|
|
|
|
// Set actual radio button if both set values are the same as actual
|
2002-02-08 22:40:59 +00:00
|
|
|
SetSizeWidgets(width, height);
|
2002-01-15 15:49:46 +00:00
|
|
|
|
2002-02-08 22:40:59 +00:00
|
|
|
gDialog.widthInput.value = gConstrainWidth = width ? width : (gActualWidth ? gActualWidth : "");
|
|
|
|
gDialog.heightInput.value = gConstrainHeight = height ? height : (gActualHeight ? gActualHeight : "");
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
// set spacing editfields
|
|
|
|
gDialog.imagelrInput.value = globalElement.getAttribute("hspace");
|
|
|
|
gDialog.imagetbInput.value = globalElement.getAttribute("vspace");
|
|
|
|
|
|
|
|
// dialog.border.value = globalElement.getAttribute("border");
|
2002-01-24 15:41:20 +00:00
|
|
|
var bv = GetHTMLOrCSSStyleValue(globalElement, "border", "border-top-width");
|
2002-08-13 17:30:23 +00:00
|
|
|
if (/px/.test(bv))
|
2002-01-15 15:49:46 +00:00
|
|
|
{
|
|
|
|
// Strip out the px
|
2002-08-13 17:30:23 +00:00
|
|
|
bv = RegExp.leftContext;
|
2002-01-15 15:49:46 +00:00
|
|
|
}
|
|
|
|
else if (bv == "thin")
|
|
|
|
{
|
|
|
|
bv = "1";
|
|
|
|
}
|
|
|
|
else if (bv == "medium")
|
|
|
|
{
|
|
|
|
bv = "3";
|
|
|
|
}
|
|
|
|
else if (bv == "thick")
|
|
|
|
{
|
|
|
|
bv = "5";
|
|
|
|
}
|
|
|
|
gDialog.border.value = bv;
|
|
|
|
|
|
|
|
// Get alignment setting
|
|
|
|
var align = globalElement.getAttribute("align");
|
2002-01-24 15:41:20 +00:00
|
|
|
if (align)
|
2002-01-15 15:49:46 +00:00
|
|
|
align = align.toLowerCase();
|
2002-01-24 15:41:20 +00:00
|
|
|
|
2002-01-15 15:49:46 +00:00
|
|
|
var imgClass;
|
|
|
|
var textID;
|
2002-01-24 15:41:20 +00:00
|
|
|
|
2002-01-15 15:49:46 +00:00
|
|
|
switch ( align )
|
|
|
|
{
|
|
|
|
case "top":
|
|
|
|
case "middle":
|
|
|
|
case "right":
|
|
|
|
case "left":
|
|
|
|
gDialog.alignTypeSelect.value = align;
|
|
|
|
break;
|
|
|
|
default: // Default or "bottom"
|
|
|
|
gDialog.alignTypeSelect.value = "bottom";
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get image map for image
|
|
|
|
gImageMap = GetImageMap();
|
|
|
|
|
|
|
|
doOverallEnabling();
|
|
|
|
doDimensionEnabling();
|
|
|
|
}
|
|
|
|
|
2002-02-08 22:40:59 +00:00
|
|
|
function SetSizeWidgets(width, height)
|
|
|
|
{
|
|
|
|
if (!(width || height) || (gActualWidth && gActualHeight && width == gActualWidth && height == gActualHeight))
|
|
|
|
gDialog.actualSizeRadio.radioGroup.selectedItem = gDialog.actualSizeRadio;
|
|
|
|
|
|
|
|
if (!gDialog.actualSizeRadio.selected)
|
|
|
|
{
|
|
|
|
gDialog.actualSizeRadio.radioGroup.selectedItem = gDialog.customSizeRadio;
|
|
|
|
|
|
|
|
// Decide if user's sizes are in the same ratio as actual sizes
|
|
|
|
if (gActualWidth && gActualHeight)
|
|
|
|
{
|
|
|
|
if (gActualWidth > gActualHeight)
|
|
|
|
gDialog.constrainCheckbox.checked = (Math.round(gActualHeight * width / gActualWidth) == height);
|
|
|
|
else
|
|
|
|
gDialog.constrainCheckbox.checked = (Math.round(gActualWidth * height / gActualHeight) == width);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-01-24 15:41:20 +00:00
|
|
|
// Disable alt text input when "Don't use alt" radio is checked
|
|
|
|
function SetAltTextDisabled(disable)
|
|
|
|
{
|
|
|
|
gDialog.altTextInput.disabled = disable;
|
|
|
|
}
|
|
|
|
|
2002-01-15 15:49:46 +00:00
|
|
|
function GetImageMap()
|
|
|
|
{
|
|
|
|
var usemap = globalElement.getAttribute("usemap");
|
|
|
|
if (usemap)
|
|
|
|
{
|
|
|
|
gCanRemoveImageMap = true;
|
|
|
|
var mapname = usemap.substring(1, usemap.length);
|
2002-09-19 03:32:23 +00:00
|
|
|
var mapCollection;
|
|
|
|
try {
|
|
|
|
mapCollection = GetCurrentEditor().document.getElementsByName(mapname);
|
|
|
|
} catch (e) {}
|
|
|
|
if (mapCollection && mapCollection[0] != null)
|
2002-01-15 15:49:46 +00:00
|
|
|
{
|
|
|
|
gInsertNewIMap = false;
|
|
|
|
return mapCollection[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
gCanRemoveImageMap = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
gInsertNewIMap = true;
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
function chooseFile()
|
|
|
|
{
|
|
|
|
if (gTimerID)
|
|
|
|
clearTimeout(gTimerID);
|
|
|
|
// Get a local file, converted into URL format
|
|
|
|
var fileName = GetLocalFileURL("img");
|
|
|
|
if (fileName)
|
|
|
|
{
|
|
|
|
// Always try to relativize local file URLs
|
|
|
|
if (gHaveDocumentUrl)
|
|
|
|
fileName = MakeRelativeUrl(fileName);
|
|
|
|
|
|
|
|
gDialog.srcInput.value = fileName;
|
|
|
|
|
|
|
|
SetRelativeCheckbox();
|
|
|
|
doOverallEnabling();
|
|
|
|
}
|
|
|
|
LoadPreviewImage();
|
|
|
|
|
|
|
|
// Put focus into the input field
|
|
|
|
SetTextboxFocus(gDialog.srcInput);
|
|
|
|
}
|
|
|
|
|
|
|
|
function PreviewImageLoaded()
|
|
|
|
{
|
|
|
|
if (gDialog.PreviewImage)
|
|
|
|
{
|
|
|
|
// Image loading has completed -- we can get actual width
|
2002-02-08 22:40:59 +00:00
|
|
|
gActualWidth = gDialog.PreviewImage.naturalWidth;
|
|
|
|
gActualHeight = gDialog.PreviewImage.naturalHeight;
|
2002-01-15 15:49:46 +00:00
|
|
|
|
2002-02-08 22:40:59 +00:00
|
|
|
if (gActualWidth && gActualHeight)
|
2002-01-15 15:49:46 +00:00
|
|
|
{
|
|
|
|
// Use actual size or scale to fit preview if either dimension is too large
|
2002-02-08 22:40:59 +00:00
|
|
|
var width = gActualWidth;
|
|
|
|
var height = gActualHeight;
|
|
|
|
if (gActualWidth > gPreviewImageWidth)
|
2002-01-15 15:49:46 +00:00
|
|
|
{
|
|
|
|
width = gPreviewImageWidth;
|
2002-02-08 22:40:59 +00:00
|
|
|
height = gActualHeight * (gPreviewImageWidth / gActualWidth);
|
2002-01-15 15:49:46 +00:00
|
|
|
}
|
|
|
|
if (height > gPreviewImageHeight)
|
|
|
|
{
|
|
|
|
height = gPreviewImageHeight;
|
2002-02-08 22:40:59 +00:00
|
|
|
width = gActualWidth * (gPreviewImageHeight / gActualHeight);
|
2002-01-15 15:49:46 +00:00
|
|
|
}
|
|
|
|
gDialog.PreviewImage.width = width;
|
|
|
|
gDialog.PreviewImage.height = height;
|
|
|
|
|
2002-02-08 22:40:59 +00:00
|
|
|
gDialog.PreviewWidth.setAttribute("value", gActualWidth);
|
|
|
|
gDialog.PreviewHeight.setAttribute("value", gActualHeight);
|
2002-01-15 15:49:46 +00:00
|
|
|
|
2002-11-19 15:51:56 +00:00
|
|
|
gDialog.PreviewSize.collapsed = false;
|
|
|
|
gDialog.ImageHolder.collapsed = false;
|
2002-01-15 15:49:46 +00:00
|
|
|
|
2002-02-08 22:40:59 +00:00
|
|
|
SetSizeWidgets(gDialog.widthInput.value, gDialog.heightInput.value);
|
2002-01-15 15:49:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (gDialog.actualSizeRadio.selected)
|
|
|
|
SetActualSize();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function LoadPreviewImage()
|
|
|
|
{
|
2002-11-19 15:51:56 +00:00
|
|
|
gDialog.PreviewSize.collapsed = true;
|
2004-10-27 14:51:33 +00:00
|
|
|
// XXXbz workaround for bug 265416 / bug 266284
|
|
|
|
gDialog.ImageHolder.collapsed = true;
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
var imageSrc = TrimString(gDialog.srcInput.value);
|
|
|
|
if (!imageSrc)
|
|
|
|
return;
|
|
|
|
|
|
|
|
try {
|
|
|
|
// Remove the image URL from image cache so it loads fresh
|
|
|
|
// (if we don't do this, loads after the first will always use image cache
|
|
|
|
// and we won't see image edit changes or be able to get actual width and height)
|
|
|
|
|
|
|
|
var IOService = GetIOService();
|
|
|
|
if (IOService)
|
|
|
|
{
|
|
|
|
// We must have an absolute URL to preview it or remove it from the cache
|
|
|
|
imageSrc = MakeAbsoluteUrl(imageSrc);
|
|
|
|
|
|
|
|
if (GetScheme(imageSrc))
|
|
|
|
{
|
2002-03-06 07:48:55 +00:00
|
|
|
var uri = IOService.newURI(imageSrc, null, null);
|
2002-01-15 15:49:46 +00:00
|
|
|
if (uri)
|
|
|
|
{
|
|
|
|
var imgCacheService = Components.classes["@mozilla.org/image/cache;1"].getService();
|
|
|
|
var imgCache = imgCacheService.QueryInterface(Components.interfaces.imgICache);
|
|
|
|
|
|
|
|
// This returns error if image wasn't in the cache; ignore that
|
|
|
|
imgCache.removeEntry(uri);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch(e) {}
|
|
|
|
|
|
|
|
if (gDialog.PreviewImage)
|
|
|
|
removeEventListener("load", PreviewImageLoaded, true);
|
|
|
|
|
|
|
|
if (gDialog.ImageHolder.firstChild)
|
|
|
|
gDialog.ImageHolder.removeChild(gDialog.ImageHolder.firstChild);
|
|
|
|
|
|
|
|
gDialog.PreviewImage = document.createElementNS("http://www.w3.org/1999/xhtml", "html:img");
|
|
|
|
if (gDialog.PreviewImage)
|
|
|
|
{
|
2003-03-21 00:29:31 +00:00
|
|
|
// set the src before appending to the document -- see bug 198435 for why
|
|
|
|
// this is needed.
|
2004-10-27 14:51:33 +00:00
|
|
|
// XXXbz that bug is long-since fixed. Is this still needed?
|
2002-01-15 15:49:46 +00:00
|
|
|
gDialog.PreviewImage.addEventListener("load", PreviewImageLoaded, true);
|
|
|
|
gDialog.PreviewImage.src = imageSrc;
|
2003-03-21 00:29:31 +00:00
|
|
|
gDialog.ImageHolder.appendChild(gDialog.PreviewImage);
|
2002-01-15 15:49:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function SetActualSize()
|
|
|
|
{
|
2002-02-08 22:40:59 +00:00
|
|
|
gDialog.widthInput.value = gActualWidth ? gActualWidth : "";
|
2002-01-15 15:49:46 +00:00
|
|
|
gDialog.widthUnitsMenulist.selectedIndex = 0;
|
2002-02-08 22:40:59 +00:00
|
|
|
gDialog.heightInput.value = gActualHeight ? gActualHeight : "";
|
2002-01-15 15:49:46 +00:00
|
|
|
gDialog.heightUnitsMenulist.selectedIndex = 0;
|
|
|
|
doDimensionEnabling();
|
|
|
|
}
|
|
|
|
|
|
|
|
function ChangeImageSrc()
|
|
|
|
{
|
|
|
|
if (gTimerID)
|
|
|
|
clearTimeout(gTimerID);
|
|
|
|
|
|
|
|
gTimerID = setTimeout("LoadPreviewImage()", 800);
|
|
|
|
|
|
|
|
SetRelativeCheckbox();
|
|
|
|
doOverallEnabling();
|
|
|
|
}
|
|
|
|
|
|
|
|
function doDimensionEnabling()
|
|
|
|
{
|
|
|
|
// Enabled only if "Custom" is selected
|
|
|
|
var enable = (gDialog.customSizeRadio.selected);
|
|
|
|
|
|
|
|
// BUG 74145: After input field is disabled,
|
|
|
|
// setting it enabled causes blinking caret to appear
|
|
|
|
// even though focus isn't set to it.
|
|
|
|
SetElementEnabledById( "heightInput", enable );
|
|
|
|
SetElementEnabledById( "heightLabel", enable );
|
|
|
|
SetElementEnabledById( "heightUnitsMenulist", enable );
|
|
|
|
|
|
|
|
SetElementEnabledById( "widthInput", enable );
|
|
|
|
SetElementEnabledById( "widthLabel", enable);
|
|
|
|
SetElementEnabledById( "widthUnitsMenulist", enable );
|
|
|
|
|
|
|
|
var constrainEnable = enable
|
|
|
|
&& ( gDialog.widthUnitsMenulist.selectedIndex == 0 )
|
|
|
|
&& ( gDialog.heightUnitsMenulist.selectedIndex == 0 );
|
|
|
|
|
|
|
|
SetElementEnabledById( "constrainCheckbox", constrainEnable );
|
|
|
|
}
|
|
|
|
|
|
|
|
function doOverallEnabling()
|
|
|
|
{
|
|
|
|
var enabled = TrimString(gDialog.srcInput.value) != "";
|
|
|
|
|
|
|
|
SetElementEnabled(gDialog.OkButton, enabled);
|
|
|
|
SetElementEnabledById("AdvancedEditButton1", enabled);
|
|
|
|
SetElementEnabledById("imagemapLabel", enabled);
|
|
|
|
|
|
|
|
//TODO: Restore when Image Map editor is finished
|
|
|
|
//SetElementEnabledById("editImageMap", enabled);
|
|
|
|
SetElementEnabledById("removeImageMap", gCanRemoveImageMap);
|
|
|
|
}
|
|
|
|
|
|
|
|
function ToggleConstrain()
|
|
|
|
{
|
|
|
|
// If just turned on, save the current width and height as basis for constrain ratio
|
|
|
|
// Thus clicking on/off lets user say "Use these values as aspect ration"
|
|
|
|
if (gDialog.constrainCheckbox.checked && !gDialog.constrainCheckbox.disabled
|
|
|
|
&& (gDialog.widthUnitsMenulist.selectedIndex == 0)
|
|
|
|
&& (gDialog.heightUnitsMenulist.selectedIndex == 0))
|
|
|
|
{
|
|
|
|
gConstrainWidth = Number(TrimString(gDialog.widthInput.value));
|
|
|
|
gConstrainHeight = Number(TrimString(gDialog.heightInput.value));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function constrainProportions( srcID, destID )
|
|
|
|
{
|
|
|
|
var srcElement = document.getElementById(srcID);
|
|
|
|
if (!srcElement)
|
|
|
|
return;
|
|
|
|
|
|
|
|
var destElement = document.getElementById(destID);
|
|
|
|
if (!destElement)
|
|
|
|
return;
|
|
|
|
|
|
|
|
// always force an integer (whether we are constraining or not)
|
|
|
|
forceInteger(srcID);
|
|
|
|
|
2002-02-08 22:40:59 +00:00
|
|
|
if (!gActualWidth || !gActualHeight ||
|
2002-01-15 15:49:46 +00:00
|
|
|
!(gDialog.constrainCheckbox.checked && !gDialog.constrainCheckbox.disabled))
|
|
|
|
return;
|
|
|
|
|
|
|
|
// double-check that neither width nor height is in percent mode; bail if so!
|
|
|
|
if ( (gDialog.widthUnitsMenulist.selectedIndex != 0)
|
|
|
|
|| (gDialog.heightUnitsMenulist.selectedIndex != 0) )
|
|
|
|
return;
|
|
|
|
|
|
|
|
// This always uses the actual width and height ratios
|
|
|
|
// which is kind of funky if you change one number without the constrain
|
|
|
|
// and then turn constrain on and change a number
|
|
|
|
// I prefer the old strategy (below) but I can see some merit to this solution
|
|
|
|
if (srcID == "widthInput")
|
2002-02-08 22:40:59 +00:00
|
|
|
destElement.value = Math.round( srcElement.value * gActualHeight / gActualWidth );
|
2002-01-15 15:49:46 +00:00
|
|
|
else
|
2002-02-08 22:40:59 +00:00
|
|
|
destElement.value = Math.round( srcElement.value * gActualWidth / gActualHeight );
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
// With this strategy, the width and height ratio
|
|
|
|
// can be reset to whatever the user entered.
|
|
|
|
if (srcID == "widthInput")
|
|
|
|
destElement.value = Math.round( srcElement.value * gConstrainHeight / gConstrainWidth );
|
|
|
|
else
|
|
|
|
destElement.value = Math.round( srcElement.value * gConstrainWidth / gConstrainHeight );
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
function editImageMap()
|
|
|
|
{
|
|
|
|
// Create an imagemap for image map editor
|
|
|
|
if (gInsertNewIMap)
|
2002-09-19 03:32:23 +00:00
|
|
|
{
|
|
|
|
try {
|
|
|
|
gImageMap = GetCurrentEditor().createElementWithDefaults("map");
|
|
|
|
} catch (e) {}
|
|
|
|
}
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
// Note: We no longer pass in a copy of the global ImageMap. ImageMap editor should create a copy and manage onOk and onCancel behavior
|
|
|
|
window.openDialog("chrome://editor/content/EdImageMap.xul", "_blank", "chrome,close,titlebar,modal", globalElement, gImageMap);
|
|
|
|
}
|
|
|
|
|
|
|
|
function removeImageMap()
|
|
|
|
{
|
|
|
|
gRemoveImageMap = true;
|
|
|
|
gCanRemoveImageMap = false;
|
|
|
|
SetElementEnabledById("removeImageMap", false);
|
|
|
|
}
|
|
|
|
|
|
|
|
function SwitchToValidatePanel()
|
|
|
|
{
|
|
|
|
if (gDialog.tabBox && gValidateTab && gDialog.tabBox.selectedTab != gValidateTab)
|
|
|
|
gDialog.tabBox.selectedTab = gValidateTab;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get data from widgets, validate, and set for the global element
|
|
|
|
// accessible to AdvancedEdit() [in EdDialogCommon.js]
|
|
|
|
function ValidateImage()
|
|
|
|
{
|
2002-09-19 03:32:23 +00:00
|
|
|
var editor = GetCurrentEditor();
|
|
|
|
if (!editor)
|
|
|
|
return false;
|
|
|
|
|
2002-01-15 15:49:46 +00:00
|
|
|
gValidateTab = gDialog.tabLocation;
|
|
|
|
if (!gDialog.srcInput.value)
|
|
|
|
{
|
|
|
|
AlertWithTitle(null, GetString("MissingImageError"));
|
|
|
|
SwitchToValidatePanel();
|
|
|
|
gDialog.srcInput.focus();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// We must convert to "file:///" or "http://" format else image doesn't load!
|
|
|
|
var src = TrimString(gDialog.srcInput.value);
|
2005-09-16 14:48:04 +00:00
|
|
|
var checkbox = document.getElementById("MakeRelativeCheckbox");
|
|
|
|
try
|
|
|
|
{
|
|
|
|
if (checkbox && !checkbox.checked)
|
|
|
|
{
|
|
|
|
var URIFixup = Components.classes["@mozilla.org/docshell/urifixup;1"]
|
|
|
|
.getService(Components.interfaces.nsIURIFixup);
|
|
|
|
src = URIFixup.createFixupURI(src, Components.interfaces.nsIURIFixup.FIXUP_FLAG_NONE).spec;
|
|
|
|
}
|
|
|
|
} catch (e) { }
|
|
|
|
|
2002-01-15 15:49:46 +00:00
|
|
|
globalElement.setAttribute("src", src);
|
|
|
|
|
2003-09-14 14:20:06 +00:00
|
|
|
var title = TrimString(gDialog.titleInput.value);
|
|
|
|
if (title)
|
|
|
|
globalElement.setAttribute("title", title);
|
|
|
|
else
|
|
|
|
globalElement.removeAttribute("title");
|
2002-09-03 23:37:58 +00:00
|
|
|
|
2002-01-24 15:41:20 +00:00
|
|
|
// Force user to enter Alt text only if "Alternate text" radio is checked
|
|
|
|
// Don't allow just spaces in alt text
|
|
|
|
var alt = "";
|
|
|
|
var useAlt = gDialog.altTextRadioGroup.selectedItem == gDialog.altTextRadio;
|
|
|
|
if (useAlt)
|
|
|
|
alt = TrimString(gDialog.altTextInput.value);
|
|
|
|
|
|
|
|
if (gDoAltTextError && useAlt && !alt)
|
2002-01-15 15:49:46 +00:00
|
|
|
{
|
|
|
|
AlertWithTitle(null, GetString("NoAltText"));
|
|
|
|
SwitchToValidatePanel();
|
|
|
|
gDialog.altTextInput.focus();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
globalElement.setAttribute("alt", alt);
|
|
|
|
|
|
|
|
var width = "";
|
|
|
|
var height = "";
|
|
|
|
|
|
|
|
gValidateTab = gDialog.tabDimensions;
|
|
|
|
if (!gDialog.actualSizeRadio.selected)
|
|
|
|
{
|
|
|
|
// Get user values for width and height
|
2002-08-15 21:49:40 +00:00
|
|
|
width = ValidateNumber(gDialog.widthInput, gDialog.widthUnitsMenulist, 1, gMaxPixels,
|
2002-01-15 15:49:46 +00:00
|
|
|
globalElement, "width", false, true);
|
|
|
|
if (gValidationError)
|
|
|
|
return false;
|
|
|
|
|
2002-08-15 21:49:40 +00:00
|
|
|
height = ValidateNumber(gDialog.heightInput, gDialog.heightUnitsMenulist, 1, gMaxPixels,
|
2002-01-15 15:49:46 +00:00
|
|
|
globalElement, "height", false, true);
|
|
|
|
if (gValidationError)
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// We always set the width and height attributes, even if same as actual.
|
|
|
|
// This speeds up layout of pages since sizes are known before image is loaded
|
|
|
|
if (!width)
|
2002-02-08 22:40:59 +00:00
|
|
|
width = gActualWidth;
|
2002-01-15 15:49:46 +00:00
|
|
|
if (!height)
|
2002-02-08 22:40:59 +00:00
|
|
|
height = gActualHeight;
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
// Remove existing width and height only if source changed
|
|
|
|
// and we couldn't obtain actual dimensions
|
|
|
|
var srcChanged = (src != gOriginalSrc);
|
|
|
|
if (width)
|
2004-07-20 19:11:04 +00:00
|
|
|
editor.setAttributeOrEquivalent(globalElement, "width", width, true);
|
2002-01-15 15:49:46 +00:00
|
|
|
else if (srcChanged)
|
2002-09-19 03:32:23 +00:00
|
|
|
editor.removeAttributeOrEquivalent(globalElement, "width", true);
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
if (height)
|
2004-07-20 19:11:04 +00:00
|
|
|
editor.setAttributeOrEquivalent(globalElement, "height", height, true);
|
2002-01-15 15:49:46 +00:00
|
|
|
else if (srcChanged)
|
2002-09-19 03:32:23 +00:00
|
|
|
editor.removeAttributeOrEquivalent(globalElement, "height", true);
|
2002-01-15 15:49:46 +00:00
|
|
|
|
|
|
|
// spacing attributes
|
|
|
|
gValidateTab = gDialog.tabBorder;
|
2002-08-15 21:49:40 +00:00
|
|
|
ValidateNumber(gDialog.imagelrInput, null, 0, gMaxPixels,
|
2002-01-15 15:49:46 +00:00
|
|
|
globalElement, "hspace", false, true, true);
|
|
|
|
if (gValidationError)
|
|
|
|
return false;
|
|
|
|
|
2002-08-15 21:49:40 +00:00
|
|
|
ValidateNumber(gDialog.imagetbInput, null, 0, gMaxPixels,
|
2002-01-15 15:49:46 +00:00
|
|
|
globalElement, "vspace", false, true);
|
|
|
|
if (gValidationError)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// note this is deprecated and should be converted to stylesheets
|
2002-08-15 21:49:40 +00:00
|
|
|
ValidateNumber(gDialog.border, null, 0, gMaxPixels,
|
2002-01-15 15:49:46 +00:00
|
|
|
globalElement, "border", false, true);
|
|
|
|
if (gValidationError)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// Default or setting "bottom" means don't set the attribute
|
|
|
|
// Note that the attributes "left" and "right" are opposite
|
|
|
|
// of what we use in the UI, which describes where the TEXT wraps,
|
|
|
|
// not the image location (which is what the HTML describes)
|
|
|
|
switch ( gDialog.alignTypeSelect.value )
|
|
|
|
{
|
|
|
|
case "top":
|
|
|
|
case "middle":
|
|
|
|
case "right":
|
|
|
|
case "left":
|
2004-07-20 19:11:04 +00:00
|
|
|
editor.setAttributeOrEquivalent( globalElement, "align",
|
|
|
|
gDialog.alignTypeSelect.value , true);
|
2002-01-15 15:49:46 +00:00
|
|
|
break;
|
|
|
|
default:
|
2002-09-19 03:32:23 +00:00
|
|
|
try {
|
|
|
|
editor.removeAttributeOrEquivalent(globalElement, "align", true);
|
|
|
|
} catch (e) {}
|
2002-01-15 15:49:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|