mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
b0cbe263c6
- Bug 1238964 Part 1: Hold new printable page sizes in print nsIPrintSettingsWin. r=jimm (b5e4d012ba) - Bug 1238964 Part 2: Move separate DEVMODE to nsIPrintSettings copying into nsPrintSettingsWin. r=jimm (cb7bb66037) - Bug 1218029 - Adds SRICheckDataVerifier for progressing data handling. r=francois (8331afc1a7) - Bug 1218029 - Implements progressive Unicode chars decoding in nsScriptLoader. r=djvj (2c32ca259a) - Bug 1237201 part 1 - Use MOZ_ALWAYS_TRUE in nsScriptLoadHandler::TryDecodeRawData. r=yury (8f7496be23) - Bug 1237201 part 2 - Handle Vector OOM in gfx/. r=jrmuizel,kats (d5e8bd3383) - Bug 1237201 part 3 - Handle Vector OOM in StreamingLexer. r=njn (be383e35b4) - Bug 1237201 part 4 - Handle Vector OOM in ipc/. r=billm (fe9a3bf25a) - Bug 1237201 part 5 - Ignore Vector OOM in JSMainRuntimeCompartmentsReporter. r=njn (d0070c0636) - Bug 1237201 part 6 - Handle Vector OOM in media/webrtc/. r=jesup (eab4e00735) - Bug 1186491 - Splitting nsIPerformanceStats in two;r=froydnj (006b578345) - Bug 1186491 - An API for watching slow performance alerts (xpcom-level);r=froydnj (4fcefd66f5) - Bug 1237201 part 7 - Handle Vector OOM in nsPerformanceStats, telemetry. r=Yoric (6021b583ff) - Bug 1237201 part 8 - Make fallible Vector methods MOZ_WARN_UNUSED_RESULT. r=jwalden (90144c2d35) - Bug 1237201 part 9 - Fix remaining issues. r=nfroyd (25b86adb6d) - Bug 1186491 - An API for watching slow performance alerts (js-level); r=felipe (f04d277c80) - Bug 1200172 - AddonWatcher now discards data if the system is apparently too busy/just back from hibernation. r=mossop (66a3840b73) - Bug 1205840 - Typo fixes in AddonWatcher.jsm. r=felipe (760df6764c) - Bug 1186491 - Reworking AddonWatcher to use low-level performance watch API;r=mossop (81cc64263e) - Bug 1200169 - Making the slow add-on watcher more tolerant;r=Felipe (fcf988d985) - Bug 1157009 - Redesign about:performance. r=felipe (cacc590716) - Bug 1189513 - Get rid of separation between e10s and non-e10s probes; r=felipe (7a6d996c93) - Bug 1191327 - Recapitulates alerts in about:performance now. r=felipe (53ecc02da9) - Bug 1189799 - Make sure that about:performance displays each add-on only once (front-end);r=felipe (1ee53a0410) - Bug 1208747 - Move most of Stopwatch-related code to XPCOM-land (JS-level);r=felipe (84af14c20e) - Bug 1229519: Fix miscellaneous parts of toolkit to pass eslint checks. r=MattN (00ce3585c5) - Bug 1230735 - AddonWatcher.alerts is now a map;r=Felipe (81bbafbbd4) - Bug 1241838 - Removing erroneous CPOW suffix, reworking buggy jank suffix;r=Felipe (020d6928e6) - Bug 1175098 - Fix double-loading of PerformanceStats content script. r=mconley (fb1c499343) - Bug 1189799 - Make sure that about:performance displays each add-on only once (back-end);r=felipe (1eac8258df) - Bug 1221761 - Probe.prototype.release() now swallows NS_ERROR_NOT_AVAILABLE. r=felipe (ba1d0032a9) - Bug 1142937 - AddonWatcher now communicates through nsIObserverService. r=felipe (ea2e7ccdaa) - Bug 967873 - Test changes for async removeTab (r=Gijs) (dae5cbf835) - more missing parts of Bug 1132072 - Tab switch refactoring (r=mconley) (dc5e310537) - Bug 1191460 Rebased patch and added userContextId to origin attributes. (r=tanvi,r=sicking) (723999e7fa) - Bug 1239040 - Cleanup of DrawTargetSkia GetBitmapForSurface to use installPixels. r=jrmuizel (4016f4d734) - Bug 1239040 - Cleanup of DrawTargetSkia Mask and MaskSurface. r=jrmuizel (908a44d47e) - Bug 1239040 - Implement PushLayer for DrawTargetSkia. r=Bas (ae74697559) - Bug 1246756 - part 1 - fix moz2d Skia usage for Skia m49 update. r=jrmuizel (5e4b0f41e3) - Bug 1239040 - Allow usage of SkCanvas::getTopDevice in Skia. r=jrmuizel (19bdd2cecb) - Bug 1239040 - Fix DrawTargetCairo/DrawTargetSkia LockBits and BorrowedXlibDrawable to work inside PushLayer. r=jrmuizel (b9ba04009b) - Bug 1239040 - Cleanup of DrawTargetSkia CopySurface to avoid accessing bottom layer directly. r=jrmuizel (6690702507) - Bug 1240437: Implement PushLayer and PopLayer for DrawTargetRecording. r=bas (22673a1b52) - Bug 1220629 - Part 1: Add PushLayer/PopLayer API to DrawTarget baseclass. r=jrmuizel (c4b4315749) - Bug 1220629 - Part 2: Prepare DrawTargetD2D1 for the possibilities of layers existing inside it. r=jrmuizel (f2a74151a8) - Bug 1220629 - Part 3: Implement PushLayer/PopLayer API in cairo. r=jrmuizel (9a52965141) - Bug 1220629 - Part 4: Allow gfxContext to use the native pushlayer implementations based on a pref. r=jrmuizel (f13b773ff3) - Bug 1220629 - Part 5: Implement PushLayer/PopLayer API for Direct2D 1.1. r=jrmuizel (8a040648a2) - Bug 1220629 - Part 6: Implement PushLayer/PopLayer API in several wrapper DT types. r=jrmuizel (cf76723216) - Bug 1220629 - Part 7: Mark several reftests fuzzy. r=jrmuizel (a6deab2300) - Bug 1220629 - Part 8: Enable native PushLayer/PopLayer by default on Windows and Linux. r=jrmuizel (eef18e1e3e) - Bug 1234494 - part 1 - don't build in Skia GPU code if support is disabled, r=jrmuizel (4c74813077) - Bug 1234494 - part 2 - disable Skia GPU support by default on certain *BSDs, r=glandium (6184133b33) - Bug 1246756 - part 2 - update Skia moz.build for m49 update. r=jrmuizel (e0cf4ab953) - Bug 1244454 - Fixed skia compilation on mingw. r=lsalzman (064a56e56e) - Bug 1242044 - "layout/reftests/css-gradients/linear-zero-length-1 fails under Skia content". r=jmuizelaar (bee8f76e72) - Bug 1242751 - fix assertion in SkLinearGradient. r=jmuizelaar (f5df5ed88f) - Bug 1238795 - Fix SkGpuDevice::drawBitmapRect to always update clips. r=jrmuizel (05a9a6b10a) - Bug 1230096 - fix GrAAConvexTessellator assertion. r=jrmuizel (18aef9bdcc) - Bug 1237983 - Investigate and remove the Bagheera Client Implementation. r=gfritzsche (6de39c0e32) - Bug 1246756 - part 3 - update Skia to m49 branch. r=jrmuizel (a02a53e368) - Bug 1234526 - Remove services/healthreport. r=gfritzsche (bb0c567255) - Bug 1234522 - Remove services/datareporting. r=gfritzsche (c7bfec7784) - Bug 1211166 - Use AppConstants in SessionRecorder.jsm r=ted (4434996c34) - Bug 1246756 - Cross compilation fixup. r=upstream (99e3e40ba1) - Bug 1248228 - Build fix for SkOSFile_stdio on OpenBSD. r=jmuizelaar (bbb1eb7ac0) - Bug 1250196 - Part 1: Import mozilla::Forward and mozilla::UniqePtr into the std namespace in a way that is compatible with libc++; r=lsalzman (ffeebcc133) - Bug 1248851 part 4 - Mark UniquePtr::release() MOZ_WARN_UNUSED_RESULT. r=Waldo (f43cced74c) - Bug 1250196 - Part 2: Rename UniquePtr::getDeleter() to get_deleter() in order to make it compatible with std::unique_ptr; r=froydnj (f8aeabfc9a) - Bug 1248851 part 3 - Fix a potential double-free issue in indexedDB. r=sicking (4d13f5047b) - Bug 1248851 part 2 - Remove redundant release() calls in indexedDB code. r=sicking (86d67ffad8) - Bug 1239702 - Fix SK_ARM_HAS_NEON build config r=lsalzman (4233a57122) - Bug 1245979 - make mfbt Function reference-counted so that it can be cheaply copied for compatibility with Skia. r=froydnj (bd69e9c07b) - Bug 1245055 - Remove gfx/skia/Makefile.in. r=mshal (bf2c611f38) - Bug 1232694 - fix typo in Compiler.h; r=botond (2b5abb9d2d) - Bug 1228641 - Rename begin/size to aBegin/aSize to avoid shadow warnings; r=botond (9222809505) - Bug 1248784 - Rename the existing AddRefTraits to ConstRemovingRefPtrTraits. r=froydnj (99d7b0ae1f) - Bug 1248784 - Extract the AddRef/Release calls into a non-inner helper trait. r=froydnj (37243b6235) - Bug 1248784 - Followup to add requested comment. r=froydnj DONTBUILD (0e870b586b) - Bug 1242794 - make SkGrPixelRef::deepCopy preserve alpha type. r=jmuizelaar (0fb454c326) - Bug 1201037 - (Linux) squash network-change events during 1000ms, r=mcmanus (087f57c44d) - Bug 1235509 - Link monitor should not fire link change events for the refresh of the ipv6 lifetime. r=bagder (c507a319c4) - Bug 1234548 - Don't send network change events if routes are changed. r=mcmanus, r=bagder (5cd0bc582e) - Bug 1234548 - Remove unused variables. r=bustage (42df135fbf) - Bug 1240515 - change allocator for addr and localaddr from malloc to new, since the smart pointer that is used uses delete operator. r=dragana (02f5d5433c) - Bug 1241901 part 1 - Remove nsAutoPtr uses in nsNotifyAddrListener on Linux. r=bagder (f8696ad190) - Bug 1241901 part 2 - Use intptr_t to pass bluetooth service class instead of a pointer to heap. r=shawnjohnjr (5c86a164fa) - Bug 1241901 part 3 - Add IsMemberPointer and IsScalar type traits. r=froydnj (80747268bd) - Bug 1243876 - fix ConvertibleTester to not cause incomplete type errors with UniquePtr and Skia. r=nfroyd (c5588dd270) - Bug 1234736 - IonMonkey: Recover Math.imul as an int32 operation. r=h4writer (459b92c618) - Bug 1228571 - Fix GenerateSeed to not leave seed uninitialized if reading from /dev/urandom fails. r=cpeterson (3be0a2816b) - Bug 1233302: Don't crash if we can't open /dev/urandom; just fall back to PRMJ_Now. (d83ae5540a) - Bug 1167248 - Call RtlGenRandom() instead of rand_s() to workaround crashes from injected third-party hooks. r=jandem (678e7a0056) - Bug 1236619 Fix compilation failure with warnings-as-errors with some compilers. r=njn (043956881d) - Bug 1167248 - Cross compilation fixup. (f4a34fb229)
865 lines
28 KiB
C++
865 lines
28 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
/* -------------------------------------------------------------------
|
|
To Build This:
|
|
|
|
You need to add this to the the makefile.win in mozilla/dom/base:
|
|
|
|
.\$(OBJDIR)\nsFlyOwnPrintDialog.obj \
|
|
|
|
|
|
And this to the makefile.win in mozilla/content/build:
|
|
|
|
WIN_LIBS= \
|
|
winspool.lib \
|
|
comctl32.lib \
|
|
comdlg32.lib
|
|
|
|
---------------------------------------------------------------------- */
|
|
|
|
#include "plstr.h"
|
|
#include <windows.h>
|
|
#include <tchar.h>
|
|
|
|
#include <unknwn.h>
|
|
#include <commdlg.h>
|
|
|
|
#include "nsIWebBrowserPrint.h"
|
|
#include "nsString.h"
|
|
#include "nsIServiceManager.h"
|
|
#include "nsReadableUtils.h"
|
|
#include "nsIPrintSettings.h"
|
|
#include "nsIPrintSettingsWin.h"
|
|
#include "nsIPrintOptions.h"
|
|
|
|
#include "nsRect.h"
|
|
|
|
#include "nsIPrefService.h"
|
|
#include "nsIPrefBranch.h"
|
|
|
|
#include "nsCRT.h"
|
|
#include "prenv.h" /* for PR_GetEnv */
|
|
|
|
#include <windows.h>
|
|
#include <winspool.h>
|
|
|
|
// For Localization
|
|
#include "nsIStringBundle.h"
|
|
|
|
// For NS_CopyUnicodeToNative
|
|
#include "nsNativeCharsetUtils.h"
|
|
|
|
// This is for extending the dialog
|
|
#include <dlgs.h>
|
|
|
|
// Default labels for the radio buttons
|
|
static const char* kAsLaidOutOnScreenStr = "As &laid out on the screen";
|
|
static const char* kTheSelectedFrameStr = "The selected &frame";
|
|
static const char* kEachFrameSeparately = "&Each frame separately";
|
|
|
|
|
|
//-----------------------------------------------
|
|
// Global Data
|
|
//-----------------------------------------------
|
|
// Identifies which new radio btn was cliked on
|
|
static UINT gFrameSelectedRadioBtn = 0;
|
|
|
|
// Indicates whether the native print dialog was successfully extended
|
|
static bool gDialogWasExtended = false;
|
|
|
|
#define PRINTDLG_PROPERTIES "chrome://global/locale/printdialog.properties"
|
|
|
|
static HWND gParentWnd = nullptr;
|
|
|
|
//----------------------------------------------------------------------------------
|
|
// Return localized bundle for resource strings
|
|
static nsresult
|
|
GetLocalizedBundle(const char * aPropFileName, nsIStringBundle** aStrBundle)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aPropFileName);
|
|
NS_ENSURE_ARG_POINTER(aStrBundle);
|
|
|
|
nsresult rv;
|
|
nsCOMPtr<nsIStringBundle> bundle;
|
|
|
|
|
|
// Create bundle
|
|
nsCOMPtr<nsIStringBundleService> stringService =
|
|
do_GetService(NS_STRINGBUNDLE_CONTRACTID, &rv);
|
|
if (NS_SUCCEEDED(rv) && stringService) {
|
|
rv = stringService->CreateBundle(aPropFileName, aStrBundle);
|
|
}
|
|
|
|
return rv;
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Return localized string
|
|
static nsresult
|
|
GetLocalizedString(nsIStringBundle* aStrBundle, const char* aKey, nsString& oVal)
|
|
{
|
|
NS_ENSURE_ARG_POINTER(aStrBundle);
|
|
NS_ENSURE_ARG_POINTER(aKey);
|
|
|
|
// Determine default label from string bundle
|
|
nsXPIDLString valUni;
|
|
nsAutoString key;
|
|
key.AssignWithConversion(aKey);
|
|
nsresult rv = aStrBundle->GetStringFromName(key.get(), getter_Copies(valUni));
|
|
if (NS_SUCCEEDED(rv) && valUni) {
|
|
oVal.Assign(valUni);
|
|
} else {
|
|
oVal.Truncate();
|
|
}
|
|
return rv;
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Set a multi-byte string in the control
|
|
static void SetTextOnWnd(HWND aControl, const nsString& aStr)
|
|
{
|
|
nsAutoCString text;
|
|
if (NS_SUCCEEDED(NS_CopyUnicodeToNative(aStr, text))) {
|
|
::SetWindowText(aControl, text.get());
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Will get the control and localized string by "key"
|
|
static void SetText(HWND aParent,
|
|
UINT aId,
|
|
nsIStringBundle* aStrBundle,
|
|
const char* aKey)
|
|
{
|
|
HWND wnd = GetDlgItem (aParent, aId);
|
|
if (!wnd) {
|
|
return;
|
|
}
|
|
nsAutoString str;
|
|
nsresult rv = GetLocalizedString(aStrBundle, aKey, str);
|
|
if (NS_SUCCEEDED(rv)) {
|
|
SetTextOnWnd(wnd, str);
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
static void SetRadio(HWND aParent,
|
|
UINT aId,
|
|
bool aIsSet,
|
|
bool isEnabled = true)
|
|
{
|
|
HWND wnd = ::GetDlgItem (aParent, aId);
|
|
if (!wnd) {
|
|
return;
|
|
}
|
|
if (!isEnabled) {
|
|
::EnableWindow(wnd, FALSE);
|
|
return;
|
|
}
|
|
::EnableWindow(wnd, TRUE);
|
|
::SendMessage(wnd, BM_SETCHECK, (WPARAM)aIsSet, (LPARAM)0);
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
static void SetRadioOfGroup(HWND aDlg, int aRadId)
|
|
{
|
|
int radioIds[] = {rad4, rad5, rad6};
|
|
int numRads = 3;
|
|
|
|
for (int i=0;i<numRads;i++) {
|
|
HWND radWnd = ::GetDlgItem(aDlg, radioIds[i]);
|
|
if (radWnd != nullptr) {
|
|
::SendMessage(radWnd, BM_SETCHECK, (WPARAM)(radioIds[i] == aRadId), (LPARAM)0);
|
|
}
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
typedef struct {
|
|
const char * mKeyStr;
|
|
long mKeyId;
|
|
} PropKeyInfo;
|
|
|
|
// These are the control ids used in the dialog and
|
|
// defined by MS-Windows in commdlg.h
|
|
static PropKeyInfo gAllPropKeys[] = {
|
|
{"printFramesTitleWindows", grp3},
|
|
{"asLaidOutWindows", rad4},
|
|
{"selectedFrameWindows", rad5},
|
|
{"separateFramesWindows", rad6},
|
|
{nullptr, 0}};
|
|
|
|
//--------------------------------------------------------
|
|
//--------------------------------------------------------
|
|
//--------------------------------------------------------
|
|
//--------------------------------------------------------
|
|
// Get the absolute coords of the child windows relative
|
|
// to its parent window
|
|
static void GetLocalRect(HWND aWnd, RECT& aRect, HWND aParent)
|
|
{
|
|
::GetWindowRect(aWnd, &aRect);
|
|
|
|
// MapWindowPoints converts screen coordinates to client coordinates.
|
|
// It works correctly in both left-to-right and right-to-left windows.
|
|
::MapWindowPoints(nullptr, aParent, (LPPOINT)&aRect, 2);
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Show or Hide the control
|
|
static void Show(HWND aWnd, bool bState)
|
|
{
|
|
if (aWnd) {
|
|
::ShowWindow(aWnd, bState?SW_SHOW:SW_HIDE);
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Create a child window "control"
|
|
static HWND CreateControl(LPCTSTR aType,
|
|
DWORD aStyle,
|
|
HINSTANCE aHInst,
|
|
HWND aHdlg,
|
|
int aId,
|
|
const nsAString& aStr,
|
|
const nsIntRect& aRect)
|
|
{
|
|
nsAutoCString str;
|
|
if (NS_FAILED(NS_CopyUnicodeToNative(aStr, str)))
|
|
return nullptr;
|
|
|
|
HWND hWnd = ::CreateWindow (aType, str.get(),
|
|
WS_CHILD | WS_CLIPSIBLINGS | WS_VISIBLE | aStyle,
|
|
aRect.x, aRect.y, aRect.width, aRect.height,
|
|
(HWND)aHdlg, (HMENU)(intptr_t)aId,
|
|
aHInst, nullptr);
|
|
if (hWnd == nullptr) return nullptr;
|
|
|
|
// get the native font for the dialog and
|
|
// set it into the new control
|
|
HFONT hFont = (HFONT)::SendMessage(aHdlg, WM_GETFONT, (WPARAM)0, (LPARAM)0);
|
|
if (hFont != nullptr) {
|
|
::SendMessage(hWnd, WM_SETFONT, (WPARAM) hFont, (LPARAM)0);
|
|
}
|
|
return hWnd;
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Create a Radio Button
|
|
static HWND CreateRadioBtn(HINSTANCE aHInst,
|
|
HWND aHdlg,
|
|
int aId,
|
|
const char* aStr,
|
|
const nsIntRect& aRect)
|
|
{
|
|
nsString cStr;
|
|
cStr.AssignWithConversion(aStr);
|
|
return CreateControl("BUTTON", BS_RADIOBUTTON, aHInst, aHdlg, aId, cStr, aRect);
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Create a Group Box
|
|
static HWND CreateGroupBox(HINSTANCE aHInst,
|
|
HWND aHdlg,
|
|
int aId,
|
|
const nsAString& aStr,
|
|
const nsIntRect& aRect)
|
|
{
|
|
return CreateControl("BUTTON", BS_GROUPBOX, aHInst, aHdlg, aId, aStr, aRect);
|
|
}
|
|
|
|
//--------------------------------------------------------
|
|
// Localizes and initializes the radio buttons and group
|
|
static void InitializeExtendedDialog(HWND hdlg, int16_t aHowToEnableFrameUI)
|
|
{
|
|
MOZ_ASSERT(aHowToEnableFrameUI != nsIPrintSettings::kFrameEnableNone,
|
|
"should not be called");
|
|
|
|
// Localize the new controls in the print dialog
|
|
nsCOMPtr<nsIStringBundle> strBundle;
|
|
if (NS_SUCCEEDED(GetLocalizedBundle(PRINTDLG_PROPERTIES, getter_AddRefs(strBundle)))) {
|
|
int32_t i = 0;
|
|
while (gAllPropKeys[i].mKeyStr != nullptr) {
|
|
SetText(hdlg, gAllPropKeys[i].mKeyId, strBundle, gAllPropKeys[i].mKeyStr);
|
|
i++;
|
|
}
|
|
}
|
|
|
|
// Set up radio buttons
|
|
if (aHowToEnableFrameUI == nsIPrintSettings::kFrameEnableAll) {
|
|
SetRadio(hdlg, rad4, false);
|
|
SetRadio(hdlg, rad5, true);
|
|
SetRadio(hdlg, rad6, false);
|
|
// set default so user doesn't have to actually press on it
|
|
gFrameSelectedRadioBtn = rad5;
|
|
|
|
} else { // nsIPrintSettings::kFrameEnableAsIsAndEach
|
|
SetRadio(hdlg, rad4, false);
|
|
SetRadio(hdlg, rad5, false, false);
|
|
SetRadio(hdlg, rad6, true);
|
|
// set default so user doesn't have to actually press on it
|
|
gFrameSelectedRadioBtn = rad6;
|
|
}
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------
|
|
// Special Hook Procedure for handling the print dialog messages
|
|
static UINT CALLBACK PrintHookProc(HWND hdlg, UINT uiMsg, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
|
|
if (uiMsg == WM_COMMAND) {
|
|
UINT id = LOWORD(wParam);
|
|
if (id == rad4 || id == rad5 || id == rad6) {
|
|
gFrameSelectedRadioBtn = id;
|
|
SetRadioOfGroup(hdlg, id);
|
|
}
|
|
|
|
} else if (uiMsg == WM_INITDIALOG) {
|
|
PRINTDLG * printDlg = (PRINTDLG *)lParam;
|
|
if (printDlg == nullptr) return 0L;
|
|
|
|
int16_t howToEnableFrameUI = (int16_t)printDlg->lCustData;
|
|
// don't add frame options if they would be disabled anyway
|
|
// because there are no frames
|
|
if (howToEnableFrameUI == nsIPrintSettings::kFrameEnableNone)
|
|
return TRUE;
|
|
|
|
HINSTANCE hInst = (HINSTANCE)::GetWindowLongPtr(hdlg, GWLP_HINSTANCE);
|
|
if (hInst == nullptr) return 0L;
|
|
|
|
// Start by getting the local rects of several of the controls
|
|
// so we can calculate where the new controls are
|
|
HWND wnd = ::GetDlgItem(hdlg, grp1);
|
|
if (wnd == nullptr) return 0L;
|
|
RECT dlgRect;
|
|
GetLocalRect(wnd, dlgRect, hdlg);
|
|
|
|
wnd = ::GetDlgItem(hdlg, rad1); // this is the top control "All"
|
|
if (wnd == nullptr) return 0L;
|
|
RECT rad1Rect;
|
|
GetLocalRect(wnd, rad1Rect, hdlg);
|
|
|
|
wnd = ::GetDlgItem(hdlg, rad2); // this is the bottom control "Selection"
|
|
if (wnd == nullptr) return 0L;
|
|
RECT rad2Rect;
|
|
GetLocalRect(wnd, rad2Rect, hdlg);
|
|
|
|
wnd = ::GetDlgItem(hdlg, rad3); // this is the middle control "Pages"
|
|
if (wnd == nullptr) return 0L;
|
|
RECT rad3Rect;
|
|
GetLocalRect(wnd, rad3Rect, hdlg);
|
|
|
|
HWND okWnd = ::GetDlgItem(hdlg, IDOK);
|
|
if (okWnd == nullptr) return 0L;
|
|
RECT okRect;
|
|
GetLocalRect(okWnd, okRect, hdlg);
|
|
|
|
wnd = ::GetDlgItem(hdlg, grp4); // this is the "Print range" groupbox
|
|
if (wnd == nullptr) return 0L;
|
|
RECT prtRect;
|
|
GetLocalRect(wnd, prtRect, hdlg);
|
|
|
|
|
|
// calculate various different "gaps" for layout purposes
|
|
|
|
int rbGap = rad3Rect.top - rad1Rect.bottom; // gap between radiobtns
|
|
int grpBotGap = dlgRect.bottom - rad2Rect.bottom; // gap from bottom rb to bottom of grpbox
|
|
int grpGap = dlgRect.top - prtRect.bottom ; // gap between group boxes
|
|
int top = dlgRect.bottom + grpGap;
|
|
int radHgt = rad1Rect.bottom - rad1Rect.top + 1; // top of new group box
|
|
int y = top+(rad1Rect.top-dlgRect.top); // starting pos of first radio
|
|
int rbWidth = dlgRect.right - rad1Rect.left - 5; // measure from rb left to the edge of the groupbox
|
|
// (5 is arbitrary)
|
|
nsIntRect rect;
|
|
|
|
// Create and position the radio buttons
|
|
//
|
|
// If any one control cannot be created then
|
|
// hide the others and bail out
|
|
//
|
|
rect.SetRect(rad1Rect.left, y, rbWidth,radHgt);
|
|
HWND rad4Wnd = CreateRadioBtn(hInst, hdlg, rad4, kAsLaidOutOnScreenStr, rect);
|
|
if (rad4Wnd == nullptr) return 0L;
|
|
y += radHgt + rbGap;
|
|
|
|
rect.SetRect(rad1Rect.left, y, rbWidth, radHgt);
|
|
HWND rad5Wnd = CreateRadioBtn(hInst, hdlg, rad5, kTheSelectedFrameStr, rect);
|
|
if (rad5Wnd == nullptr) {
|
|
Show(rad4Wnd, FALSE); // hide
|
|
return 0L;
|
|
}
|
|
y += radHgt + rbGap;
|
|
|
|
rect.SetRect(rad1Rect.left, y, rbWidth, radHgt);
|
|
HWND rad6Wnd = CreateRadioBtn(hInst, hdlg, rad6, kEachFrameSeparately, rect);
|
|
if (rad6Wnd == nullptr) {
|
|
Show(rad4Wnd, FALSE); // hide
|
|
Show(rad5Wnd, FALSE); // hide
|
|
return 0L;
|
|
}
|
|
y += radHgt + grpBotGap;
|
|
|
|
// Create and position the group box
|
|
rect.SetRect (dlgRect.left, top, dlgRect.right-dlgRect.left+1, y-top+1);
|
|
HWND grpBoxWnd = CreateGroupBox(hInst, hdlg, grp3, NS_LITERAL_STRING("Print Frame"), rect);
|
|
if (grpBoxWnd == nullptr) {
|
|
Show(rad4Wnd, FALSE); // hide
|
|
Show(rad5Wnd, FALSE); // hide
|
|
Show(rad6Wnd, FALSE); // hide
|
|
return 0L;
|
|
}
|
|
|
|
// Here we figure out the old height of the dlg
|
|
// then figure its gap from the old grpbx to the bottom
|
|
// then size the dlg
|
|
RECT pr, cr;
|
|
::GetWindowRect(hdlg, &pr);
|
|
::GetClientRect(hdlg, &cr);
|
|
|
|
int dlgHgt = (cr.bottom - cr.top) + 1;
|
|
int bottomGap = dlgHgt - okRect.bottom;
|
|
pr.bottom += (dlgRect.bottom-dlgRect.top) + grpGap + 1 - (dlgHgt-dlgRect.bottom) + bottomGap;
|
|
|
|
::SetWindowPos(hdlg, nullptr, pr.left, pr.top, pr.right-pr.left+1, pr.bottom-pr.top+1,
|
|
SWP_NOMOVE|SWP_NOREDRAW|SWP_NOZORDER);
|
|
|
|
// figure out the new height of the dialog
|
|
::GetClientRect(hdlg, &cr);
|
|
dlgHgt = (cr.bottom - cr.top) + 1;
|
|
|
|
// Reposition the OK and Cancel btns
|
|
int okHgt = okRect.bottom - okRect.top + 1;
|
|
::SetWindowPos(okWnd, nullptr, okRect.left, dlgHgt-bottomGap-okHgt, 0, 0,
|
|
SWP_NOSIZE|SWP_NOREDRAW|SWP_NOZORDER);
|
|
|
|
HWND cancelWnd = ::GetDlgItem(hdlg, IDCANCEL);
|
|
if (cancelWnd == nullptr) return 0L;
|
|
|
|
RECT cancelRect;
|
|
GetLocalRect(cancelWnd, cancelRect, hdlg);
|
|
int cancelHgt = cancelRect.bottom - cancelRect.top + 1;
|
|
::SetWindowPos(cancelWnd, nullptr, cancelRect.left, dlgHgt-bottomGap-cancelHgt, 0, 0,
|
|
SWP_NOSIZE|SWP_NOREDRAW|SWP_NOZORDER);
|
|
|
|
// localize and initialize the groupbox and radiobuttons
|
|
InitializeExtendedDialog(hdlg, howToEnableFrameUI);
|
|
|
|
// Looks like we were able to extend the dialog
|
|
gDialogWasExtended = true;
|
|
return TRUE;
|
|
}
|
|
return 0L;
|
|
}
|
|
|
|
//----------------------------------------------------------------------------------
|
|
// Returns a Global Moveable Memory Handle to a DevMode
|
|
// from the Printer by the name of aPrintName
|
|
//
|
|
// NOTE:
|
|
// This function assumes that aPrintName has already been converted from
|
|
// unicode
|
|
//
|
|
HGLOBAL CreateGlobalDevModeAndInit(const nsXPIDLString& aPrintName, nsIPrintSettings* aPS)
|
|
{
|
|
HGLOBAL hGlobalDevMode = nullptr;
|
|
|
|
HANDLE hPrinter = nullptr;
|
|
// const cast kludge for silly Win32 api's
|
|
LPWSTR printName = const_cast<wchar_t*>(static_cast<const wchar_t*>(aPrintName.get()));
|
|
BOOL status = ::OpenPrinterW(printName, &hPrinter, nullptr);
|
|
if (status) {
|
|
|
|
LPDEVMODEW pNewDevMode;
|
|
DWORD dwNeeded, dwRet;
|
|
|
|
// Get the buffer size
|
|
dwNeeded = ::DocumentPropertiesW(gParentWnd, hPrinter, printName, nullptr, nullptr, 0);
|
|
if (dwNeeded == 0) {
|
|
return nullptr;
|
|
}
|
|
|
|
// Allocate a buffer of the correct size.
|
|
pNewDevMode = (LPDEVMODEW)::HeapAlloc (::GetProcessHeap(), HEAP_ZERO_MEMORY, dwNeeded);
|
|
if (!pNewDevMode) return nullptr;
|
|
|
|
hGlobalDevMode = (HGLOBAL)::GlobalAlloc(GHND, dwNeeded);
|
|
if (!hGlobalDevMode) {
|
|
::HeapFree(::GetProcessHeap(), 0, pNewDevMode);
|
|
return nullptr;
|
|
}
|
|
|
|
dwRet = ::DocumentPropertiesW(gParentWnd, hPrinter, printName, pNewDevMode, nullptr, DM_OUT_BUFFER);
|
|
|
|
if (dwRet != IDOK) {
|
|
::HeapFree(::GetProcessHeap(), 0, pNewDevMode);
|
|
::GlobalFree(hGlobalDevMode);
|
|
::ClosePrinter(hPrinter);
|
|
return nullptr;
|
|
}
|
|
|
|
// Lock memory and copy contents from DEVMODE (current printer)
|
|
// to Global Memory DEVMODE
|
|
LPDEVMODEW devMode = (DEVMODEW *)::GlobalLock(hGlobalDevMode);
|
|
if (devMode) {
|
|
memcpy(devMode, pNewDevMode, dwNeeded);
|
|
// Initialize values from the PrintSettings
|
|
nsCOMPtr<nsIPrintSettingsWin> psWin = do_QueryInterface(aPS);
|
|
MOZ_ASSERT(psWin);
|
|
psWin->CopyToNative(devMode);
|
|
|
|
// Sets back the changes we made to the DevMode into the Printer Driver
|
|
dwRet = ::DocumentPropertiesW(gParentWnd, hPrinter, printName, devMode, devMode, DM_IN_BUFFER | DM_OUT_BUFFER);
|
|
if (dwRet != IDOK) {
|
|
::GlobalUnlock(hGlobalDevMode);
|
|
::GlobalFree(hGlobalDevMode);
|
|
::HeapFree(::GetProcessHeap(), 0, pNewDevMode);
|
|
::ClosePrinter(hPrinter);
|
|
return nullptr;
|
|
}
|
|
|
|
::GlobalUnlock(hGlobalDevMode);
|
|
} else {
|
|
::GlobalFree(hGlobalDevMode);
|
|
hGlobalDevMode = nullptr;
|
|
}
|
|
|
|
::HeapFree(::GetProcessHeap(), 0, pNewDevMode);
|
|
|
|
::ClosePrinter(hPrinter);
|
|
|
|
} else {
|
|
return nullptr;
|
|
}
|
|
|
|
return hGlobalDevMode;
|
|
}
|
|
|
|
//------------------------------------------------------------------
|
|
// helper
|
|
static void GetDefaultPrinterNameFromGlobalPrinters(nsXPIDLString &printerName)
|
|
{
|
|
nsCOMPtr<nsIPrinterEnumerator> prtEnum = do_GetService("@mozilla.org/gfx/printerenumerator;1");
|
|
if (prtEnum) {
|
|
prtEnum->GetDefaultPrinterName(getter_Copies(printerName));
|
|
}
|
|
}
|
|
|
|
// Determine whether we have a completely native dialog
|
|
// or whether we cshould extend it
|
|
static bool ShouldExtendPrintDialog()
|
|
{
|
|
nsresult rv;
|
|
nsCOMPtr<nsIPrefService> prefs =
|
|
do_GetService(NS_PREFSERVICE_CONTRACTID, &rv);
|
|
NS_ENSURE_SUCCESS(rv, true);
|
|
nsCOMPtr<nsIPrefBranch> prefBranch;
|
|
rv = prefs->GetBranch(nullptr, getter_AddRefs(prefBranch));
|
|
NS_ENSURE_SUCCESS(rv, true);
|
|
|
|
bool result;
|
|
rv = prefBranch->GetBoolPref("print.extend_native_print_dialog", &result);
|
|
NS_ENSURE_SUCCESS(rv, true);
|
|
return result;
|
|
}
|
|
|
|
//------------------------------------------------------------------
|
|
// Displays the native Print Dialog
|
|
static nsresult
|
|
ShowNativePrintDialog(HWND aHWnd,
|
|
nsIPrintSettings* aPrintSettings)
|
|
{
|
|
//NS_ENSURE_ARG_POINTER(aHWnd);
|
|
NS_ENSURE_ARG_POINTER(aPrintSettings);
|
|
|
|
gDialogWasExtended = false;
|
|
|
|
HGLOBAL hGlobalDevMode = nullptr;
|
|
HGLOBAL hDevNames = nullptr;
|
|
|
|
// Get the Print Name to be used
|
|
nsXPIDLString printerName;
|
|
aPrintSettings->GetPrinterName(getter_Copies(printerName));
|
|
|
|
// If there is no name then use the default printer
|
|
if (printerName.IsEmpty()) {
|
|
GetDefaultPrinterNameFromGlobalPrinters(printerName);
|
|
} else {
|
|
HANDLE hPrinter = nullptr;
|
|
if(!::OpenPrinterW(const_cast<wchar_t*>(static_cast<const wchar_t*>(printerName.get())), &hPrinter, nullptr)) {
|
|
// If the last used printer is not found, we should use default printer.
|
|
GetDefaultPrinterNameFromGlobalPrinters(printerName);
|
|
} else {
|
|
::ClosePrinter(hPrinter);
|
|
}
|
|
}
|
|
|
|
// Now create a DEVNAMES struct so the the dialog is initialized correctly.
|
|
|
|
uint32_t len = printerName.Length();
|
|
hDevNames = (HGLOBAL)::GlobalAlloc(GHND, sizeof(wchar_t) * (len + 1) +
|
|
sizeof(DEVNAMES));
|
|
if (!hDevNames) {
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
|
|
DEVNAMES* pDevNames = (DEVNAMES*)::GlobalLock(hDevNames);
|
|
if (!pDevNames) {
|
|
::GlobalFree(hDevNames);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
pDevNames->wDriverOffset = sizeof(DEVNAMES)/sizeof(wchar_t);
|
|
pDevNames->wDeviceOffset = sizeof(DEVNAMES)/sizeof(wchar_t);
|
|
pDevNames->wOutputOffset = sizeof(DEVNAMES)/sizeof(wchar_t)+len;
|
|
pDevNames->wDefault = 0;
|
|
|
|
memcpy(pDevNames+1, printerName, (len + 1) * sizeof(wchar_t));
|
|
::GlobalUnlock(hDevNames);
|
|
|
|
// Create a Moveable Memory Object that holds a new DevMode
|
|
// from the Printer Name
|
|
// The PRINTDLG.hDevMode requires that it be a moveable memory object
|
|
// NOTE: We only need to free hGlobalDevMode when the dialog is cancelled
|
|
// When the user prints, it comes back in the printdlg struct and
|
|
// is used and cleaned up later
|
|
hGlobalDevMode = CreateGlobalDevModeAndInit(printerName, aPrintSettings);
|
|
|
|
// Prepare to Display the Print Dialog
|
|
PRINTDLGW prntdlg;
|
|
memset(&prntdlg, 0, sizeof(PRINTDLGW));
|
|
|
|
prntdlg.lStructSize = sizeof(prntdlg);
|
|
prntdlg.hwndOwner = aHWnd;
|
|
prntdlg.hDevMode = hGlobalDevMode;
|
|
prntdlg.hDevNames = hDevNames;
|
|
prntdlg.hDC = nullptr;
|
|
prntdlg.Flags = PD_ALLPAGES | PD_RETURNIC |
|
|
PD_USEDEVMODECOPIESANDCOLLATE | PD_COLLATE;
|
|
|
|
// if there is a current selection then enable the "Selection" radio button
|
|
int16_t howToEnableFrameUI = nsIPrintSettings::kFrameEnableNone;
|
|
bool isOn;
|
|
aPrintSettings->GetPrintOptions(nsIPrintSettings::kEnableSelectionRB, &isOn);
|
|
if (!isOn) {
|
|
prntdlg.Flags |= PD_NOSELECTION;
|
|
}
|
|
aPrintSettings->GetHowToEnableFrameUI(&howToEnableFrameUI);
|
|
|
|
int32_t pg = 1;
|
|
aPrintSettings->GetStartPageRange(&pg);
|
|
prntdlg.nFromPage = pg;
|
|
|
|
aPrintSettings->GetEndPageRange(&pg);
|
|
prntdlg.nToPage = pg;
|
|
|
|
prntdlg.nMinPage = 1;
|
|
prntdlg.nMaxPage = 0xFFFF;
|
|
prntdlg.nCopies = 1;
|
|
prntdlg.lpfnSetupHook = nullptr;
|
|
prntdlg.lpSetupTemplateName = nullptr;
|
|
prntdlg.hPrintTemplate = nullptr;
|
|
prntdlg.hSetupTemplate = nullptr;
|
|
|
|
prntdlg.hInstance = nullptr;
|
|
prntdlg.lpPrintTemplateName = nullptr;
|
|
|
|
if (!ShouldExtendPrintDialog()) {
|
|
prntdlg.lCustData = 0;
|
|
prntdlg.lpfnPrintHook = nullptr;
|
|
} else {
|
|
// Set up print dialog "hook" procedure for extending the dialog
|
|
prntdlg.lCustData = (DWORD)howToEnableFrameUI;
|
|
prntdlg.lpfnPrintHook = (LPPRINTHOOKPROC)PrintHookProc;
|
|
prntdlg.Flags |= PD_ENABLEPRINTHOOK;
|
|
}
|
|
|
|
BOOL result = ::PrintDlgW(&prntdlg);
|
|
|
|
if (TRUE == result) {
|
|
// check to make sure we don't have any nullptr pointers
|
|
NS_ENSURE_TRUE(aPrintSettings && prntdlg.hDevMode, NS_ERROR_FAILURE);
|
|
|
|
if (prntdlg.hDevNames == nullptr) {
|
|
::GlobalFree(hGlobalDevMode);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
// Lock the deviceNames and check for nullptr
|
|
DEVNAMES *devnames = (DEVNAMES *)::GlobalLock(prntdlg.hDevNames);
|
|
if (devnames == nullptr) {
|
|
::GlobalFree(hGlobalDevMode);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
char16_t* device = &(((char16_t *)devnames)[devnames->wDeviceOffset]);
|
|
char16_t* driver = &(((char16_t *)devnames)[devnames->wDriverOffset]);
|
|
|
|
// Check to see if the "Print To File" control is checked
|
|
// then take the name from devNames and set it in the PrintSettings
|
|
//
|
|
// NOTE:
|
|
// As per Microsoft SDK documentation the returned value offset from
|
|
// devnames->wOutputOffset is either "FILE:" or nullptr
|
|
// if the "Print To File" checkbox is checked it MUST be "FILE:"
|
|
// We assert as an extra safety check.
|
|
if (prntdlg.Flags & PD_PRINTTOFILE) {
|
|
char16ptr_t fileName = &(((wchar_t *)devnames)[devnames->wOutputOffset]);
|
|
NS_ASSERTION(wcscmp(fileName, L"FILE:") == 0, "FileName must be `FILE:`");
|
|
aPrintSettings->SetToFileName(fileName);
|
|
aPrintSettings->SetPrintToFile(true);
|
|
} else {
|
|
// clear "print to file" info
|
|
aPrintSettings->SetPrintToFile(false);
|
|
aPrintSettings->SetToFileName(nullptr);
|
|
}
|
|
|
|
nsCOMPtr<nsIPrintSettingsWin> psWin(do_QueryInterface(aPrintSettings));
|
|
if (!psWin) {
|
|
::GlobalFree(hGlobalDevMode);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
// Setup local Data members
|
|
psWin->SetDeviceName(device);
|
|
psWin->SetDriverName(driver);
|
|
|
|
#if defined(DEBUG_rods) || defined(DEBUG_dcone)
|
|
wprintf(L"printer: driver %s, device %s flags: %d\n", driver, device, prntdlg.Flags);
|
|
#endif
|
|
// fill the print options with the info from the dialog
|
|
|
|
aPrintSettings->SetPrinterName(device);
|
|
|
|
if (prntdlg.Flags & PD_SELECTION) {
|
|
aPrintSettings->SetPrintRange(nsIPrintSettings::kRangeSelection);
|
|
|
|
} else if (prntdlg.Flags & PD_PAGENUMS) {
|
|
aPrintSettings->SetPrintRange(nsIPrintSettings::kRangeSpecifiedPageRange);
|
|
aPrintSettings->SetStartPageRange(prntdlg.nFromPage);
|
|
aPrintSettings->SetEndPageRange(prntdlg.nToPage);
|
|
|
|
} else { // (prntdlg.Flags & PD_ALLPAGES)
|
|
aPrintSettings->SetPrintRange(nsIPrintSettings::kRangeAllPages);
|
|
}
|
|
|
|
if (howToEnableFrameUI != nsIPrintSettings::kFrameEnableNone) {
|
|
// make sure the dialog got extended
|
|
if (gDialogWasExtended) {
|
|
// check to see about the frame radio buttons
|
|
switch (gFrameSelectedRadioBtn) {
|
|
case rad4:
|
|
aPrintSettings->SetPrintFrameType(nsIPrintSettings::kFramesAsIs);
|
|
break;
|
|
case rad5:
|
|
aPrintSettings->SetPrintFrameType(nsIPrintSettings::kSelectedFrame);
|
|
break;
|
|
case rad6:
|
|
aPrintSettings->SetPrintFrameType(nsIPrintSettings::kEachFrameSep);
|
|
break;
|
|
} // switch
|
|
} else {
|
|
// if it didn't get extended then have it default to printing
|
|
// each frame separately
|
|
aPrintSettings->SetPrintFrameType(nsIPrintSettings::kEachFrameSep);
|
|
}
|
|
} else {
|
|
aPrintSettings->SetPrintFrameType(nsIPrintSettings::kNoFrames);
|
|
}
|
|
// Unlock DeviceNames
|
|
::GlobalUnlock(prntdlg.hDevNames);
|
|
|
|
// Transfer the settings from the native data to the PrintSettings
|
|
LPDEVMODEW devMode = (LPDEVMODEW)::GlobalLock(prntdlg.hDevMode);
|
|
if (!devMode || !prntdlg.hDC) {
|
|
::GlobalFree(hGlobalDevMode);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
psWin->SetDevMode(devMode); // copies DevMode
|
|
psWin->CopyFromNative(prntdlg.hDC, devMode);
|
|
::GlobalUnlock(prntdlg.hDevMode);
|
|
::DeleteDC(prntdlg.hDC);
|
|
|
|
#if defined(DEBUG_rods) || defined(DEBUG_dcone)
|
|
bool printSelection = prntdlg.Flags & PD_SELECTION;
|
|
bool printAllPages = prntdlg.Flags & PD_ALLPAGES;
|
|
bool printNumPages = prntdlg.Flags & PD_PAGENUMS;
|
|
int32_t fromPageNum = 0;
|
|
int32_t toPageNum = 0;
|
|
|
|
if (printNumPages) {
|
|
fromPageNum = prntdlg.nFromPage;
|
|
toPageNum = prntdlg.nToPage;
|
|
}
|
|
if (printSelection) {
|
|
printf("Printing the selection\n");
|
|
|
|
} else if (printAllPages) {
|
|
printf("Printing all the pages\n");
|
|
|
|
} else {
|
|
printf("Printing from page no. %d to %d\n", fromPageNum, toPageNum);
|
|
}
|
|
#endif
|
|
|
|
} else {
|
|
::SetFocus(aHWnd);
|
|
aPrintSettings->SetIsCancelled(true);
|
|
if (hGlobalDevMode) ::GlobalFree(hGlobalDevMode);
|
|
return NS_ERROR_ABORT;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
//------------------------------------------------------------------
|
|
static void
|
|
PrepareForPrintDialog(nsIWebBrowserPrint* aWebBrowserPrint, nsIPrintSettings* aPS)
|
|
{
|
|
NS_ASSERTION(aWebBrowserPrint, "Can't be null");
|
|
NS_ASSERTION(aPS, "Can't be null");
|
|
|
|
bool isFramesetDocument;
|
|
bool isFramesetFrameSelected;
|
|
bool isIFrameSelected;
|
|
bool isRangeSelection;
|
|
|
|
aWebBrowserPrint->GetIsFramesetDocument(&isFramesetDocument);
|
|
aWebBrowserPrint->GetIsFramesetFrameSelected(&isFramesetFrameSelected);
|
|
aWebBrowserPrint->GetIsIFrameSelected(&isIFrameSelected);
|
|
aWebBrowserPrint->GetIsRangeSelection(&isRangeSelection);
|
|
|
|
// Setup print options for UI
|
|
if (isFramesetDocument) {
|
|
if (isFramesetFrameSelected) {
|
|
aPS->SetHowToEnableFrameUI(nsIPrintSettings::kFrameEnableAll);
|
|
} else {
|
|
aPS->SetHowToEnableFrameUI(nsIPrintSettings::kFrameEnableAsIsAndEach);
|
|
}
|
|
} else {
|
|
aPS->SetHowToEnableFrameUI(nsIPrintSettings::kFrameEnableNone);
|
|
}
|
|
|
|
// Now determine how to set up the Frame print UI
|
|
aPS->SetPrintOptions(nsIPrintSettings::kEnableSelectionRB, isRangeSelection || isIFrameSelected);
|
|
|
|
}
|
|
|
|
//----------------------------------------------------------------------------------
|
|
//-- Show Print Dialog
|
|
//----------------------------------------------------------------------------------
|
|
nsresult NativeShowPrintDialog(HWND aHWnd,
|
|
nsIWebBrowserPrint* aWebBrowserPrint,
|
|
nsIPrintSettings* aPrintSettings)
|
|
{
|
|
PrepareForPrintDialog(aWebBrowserPrint, aPrintSettings);
|
|
|
|
nsresult rv = ShowNativePrintDialog(aHWnd, aPrintSettings);
|
|
if (aHWnd) {
|
|
::DestroyWindow(aHWnd);
|
|
}
|
|
|
|
return rv;
|
|
}
|
|
|