bump product version to 4.1.6.2
[LibreOffice.git] / sc / source / ui / docshell / docsh4.cxx
blob5511b61cfdeefdfaf807b3f7a0af39c04392ddec
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <config_features.h>
22 #include <com/sun/star/embed/XEmbeddedObject.hpp>
23 #include <com/sun/star/frame/Desktop.hpp>
24 #include <com/sun/star/frame/XComponentLoader.hpp>
26 using namespace ::com::sun::star;
28 #include <math.h> // prevent conflict between exception and std::exception
30 #include "scitems.hxx"
31 #include <sfx2/fcontnr.hxx>
32 #include <sfx2/objface.hxx>
33 #include <sfx2/docfile.hxx>
34 #include <svtools/ehdl.hxx>
35 #include <basic/sbxcore.hxx>
36 #include <svtools/sfxecode.hxx>
37 #include <svx/ofaitem.hxx>
38 #include <svl/whiter.hxx>
39 #include <vcl/msgbox.hxx>
40 #include <vcl/waitobj.hxx>
41 #include <svx/dataaccessdescriptor.hxx>
42 #include <svx/drawitem.hxx>
43 #include <svx/fmshell.hxx>
44 #include <svtools/xwindowitem.hxx>
45 #include <sfx2/passwd.hxx>
46 #include <sfx2/filedlghelper.hxx>
47 #include <sfx2/dispatch.hxx>
48 #include <svl/PasswordHelper.hxx>
49 #include <svl/documentlockfile.hxx>
50 #include <svl/sharecontrolfile.hxx>
52 #include <comphelper/processfactory.hxx>
53 #include "docuno.hxx"
55 #include <com/sun/star/sdbc/XResultSet.hpp>
56 #include "docsh.hxx"
57 #include "docshimp.hxx"
58 #include "docfunc.hxx"
59 #include "sc.hrc"
60 #include "stlsheet.hxx"
61 #include "stlpool.hxx"
62 #include "appoptio.hxx"
63 #include "globstr.hrc"
64 #include "global.hxx"
65 #include "dbdocfun.hxx"
66 #include "printfun.hxx" // DrawToDev
67 #include "viewdata.hxx"
68 #include "tabvwsh.hxx"
69 #include "impex.hxx"
70 #include "attrib.hxx"
71 #include "undodat.hxx"
72 #include "autostyl.hxx"
73 #include "undocell.hxx"
74 #include "undotab.hxx"
75 #include "inputhdl.hxx"
76 #include "dbdata.hxx"
77 #include "servobj.hxx"
78 #include "rangenam.hxx"
79 #include "scmod.hxx"
80 #include "chgviset.hxx"
81 #include "reffact.hxx"
82 #include "chartlis.hxx"
83 #include "chartpos.hxx"
84 #include "waitoff.hxx"
85 #include "tablink.hxx" // ScDocumentLoader statics
86 #include "drwlayer.hxx"
87 #include "docoptio.hxx"
88 #include "undostyl.hxx"
89 #include "rangeseq.hxx"
90 #include "chgtrack.hxx"
91 #include "printopt.hxx"
92 #include <com/sun/star/document/UpdateDocMode.hpp>
93 #include "scresid.hxx"
94 #include "scabstdlg.hxx"
95 #include "externalrefmgr.hxx"
96 #include "sharedocdlg.hxx"
97 #include "conditio.hxx"
98 #include "sheetevents.hxx"
100 //------------------------------------------------------------------
102 #define IS_SHARE_HEADER(set) \
103 ((SfxBoolItem&) \
104 ((SvxSetItem&)(set).Get(ATTR_PAGE_HEADERSET)).GetItemSet(). \
105 Get(ATTR_PAGE_SHARED)).GetValue()
107 #define IS_SHARE_FOOTER(set) \
108 ((SfxBoolItem&) \
109 ((SvxSetItem&)(set).Get(ATTR_PAGE_FOOTERSET)).GetItemSet(). \
110 Get(ATTR_PAGE_SHARED)).GetValue()
112 #define SC_PREVIEW_SIZE_X 10000
113 #define SC_PREVIEW_SIZE_Y 12400
116 //------------------------------------------------------------------
118 void ScDocShell::Execute( SfxRequest& rReq )
120 // SID_SC_RANGE (Range),
121 // SID_SC_CELLTEXT (CellText),
122 // SID_SC_CELLS (Cells) - removed (old Basic)
124 const SfxItemSet* pReqArgs = rReq.GetArgs();
125 SfxBindings* pBindings = GetViewBindings();
126 sal_Bool bUndo (aDocument.IsUndoEnabled());
128 sal_uInt16 nSlot = rReq.GetSlot();
129 switch ( nSlot )
131 case SID_SC_SETTEXT:
133 const SfxPoolItem* pColItem;
134 const SfxPoolItem* pRowItem;
135 const SfxPoolItem* pTabItem;
136 const SfxPoolItem* pTextItem;
137 if( pReqArgs && pReqArgs->HasItem( FN_PARAM_1, &pColItem ) &&
138 pReqArgs->HasItem( FN_PARAM_2, &pRowItem ) &&
139 pReqArgs->HasItem( FN_PARAM_3, &pTabItem ) &&
140 pReqArgs->HasItem( SID_SC_SETTEXT, &pTextItem ) )
142 // Parameter sind 1-based !!!
143 SCCOL nCol = ((SfxInt16Item*)pColItem)->GetValue() - 1;
144 SCROW nRow = ((SfxInt32Item*)pRowItem)->GetValue() - 1;
145 SCTAB nTab = ((SfxInt16Item*)pTabItem)->GetValue() - 1;
147 SCTAB nTabCount = aDocument.GetTableCount();
148 if ( ValidCol(nCol) && ValidRow(nRow) && ValidTab(nTab,nTabCount) )
150 if ( aDocument.IsBlockEditable( nTab, nCol,nRow, nCol, nRow ) )
152 String aVal = ((const SfxStringItem*)pTextItem)->GetValue();
153 aDocument.SetString( nCol, nRow, nTab, aVal );
155 PostPaintCell( nCol, nRow, nTab );
156 SetDocumentModified();
158 rReq.Done();
159 break;
161 else // geschuetzte Zelle
163 #ifndef DISABLE_SCRIPTING
164 SbxBase::SetError( SbxERR_BAD_PARAMETER ); //! welchen Fehler ?
165 #endif
166 break;
170 #ifndef DISABLE_SCRIPTING
171 SbxBase::SetError( SbxERR_NO_OBJECT );
172 #endif
174 break;
176 case SID_SBA_IMPORT:
178 if (pReqArgs)
180 const SfxPoolItem* pItem;
181 svx::ODataAccessDescriptor aDesc;
182 if ( pReqArgs->GetItemState( nSlot, true, &pItem ) == SFX_ITEM_SET )
184 uno::Any aAny = static_cast<const SfxUsrAnyItem*>(pItem)->GetValue();
185 uno::Sequence<beans::PropertyValue> aProperties;
186 if ( aAny >>= aProperties )
187 aDesc.initializeFrom( aProperties );
190 String sTarget;
191 if ( pReqArgs->GetItemState( FN_PARAM_1, sal_True, &pItem ) == SFX_ITEM_SET )
192 sTarget = ((const SfxStringItem*)pItem)->GetValue();
194 sal_Bool bIsNewArea = sal_True; // Default sal_True (keine Nachfrage)
195 if ( pReqArgs->GetItemState( FN_PARAM_2, sal_True, &pItem ) == SFX_ITEM_SET )
196 bIsNewArea = ((const SfxBoolItem*)pItem)->GetValue();
198 // bei Bedarf neuen Datenbankbereich anlegen
199 bool bMakeArea = false;
200 if (bIsNewArea)
202 ScDBCollection* pDBColl = aDocument.GetDBCollection();
203 if ( !pDBColl || !pDBColl->getNamedDBs().findByUpperName(ScGlobal::pCharClass->uppercase(sTarget)) )
205 ScAddress aPos;
206 if ( aPos.Parse( sTarget, &aDocument, aDocument.GetAddressConvention() ) & SCA_VALID )
208 bMakeArea = true;
209 if (bUndo)
211 String aStrImport = ScGlobal::GetRscString( STR_UNDO_IMPORTDATA );
212 GetUndoManager()->EnterListAction( aStrImport, aStrImport );
215 ScDBData* pDBData = GetDBData( ScRange(aPos), SC_DB_IMPORT, SC_DBSEL_KEEP );
216 OSL_ENSURE(pDBData, "kann DB-Daten nicht anlegen");
217 sTarget = pDBData->GetName();
222 // nachfragen, bevor alter DB-Bereich ueberschrieben wird
223 bool bDo = true;
224 if (!bIsNewArea)
226 String aTemplate = ScGlobal::GetRscString( STR_IMPORT_REPLACE );
227 String aMessage = aTemplate.GetToken( 0, '#' );
228 aMessage += sTarget;
229 aMessage += aTemplate.GetToken( 1, '#' );
231 QueryBox aBox( 0, WinBits(WB_YES_NO | WB_DEF_YES), aMessage );
232 bDo = ( aBox.Execute() == RET_YES );
235 if (bDo)
237 ScDBDocFunc(*this).UpdateImport( sTarget, aDesc );
238 rReq.Done();
240 // UpdateImport aktualisiert auch die internen Operationen
242 else
243 rReq.Ignore();
245 if ( bMakeArea && bUndo)
246 GetUndoManager()->LeaveListAction();
248 else
250 OSL_FAIL( "arguments expected" );
253 break;
255 case SID_CHART_SOURCE:
256 case SID_CHART_ADDSOURCE:
257 if (pReqArgs)
259 ScDocument* pDoc = GetDocument();
260 const SfxPoolItem* pItem;
261 String aChartName, aRangeName;
263 ScRange aSingleRange;
264 ScRangeListRef aRangeListRef;
265 sal_Bool bMultiRange = false;
267 sal_Bool bColHeaders = sal_True;
268 sal_Bool bRowHeaders = sal_True;
269 sal_Bool bColInit = false;
270 sal_Bool bRowInit = false;
271 sal_Bool bAddRange = (nSlot == SID_CHART_ADDSOURCE);
273 if( pReqArgs->HasItem( SID_CHART_NAME, &pItem ) )
274 aChartName = ((const SfxStringItem*)pItem)->GetValue();
276 if( pReqArgs->HasItem( SID_CHART_SOURCE, &pItem ) )
277 aRangeName = ((const SfxStringItem*)pItem)->GetValue();
279 if( pReqArgs->HasItem( FN_PARAM_1, &pItem ) )
281 bColHeaders = ((const SfxBoolItem*)pItem)->GetValue();
282 bColInit = sal_True;
284 if( pReqArgs->HasItem( FN_PARAM_2, &pItem ) )
286 bRowHeaders = ((const SfxBoolItem*)pItem)->GetValue();
287 bRowInit = sal_True;
290 ScAddress::Details aDetails(pDoc->GetAddressConvention(), 0, 0);
291 sal_Bool bValid = ( aSingleRange.ParseAny( aRangeName, pDoc, aDetails ) & SCA_VALID ) != 0;
292 if (!bValid)
294 aRangeListRef = new ScRangeList;
295 aRangeListRef->Parse( aRangeName, pDoc );
296 if ( !aRangeListRef->empty() )
298 bMultiRange = true;
299 aSingleRange = *aRangeListRef->front(); // fuer Header
300 bValid = true;
302 else
303 aRangeListRef.Clear();
306 ScTabViewShell* pViewSh = ScTabViewShell::GetActiveViewShell();
307 if (pViewSh && bValid && aChartName.Len() != 0 )
309 Window* pParent = pViewSh->GetDialogParent();
311 SCCOL nCol1 = aSingleRange.aStart.Col();
312 SCROW nRow1 = aSingleRange.aStart.Row();
313 SCCOL nCol2 = aSingleRange.aEnd.Col();
314 SCROW nRow2 = aSingleRange.aEnd.Row();
315 SCTAB nTab = aSingleRange.aStart.Tab();
317 //! immer oder gar nicht begrenzen ???
318 if (!bMultiRange)
319 aDocument.LimitChartArea( nTab, nCol1,nRow1, nCol2,nRow2 );
321 // Dialog fuer Spalten/Zeilenkoepfe
322 sal_Bool bOk = sal_True;
323 if ( !bAddRange && ( !bColInit || !bRowInit ) )
325 ScChartPositioner aChartPositioner( &aDocument, nTab, nCol1,nRow1, nCol2,nRow2 );
326 if (!bColInit)
327 bColHeaders = aChartPositioner.HasColHeaders();
328 if (!bRowInit)
329 bRowHeaders = aChartPositioner.HasRowHeaders();
331 ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
332 OSL_ENSURE(pFact, "ScAbstractFactory create fail!");
334 AbstractScColRowLabelDlg* pDlg = pFact->CreateScColRowLabelDlg( pParent, RID_SCDLG_CHARTCOLROW, bRowHeaders, bColHeaders);
335 OSL_ENSURE(pDlg, "Dialog create fail!");
336 if ( pDlg->Execute() == RET_OK )
338 bColHeaders = pDlg->IsRow();
339 bRowHeaders = pDlg->IsCol();
341 rReq.AppendItem(SfxBoolItem(FN_PARAM_1, bColHeaders));
342 rReq.AppendItem(SfxBoolItem(FN_PARAM_2, bRowHeaders));
344 else
345 bOk = false;
346 delete pDlg;
349 if (bOk) // ausfuehren
351 if (bMultiRange)
353 if (bUndo)
355 GetUndoManager()->AddUndoAction(
356 new ScUndoChartData( this, aChartName, aRangeListRef,
357 bColHeaders, bRowHeaders, bAddRange ) );
359 aDocument.UpdateChartArea( aChartName, aRangeListRef,
360 bColHeaders, bRowHeaders, bAddRange );
362 else
364 ScRange aNewRange( nCol1,nRow1,nTab, nCol2,nRow2,nTab );
365 if (bUndo)
367 GetUndoManager()->AddUndoAction(
368 new ScUndoChartData( this, aChartName, aNewRange,
369 bColHeaders, bRowHeaders, bAddRange ) );
371 aDocument.UpdateChartArea( aChartName, aNewRange,
372 bColHeaders, bRowHeaders, bAddRange );
376 else
378 OSL_FAIL("UpdateChartArea: keine ViewShell oder falsche Daten");
380 rReq.Done();
382 else
384 OSL_FAIL("SID_CHART_SOURCE ohne Argumente");
386 break;
388 case FID_AUTO_CALC:
390 sal_Bool bNewVal;
391 const SfxPoolItem* pItem;
392 if ( pReqArgs && SFX_ITEM_SET == pReqArgs->GetItemState( nSlot, sal_True, &pItem ) )
393 bNewVal = ((const SfxBoolItem*)pItem)->GetValue();
394 else
395 bNewVal = !aDocument.GetAutoCalc(); // Toggle fuer Menue
396 aDocument.SetAutoCalc( bNewVal );
397 SetDocumentModified();
398 if (pBindings)
400 pBindings->Invalidate( FID_AUTO_CALC );
402 rReq.AppendItem( SfxBoolItem( FID_AUTO_CALC, bNewVal ) );
403 rReq.Done();
405 break;
406 case FID_RECALC:
407 DoRecalc( rReq.IsAPI() );
408 rReq.Done();
409 break;
410 case FID_HARD_RECALC:
411 DoHardRecalc( rReq.IsAPI() );
412 rReq.Done();
413 break;
414 case SID_UPDATETABLINKS:
416 ScDocument* pDoc = GetDocument();
418 ScLkUpdMode nSet=pDoc->GetLinkMode();
420 sal_uInt16 nDlgRet=RET_NO;
421 if(nSet==LM_UNKNOWN)
423 ScAppOptions aAppOptions=SC_MOD()->GetAppOptions();
424 nSet=aAppOptions.GetLinkMode();
427 if (nCanUpdate == com::sun::star::document::UpdateDocMode::NO_UPDATE)
428 nSet = LM_NEVER;
429 else if (nCanUpdate == com::sun::star::document::UpdateDocMode::QUIET_UPDATE &&
430 nSet == LM_ON_DEMAND)
431 nSet = LM_NEVER;
432 else if (nCanUpdate == com::sun::star::document::UpdateDocMode::FULL_UPDATE)
433 nSet = LM_ALWAYS;
435 if(nSet==LM_ON_DEMAND)
437 QueryBox aBox( GetActiveDialogParent(), WinBits(WB_YES_NO | WB_DEF_YES),
438 ScGlobal::GetRscString(STR_RELOAD_TABLES) );
440 nDlgRet=aBox.Execute();
443 if (nDlgRet == RET_YES || nSet==LM_ALWAYS)
445 ReloadTabLinks();
446 aDocument.UpdateExternalRefLinks(GetActiveDialogParent());
447 aDocument.UpdateDdeLinks(GetActiveDialogParent());
448 aDocument.UpdateAreaLinks();
450 //! Test, ob Fehler
451 rReq.Done();
453 else
454 rReq.Ignore();
456 break;
458 case SID_REIMPORT_AFTER_LOAD:
460 // wird nach dem Laden aufgerufen, wenn DB-Bereiche mit
461 // weggelassenen Daten enthalten sind
463 sal_Bool bDone = false;
464 ScDBCollection* pDBColl = aDocument.GetDBCollection();
466 if ((nCanUpdate != com::sun::star::document::UpdateDocMode::NO_UPDATE) &&
467 (nCanUpdate != com::sun::star::document::UpdateDocMode::QUIET_UPDATE))
469 ScRange aRange;
470 ScTabViewShell* pViewSh = GetBestViewShell();
471 OSL_ENSURE(pViewSh,"SID_REIMPORT_AFTER_LOAD: keine View");
472 if (pViewSh && pDBColl)
474 QueryBox aBox( GetActiveDialogParent(), WinBits(WB_YES_NO | WB_DEF_YES),
475 ScGlobal::GetRscString(STR_REIMPORT_AFTER_LOAD) );
476 if (aBox.Execute() == RET_YES)
478 ScDBCollection::NamedDBs& rDBs = pDBColl->getNamedDBs();
479 ScDBCollection::NamedDBs::iterator itr = rDBs.begin(), itrEnd = rDBs.end();
480 for (; itr != itrEnd; ++itr)
482 ScDBData& rDBData = *itr;
483 if ( rDBData.IsStripData() &&
484 rDBData.HasImportParam() && !rDBData.HasImportSelection() )
486 rDBData.GetArea(aRange);
487 pViewSh->MarkRange(aRange);
489 // Import und interne Operationen wie SID_REFRESH_DBAREA
490 // (Abfrage auf Import hier nicht noetig)
492 ScImportParam aImportParam;
493 rDBData.GetImportParam( aImportParam );
494 bool bContinue = pViewSh->ImportData( aImportParam );
495 rDBData.SetImportParam( aImportParam );
497 // markieren (Groesse kann sich geaendert haben)
498 rDBData.GetArea(aRange);
499 pViewSh->MarkRange(aRange);
501 if ( bContinue ) // Fehler beim Import -> Abbruch
503 // interne Operationen, wenn welche gespeichert
505 if ( rDBData.HasQueryParam() || rDBData.HasSortParam() ||
506 rDBData.HasSubTotalParam() )
507 pViewSh->RepeatDB();
509 // Pivottabellen die den Bereich als Quelldaten haben
511 RefreshPivotTables(aRange);
515 bDone = true;
520 if ( !bDone && pDBColl )
522 // wenn nicht, dann aber die abhaengigen Formeln updaten
523 //! auch fuer einzelne Bereiche, die nicht aktualisiert werden koennen
525 aDocument.CalcAll(); //! nur die abhaengigen
526 PostDataChanged();
529 if (bDone)
530 rReq.Done();
531 else
532 rReq.Ignore();
534 break;
537 case SID_AUTO_STYLE:
538 OSL_FAIL("use ScAutoStyleHint instead of SID_AUTO_STYLE");
539 break;
541 case SID_GET_COLORLIST:
543 SvxColorListItem* pColItem = (SvxColorListItem*)GetItem(SID_COLOR_TABLE);
544 XColorListRef pList = pColItem->GetColorList();
545 rReq.SetReturnValue(OfaRefItem<XColorList>(SID_GET_COLORLIST, pList));
547 break;
549 case FID_CHG_RECORD:
551 ScDocument* pDoc = GetDocument();
552 if(pDoc!=NULL)
554 // get argument (recorded macro)
555 SFX_REQUEST_ARG( rReq, pItem, SfxBoolItem, FID_CHG_RECORD, false );
556 sal_Bool bDo = sal_True;
558 // xmlsec05/06:
559 // getting real parent window when called from Security-Options TP
560 Window* pParent = NULL;
561 const SfxPoolItem* pParentItem;
562 if( pReqArgs && SFX_ITEM_SET == pReqArgs->GetItemState( SID_ATTR_XWINDOW, false, &pParentItem ) )
563 pParent = ( ( const XWindowItem* ) pParentItem )->GetWindowPtr();
565 // desired state
566 ScChangeTrack* pChangeTrack = pDoc->GetChangeTrack();
567 sal_Bool bActivateTracking = (pChangeTrack == 0); // toggle
568 if ( pItem )
569 bActivateTracking = pItem->GetValue(); // from argument
571 if ( !bActivateTracking )
573 if ( !pItem )
575 // no dialog on playing the macro
576 WarningBox aBox( pParent ? pParent : GetActiveDialogParent(),
577 WinBits(WB_YES_NO | WB_DEF_NO),
578 ScGlobal::GetRscString( STR_END_REDLINING ) );
579 bDo = ( aBox.Execute() == RET_YES );
582 if ( bDo )
584 if ( pChangeTrack->IsProtected() )
585 bDo = ExecuteChangeProtectionDialog( NULL );
586 if ( bDo )
588 pDoc->EndChangeTracking();
589 PostPaintGridAll();
593 else
595 pDoc->StartChangeTracking();
596 ScChangeViewSettings aChangeViewSet;
597 aChangeViewSet.SetShowChanges(sal_True);
598 pDoc->SetChangeViewSettings(aChangeViewSet);
601 if ( bDo )
603 UpdateAcceptChangesDialog();
605 // Slots invalidieren
606 if (pBindings)
607 pBindings->InvalidateAll(false);
608 if ( !pItem )
609 rReq.AppendItem( SfxBoolItem( FID_CHG_RECORD, bActivateTracking ) );
610 rReq.Done();
612 else
613 rReq.Ignore();
616 break;
618 case SID_CHG_PROTECT :
620 Window* pParent = NULL;
621 const SfxPoolItem* pParentItem;
622 if( pReqArgs && SFX_ITEM_SET == pReqArgs->GetItemState( SID_ATTR_XWINDOW, false, &pParentItem ) )
623 pParent = ( ( const XWindowItem* ) pParentItem )->GetWindowPtr();
624 if ( ExecuteChangeProtectionDialog( pParent ) )
626 rReq.Done();
627 SetDocumentModified();
629 else
630 rReq.Ignore();
632 break;
634 case SID_DOCUMENT_MERGE:
635 case SID_DOCUMENT_COMPARE:
637 sal_Bool bDo = sal_True;
638 ScChangeTrack* pChangeTrack = aDocument.GetChangeTrack();
639 if ( pChangeTrack && !pImpl->bIgnoreLostRedliningWarning )
641 if ( nSlot == SID_DOCUMENT_COMPARE )
642 { //! old changes trace will be lost
643 WarningBox aBox( GetActiveDialogParent(),
644 WinBits(WB_YES_NO | WB_DEF_NO),
645 ScGlobal::GetRscString( STR_END_REDLINING ) );
646 if( aBox.Execute() == RET_YES )
647 bDo = ExecuteChangeProtectionDialog( NULL, sal_True );
648 else
649 bDo = false;
651 else // merge might reject some actions
652 bDo = ExecuteChangeProtectionDialog( NULL, sal_True );
654 if ( !bDo )
656 rReq.Ignore();
657 break;
659 SfxApplication* pApp = SFX_APP();
660 const SfxPoolItem* pItem;
661 SfxMedium* pMed = NULL;
662 if ( pReqArgs &&
663 pReqArgs->GetItemState( SID_FILE_NAME, sal_True, &pItem ) == SFX_ITEM_SET &&
664 pItem->ISA(SfxStringItem) )
666 OUString aFileName =
667 static_cast<const SfxStringItem*>(pItem)->GetValue();
669 OUString aFilterName;
670 if ( pReqArgs->GetItemState( SID_FILTER_NAME, sal_True, &pItem ) == SFX_ITEM_SET &&
671 pItem->ISA(SfxStringItem) )
673 aFilterName = static_cast<const SfxStringItem*>(pItem)->GetValue();
675 OUString aOptions;
676 if ( pReqArgs->GetItemState( SID_FILE_FILTEROPTIONS, sal_True, &pItem ) == SFX_ITEM_SET &&
677 pItem->ISA(SfxStringItem) )
679 aOptions = static_cast<const SfxStringItem*>(pItem)->GetValue();
681 short nVersion = 0;
682 if ( pReqArgs->GetItemState( SID_VERSION, sal_True, &pItem ) == SFX_ITEM_SET &&
683 pItem->ISA(SfxInt16Item) )
685 nVersion = static_cast<const SfxInt16Item*>(pItem)->GetValue();
688 // kein Filter angegeben -> Detection
689 if (aFilterName.isEmpty())
690 ScDocumentLoader::GetFilterName( aFileName, aFilterName, aOptions, true, false );
692 // filter name from dialog contains application prefix,
693 // GetFilter needs name without the prefix.
694 ScDocumentLoader::RemoveAppPrefix( aFilterName );
696 const SfxFilter* pFilter = ScDocShell::Factory().GetFilterContainer()->GetFilter4FilterName( aFilterName );
697 SfxItemSet* pSet = new SfxAllItemSet( pApp->GetPool() );
698 if (!aOptions.isEmpty())
699 pSet->Put( SfxStringItem( SID_FILE_FILTEROPTIONS, aOptions ) );
700 if ( nVersion != 0 )
701 pSet->Put( SfxInt16Item( SID_VERSION, nVersion ) );
702 pMed = new SfxMedium( aFileName, STREAM_STD_READ, pFilter, pSet );
704 else
706 // start file dialog asynchronous
707 pImpl->bIgnoreLostRedliningWarning = true;
708 delete pImpl->pRequest;
709 pImpl->pRequest = new SfxRequest( rReq );
710 delete pImpl->pDocInserter;
711 pImpl->pDocInserter = new ::sfx2::DocumentInserter(
712 OUString::createFromAscii( ScDocShell::Factory().GetShortName() ), 0 );
713 pImpl->pDocInserter->StartExecuteModal( LINK( this, ScDocShell, DialogClosedHdl ) );
714 return ;
717 if ( pMed ) // nun wirklich ausfuehren...
719 SfxErrorContext aEc( ERRCTX_SFX_OPENDOC, pMed->GetName() );
721 // pOtherDocSh->DoClose() will be called explicitly later, but it is still more safe to use SfxObjectShellLock here
722 ScDocShell* pOtherDocSh = new ScDocShell;
723 SfxObjectShellLock aDocShTablesRef = pOtherDocSh;
724 pOtherDocSh->DoLoad( pMed );
725 sal_uLong nErr = pOtherDocSh->GetErrorCode();
726 if (nErr)
727 ErrorHandler::HandleError( nErr ); // auch Warnings
729 if ( !pOtherDocSh->GetError() ) // nur Errors
731 sal_Bool bHadTrack = ( aDocument.GetChangeTrack() != NULL );
732 #if HAVE_FEATURE_MULTIUSER_ENVIRONMENT
733 sal_uLong nStart = 0;
734 if ( nSlot == SID_DOCUMENT_MERGE && pChangeTrack )
736 nStart = pChangeTrack->GetActionMax() + 1;
738 #endif
739 if ( nSlot == SID_DOCUMENT_COMPARE )
740 CompareDocument( *pOtherDocSh->GetDocument() );
741 else
742 MergeDocument( *pOtherDocSh->GetDocument() );
744 // show "accept changes" dialog
745 //! get view for this document!
746 if ( !IsDocShared() )
748 SfxViewFrame* pViewFrm = SfxViewFrame::Current();
749 if ( pViewFrm )
751 pViewFrm->ShowChildWindow( ScAcceptChgDlgWrapper::GetChildWindowId(), sal_True ); //@51669
753 if ( pBindings )
755 pBindings->Invalidate( FID_CHG_ACCEPT );
759 rReq.SetReturnValue( SfxInt32Item( nSlot, 0 ) ); //! ???????
760 rReq.Done();
762 if (!bHadTrack) // neu eingeschaltet -> auch anzeigen
764 ScChangeViewSettings* pOldSet = aDocument.GetChangeViewSettings();
765 if ( !pOldSet || !pOldSet->ShowChanges() )
767 ScChangeViewSettings aChangeViewSet;
768 aChangeViewSet.SetShowChanges(sal_True);
769 aDocument.SetChangeViewSettings(aChangeViewSet);
772 #if HAVE_FEATURE_MULTIUSER_ENVIRONMENT
773 else if ( nSlot == SID_DOCUMENT_MERGE && IsDocShared() && pChangeTrack )
775 sal_uLong nEnd = pChangeTrack->GetActionMax();
776 if ( nEnd >= nStart )
778 // only show changes from merged document
779 ScChangeViewSettings aChangeViewSet;
780 aChangeViewSet.SetShowChanges( sal_True );
781 aChangeViewSet.SetShowAccepted( sal_True );
782 aChangeViewSet.SetHasActionRange( true );
783 aChangeViewSet.SetTheActionRange( nStart, nEnd );
784 aDocument.SetChangeViewSettings( aChangeViewSet );
786 // update view
787 PostPaintExtras();
788 PostPaintGridAll();
791 #endif
793 pOtherDocSh->DoClose(); // delete passiert mit der Ref
796 break;
798 case SID_DELETE_SCENARIO:
799 if (pReqArgs)
801 const SfxPoolItem* pItem;
802 if ( pReqArgs->GetItemState( nSlot, sal_True, &pItem ) == SFX_ITEM_SET )
804 if ( pItem->ISA(SfxStringItem) )
806 String aName = ((const SfxStringItem*)pItem)->GetValue();
807 SCTAB nTab;
808 if (aDocument.GetTable( aName, nTab ))
810 // DeleteTable von viewfunc nach docfunc verschieben!
812 ScTabViewShell* pSh = GetBestViewShell();
813 if ( pSh )
815 //! SetTabNo in DeleteTable weglassen?
816 SCTAB nDispTab = pSh->GetViewData()->GetTabNo();
817 pSh->DeleteTable( nTab );
818 pSh->SetTabNo(nDispTab);
819 rReq.Done();
825 break;
827 case SID_EDIT_SCENARIO:
829 const SfxPoolItem* pItem;
830 if ( pReqArgs->GetItemState( nSlot, sal_True, &pItem ) == SFX_ITEM_SET )
832 if ( pItem->ISA(SfxStringItem) )
834 OUString aName = ((const SfxStringItem*)pItem)->GetValue();
835 SCTAB nTab;
836 if (aDocument.GetTable( aName, nTab ))
838 if (aDocument.IsScenario(nTab))
840 OUString aComment;
841 Color aColor;
842 sal_uInt16 nFlags;
843 aDocument.GetScenarioData( nTab, aComment, aColor, nFlags );
845 // Determine if the Sheet that the Scenario was created on
846 // is protected. But first we need to find that Sheet.
847 // Rewind back to the actual sheet.
848 SCTAB nActualTab = nTab;
851 nActualTab--;
853 while(aDocument.IsScenario(nActualTab));
854 sal_Bool bSheetProtected = aDocument.IsTabProtected(nActualTab);
856 ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
857 OSL_ENSURE(pFact, "ScAbstractFactory create fail!");
859 AbstractScNewScenarioDlg* pNewDlg = pFact->CreateScNewScenarioDlg( GetActiveDialogParent(), aName, RID_SCDLG_NEWSCENARIO, true,bSheetProtected);
860 OSL_ENSURE(pNewDlg, "Dialog create fail!");
861 pNewDlg->SetScenarioData( aName, aComment, aColor, nFlags );
862 if ( pNewDlg->Execute() == RET_OK )
864 pNewDlg->GetScenarioData( aName, aComment, aColor, nFlags );
865 ModifyScenario( nTab, aName, aComment, aColor, nFlags );
866 rReq.Done();
868 delete pNewDlg;
874 break;
876 case SID_ATTR_YEAR2000 :
878 const SfxPoolItem* pItem;
879 if ( pReqArgs->GetItemState( nSlot, sal_True, &pItem ) == SFX_ITEM_SET )
881 if ( pItem->ISA(SfxUInt16Item) )
883 sal_uInt16 nY2k = ((SfxUInt16Item*)pItem)->GetValue();
884 // immer an den DocOptions setzen, damit das auch fuer SO50
885 // gespeichert wird (und alle Abfragen bisher auch darauf laufen).
886 // SetDocOptions propagiert das an den NumberFormatter
887 ScDocOptions aDocOpt( aDocument.GetDocOptions() );
888 aDocOpt.SetYear2000( nY2k );
889 aDocument.SetDocOptions( aDocOpt );
890 // die FormShell soll es mitbekommen
891 ScTabViewShell* pSh = GetBestViewShell();
892 if ( pSh )
894 FmFormShell* pFSh = pSh->GetFormShell();
895 if ( pFSh )
896 pFSh->SetY2KState( nY2k );
901 break;
903 #if HAVE_FEATURE_MULTIUSER_ENVIRONMENT
904 case SID_SHARE_DOC:
906 ScViewData* pViewData = GetViewData();
907 if ( !pViewData )
909 rReq.Ignore();
910 break;
913 ScShareDocumentDlg aDlg( GetActiveDialogParent(), pViewData );
914 if ( aDlg.Execute() == RET_OK )
916 bool bSetShared = aDlg.IsShareDocumentChecked();
917 if ( bSetShared != static_cast< bool >( IsDocShared() ) )
919 if ( bSetShared )
921 bool bContinue = true;
922 if ( HasName() )
924 QueryBox aBox( GetActiveDialogParent(), WinBits( WB_YES_NO | WB_DEF_YES ),
925 ScGlobal::GetRscString( STR_DOC_WILLBESAVED ) );
926 if ( aBox.Execute() == RET_NO )
928 bContinue = false;
931 if ( bContinue )
933 EnableSharedSettings( true );
935 SC_MOD()->SetInSharedDocSaving( true );
936 if ( !SwitchToShared( sal_True, sal_True ) )
938 // TODO/LATER: what should be done in case the switch has failed?
939 // for example in case the user has cancelled the saveAs operation
942 SC_MOD()->SetInSharedDocSaving( false );
944 InvalidateName();
945 GetUndoManager()->Clear();
947 ScTabView* pTabView = dynamic_cast< ScTabView* >( pViewData->GetView() );
948 if ( pTabView )
950 pTabView->UpdateLayerLocks();
954 else
956 uno::Reference< frame::XModel > xModel;
959 // load shared file
960 xModel.set( LoadSharedDocument(), uno::UNO_QUERY_THROW );
961 uno::Reference< util::XCloseable > xCloseable( xModel, uno::UNO_QUERY_THROW );
963 // check if shared flag is set in shared file
964 bool bShared = false;
965 ScModelObj* pDocObj = ScModelObj::getImplementation( xModel );
966 if ( pDocObj )
968 ScDocShell* pDocShell = dynamic_cast< ScDocShell* >( pDocObj->GetEmbeddedObject() );
969 if ( pDocShell )
971 bShared = pDocShell->HasSharedXMLFlagSet();
975 // #i87870# check if shared status was disabled and enabled again
976 bool bOwnEntry = false;
979 ::svt::ShareControlFile aControlFile( GetSharedFileURL() );
980 bOwnEntry = aControlFile.HasOwnEntry();
982 catch ( uno::Exception& )
986 if ( bShared && bOwnEntry )
988 uno::Reference< frame::XStorable > xStorable( xModel, uno::UNO_QUERY_THROW );
989 if ( xStorable->isReadonly() )
991 xCloseable->close( sal_True );
993 String aUserName( ScGlobal::GetRscString( STR_UNKNOWN_USER ) );
996 ::svt::DocumentLockFile aLockFile( GetSharedFileURL() );
997 uno::Sequence< OUString > aData = aLockFile.GetLockData();
998 if ( aData.getLength() > LOCKFILE_SYSUSERNAME_ID )
1000 if ( !aData[LOCKFILE_OOOUSERNAME_ID].isEmpty() )
1002 aUserName = aData[LOCKFILE_OOOUSERNAME_ID];
1004 else if ( !aData[LOCKFILE_SYSUSERNAME_ID].isEmpty() )
1006 aUserName = aData[LOCKFILE_SYSUSERNAME_ID];
1010 catch ( uno::Exception& )
1013 String aMessage( ScGlobal::GetRscString( STR_FILE_LOCKED_TRY_LATER ) );
1014 aMessage.SearchAndReplaceAscii( "%1", aUserName );
1016 WarningBox aBox( GetActiveDialogParent(), WinBits( WB_OK ), aMessage );
1017 aBox.Execute();
1019 else
1021 WarningBox aBox( GetActiveDialogParent(), WinBits( WB_YES_NO | WB_DEF_YES ),
1022 ScGlobal::GetRscString( STR_DOC_DISABLESHARED ) );
1023 if ( aBox.Execute() == RET_YES )
1025 xCloseable->close( sal_True );
1027 if ( !SwitchToShared( false, sal_True ) )
1029 // TODO/LATER: what should be done in case the switch has failed?
1030 // for example in case the user has cancelled the saveAs operation
1033 EnableSharedSettings( false );
1035 if ( pBindings )
1037 pBindings->ExecuteSynchron( SID_SAVEDOC );
1040 ScTabView* pTabView = dynamic_cast< ScTabView* >( pViewData->GetView() );
1041 if ( pTabView )
1043 pTabView->UpdateLayerLocks();
1046 else
1048 xCloseable->close( sal_True );
1052 else
1054 xCloseable->close( sal_True );
1055 WarningBox aBox( GetActiveDialogParent(), WinBits( WB_OK ),
1056 ScGlobal::GetRscString( STR_DOC_NOLONGERSHARED ) );
1057 aBox.Execute();
1060 catch ( uno::Exception& )
1062 OSL_FAIL( "SID_SHARE_DOC: caught exception\n" );
1063 SC_MOD()->SetInSharedDocSaving( false );
1067 uno::Reference< util::XCloseable > xClose( xModel, uno::UNO_QUERY_THROW );
1068 xClose->close( sal_True );
1070 catch ( uno::Exception& )
1077 rReq.Done();
1079 break;
1080 #endif
1081 case SID_OPEN_CALC:
1083 SfxStringItem aApp(SID_DOC_SERVICE, OUString("com.sun.star.sheet.SpreadsheetDocument"));
1084 SfxStringItem aTarget(SID_TARGETNAME, OUString("_blank"));
1085 GetViewData()->GetDispatcher().Execute(
1086 SID_OPENDOC, SFX_CALLMODE_API|SFX_CALLMODE_SYNCHRON, &aApp, &aTarget, 0L);
1088 break;
1089 default:
1091 // kleiner (?) Hack -> forward der Slots an TabViewShell
1092 ScTabViewShell* pSh = GetBestViewShell();
1093 if ( pSh )
1094 pSh->Execute( rReq );
1095 #ifndef DISABLE_SCRIPTING
1096 else
1097 SbxBase::SetError( SbxERR_NO_ACTIVE_OBJECT );
1098 #endif
1104 //------------------------------------------------------------------
1106 void UpdateAcceptChangesDialog()
1108 // update "accept changes" dialog
1109 //! notify all views
1110 SfxViewFrame* pViewFrm = SfxViewFrame::Current();
1111 if ( pViewFrm && pViewFrm->HasChildWindow( FID_CHG_ACCEPT ) )
1113 SfxChildWindow* pChild = pViewFrm->GetChildWindow( FID_CHG_ACCEPT );
1114 if ( pChild )
1115 ((ScAcceptChgDlgWrapper*)pChild)->ReInitDlg();
1119 //------------------------------------------------------------------
1121 bool ScDocShell::ExecuteChangeProtectionDialog( Window* _pParent, sal_Bool bJustQueryIfProtected )
1123 bool bDone = false;
1124 ScChangeTrack* pChangeTrack = aDocument.GetChangeTrack();
1125 if ( pChangeTrack )
1127 bool bProtected = pChangeTrack->IsProtected();
1128 if ( bJustQueryIfProtected && !bProtected )
1129 return true;
1131 String aTitle( ScResId( bProtected ? SCSTR_CHG_UNPROTECT : SCSTR_CHG_PROTECT ) );
1132 String aText( ScResId( SCSTR_PASSWORD ) );
1133 String aPassword;
1135 SfxPasswordDialog* pDlg = new SfxPasswordDialog(
1136 _pParent ? _pParent : GetActiveDialogParent(), &aText );
1137 pDlg->SetText( aTitle );
1138 pDlg->SetMinLen( 1 );
1139 pDlg->SetHelpId( GetStaticInterface()->GetSlot(SID_CHG_PROTECT)->GetCommand() );
1140 pDlg->SetEditHelpId( HID_CHG_PROTECT );
1141 if ( !bProtected )
1142 pDlg->ShowExtras( SHOWEXTRAS_CONFIRM );
1143 if ( pDlg->Execute() == RET_OK )
1144 aPassword = pDlg->GetPassword();
1145 delete pDlg;
1147 if ( aPassword.Len() )
1149 if ( bProtected )
1151 if ( SvPasswordHelper::CompareHashPassword(pChangeTrack->GetProtection(), aPassword) )
1153 if ( bJustQueryIfProtected )
1154 bDone = true;
1155 else
1156 pChangeTrack->SetProtection(
1157 com::sun::star::uno::Sequence< sal_Int8 > (0) );
1159 else
1161 InfoBox aBox( GetActiveDialogParent(),
1162 String( ScResId( SCSTR_WRONGPASSWORD ) ) );
1163 aBox.Execute();
1166 else
1168 com::sun::star::uno::Sequence< sal_Int8 > aPass;
1169 SvPasswordHelper::GetHashPassword( aPass, aPassword );
1170 pChangeTrack->SetProtection( aPass );
1172 if ( bProtected != pChangeTrack->IsProtected() )
1174 UpdateAcceptChangesDialog();
1175 bDone = true;
1179 else if ( bJustQueryIfProtected )
1180 bDone = true;
1181 return bDone;
1185 //------------------------------------------------------------------
1187 void ScDocShell::DoRecalc( bool bApi )
1189 bool bDone = false;
1190 ScTabViewShell* pSh = GetBestViewShell();
1191 if ( pSh )
1193 ScInputHandler* pHdl = SC_MOD()->GetInputHdl(pSh);
1194 if ( pHdl && pHdl->IsInputMode() && pHdl->IsFormulaMode() && !bApi )
1196 pHdl->FormulaPreview(); // Teilergebnis als QuickHelp
1197 bDone = true;
1199 else
1201 pSh->UpdateInputLine(); // InputEnterHandler
1202 pSh->UpdateInputHandler();
1205 if (!bDone) // sonst Dokument neu berechnen
1207 WaitObject aWaitObj( GetActiveDialogParent() );
1208 aDocument.CalcFormulaTree();
1209 if ( pSh )
1210 pSh->UpdateCharts(true);
1212 aDocument.BroadcastUno( SfxSimpleHint( SFX_HINT_DATACHANGED ) );
1214 // Wenn es Charts gibt, dann alles painten, damit nicht
1215 // PostDataChanged und die Charts nacheinander kommen und Teile
1216 // doppelt gepainted werden.
1218 ScChartListenerCollection* pCharts = aDocument.GetChartListenerCollection();
1219 if ( pCharts && pCharts->hasListeners() )
1220 PostPaintGridAll();
1221 else
1222 PostDataChanged();
1226 void ScDocShell::DoHardRecalc( bool /* bApi */ )
1228 WaitObject aWaitObj( GetActiveDialogParent() );
1229 ScTabViewShell* pSh = GetBestViewShell();
1230 if ( pSh )
1232 pSh->UpdateInputLine(); // InputEnterHandler
1233 pSh->UpdateInputHandler();
1235 aDocument.CalcAll();
1236 GetDocFunc().DetectiveRefresh(); // erzeugt eigenes Undo
1237 if ( pSh )
1238 pSh->UpdateCharts(true);
1240 // set notification flags for "calculate" event (used in SFX_HINT_DATACHANGED broadcast)
1241 // (might check for the presence of any formulas on each sheet)
1242 SCTAB nTabCount = aDocument.GetTableCount();
1243 SCTAB nTab;
1244 if (aDocument.HasAnySheetEventScript( SC_SHEETEVENT_CALCULATE, true )) // search also for VBA hendler
1245 for (nTab=0; nTab<nTabCount; nTab++)
1246 aDocument.SetCalcNotification(nTab);
1248 // CalcAll doesn't broadcast value changes, so SC_HINT_CALCALL is broadcasted globally
1249 // in addition to SFX_HINT_DATACHANGED.
1250 aDocument.BroadcastUno( SfxSimpleHint( SC_HINT_CALCALL ) );
1251 aDocument.BroadcastUno( SfxSimpleHint( SFX_HINT_DATACHANGED ) );
1253 // use hard recalc also to disable stream-copying of all sheets
1254 // (somewhat consistent with charts)
1255 for (nTab=0; nTab<nTabCount; nTab++)
1256 if (aDocument.IsStreamValid(nTab))
1257 aDocument.SetStreamValid(nTab, false);
1259 PostPaintGridAll();
1262 //------------------------------------------------------------------
1264 void ScDocShell::DoAutoStyle( const ScRange& rRange, const String& rStyle )
1266 ScStyleSheetPool* pStylePool = aDocument.GetStyleSheetPool();
1267 ScStyleSheet* pStyleSheet =
1268 pStylePool->FindCaseIns( rStyle, SFX_STYLE_FAMILY_PARA );
1269 if (!pStyleSheet)
1270 pStyleSheet = (ScStyleSheet*)
1271 pStylePool->Find( ScGlobal::GetRscString(STR_STYLENAME_STANDARD), SFX_STYLE_FAMILY_PARA );
1272 if (pStyleSheet)
1274 OSL_ENSURE(rRange.aStart.Tab() == rRange.aEnd.Tab(),
1275 "DoAutoStyle mit mehreren Tabellen");
1276 SCTAB nTab = rRange.aStart.Tab();
1277 SCCOL nStartCol = rRange.aStart.Col();
1278 SCROW nStartRow = rRange.aStart.Row();
1279 SCCOL nEndCol = rRange.aEnd.Col();
1280 SCROW nEndRow = rRange.aEnd.Row();
1281 aDocument.ApplyStyleAreaTab( nStartCol, nStartRow, nEndCol, nEndRow, nTab, *pStyleSheet );
1282 aDocument.ExtendMerge( nStartCol, nStartRow, nEndCol, nEndRow, nTab );
1283 PostPaint( nStartCol, nStartRow, nTab, nEndCol, nEndRow, nTab, PAINT_GRID );
1287 //------------------------------------------------------------------
1289 void ScDocShell::NotifyStyle( const SfxStyleSheetHint& rHint )
1291 sal_uInt16 nId = rHint.GetHint();
1292 const SfxStyleSheetBase* pStyle = rHint.GetStyleSheet();
1293 if (!pStyle)
1294 return;
1296 if ( pStyle->GetFamily() == SFX_STYLE_FAMILY_PAGE )
1298 if ( nId == SFX_STYLESHEET_MODIFIED )
1300 ScDocShellModificator aModificator( *this );
1302 OUString aNewName = pStyle->GetName();
1303 OUString aOldName = aNewName;
1304 sal_Bool bExtended = rHint.ISA(SfxStyleSheetHintExtended); // Name geaendert?
1305 if (bExtended)
1306 aOldName = ((SfxStyleSheetHintExtended&)rHint).GetOldName();
1308 if ( aNewName != aOldName )
1309 aDocument.RenamePageStyleInUse( aOldName, aNewName );
1311 SCTAB nTabCount = aDocument.GetTableCount();
1312 for (SCTAB nTab=0; nTab<nTabCount; nTab++)
1313 if (aDocument.GetPageStyle(nTab) == aNewName) // schon auf neu angepasst
1315 aDocument.PageStyleModified( nTab, aNewName );
1316 ScPrintFunc aPrintFunc( this, GetPrinter(), nTab );
1317 aPrintFunc.UpdatePages();
1320 aModificator.SetDocumentModified();
1322 if (bExtended)
1324 SfxBindings* pBindings = GetViewBindings();
1325 if (pBindings)
1327 pBindings->Invalidate( SID_STATUS_PAGESTYLE );
1328 pBindings->Invalidate( SID_STYLE_FAMILY4 );
1329 pBindings->Invalidate( FID_RESET_PRINTZOOM );
1330 pBindings->Invalidate( SID_ATTR_PARA_LEFT_TO_RIGHT );
1331 pBindings->Invalidate( SID_ATTR_PARA_RIGHT_TO_LEFT );
1336 else if ( pStyle->GetFamily() == SFX_STYLE_FAMILY_PARA )
1338 if ( nId == SFX_STYLESHEET_MODIFIED)
1340 OUString aNewName = pStyle->GetName();
1341 OUString aOldName = aNewName;
1342 sal_Bool bExtended = rHint.ISA(SfxStyleSheetHintExtended);
1343 if (bExtended)
1344 aOldName = ((SfxStyleSheetHintExtended&)rHint).GetOldName();
1345 if ( aNewName != aOldName )
1347 for(SCTAB i = 0; i < aDocument.GetTableCount(); ++i)
1349 ScConditionalFormatList* pList = aDocument.GetCondFormList(i);
1350 if (pList)
1351 pList->RenameCellStyle( aOldName,aNewName );
1357 // alles andere geht ueber Slots...
1360 // wie in printfun.cxx
1361 #define ZOOM_MIN 10
1363 void ScDocShell::SetPrintZoom( SCTAB nTab, sal_uInt16 nScale, sal_uInt16 nPages )
1365 sal_Bool bUndo(aDocument.IsUndoEnabled());
1366 String aStyleName = aDocument.GetPageStyle( nTab );
1367 ScStyleSheetPool* pStylePool = aDocument.GetStyleSheetPool();
1368 SfxStyleSheetBase* pStyleSheet = pStylePool->Find( aStyleName, SFX_STYLE_FAMILY_PAGE );
1369 OSL_ENSURE( pStyleSheet, "PageStyle not found" );
1370 if ( pStyleSheet )
1372 ScDocShellModificator aModificator( *this );
1374 SfxItemSet& rSet = pStyleSheet->GetItemSet();
1375 if (bUndo)
1377 sal_uInt16 nOldScale = ((const SfxUInt16Item&)rSet.Get(ATTR_PAGE_SCALE)).GetValue();
1378 sal_uInt16 nOldPages = ((const SfxUInt16Item&)rSet.Get(ATTR_PAGE_SCALETOPAGES)).GetValue();
1379 GetUndoManager()->AddUndoAction( new ScUndoPrintZoom(
1380 this, nTab, nOldScale, nOldPages, nScale, nPages ) );
1383 rSet.Put( SfxUInt16Item( ATTR_PAGE_SCALE, nScale ) );
1384 rSet.Put( SfxUInt16Item( ATTR_PAGE_SCALETOPAGES, nPages ) );
1386 ScPrintFunc aPrintFunc( this, GetPrinter(), nTab );
1387 aPrintFunc.UpdatePages();
1388 aModificator.SetDocumentModified();
1390 SfxBindings* pBindings = GetViewBindings();
1391 if (pBindings)
1392 pBindings->Invalidate( FID_RESET_PRINTZOOM );
1396 bool ScDocShell::AdjustPrintZoom( const ScRange& rRange )
1398 bool bChange = false;
1399 SCTAB nTab = rRange.aStart.Tab();
1401 String aStyleName = aDocument.GetPageStyle( nTab );
1402 ScStyleSheetPool* pStylePool = aDocument.GetStyleSheetPool();
1403 SfxStyleSheetBase* pStyleSheet = pStylePool->Find( aStyleName, SFX_STYLE_FAMILY_PAGE );
1404 OSL_ENSURE( pStyleSheet, "PageStyle not found" );
1405 if ( pStyleSheet )
1407 SfxItemSet& rSet = pStyleSheet->GetItemSet();
1408 sal_Bool bHeaders = ((const SfxBoolItem&)rSet.Get(ATTR_PAGE_HEADERS)).GetValue();
1409 sal_uInt16 nOldScale = ((const SfxUInt16Item&)rSet.Get(ATTR_PAGE_SCALE)).GetValue();
1410 sal_uInt16 nOldPages = ((const SfxUInt16Item&)rSet.Get(ATTR_PAGE_SCALETOPAGES)).GetValue();
1411 const ScRange* pRepeatCol = aDocument.GetRepeatColRange( nTab );
1412 const ScRange* pRepeatRow = aDocument.GetRepeatRowRange( nTab );
1414 // benoetigte Skalierung fuer Selektion ausrechnen
1416 sal_uInt16 nNewScale = nOldScale;
1418 long nBlkTwipsX = 0;
1419 if (bHeaders)
1420 nBlkTwipsX += (long) PRINT_HEADER_WIDTH;
1421 SCCOL nStartCol = rRange.aStart.Col();
1422 SCCOL nEndCol = rRange.aEnd.Col();
1423 if ( pRepeatCol && nStartCol >= pRepeatCol->aStart.Col() )
1425 for (SCCOL i=pRepeatCol->aStart.Col(); i<=pRepeatCol->aEnd.Col(); i++ )
1426 nBlkTwipsX += aDocument.GetColWidth( i, nTab );
1427 if ( nStartCol <= pRepeatCol->aEnd.Col() )
1428 nStartCol = pRepeatCol->aEnd.Col() + 1;
1430 // legacy compilers' own scope for i
1432 for ( SCCOL i=nStartCol; i<=nEndCol; i++ )
1433 nBlkTwipsX += aDocument.GetColWidth( i, nTab );
1436 long nBlkTwipsY = 0;
1437 if (bHeaders)
1438 nBlkTwipsY += (long) PRINT_HEADER_HEIGHT;
1439 SCROW nStartRow = rRange.aStart.Row();
1440 SCROW nEndRow = rRange.aEnd.Row();
1441 if ( pRepeatRow && nStartRow >= pRepeatRow->aStart.Row() )
1443 nBlkTwipsY += aDocument.GetRowHeight( pRepeatRow->aStart.Row(),
1444 pRepeatRow->aEnd.Row(), nTab );
1445 if ( nStartRow <= pRepeatRow->aEnd.Row() )
1446 nStartRow = pRepeatRow->aEnd.Row() + 1;
1448 nBlkTwipsY += aDocument.GetRowHeight( nStartRow, nEndRow, nTab );
1450 Size aPhysPage;
1451 long nHdr, nFtr;
1452 ScPrintFunc aOldPrFunc( this, GetPrinter(), nTab );
1453 aOldPrFunc.GetScaleData( aPhysPage, nHdr, nFtr );
1454 nBlkTwipsY += nHdr + nFtr;
1456 if ( nBlkTwipsX == 0 ) // hidden columns/rows may lead to 0
1457 nBlkTwipsX = 1;
1458 if ( nBlkTwipsY == 0 )
1459 nBlkTwipsY = 1;
1461 long nNeeded = std::min( aPhysPage.Width() * 100 / nBlkTwipsX,
1462 aPhysPage.Height() * 100 / nBlkTwipsY );
1463 if ( nNeeded < ZOOM_MIN )
1464 nNeeded = ZOOM_MIN; // Begrenzung
1465 if ( nNeeded < (long) nNewScale )
1466 nNewScale = (sal_uInt16) nNeeded;
1468 bChange = ( nNewScale != nOldScale || nOldPages != 0 );
1469 if ( bChange )
1470 SetPrintZoom( nTab, nNewScale, 0 );
1472 return bChange;
1475 void ScDocShell::PageStyleModified( const OUString& rStyleName, sal_Bool bApi )
1477 ScDocShellModificator aModificator( *this );
1479 sal_Bool bWarn = false;
1481 SCTAB nTabCount = aDocument.GetTableCount();
1482 SCTAB nUseTab = MAXTAB+1;
1483 for (SCTAB nTab=0; nTab<nTabCount && nUseTab>MAXTAB; nTab++)
1484 if ( aDocument.GetPageStyle(nTab) == rStyleName &&
1485 ( !bApi || aDocument.GetPageSize(nTab).Width() ) )
1486 nUseTab = nTab;
1487 // bei bApi nur, wenn Umbrueche schon angezeigt
1489 if (ValidTab(nUseTab)) // nicht verwendet -> nichts zu tun
1491 ScPrintFunc aPrintFunc( this, GetPrinter(), nUseTab ); //! ohne CountPages auskommen
1492 if (!aPrintFunc.UpdatePages()) // setzt Umbrueche auf allen Tabs
1493 bWarn = sal_True;
1495 if (bWarn && !bApi)
1497 ScWaitCursorOff aWaitOff( GetActiveDialogParent() );
1498 InfoBox aInfoBox(GetActiveDialogParent(),
1499 ScGlobal::GetRscString(STR_PRINT_INVALID_AREA));
1500 aInfoBox.Execute();
1504 aModificator.SetDocumentModified();
1506 SfxBindings* pBindings = GetViewBindings();
1507 if (pBindings)
1509 pBindings->Invalidate( FID_RESET_PRINTZOOM );
1510 pBindings->Invalidate( SID_ATTR_PARA_LEFT_TO_RIGHT );
1511 pBindings->Invalidate( SID_ATTR_PARA_RIGHT_TO_LEFT );
1515 void ScDocShell::ExecutePageStyle( SfxViewShell& rCaller,
1516 SfxRequest& rReq,
1517 SCTAB nCurTab )
1519 const SfxItemSet* pReqArgs = rReq.GetArgs();
1521 switch ( rReq.GetSlot() )
1523 case SID_STATUS_PAGESTYLE: // Click auf StatusBar-Control
1524 case SID_FORMATPAGE:
1526 if ( pReqArgs != NULL )
1529 else if ( pReqArgs == NULL )
1531 sal_Bool bUndo(aDocument.IsUndoEnabled());
1532 String aOldName = aDocument.GetPageStyle( nCurTab );
1533 ScStyleSheetPool* pStylePool = aDocument.GetStyleSheetPool();
1534 SfxStyleSheetBase* pStyleSheet
1535 = pStylePool->Find( aOldName, SFX_STYLE_FAMILY_PAGE );
1537 OSL_ENSURE( pStyleSheet, "PageStyle not found! :-/" );
1539 if ( pStyleSheet )
1541 ScStyleSaveData aOldData;
1542 if (bUndo)
1543 aOldData.InitFromStyle( pStyleSheet );
1545 SfxItemSet& rStyleSet = pStyleSheet->GetItemSet();
1547 ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
1548 OSL_ENSURE(pFact, "ScAbstractFactory create fail!");
1550 SfxAbstractTabDialog* pDlg = pFact->CreateScStyleDlg( GetActiveDialogParent(), *pStyleSheet, RID_SCDLG_STYLES_PAGE, RID_SCDLG_STYLES_PAGE );
1551 OSL_ENSURE(pDlg, "Dialog create fail!");
1553 if ( pDlg->Execute() == RET_OK )
1555 const SfxItemSet* pOutSet = pDlg->GetOutputItemSet();
1557 WaitObject aWait( GetActiveDialogParent() );
1559 String aNewName = pStyleSheet->GetName();
1560 if ( aNewName != aOldName &&
1561 aDocument.RenamePageStyleInUse( aOldName, aNewName ) )
1563 SfxBindings* pBindings = GetViewBindings();
1564 if (pBindings)
1566 pBindings->Invalidate( SID_STATUS_PAGESTYLE );
1567 pBindings->Invalidate( FID_RESET_PRINTZOOM );
1571 if ( pOutSet )
1572 aDocument.ModifyStyleSheet( *pStyleSheet, *pOutSet );
1574 // merken fuer GetState():
1575 GetPageOnFromPageStyleSet( &rStyleSet, nCurTab, bHeaderOn, bFooterOn );
1576 rCaller.GetViewFrame()->GetBindings().Invalidate( SID_HFEDIT );
1578 ScStyleSaveData aNewData;
1579 aNewData.InitFromStyle( pStyleSheet );
1580 if (bUndo)
1582 GetUndoManager()->AddUndoAction(
1583 new ScUndoModifyStyle( this, SFX_STYLE_FAMILY_PAGE,
1584 aOldData, aNewData ) );
1587 PageStyleModified( aNewName, false );
1588 rReq.Done();
1590 delete pDlg;
1592 rStyleSet.ClearItem( ATTR_PAGE_PAPERTRAY );
1596 break;
1598 case SID_HFEDIT:
1600 if ( pReqArgs != NULL )
1603 else if ( pReqArgs == NULL )
1605 String aStr( aDocument.GetPageStyle( nCurTab ) );
1607 ScStyleSheetPool* pStylePool
1608 = aDocument.GetStyleSheetPool();
1610 SfxStyleSheetBase* pStyleSheet
1611 = pStylePool->Find( aStr, SFX_STYLE_FAMILY_PAGE );
1613 OSL_ENSURE( pStyleSheet, "PageStyle not found! :-/" );
1615 if ( pStyleSheet )
1617 SfxItemSet& rStyleSet = pStyleSheet->GetItemSet();
1619 SvxPageUsage eUsage =
1620 SvxPageUsage( ((const SvxPageItem&)
1621 rStyleSet.Get( ATTR_PAGE )).
1622 GetPageUsage() );
1623 sal_Bool bShareHeader = IS_SHARE_HEADER(rStyleSet);
1624 sal_Bool bShareFooter = IS_SHARE_FOOTER(rStyleSet);
1625 sal_uInt16 nResId = 0;
1627 switch ( eUsage )
1629 case SVX_PAGE_LEFT:
1630 case SVX_PAGE_RIGHT:
1632 if ( bHeaderOn && bFooterOn )
1633 nResId = RID_SCDLG_HFEDIT;
1634 else if ( SVX_PAGE_RIGHT == eUsage )
1636 if ( !bHeaderOn && bFooterOn )
1637 nResId = RID_SCDLG_HFEDIT_RIGHTFOOTER;
1638 else if ( bHeaderOn && !bFooterOn )
1639 nResId = RID_SCDLG_HFEDIT_RIGHTHEADER;
1641 else
1643 // #69193a# respect "shared" setting
1644 if ( !bHeaderOn && bFooterOn )
1645 nResId = bShareFooter ?
1646 RID_SCDLG_HFEDIT_RIGHTFOOTER :
1647 RID_SCDLG_HFEDIT_LEFTFOOTER;
1648 else if ( bHeaderOn && !bFooterOn )
1649 nResId = bShareHeader ?
1650 RID_SCDLG_HFEDIT_RIGHTHEADER :
1651 RID_SCDLG_HFEDIT_LEFTHEADER;
1654 break;
1656 case SVX_PAGE_MIRROR:
1657 case SVX_PAGE_ALL:
1658 default:
1660 if ( !bShareHeader && !bShareFooter )
1662 if ( bHeaderOn && bFooterOn )
1663 nResId = RID_SCDLG_HFEDIT_ALL;
1664 else if ( !bHeaderOn && bFooterOn )
1665 nResId = RID_SCDLG_HFEDIT_FOOTER;
1666 else if ( bHeaderOn && !bFooterOn )
1667 nResId = RID_SCDLG_HFEDIT_HEADER;
1669 else if ( bShareHeader && bShareFooter )
1671 if ( bHeaderOn && bFooterOn )
1672 nResId = RID_SCDLG_HFEDIT;
1673 else
1675 if ( !bHeaderOn && bFooterOn )
1676 nResId = RID_SCDLG_HFEDIT_RIGHTFOOTER;
1677 else if ( bHeaderOn && !bFooterOn )
1678 nResId = RID_SCDLG_HFEDIT_RIGHTHEADER;
1681 else if ( !bShareHeader && bShareFooter )
1683 if ( bHeaderOn && bFooterOn )
1684 nResId = RID_SCDLG_HFEDIT_SFTR;
1685 else if ( !bHeaderOn && bFooterOn )
1686 nResId = RID_SCDLG_HFEDIT_RIGHTFOOTER;
1687 else if ( bHeaderOn && !bFooterOn )
1688 nResId = RID_SCDLG_HFEDIT_HEADER;
1690 else if ( bShareHeader && !bShareFooter )
1692 if ( bHeaderOn && bFooterOn )
1693 nResId = RID_SCDLG_HFEDIT_SHDR;
1694 else if ( !bHeaderOn && bFooterOn )
1695 nResId = RID_SCDLG_HFEDIT_FOOTER;
1696 else if ( bHeaderOn && !bFooterOn )
1697 nResId = RID_SCDLG_HFEDIT_RIGHTHEADER;
1702 ScAbstractDialogFactory* pFact = ScAbstractDialogFactory::Create();
1703 OSL_ENSURE(pFact, "ScAbstractFactory create fail!");
1705 SfxAbstractTabDialog* pDlg = pFact->CreateScHFEditDlg( SfxViewFrame::Current(),
1706 GetActiveDialogParent(),
1707 rStyleSet,
1708 aStr,
1709 nResId);
1710 OSL_ENSURE(pDlg, "Dialog create fail!");
1711 if ( pDlg->Execute() == RET_OK )
1713 const SfxItemSet* pOutSet = pDlg->GetOutputItemSet();
1715 if ( pOutSet )
1716 aDocument.ModifyStyleSheet( *pStyleSheet, *pOutSet );
1718 SetDocumentModified();
1719 rReq.Done();
1721 delete pDlg;
1725 break;
1727 default:
1728 break;
1732 void ScDocShell::GetStatePageStyle( SfxViewShell& /* rCaller */,
1733 SfxItemSet& rSet,
1734 SCTAB nCurTab )
1736 SfxWhichIter aIter(rSet);
1737 sal_uInt16 nWhich = aIter.FirstWhich();
1738 while ( nWhich )
1740 switch (nWhich)
1742 case SID_STATUS_PAGESTYLE:
1743 rSet.Put( SfxStringItem( nWhich, aDocument.GetPageStyle( nCurTab ) ) );
1744 break;
1746 case SID_HFEDIT:
1748 String aStr = aDocument.GetPageStyle( nCurTab );
1749 ScStyleSheetPool* pStylePool = aDocument.GetStyleSheetPool();
1750 SfxStyleSheetBase* pStyleSheet = pStylePool->Find( aStr, SFX_STYLE_FAMILY_PAGE );
1752 OSL_ENSURE( pStyleSheet, "PageStyle not found! :-/" );
1754 if ( pStyleSheet )
1756 SfxItemSet& rStyleSet = pStyleSheet->GetItemSet();
1757 GetPageOnFromPageStyleSet( &rStyleSet, nCurTab, bHeaderOn, bFooterOn );
1759 if ( !bHeaderOn && !bFooterOn )
1760 rSet.DisableItem( nWhich );
1763 break;
1766 nWhich = aIter.NextWhich();
1770 void ScDocShell::GetState( SfxItemSet &rSet )
1772 bool bTabView = GetBestViewShell(true) != NULL;
1774 SfxWhichIter aIter(rSet);
1775 for (sal_uInt16 nWhich = aIter.FirstWhich(); nWhich; nWhich = aIter.NextWhich())
1777 if (!bTabView)
1779 rSet.DisableItem(nWhich);
1780 continue;
1783 switch (nWhich)
1785 case FID_AUTO_CALC:
1786 if ( aDocument.GetHardRecalcState() )
1787 rSet.DisableItem( nWhich );
1788 else
1789 rSet.Put( SfxBoolItem( nWhich, aDocument.GetAutoCalc() ) );
1790 break;
1792 case FID_CHG_RECORD:
1793 if ( IsDocShared() )
1794 rSet.DisableItem( nWhich );
1795 else
1796 rSet.Put( SfxBoolItem( nWhich,
1797 aDocument.GetChangeTrack() != NULL ) );
1798 break;
1800 case SID_CHG_PROTECT:
1802 ScChangeTrack* pChangeTrack = aDocument.GetChangeTrack();
1803 if ( pChangeTrack && !IsDocShared() )
1804 rSet.Put( SfxBoolItem( nWhich,
1805 pChangeTrack->IsProtected() ) );
1806 else
1807 rSet.DisableItem( nWhich );
1809 break;
1811 case SID_DOCUMENT_COMPARE:
1813 if ( IsDocShared() )
1815 rSet.DisableItem( nWhich );
1818 break;
1820 // Wenn eine Formel editiert wird, muss FID_RECALC auf jeden Fall enabled sein.
1821 // Recalc fuer das Doc war mal wegen eines Bugs disabled, wenn AutoCalc an war,
1822 // ist jetzt wegen eines anderen Bugs aber auch immer enabled.
1824 case SID_TABLES_COUNT:
1825 rSet.Put( SfxInt16Item( nWhich, aDocument.GetTableCount() ) );
1826 break;
1828 case SID_ATTR_YEAR2000 :
1829 rSet.Put( SfxUInt16Item( nWhich,
1830 aDocument.GetDocOptions().GetYear2000() ) );
1831 break;
1833 case SID_SHARE_DOC:
1835 if ( IsReadOnly() )
1837 rSet.DisableItem( nWhich );
1840 break;
1842 default:
1845 break;
1850 void ScDocShell::GetSbxState( SfxItemSet &rSet )
1852 // SID_SC_SELECTION (Selection),
1853 // SID_SC_ACTIVECELL (ActiveCell),
1854 // SID_SC_ACTIVETAB (ActiveTable),
1855 // SID_TABLES_GET (Tables),
1856 // SID_PIVOT_GET (DataPilotTables) - removed (old Basic)
1859 // Wenn hier Slots von der View-Shell executed werden, muss auch der
1860 // GetState weitergeleitet werden!
1863 ScTabViewShell* pVisibleSh = GetBestViewShell(); // sichtbare View
1864 if ( pVisibleSh )
1865 pVisibleSh->GetState( rSet );
1868 void ScDocShell::Draw( OutputDevice* pDev, const JobSetup & /* rSetup */, sal_uInt16 nAspect )
1871 SCTAB nVisTab = aDocument.GetVisibleTab();
1872 if (!aDocument.HasTable(nVisTab))
1873 return;
1875 sal_uLong nOldLayoutMode = pDev->GetLayoutMode();
1876 pDev->SetLayoutMode( TEXT_LAYOUT_DEFAULT ); // even if it's the same, to get the metafile action
1878 if ( nAspect == ASPECT_THUMBNAIL )
1880 Rectangle aBoundRect = GetVisArea( ASPECT_THUMBNAIL );
1881 ScViewData aTmpData( this, NULL );
1882 aTmpData.SetTabNo(nVisTab);
1883 SnapVisArea( aBoundRect );
1884 aTmpData.SetScreen( aBoundRect );
1885 ScPrintFunc::DrawToDev( &aDocument, pDev, 1.0, aBoundRect, &aTmpData, sal_True );
1887 else
1889 Rectangle aBoundRect = SfxObjectShell::GetVisArea();
1890 ScViewData aTmpData( this, NULL );
1891 aTmpData.SetTabNo(nVisTab);
1892 SnapVisArea( aBoundRect );
1893 aTmpData.SetScreen( aBoundRect );
1894 ScPrintFunc::DrawToDev( &aDocument, pDev, 1.0, aBoundRect, &aTmpData, sal_True );
1897 pDev->SetLayoutMode( nOldLayoutMode );
1900 Rectangle ScDocShell::GetVisArea( sal_uInt16 nAspect ) const
1902 SfxObjectCreateMode eShellMode = GetCreateMode();
1903 if ( eShellMode == SFX_CREATE_MODE_ORGANIZER )
1905 // ohne Inhalte wissen wir auch nicht, wie gross die Inhalte sind
1906 // leeres Rechteck zurueckgeben, das wird dann nach dem Laden berechnet
1907 return Rectangle();
1910 if( nAspect == ASPECT_THUMBNAIL )
1912 Rectangle aArea( 0,0, SC_PREVIEW_SIZE_X,SC_PREVIEW_SIZE_Y );
1913 sal_Bool bNegativePage = aDocument.IsNegativePage( aDocument.GetVisibleTab() );
1914 if ( bNegativePage )
1915 ScDrawLayer::MirrorRectRTL( aArea );
1916 SnapVisArea( aArea );
1917 return aArea;
1919 else if( nAspect == ASPECT_CONTENT && eShellMode != SFX_CREATE_MODE_EMBEDDED )
1921 // Visarea holen wie nach Load
1923 SCTAB nVisTab = aDocument.GetVisibleTab();
1924 if (!aDocument.HasTable(nVisTab))
1926 nVisTab = 0;
1927 ((ScDocShell*)this)->aDocument.SetVisibleTab(nVisTab);
1929 SCCOL nStartCol;
1930 SCROW nStartRow;
1931 aDocument.GetDataStart( nVisTab, nStartCol, nStartRow );
1932 SCCOL nEndCol;
1933 SCROW nEndRow;
1934 aDocument.GetPrintArea( nVisTab, nEndCol, nEndRow );
1935 if (nStartCol>nEndCol)
1936 nStartCol = nEndCol;
1937 if (nStartRow>nEndRow)
1938 nStartRow = nEndRow;
1939 Rectangle aNewArea = ((ScDocument&)aDocument)
1940 .GetMMRect( nStartCol,nStartRow, nEndCol,nEndRow, nVisTab );
1941 //TODO/LATER: different methods for setting VisArea?!
1942 ((ScDocShell*)this)->SfxObjectShell::SetVisArea( aNewArea );
1943 return aNewArea;
1945 else
1946 return SfxObjectShell::GetVisArea( nAspect );
1949 namespace {
1951 void SnapHor( const ScDocument& rDoc, SCTAB nTab, long& rVal, SCCOL& rStartCol )
1953 SCCOL nCol = 0;
1954 long nTwips = (long) (rVal / HMM_PER_TWIPS);
1955 long nSnap = 0;
1956 while ( nCol<MAXCOL )
1958 long nAdd = rDoc.GetColWidth(nCol, nTab);
1959 if ( nSnap + nAdd/2 < nTwips || nCol < rStartCol )
1961 nSnap += nAdd;
1962 ++nCol;
1964 else
1965 break;
1967 rVal = (long) ( nSnap * HMM_PER_TWIPS );
1968 rStartCol = nCol;
1971 void SnapVer( const ScDocument& rDoc, SCTAB nTab, long& rVal, SCROW& rStartRow )
1973 SCROW nRow = 0;
1974 long nTwips = (long) (rVal / HMM_PER_TWIPS);
1975 long nSnap = 0;
1977 bool bFound = false;
1978 for (SCROW i = nRow; i <= MAXROW; ++i)
1980 SCROW nLastRow;
1981 if (rDoc.RowHidden(i, nTab, NULL, &nLastRow))
1983 i = nLastRow;
1984 continue;
1987 nRow = i;
1988 long nAdd = rDoc.GetRowHeight(i, nTab);
1989 if ( nSnap + nAdd/2 < nTwips || nRow < rStartRow )
1991 nSnap += nAdd;
1992 ++nRow;
1994 else
1996 bFound = true;
1997 break;
2000 if (!bFound)
2001 nRow = MAXROW; // all hidden down to the bottom
2003 rVal = (long) ( nSnap * HMM_PER_TWIPS );
2004 rStartRow = nRow;
2010 void ScDocShell::SnapVisArea( Rectangle& rRect ) const
2012 SCTAB nTab = aDocument.GetVisibleTab();
2013 bool bNegativePage = aDocument.IsNegativePage( nTab );
2014 if ( bNegativePage )
2015 ScDrawLayer::MirrorRectRTL( rRect ); // calculate with positive (LTR) values
2017 SCCOL nCol = 0;
2018 SnapHor( aDocument, nTab, rRect.Left(), nCol );
2019 ++nCol; // mindestens eine Spalte
2020 SnapHor( aDocument, nTab, rRect.Right(), nCol );
2022 SCROW nRow = 0;
2023 SnapVer( aDocument, nTab, rRect.Top(), nRow );
2024 ++nRow; // mindestens eine Zeile
2025 SnapVer( aDocument, nTab, rRect.Bottom(), nRow );
2027 if ( bNegativePage )
2028 ScDrawLayer::MirrorRectRTL( rRect ); // back to real rectangle
2031 void ScDocShell::GetPageOnFromPageStyleSet( const SfxItemSet* pStyleSet,
2032 SCTAB nCurTab,
2033 bool& rbHeader,
2034 bool& rbFooter )
2036 if ( !pStyleSet )
2038 ScStyleSheetPool* pStylePool = aDocument.GetStyleSheetPool();
2039 SfxStyleSheetBase* pStyleSheet = pStylePool->
2040 Find( aDocument.GetPageStyle( nCurTab ),
2041 SFX_STYLE_FAMILY_PAGE );
2043 OSL_ENSURE( pStyleSheet, "PageStyle not found! :-/" );
2045 if ( pStyleSheet )
2046 pStyleSet = &pStyleSheet->GetItemSet();
2047 else
2048 rbHeader = rbFooter = false;
2051 OSL_ENSURE( pStyleSet, "PageStyle-Set not found! :-(" );
2053 //--------------------------------------------------------------------
2055 const SvxSetItem* pSetItem = NULL;
2056 const SfxItemSet* pSet = NULL;
2058 pSetItem = (const SvxSetItem*) &pStyleSet->Get( ATTR_PAGE_HEADERSET );
2059 pSet = &pSetItem->GetItemSet();
2060 rbHeader = ((const SfxBoolItem&)pSet->Get(ATTR_PAGE_ON)).GetValue();
2062 pSetItem = (const SvxSetItem*) &pStyleSet->Get( ATTR_PAGE_FOOTERSET );
2063 pSet = &pSetItem->GetItemSet();
2064 rbFooter = ((const SfxBoolItem&)pSet->Get(ATTR_PAGE_ON)).GetValue();
2067 long ScDocShell::DdeGetData( const String& rItem,
2068 const String& rMimeType,
2069 ::com::sun::star::uno::Any & rValue )
2071 if( FORMAT_STRING == SotExchange::GetFormatIdFromMimeType( rMimeType ) )
2073 if( rItem.EqualsIgnoreCaseAscii( "Format" ) )
2075 OString aFmtByte(OUStringToOString(aDdeTextFmt,
2076 osl_getThreadTextEncoding()));
2077 rValue <<= ::com::sun::star::uno::Sequence< sal_Int8 >(
2078 (const sal_Int8*)aFmtByte.getStr(),
2079 aFmtByte.getLength() + 1 );
2080 return 1;
2082 ScImportExport aObj( &aDocument, rItem );
2083 if ( !aObj.IsRef() )
2084 return 0; // ungueltiger Bereich
2086 if( aDdeTextFmt.GetChar(0) == 'F' )
2087 aObj.SetFormulas( sal_True );
2088 if( aDdeTextFmt.EqualsAscii( "SYLK" ) ||
2089 aDdeTextFmt.EqualsAscii( "FSYLK" ) )
2091 OString aData;
2092 if( aObj.ExportByteString( aData, osl_getThreadTextEncoding(),
2093 SOT_FORMATSTR_ID_SYLK ) )
2095 rValue <<= ::com::sun::star::uno::Sequence< sal_Int8 >(
2096 (const sal_Int8*)aData.getStr(),
2097 aData.getLength() + 1 );
2098 return 1;
2100 else
2101 return 0;
2103 if( aDdeTextFmt.EqualsAscii( "CSV" ) ||
2104 aDdeTextFmt.EqualsAscii( "FCSV" ) )
2105 aObj.SetSeparator( ',' );
2106 aObj.SetExportTextOptions( ScExportTextOptions( ScExportTextOptions::ToSpace, 0, false ) );
2107 return aObj.ExportData( rMimeType, rValue ) ? 1 : 0;
2110 ScImportExport aObj( &aDocument, rItem );
2111 aObj.SetExportTextOptions( ScExportTextOptions( ScExportTextOptions::ToSpace, 0, false ) );
2112 if( aObj.IsRef() )
2113 return aObj.ExportData( rMimeType, rValue ) ? 1 : 0;
2114 return 0;
2117 long ScDocShell::DdeSetData( const String& rItem,
2118 const String& rMimeType,
2119 const ::com::sun::star::uno::Any & rValue )
2121 if( FORMAT_STRING == SotExchange::GetFormatIdFromMimeType( rMimeType ))
2123 if( rItem.EqualsIgnoreCaseAscii( "Format" ) )
2125 if ( ScByteSequenceToString::GetString( aDdeTextFmt, rValue, osl_getThreadTextEncoding() ) )
2127 aDdeTextFmt.ToUpperAscii();
2128 return 1;
2130 return 0;
2132 ScImportExport aObj( &aDocument, rItem );
2133 if( aDdeTextFmt.GetChar(0) == 'F' )
2134 aObj.SetFormulas( sal_True );
2135 if( aDdeTextFmt.EqualsAscii( "SYLK" ) ||
2136 aDdeTextFmt.EqualsAscii( "FSYLK" ) )
2138 String aData;
2139 if ( ScByteSequenceToString::GetString( aData, rValue, osl_getThreadTextEncoding() ) )
2141 return aObj.ImportString( aData, SOT_FORMATSTR_ID_SYLK ) ? 1 : 0;
2143 return 0;
2145 if( aDdeTextFmt.EqualsAscii( "CSV" ) ||
2146 aDdeTextFmt.EqualsAscii( "FCSV" ) )
2147 aObj.SetSeparator( ',' );
2148 return aObj.ImportData( rMimeType, rValue ) ? 1 : 0;
2150 ScImportExport aObj( &aDocument, rItem );
2151 if( aObj.IsRef() )
2152 return aObj.ImportData( rMimeType, rValue ) ? 1 : 0;
2153 return 0;
2156 ::sfx2::SvLinkSource* ScDocShell::DdeCreateLinkSource( const String& rItem )
2158 // only check for valid item string - range is parsed again in ScServerObject ctor
2160 // named range?
2161 String aPos = rItem;
2162 ScRangeName* pRange = aDocument.GetRangeName();
2163 if( pRange )
2165 const ScRangeData* pData = pRange->findByUpperName(ScGlobal::pCharClass->uppercase(aPos));
2166 if (pData)
2168 if( pData->HasType( RT_REFAREA )
2169 || pData->HasType( RT_ABSAREA )
2170 || pData->HasType( RT_ABSPOS ) )
2171 pData->GetSymbol( aPos ); // continue with the name's contents
2175 // Address in DDE function must be always parsed as CONV_OOO so that it
2176 // would always work regardless of current address convension. We do this
2177 // because the address item in a DDE entry is *not* normalized when saved
2178 // into ODF.
2179 ScRange aRange;
2180 bool bValid = ( (aRange.Parse(aPos, &aDocument, formula::FormulaGrammar::CONV_OOO ) & SCA_VALID) ||
2181 (aRange.aStart.Parse(aPos, &aDocument, formula::FormulaGrammar::CONV_OOO) & SCA_VALID) );
2183 ScServerObject* pObj = NULL; // NULL = error
2184 if ( bValid )
2185 pObj = new ScServerObject( this, rItem );
2187 // GetLinkManager()->InsertServer() is in the ScServerObject ctor
2189 return pObj;
2192 //------------------------------------------------------------------
2194 ScViewData* ScDocShell::GetViewData()
2196 SfxViewShell* pCur = SfxViewShell::Current();
2197 ScTabViewShell* pViewSh = PTR_CAST(ScTabViewShell,pCur);
2198 return pViewSh ? pViewSh->GetViewData() : NULL;
2201 //------------------------------------------------------------------
2203 SCTAB ScDocShell::GetCurTab()
2205 //! this must be made non-static and use a ViewShell from this document!
2207 ScViewData* pViewData = GetViewData();
2209 return pViewData ? pViewData->GetTabNo() : static_cast<SCTAB>(0);
2212 ScTabViewShell* ScDocShell::GetBestViewShell( sal_Bool bOnlyVisible )
2214 ScTabViewShell* pViewSh = ScTabViewShell::GetActiveViewShell();
2215 // falsches Doc?
2216 if( pViewSh && pViewSh->GetViewData()->GetDocShell() != this )
2217 pViewSh = NULL;
2218 if( !pViewSh )
2220 // 1. ViewShell suchen
2221 SfxViewFrame* pFrame = SfxViewFrame::GetFirst( this, bOnlyVisible );
2222 if( pFrame )
2224 SfxViewShell* p = pFrame->GetViewShell();
2225 pViewSh = PTR_CAST(ScTabViewShell,p);
2228 return pViewSh;
2231 SfxBindings* ScDocShell::GetViewBindings()
2233 // used to invalidate slots after changes to this document
2235 SfxViewShell* pViewSh = GetBestViewShell();
2236 if (pViewSh)
2237 return &pViewSh->GetViewFrame()->GetBindings();
2238 else
2239 return NULL;
2242 //------------------------------------------------------------------
2244 ScDocShell* ScDocShell::GetShellByNum( sal_uInt16 nDocNo ) // static
2246 ScDocShell* pFound = NULL;
2247 SfxObjectShell* pShell = SfxObjectShell::GetFirst();
2248 sal_uInt16 nShellCnt = 0;
2250 while ( pShell && !pFound )
2252 if ( pShell->Type() == TYPE(ScDocShell) )
2254 if ( nShellCnt == nDocNo )
2255 pFound = (ScDocShell*) pShell;
2256 else
2257 ++nShellCnt;
2259 pShell = SfxObjectShell::GetNext( *pShell );
2262 return pFound;
2265 //------------------------------------------------------------------
2267 IMPL_LINK( ScDocShell, DialogClosedHdl, sfx2::FileDialogHelper*, _pFileDlg )
2269 OSL_ENSURE( _pFileDlg, "ScDocShell::DialogClosedHdl(): no file dialog" );
2270 OSL_ENSURE( pImpl->pDocInserter, "ScDocShell::DialogClosedHdl(): no document inserter" );
2272 if ( ERRCODE_NONE == _pFileDlg->GetError() )
2274 sal_uInt16 nSlot = pImpl->pRequest->GetSlot();
2275 SfxMedium* pMed = pImpl->pDocInserter->CreateMedium();
2276 // #i87094# If a .odt was selected pMed is NULL.
2277 if (pMed)
2279 pImpl->pRequest->AppendItem( SfxStringItem( SID_FILE_NAME, pMed->GetName() ) );
2280 if ( SID_DOCUMENT_COMPARE == nSlot )
2282 if ( pMed->GetFilter() )
2283 pImpl->pRequest->AppendItem(
2284 SfxStringItem( SID_FILTER_NAME, pMed->GetFilter()->GetFilterName() ) );
2285 String sOptions = ScDocumentLoader::GetOptions( *pMed );
2286 if ( sOptions.Len() > 0 )
2287 pImpl->pRequest->AppendItem( SfxStringItem( SID_FILE_FILTEROPTIONS, sOptions ) );
2289 const SfxPoolItem* pItem = NULL;
2290 SfxItemSet* pSet = pMed->GetItemSet();
2291 if ( pSet &&
2292 pSet->GetItemState( SID_VERSION, sal_True, &pItem ) == SFX_ITEM_SET &&
2293 pItem->ISA( SfxInt16Item ) )
2295 pImpl->pRequest->AppendItem( *pItem );
2298 Execute( *(pImpl->pRequest) );
2302 pImpl->bIgnoreLostRedliningWarning = false;
2303 return 0;
2306 #if HAVE_FEATURE_MULTIUSER_ENVIRONMENT
2308 void ScDocShell::EnableSharedSettings( bool bEnable )
2310 SetDocumentModified();
2312 if ( bEnable )
2314 aDocument.EndChangeTracking();
2315 aDocument.StartChangeTracking();
2317 // hide accept or reject changes dialog
2318 sal_uInt16 nId = ScAcceptChgDlgWrapper::GetChildWindowId();
2319 SfxViewFrame* pViewFrame = SfxViewFrame::Current();
2320 if ( pViewFrame && pViewFrame->HasChildWindow( nId ) )
2322 pViewFrame->ToggleChildWindow( nId );
2323 SfxBindings* pBindings = GetViewBindings();
2324 if ( pBindings )
2326 pBindings->Invalidate( FID_CHG_ACCEPT );
2330 else
2332 aDocument.EndChangeTracking();
2335 ScChangeViewSettings aChangeViewSet;
2336 aChangeViewSet.SetShowChanges( false );
2337 aDocument.SetChangeViewSettings( aChangeViewSet );
2340 uno::Reference< frame::XModel > ScDocShell::LoadSharedDocument()
2342 uno::Reference< frame::XModel > xModel;
2345 SC_MOD()->SetInSharedDocLoading( true );
2346 uno::Reference< frame::XDesktop2 > xLoader = frame::Desktop::create( ::comphelper::getProcessComponentContext() );
2347 uno::Sequence < beans::PropertyValue > aArgs( 1 );
2348 aArgs[0].Name = OUString( "Hidden" );
2349 aArgs[0].Value <<= sal_True;
2351 if ( GetMedium() )
2353 SFX_ITEMSET_ARG( GetMedium()->GetItemSet(), pPasswordItem, SfxStringItem, SID_PASSWORD, false);
2354 if ( pPasswordItem && !pPasswordItem->GetValue().isEmpty() )
2356 aArgs.realloc( 2 );
2357 aArgs[1].Name = OUString("Password");
2358 aArgs[1].Value <<= pPasswordItem->GetValue();
2362 xModel.set(
2363 xLoader->loadComponentFromURL( GetSharedFileURL(), OUString( "_blank" ), 0, aArgs ),
2364 uno::UNO_QUERY_THROW );
2365 SC_MOD()->SetInSharedDocLoading( false );
2367 catch ( uno::Exception& )
2369 OSL_FAIL( "ScDocShell::LoadSharedDocument(): caught exception\n" );
2370 SC_MOD()->SetInSharedDocLoading( false );
2373 uno::Reference< util::XCloseable > xClose( xModel, uno::UNO_QUERY_THROW );
2374 xClose->close( sal_True );
2375 return uno::Reference< frame::XModel >();
2377 catch ( uno::Exception& )
2379 return uno::Reference< frame::XModel >();
2382 return xModel;
2385 #endif
2387 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */