xref: /aoo4110/main/sc/source/ui/docshell/editable.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_sc.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #include "editable.hxx"
30*b1cdbd2cSJim Jagielski #include "document.hxx"
31*b1cdbd2cSJim Jagielski #include "viewfunc.hxx"
32*b1cdbd2cSJim Jagielski #include "globstr.hrc"
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski //------------------------------------------------------------------
35*b1cdbd2cSJim Jagielski 
ScEditableTester()36*b1cdbd2cSJim Jagielski ScEditableTester::ScEditableTester() :
37*b1cdbd2cSJim Jagielski 	bIsEditable( sal_True ),
38*b1cdbd2cSJim Jagielski 	bOnlyMatrix( sal_True )
39*b1cdbd2cSJim Jagielski {
40*b1cdbd2cSJim Jagielski }
41*b1cdbd2cSJim Jagielski 
ScEditableTester(ScDocument * pDoc,SCTAB nTab,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow)42*b1cdbd2cSJim Jagielski ScEditableTester::ScEditableTester( ScDocument* pDoc, SCTAB nTab,
43*b1cdbd2cSJim Jagielski 						SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow ) :
44*b1cdbd2cSJim Jagielski 	bIsEditable( sal_True ),
45*b1cdbd2cSJim Jagielski 	bOnlyMatrix( sal_True )
46*b1cdbd2cSJim Jagielski {
47*b1cdbd2cSJim Jagielski 	TestBlock( pDoc, nTab, nStartCol, nStartRow, nEndCol, nEndRow );
48*b1cdbd2cSJim Jagielski }
49*b1cdbd2cSJim Jagielski 
ScEditableTester(ScDocument * pDoc,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScMarkData & rMark)50*b1cdbd2cSJim Jagielski ScEditableTester::ScEditableTester( ScDocument* pDoc,
51*b1cdbd2cSJim Jagielski 						SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
52*b1cdbd2cSJim Jagielski 						const ScMarkData& rMark ) :
53*b1cdbd2cSJim Jagielski 	bIsEditable( sal_True ),
54*b1cdbd2cSJim Jagielski 	bOnlyMatrix( sal_True )
55*b1cdbd2cSJim Jagielski {
56*b1cdbd2cSJim Jagielski 	TestSelectedBlock( pDoc, nStartCol, nStartRow, nEndCol, nEndRow, rMark );
57*b1cdbd2cSJim Jagielski }
58*b1cdbd2cSJim Jagielski 
ScEditableTester(ScDocument * pDoc,const ScRange & rRange)59*b1cdbd2cSJim Jagielski ScEditableTester::ScEditableTester( ScDocument* pDoc, const ScRange& rRange ) :
60*b1cdbd2cSJim Jagielski 	bIsEditable( sal_True ),
61*b1cdbd2cSJim Jagielski 	bOnlyMatrix( sal_True )
62*b1cdbd2cSJim Jagielski {
63*b1cdbd2cSJim Jagielski 	TestRange( pDoc, rRange );
64*b1cdbd2cSJim Jagielski }
65*b1cdbd2cSJim Jagielski 
ScEditableTester(ScDocument * pDoc,const ScMarkData & rMark)66*b1cdbd2cSJim Jagielski ScEditableTester::ScEditableTester( ScDocument* pDoc, const ScMarkData& rMark ) :
67*b1cdbd2cSJim Jagielski 	bIsEditable( sal_True ),
68*b1cdbd2cSJim Jagielski 	bOnlyMatrix( sal_True )
69*b1cdbd2cSJim Jagielski {
70*b1cdbd2cSJim Jagielski 	TestSelection( pDoc, rMark );
71*b1cdbd2cSJim Jagielski }
72*b1cdbd2cSJim Jagielski 
ScEditableTester(ScViewFunc * pView)73*b1cdbd2cSJim Jagielski ScEditableTester::ScEditableTester( ScViewFunc* pView ) :
74*b1cdbd2cSJim Jagielski 	bIsEditable( sal_True ),
75*b1cdbd2cSJim Jagielski 	bOnlyMatrix( sal_True )
76*b1cdbd2cSJim Jagielski {
77*b1cdbd2cSJim Jagielski 	TestView( pView );
78*b1cdbd2cSJim Jagielski }
79*b1cdbd2cSJim Jagielski 
80*b1cdbd2cSJim Jagielski //------------------------------------------------------------------
81*b1cdbd2cSJim Jagielski 
TestBlock(ScDocument * pDoc,SCTAB nTab,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow)82*b1cdbd2cSJim Jagielski void ScEditableTester::TestBlock( ScDocument* pDoc, SCTAB nTab,
83*b1cdbd2cSJim Jagielski 						SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow )
84*b1cdbd2cSJim Jagielski {
85*b1cdbd2cSJim Jagielski 	if ( bIsEditable || bOnlyMatrix )
86*b1cdbd2cSJim Jagielski 	{
87*b1cdbd2cSJim Jagielski 		sal_Bool bThisMatrix;
88*b1cdbd2cSJim Jagielski 		if ( !pDoc->IsBlockEditable( nTab, nStartCol, nStartRow, nEndCol, nEndRow, &bThisMatrix ) )
89*b1cdbd2cSJim Jagielski 		{
90*b1cdbd2cSJim Jagielski 			bIsEditable = sal_False;
91*b1cdbd2cSJim Jagielski 			if ( !bThisMatrix )
92*b1cdbd2cSJim Jagielski 				bOnlyMatrix = sal_False;
93*b1cdbd2cSJim Jagielski 		}
94*b1cdbd2cSJim Jagielski 	}
95*b1cdbd2cSJim Jagielski }
96*b1cdbd2cSJim Jagielski 
TestSelectedBlock(ScDocument * pDoc,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScMarkData & rMark)97*b1cdbd2cSJim Jagielski void ScEditableTester::TestSelectedBlock( ScDocument* pDoc,
98*b1cdbd2cSJim Jagielski 						SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow,
99*b1cdbd2cSJim Jagielski 						const ScMarkData& rMark )
100*b1cdbd2cSJim Jagielski {
101*b1cdbd2cSJim Jagielski 	SCTAB nTabCount = pDoc->GetTableCount();
102*b1cdbd2cSJim Jagielski 	for (SCTAB nTab=0; nTab<nTabCount; nTab++)
103*b1cdbd2cSJim Jagielski 		if (rMark.GetTableSelect(nTab))
104*b1cdbd2cSJim Jagielski 			TestBlock( pDoc, nTab, nStartCol, nStartRow, nEndCol, nEndRow );
105*b1cdbd2cSJim Jagielski }
106*b1cdbd2cSJim Jagielski 
TestRange(ScDocument * pDoc,const ScRange & rRange)107*b1cdbd2cSJim Jagielski void ScEditableTester::TestRange( ScDocument* pDoc, const ScRange& rRange )
108*b1cdbd2cSJim Jagielski {
109*b1cdbd2cSJim Jagielski 	SCCOL nStartCol = rRange.aStart.Col();
110*b1cdbd2cSJim Jagielski 	SCROW nStartRow = rRange.aStart.Row();
111*b1cdbd2cSJim Jagielski 	SCTAB nStartTab = rRange.aStart.Tab();
112*b1cdbd2cSJim Jagielski 	SCCOL nEndCol = rRange.aEnd.Col();
113*b1cdbd2cSJim Jagielski 	SCROW nEndRow = rRange.aEnd.Row();
114*b1cdbd2cSJim Jagielski 	SCTAB nEndTab = rRange.aEnd.Tab();
115*b1cdbd2cSJim Jagielski 	for (SCTAB nTab=nStartTab; nTab<=nEndTab; nTab++)
116*b1cdbd2cSJim Jagielski 		TestBlock( pDoc, nTab, nStartCol, nStartRow, nEndCol, nEndRow );
117*b1cdbd2cSJim Jagielski }
118*b1cdbd2cSJim Jagielski 
TestSelection(ScDocument * pDoc,const ScMarkData & rMark)119*b1cdbd2cSJim Jagielski void ScEditableTester::TestSelection( ScDocument* pDoc, const ScMarkData& rMark )
120*b1cdbd2cSJim Jagielski {
121*b1cdbd2cSJim Jagielski 	if ( bIsEditable || bOnlyMatrix )
122*b1cdbd2cSJim Jagielski 	{
123*b1cdbd2cSJim Jagielski 		sal_Bool bThisMatrix;
124*b1cdbd2cSJim Jagielski 		if ( !pDoc->IsSelectionEditable( rMark, &bThisMatrix ) )
125*b1cdbd2cSJim Jagielski 		{
126*b1cdbd2cSJim Jagielski 			bIsEditable = sal_False;
127*b1cdbd2cSJim Jagielski 			if ( !bThisMatrix )
128*b1cdbd2cSJim Jagielski 				bOnlyMatrix = sal_False;
129*b1cdbd2cSJim Jagielski 		}
130*b1cdbd2cSJim Jagielski 	}
131*b1cdbd2cSJim Jagielski }
132*b1cdbd2cSJim Jagielski 
TestView(ScViewFunc * pView)133*b1cdbd2cSJim Jagielski void ScEditableTester::TestView( ScViewFunc* pView )
134*b1cdbd2cSJim Jagielski {
135*b1cdbd2cSJim Jagielski 	if ( bIsEditable || bOnlyMatrix )
136*b1cdbd2cSJim Jagielski 	{
137*b1cdbd2cSJim Jagielski 		sal_Bool bThisMatrix;
138*b1cdbd2cSJim Jagielski 		if ( !pView->SelectionEditable( &bThisMatrix ) )
139*b1cdbd2cSJim Jagielski 		{
140*b1cdbd2cSJim Jagielski 			bIsEditable = sal_False;
141*b1cdbd2cSJim Jagielski 			if ( !bThisMatrix )
142*b1cdbd2cSJim Jagielski 				bOnlyMatrix = sal_False;
143*b1cdbd2cSJim Jagielski 		}
144*b1cdbd2cSJim Jagielski 	}
145*b1cdbd2cSJim Jagielski }
146*b1cdbd2cSJim Jagielski 
147*b1cdbd2cSJim Jagielski //------------------------------------------------------------------
148*b1cdbd2cSJim Jagielski 
GetMessageId() const149*b1cdbd2cSJim Jagielski sal_uInt16 ScEditableTester::GetMessageId() const
150*b1cdbd2cSJim Jagielski {
151*b1cdbd2cSJim Jagielski 	if (bIsEditable)
152*b1cdbd2cSJim Jagielski 		return 0;
153*b1cdbd2cSJim Jagielski 	else if (bOnlyMatrix)
154*b1cdbd2cSJim Jagielski 		return STR_MATRIXFRAGMENTERR;
155*b1cdbd2cSJim Jagielski 	else
156*b1cdbd2cSJim Jagielski 		return STR_PROTECTIONERR;
157*b1cdbd2cSJim Jagielski }
158*b1cdbd2cSJim Jagielski 
159