mirror of
https://github.com/rn10950/RetroZilla.git
synced 2024-11-16 12:30:13 +01:00
189 lines
5.9 KiB
JavaScript
189 lines
5.9 KiB
JavaScript
|
# -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
||
|
# ***** 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/
|
||
|
#
|
||
|
# 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.
|
||
|
#
|
||
|
# The Original Code is mozilla.org printing front-end.
|
||
|
#
|
||
|
# The Initial Developer of the Original Code is
|
||
|
# Netscape Communications Corporation.
|
||
|
# Portions created by the Initial Developer are Copyright (C) 2002
|
||
|
# the Initial Developer. All Rights Reserved.
|
||
|
#
|
||
|
# Contributors:
|
||
|
# Rod Spears <rods@netscape.com>
|
||
|
# Pierre Chanial <p_ch@verizon.net>
|
||
|
#
|
||
|
# Alternatively, the contents of this file may be used under the terms of
|
||
|
# either 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 NPL, 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 NPL, the GPL or the LGPL.
|
||
|
#
|
||
|
# ***** END LICENSE BLOCK *****
|
||
|
|
||
|
// dialog is just an array we'll use to store various properties from the dialog document...
|
||
|
var dialog;
|
||
|
|
||
|
// the printProgress is a nsIPrintProgress object
|
||
|
var printProgress = null;
|
||
|
|
||
|
// random global variables...
|
||
|
var targetFile;
|
||
|
|
||
|
var docTitle = "";
|
||
|
var docURL = "";
|
||
|
var progressParams = null;
|
||
|
|
||
|
function elipseString(aStr, doFront)
|
||
|
{
|
||
|
if (aStr.length > 3 && (aStr.substr(0, 3) == "..." || aStr.substr(aStr.length-4, 3) == "..."))
|
||
|
return aStr;
|
||
|
|
||
|
var fixedLen = 64;
|
||
|
if (aStr.length <= fixedLen)
|
||
|
return aStr;
|
||
|
|
||
|
if (doFront)
|
||
|
return "..." + aStr.substr(aStr.length-fixedLen, fixedLen);
|
||
|
|
||
|
return aStr.substr(0, fixedLen) + "...";
|
||
|
}
|
||
|
|
||
|
// all progress notifications are done through the nsIWebProgressListener implementation...
|
||
|
var progressListener = {
|
||
|
|
||
|
onStateChange: function (aWebProgress, aRequest, aStateFlags, aStatus)
|
||
|
{
|
||
|
if (aStateFlags & Components.interfaces.nsIWebProgressListener.STATE_STOP)
|
||
|
window.close();
|
||
|
},
|
||
|
|
||
|
onProgressChange: function (aWebProgress, aRequest, aCurSelfProgress, aMaxSelfProgress, aCurTotalProgress, aMaxTotalProgress)
|
||
|
{
|
||
|
if (!progressParams)
|
||
|
return;
|
||
|
var docTitleStr = elipseString(progressParams.docTitle, false);
|
||
|
if (docTitleStr != docTitle) {
|
||
|
docTitle = docTitleStr;
|
||
|
dialog.title.value = docTitle;
|
||
|
}
|
||
|
var docURLStr = elipseString(progressParams.docURL, true);
|
||
|
if (docURLStr != docURL && dialog.title != null) {
|
||
|
docURL = docURLStr;
|
||
|
if (docTitle == "")
|
||
|
dialog.title.value = docURLStr;
|
||
|
}
|
||
|
},
|
||
|
|
||
|
onLocationChange: function (aWebProgress, aRequest, aLocation) {},
|
||
|
onSecurityChange: function (aWebProgress, aRequest, state) {},
|
||
|
|
||
|
onStatusChange: function (aWebProgress, aRequest, aStatus, aMessage)
|
||
|
{
|
||
|
if (aMessage)
|
||
|
dialog.title.setAttribute("value", aMessage);
|
||
|
},
|
||
|
|
||
|
QueryInterface: function (iid)
|
||
|
{
|
||
|
if (iid.equals(Components.interfaces.nsIWebProgressListener) || iid.equals(Components.interfaces.nsISupportsWeakReference))
|
||
|
return this;
|
||
|
throw Components.results.NS_NOINTERFACE;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function onLoad() {
|
||
|
// Set global variables.
|
||
|
printProgress = window.arguments[0];
|
||
|
if (window.arguments[1]) {
|
||
|
progressParams = window.arguments[1].QueryInterface(Components.interfaces.nsIPrintProgressParams)
|
||
|
if (progressParams) {
|
||
|
docTitle = elipseString(progressParams.docTitle, false);
|
||
|
docURL = elipseString(progressParams.docURL, true);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (!printProgress) {
|
||
|
dump( "Invalid argument to printPreviewProgress.xul\n" );
|
||
|
window.close()
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
dialog = new Object;
|
||
|
dialog.strings = new Array;
|
||
|
dialog.title = document.getElementById("dialog.title");
|
||
|
dialog.titleLabel = document.getElementById("dialog.titleLabel");
|
||
|
|
||
|
dialog.title.value = docTitle;
|
||
|
|
||
|
// set our web progress listener on the helper app launcher
|
||
|
printProgress.registerListener(progressListener);
|
||
|
moveToAlertPosition();
|
||
|
|
||
|
//We need to delay the set title else dom will overwrite it
|
||
|
window.setTimeout(doneIniting, 100);
|
||
|
}
|
||
|
|
||
|
function onUnload()
|
||
|
{
|
||
|
if (!printProgress)
|
||
|
return;
|
||
|
try {
|
||
|
printProgress.unregisterListener(progressListener);
|
||
|
printProgress = null;
|
||
|
}
|
||
|
catch(e) {}
|
||
|
}
|
||
|
|
||
|
function getString (stringId) {
|
||
|
// Check if we've fetched this string already.
|
||
|
if (!(stringId in dialog.strings)) {
|
||
|
// Try to get it.
|
||
|
var elem = document.getElementById( "dialog.strings."+stringId);
|
||
|
try {
|
||
|
if (elem && elem.childNodes && elem.childNodes[0] &&
|
||
|
elem.childNodes[0].nodeValue)
|
||
|
dialog.strings[stringId] = elem.childNodes[0].nodeValue;
|
||
|
// If unable to fetch string, use an empty string.
|
||
|
else
|
||
|
dialog.strings[stringId] = "";
|
||
|
} catch (e) { dialog.strings[stringId] = ""; }
|
||
|
}
|
||
|
return dialog.strings[stringId];
|
||
|
}
|
||
|
|
||
|
// If the user presses cancel, tell the app launcher and close the dialog...
|
||
|
function onCancel ()
|
||
|
{
|
||
|
// Cancel app launcher.
|
||
|
try {
|
||
|
printProgress.processCanceledByUser = true;
|
||
|
}
|
||
|
catch(e) {return true;}
|
||
|
|
||
|
// don't Close up dialog by returning false, the backend will close the dialog when everything will be aborted.
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
function doneIniting()
|
||
|
{
|
||
|
// called by function timeout in onLoad
|
||
|
printProgress.doneIniting();
|
||
|
}
|