1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_svx.hxx"
30 #include <svx/sdrmasterpagedescriptor.hxx>
31 #include <svx/sdr/contact/viewcontactofmasterpagedescriptor.hxx>
32 #include <svx/svdpage.hxx>
33 
34 // #i42075#
35 #include <svx/svdobj.hxx>
36 #include <svx/xfillit0.hxx>
37 #include <svl/itemset.hxx>
38 
39 //////////////////////////////////////////////////////////////////////////////
40 
41 namespace sdr
42 {
43 	// ViewContact part
44 	sdr::contact::ViewContact* MasterPageDescriptor::CreateObjectSpecificViewContact()
45 	{
46 		return new sdr::contact::ViewContactOfMasterPageDescriptor(*this);
47 	}
48 
49 	MasterPageDescriptor::MasterPageDescriptor(SdrPage& aOwnerPage, SdrPage& aUsedPage)
50 	:	maOwnerPage(aOwnerPage),
51 		maUsedPage(aUsedPage),
52 		mpViewContact(0L)
53 	{
54 		// all layers visible
55 		maVisibleLayers.SetAll();
56 
57 		// register at used page
58 		maUsedPage.AddPageUser(*this);
59 	}
60 
61 	MasterPageDescriptor::~MasterPageDescriptor()
62 	{
63 		// de-register at used page
64 		maUsedPage.RemovePageUser(*this);
65 
66 		if(mpViewContact)
67 		{
68 			delete mpViewContact;
69 			mpViewContact = 0L;
70 		}
71 	}
72 
73 	// ViewContact part
74 	sdr::contact::ViewContact& MasterPageDescriptor::GetViewContact() const
75 	{
76 		if(!mpViewContact)
77 		{
78 			const_cast< MasterPageDescriptor* >(this)->mpViewContact =
79                 const_cast< MasterPageDescriptor* >(this)->CreateObjectSpecificViewContact();
80 		}
81 
82 		return *mpViewContact;
83 	}
84 
85 	// this method is called form the destructor of the referenced page.
86 	// do all necessary action to forget the page. It is not necessary to call
87 	// RemovePageUser(), that is done form the destructor.
88 	void MasterPageDescriptor::PageInDestruction(const SdrPage& /*rPage*/)
89 	{
90 		maOwnerPage.TRG_ClearMasterPage();
91 	}
92 
93 	void MasterPageDescriptor::SetVisibleLayers(const SetOfByte& rNew)
94 	{
95 		if(rNew != maVisibleLayers)
96 		{
97 			maVisibleLayers = rNew;
98 			GetViewContact().ActionChanged();
99 		}
100 	}
101 
102 	// operators
103 	sal_Bool MasterPageDescriptor::operator==(const MasterPageDescriptor& rCandidate) const
104 	{
105 		return (&maOwnerPage == &rCandidate.maOwnerPage
106 			&& &maUsedPage == &rCandidate.maUsedPage
107 			&& maVisibleLayers == rCandidate.maVisibleLayers);
108 	}
109 
110 	sal_Bool MasterPageDescriptor::operator!=(const MasterPageDescriptor& rCandidate) const
111 	{
112 		return (&maOwnerPage != &rCandidate.maOwnerPage
113 			|| &maUsedPage != &rCandidate.maUsedPage
114 			|| maVisibleLayers != rCandidate.maVisibleLayers);
115 	}
116 
117     const SdrPageProperties* MasterPageDescriptor::getCorrectSdrPageProperties() const
118     {
119         const SdrPage* pCorrectPage = &GetOwnerPage();
120         const SdrPageProperties* pCorrectProperties = &pCorrectPage->getSdrPageProperties();
121 
122         if(XFILL_NONE == ((const XFillStyleItem&)pCorrectProperties->GetItemSet().Get(XATTR_FILLSTYLE)).GetValue())
123         {
124             pCorrectPage = &GetUsedPage();
125             pCorrectProperties = &pCorrectPage->getSdrPageProperties();
126         }
127 
128         if(pCorrectPage->IsMasterPage() && !pCorrectProperties->GetStyleSheet())
129         {
130             // #i110846# Suppress SdrPage FillStyle for MasterPages without StyleSheets,
131             // else the PoolDefault (XFILL_COLOR and Blue8) will be used. Normally, all
132             // MasterPages should have a StyleSheet excactly for this reason, but historically
133             // e.g. the Notes MasterPage has no StyleSheet set (and there maybe others).
134             pCorrectProperties = 0;
135         }
136 
137         return pCorrectProperties;
138     }
139 } // end of namespace sdr
140 
141 //////////////////////////////////////////////////////////////////////////////
142 // eof
143