Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
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/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
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 .
18 : */
19 :
20 :
21 : #include "scitems.hxx"
22 : #include <sfx2/bindings.hxx>
23 : #include <sfx2/viewsh.hxx>
24 : #include <sfx2/dispatch.hxx>
25 : #include <editeng/fontitem.hxx>
26 : #include <editeng/langitem.hxx>
27 : #include <editeng/scripttypeitem.hxx>
28 : #include <svl/itempool.hxx>
29 : #include <svl/itemset.hxx>
30 : #include <svl/cjkoptions.hxx>
31 : #include <svl/ctloptions.hxx>
32 : #include <vcl/svapp.hxx>
33 : #include <vcl/msgbox.hxx>
34 : #include <vcl/wrkwin.hxx>
35 : #include <sfx2/request.hxx>
36 : #include <sfx2/objsh.hxx>
37 : #include <svl/stritem.hxx>
38 : #include <svl/eitem.hxx>
39 :
40 : #include <com/sun/star/i18n/TransliterationModules.hpp>
41 : #include <com/sun/star/i18n/TransliterationModulesExtra.hpp>
42 :
43 :
44 : #include "viewutil.hxx"
45 : #include "global.hxx"
46 : #include "chgtrack.hxx"
47 : #include "chgviset.hxx"
48 : #include "markdata.hxx"
49 :
50 : #include <svx/svxdlg.hxx>
51 : #include <svx/dialogs.hrc>
52 : // STATIC DATA -----------------------------------------------------------
53 :
54 : //==================================================================
55 :
56 0 : void ScViewUtil::PutItemScript( SfxItemSet& rShellSet, const SfxItemSet& rCoreSet,
57 : sal_uInt16 nWhichId, sal_uInt16 nScript )
58 : {
59 : // take the effective item from rCoreSet according to nScript
60 : // and put in rShellSet under the (base) nWhichId
61 :
62 0 : SfxItemPool& rPool = *rShellSet.GetPool();
63 0 : SvxScriptSetItem aSetItem( rPool.GetSlotId(nWhichId), rPool );
64 : // use PutExtended with eDefaultAs = SFX_ITEM_SET, so defaults from rCoreSet
65 : // (document pool) are read and put into rShellSet (MessagePool)
66 0 : aSetItem.GetItemSet().PutExtended( rCoreSet, SFX_ITEM_DONTCARE, SFX_ITEM_SET );
67 0 : const SfxPoolItem* pI = aSetItem.GetItemOfScript( nScript );
68 0 : if (pI)
69 0 : rShellSet.Put( *pI, nWhichId );
70 : else
71 0 : rShellSet.InvalidateItem( nWhichId );
72 0 : }
73 :
74 0 : sal_uInt16 ScViewUtil::GetEffLanguage( ScDocument* pDoc, const ScAddress& rPos )
75 : {
76 : // used for thesaurus
77 :
78 0 : sal_uInt8 nScript = pDoc->GetScriptType( rPos.Col(), rPos.Row(), rPos.Tab() );
79 : sal_uInt16 nWhich = ( nScript == SCRIPTTYPE_ASIAN ) ? ATTR_CJK_FONT_LANGUAGE :
80 0 : ( ( nScript == SCRIPTTYPE_COMPLEX ) ? ATTR_CTL_FONT_LANGUAGE : ATTR_FONT_LANGUAGE );
81 0 : const SfxPoolItem* pItem = pDoc->GetAttr( rPos.Col(), rPos.Row(), rPos.Tab(), nWhich);
82 0 : SvxLanguageItem* pLangIt = PTR_CAST( SvxLanguageItem, pItem );
83 : LanguageType eLnge;
84 0 : if (pLangIt)
85 : {
86 0 : eLnge = (LanguageType) pLangIt->GetValue();
87 0 : if (eLnge == LANGUAGE_DONTKNOW) //! can this happen?
88 : {
89 : LanguageType eLatin, eCjk, eCtl;
90 0 : pDoc->GetLanguage( eLatin, eCjk, eCtl );
91 : eLnge = ( nScript == SCRIPTTYPE_ASIAN ) ? eCjk :
92 0 : ( ( nScript == SCRIPTTYPE_COMPLEX ) ? eCtl : eLatin );
93 : }
94 : }
95 : else
96 0 : eLnge = LANGUAGE_ENGLISH_US;
97 0 : if ( eLnge == LANGUAGE_SYSTEM )
98 0 : eLnge = Application::GetSettings().GetLanguageTag().getLanguageType(); // never use SYSTEM for spelling
99 :
100 0 : return eLnge;
101 : }
102 :
103 0 : sal_Int32 ScViewUtil::GetTransliterationType( sal_uInt16 nSlotID )
104 : {
105 0 : sal_Int32 nType = 0;
106 0 : switch ( nSlotID )
107 : {
108 : case SID_TRANSLITERATE_SENTENCE_CASE:
109 0 : nType = com::sun::star::i18n::TransliterationModulesExtra::SENTENCE_CASE;
110 0 : break;
111 : case SID_TRANSLITERATE_TITLE_CASE:
112 0 : nType = com::sun::star::i18n::TransliterationModulesExtra::TITLE_CASE;
113 0 : break;
114 : case SID_TRANSLITERATE_TOGGLE_CASE:
115 0 : nType = com::sun::star::i18n::TransliterationModulesExtra::TOGGLE_CASE;
116 0 : break;
117 : case SID_TRANSLITERATE_UPPER:
118 0 : nType = com::sun::star::i18n::TransliterationModules_LOWERCASE_UPPERCASE;
119 0 : break;
120 : case SID_TRANSLITERATE_LOWER:
121 0 : nType = com::sun::star::i18n::TransliterationModules_UPPERCASE_LOWERCASE;
122 0 : break;
123 : case SID_TRANSLITERATE_HALFWIDTH:
124 0 : nType = com::sun::star::i18n::TransliterationModules_FULLWIDTH_HALFWIDTH;
125 0 : break;
126 : case SID_TRANSLITERATE_FULLWIDTH:
127 0 : nType = com::sun::star::i18n::TransliterationModules_HALFWIDTH_FULLWIDTH;
128 0 : break;
129 : case SID_TRANSLITERATE_HIRAGANA:
130 0 : nType = com::sun::star::i18n::TransliterationModules_KATAKANA_HIRAGANA;
131 0 : break;
132 : case SID_TRANSLITERATE_KATAGANA:
133 0 : nType = com::sun::star::i18n::TransliterationModules_HIRAGANA_KATAKANA;
134 0 : break;
135 : }
136 0 : return nType;
137 : }
138 :
139 0 : sal_Bool ScViewUtil::IsActionShown( const ScChangeAction& rAction,
140 : const ScChangeViewSettings& rSettings,
141 : ScDocument& rDocument )
142 : {
143 : // abgelehnte werden durch eine invertierende akzeptierte Action dargestellt,
144 : // die Reihenfolge von ShowRejected/ShowAccepted ist deswegen wichtig
145 :
146 0 : if ( !rSettings.IsShowRejected() && rAction.IsRejecting() )
147 0 : return false;
148 :
149 0 : if ( !rSettings.IsShowAccepted() && rAction.IsAccepted() && !rAction.IsRejecting() )
150 0 : return false;
151 :
152 0 : if ( rSettings.HasAuthor() )
153 : {
154 0 : if ( rSettings.IsEveryoneButMe() )
155 : {
156 : // GetUser() am ChangeTrack ist der aktuelle Benutzer
157 0 : ScChangeTrack* pTrack = rDocument.GetChangeTrack();
158 0 : if ( !pTrack || rAction.GetUser().equals(pTrack->GetUser()) )
159 0 : return false;
160 : }
161 0 : else if ( !rAction.GetUser().equals(rSettings.GetTheAuthorToShow()) )
162 0 : return false;
163 : }
164 :
165 0 : if ( rSettings.HasComment() )
166 : {
167 0 : rtl::OUStringBuffer aBuf(rAction.GetComment());
168 0 : aBuf.appendAscii(RTL_CONSTASCII_STRINGPARAM(" ("));
169 0 : rtl::OUString aTmp;
170 0 : rAction.GetDescription(aTmp, &rDocument);
171 0 : aBuf.append(aTmp);
172 0 : aBuf.append(sal_Unicode(')'));
173 0 : rtl::OUString aComStr = aBuf.makeStringAndClear();
174 :
175 0 : if(!rSettings.IsValidComment(&aComStr))
176 0 : return false;
177 : }
178 :
179 0 : if ( rSettings.HasRange() )
180 0 : if ( !rSettings.GetTheRangeList().Intersects( rAction.GetBigRange().MakeRange() ) )
181 0 : return false;
182 :
183 0 : if ( rSettings.HasDate() && rSettings.GetTheDateMode() != SCDM_NO_DATEMODE )
184 : {
185 0 : DateTime aDateTime = rAction.GetDateTime();
186 0 : const DateTime& rFirst = rSettings.GetTheFirstDateTime();
187 0 : const DateTime& rLast = rSettings.GetTheLastDateTime();
188 0 : switch ( rSettings.GetTheDateMode() )
189 : { // korrespondiert mit ScHighlightChgDlg::OKBtnHdl
190 : case SCDM_DATE_BEFORE:
191 0 : if ( aDateTime > rFirst )
192 0 : return false;
193 0 : break;
194 :
195 : case SCDM_DATE_SINCE:
196 0 : if ( aDateTime < rFirst )
197 0 : return false;
198 0 : break;
199 :
200 : case SCDM_DATE_EQUAL:
201 : case SCDM_DATE_BETWEEN:
202 0 : if ( aDateTime < rFirst || aDateTime > rLast )
203 0 : return false;
204 0 : break;
205 :
206 : case SCDM_DATE_NOTEQUAL:
207 0 : if ( aDateTime >= rFirst && aDateTime <= rLast )
208 0 : return false;
209 0 : break;
210 :
211 : case SCDM_DATE_SAVE:
212 : {
213 0 : ScChangeTrack* pTrack = rDocument.GetChangeTrack();
214 0 : if ( !pTrack || pTrack->GetLastSavedActionNumber() >=
215 0 : rAction.GetActionNumber() )
216 0 : return false;
217 : }
218 0 : break;
219 :
220 : default:
221 : {
222 : // added to avoid warnings
223 : }
224 : }
225 : }
226 :
227 0 : if ( rSettings.HasActionRange() )
228 : {
229 0 : sal_uLong nAction = rAction.GetActionNumber();
230 : sal_uLong nFirstAction;
231 : sal_uLong nLastAction;
232 0 : rSettings.GetTheActionRange( nFirstAction, nLastAction );
233 0 : if ( nAction < nFirstAction || nAction > nLastAction )
234 : {
235 0 : return false;
236 : }
237 : }
238 :
239 0 : return sal_True;
240 : }
241 :
242 0 : void ScViewUtil::UnmarkFiltered( ScMarkData& rMark, ScDocument* pDoc )
243 : {
244 0 : rMark.MarkToMulti();
245 :
246 0 : ScRange aMultiArea;
247 0 : rMark.GetMultiMarkArea( aMultiArea );
248 0 : SCCOL nStartCol = aMultiArea.aStart.Col();
249 0 : SCROW nStartRow = aMultiArea.aStart.Row();
250 0 : SCCOL nEndCol = aMultiArea.aEnd.Col();
251 0 : SCROW nEndRow = aMultiArea.aEnd.Row();
252 :
253 0 : bool bChanged = false;
254 0 : ScMarkData::iterator itr = rMark.begin(), itrEnd = rMark.end();
255 0 : for (; itr != itrEnd; ++itr)
256 : {
257 0 : SCTAB nTab = *itr;
258 0 : for (SCROW nRow = nStartRow; nRow <= nEndRow; ++nRow)
259 : {
260 0 : SCROW nLastRow = nRow;
261 0 : if (pDoc->RowFiltered(nRow, nTab, NULL, &nLastRow))
262 : {
263 : // use nStartCol/nEndCol, so the multi mark area isn't extended to all columns
264 : // (visible in repaint for indentation)
265 : rMark.SetMultiMarkArea(
266 0 : ScRange(nStartCol, nRow, nTab, nEndCol, nLastRow, nTab), false);
267 0 : bChanged = true;
268 0 : nRow = nLastRow;
269 : }
270 : }
271 : }
272 :
273 0 : if ( bChanged && !rMark.HasAnyMultiMarks() )
274 0 : rMark.ResetMark();
275 :
276 0 : rMark.MarkToSimple();
277 0 : }
278 :
279 :
280 0 : bool ScViewUtil::FitToUnfilteredRows( ScRange & rRange, ScDocument * pDoc, size_t nRows )
281 : {
282 0 : SCTAB nTab = rRange.aStart.Tab();
283 0 : bool bOneTabOnly = (nTab == rRange.aEnd.Tab());
284 : // Always fit the range on its first sheet.
285 : OSL_ENSURE( bOneTabOnly, "ScViewUtil::ExtendToUnfilteredRows: works only on one sheet");
286 0 : SCROW nStartRow = rRange.aStart.Row();
287 0 : SCROW nLastRow = pDoc->LastNonFilteredRow(nStartRow, MAXROW, nTab);
288 0 : if (ValidRow(nLastRow))
289 0 : rRange.aEnd.SetRow(nLastRow);
290 0 : SCROW nCount = pDoc->CountNonFilteredRows(nStartRow, MAXROW, nTab);
291 0 : return static_cast<size_t>(nCount) == nRows && bOneTabOnly;
292 : }
293 :
294 0 : bool ScViewUtil::HasFiltered( const ScRange& rRange, ScDocument* pDoc )
295 : {
296 0 : SCROW nStartRow = rRange.aStart.Row();
297 0 : SCROW nEndRow = rRange.aEnd.Row();
298 0 : for (SCTAB nTab=rRange.aStart.Tab(); nTab<=rRange.aEnd.Tab(); nTab++)
299 : {
300 0 : if (pDoc->HasFilteredRows(nStartRow, nEndRow, nTab))
301 0 : return true;
302 : }
303 :
304 0 : return false;
305 : }
306 :
307 0 : void ScViewUtil::HideDisabledSlot( SfxItemSet& rSet, SfxBindings& rBindings, sal_uInt16 nSlotId )
308 : {
309 0 : SvtCJKOptions aCJKOptions;
310 0 : SvtCTLOptions aCTLOptions;
311 0 : bool bEnabled = true;
312 :
313 0 : switch( nSlotId )
314 : {
315 : case SID_CHINESE_CONVERSION:
316 : case SID_HANGUL_HANJA_CONVERSION:
317 0 : bEnabled = aCJKOptions.IsAnyEnabled();
318 0 : break;
319 :
320 : case SID_TRANSLITERATE_HALFWIDTH:
321 : case SID_TRANSLITERATE_FULLWIDTH:
322 : case SID_TRANSLITERATE_HIRAGANA:
323 : case SID_TRANSLITERATE_KATAGANA:
324 0 : bEnabled = aCJKOptions.IsChangeCaseMapEnabled();
325 0 : break;
326 :
327 : case SID_INSERT_RLM:
328 : case SID_INSERT_LRM:
329 : case SID_INSERT_ZWNBSP:
330 : case SID_INSERT_ZWSP:
331 0 : bEnabled = aCTLOptions.IsCTLFontEnabled();
332 0 : break;
333 :
334 : default:
335 : OSL_FAIL( "ScViewUtil::HideDisabledSlot - unknown slot ID" );
336 0 : return;
337 : }
338 :
339 0 : rBindings.SetVisibleState( nSlotId, bEnabled );
340 0 : if( !bEnabled )
341 0 : rSet.DisableItem( nSlotId );
342 : }
343 :
344 : //==================================================================
345 :
346 0 : sal_Bool ScViewUtil::ExecuteCharMap( const SvxFontItem& rOldFont,
347 : SfxViewFrame& rFrame,
348 : SvxFontItem& rNewFont,
349 : String& rString )
350 : {
351 0 : sal_Bool bRet = false;
352 0 : SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
353 0 : if(pFact)
354 : {
355 0 : SfxAllItemSet aSet( rFrame.GetObjectShell()->GetPool() );
356 0 : aSet.Put( SfxBoolItem( FN_PARAM_1, false ) );
357 0 : aSet.Put( SvxFontItem( rOldFont.GetFamily(), rOldFont.GetFamilyName(), rOldFont.GetStyleName(), rOldFont.GetPitch(), rOldFont.GetCharSet(), aSet.GetPool()->GetWhich( SID_ATTR_CHAR_FONT ) ) );
358 0 : SfxAbstractDialog* pDlg = pFact->CreateSfxDialog( &rFrame.GetWindow(), aSet, rFrame.GetFrame().GetFrameInterface(), RID_SVXDLG_CHARMAP );
359 0 : if ( pDlg->Execute() == RET_OK )
360 : {
361 0 : SFX_ITEMSET_ARG( pDlg->GetOutputItemSet(), pItem, SfxStringItem, SID_CHARMAP, false );
362 0 : SFX_ITEMSET_ARG( pDlg->GetOutputItemSet(), pFontItem, SvxFontItem, SID_ATTR_CHAR_FONT, false );
363 0 : if ( pItem )
364 0 : rString = pItem->GetValue();
365 0 : if ( pFontItem )
366 0 : rNewFont = SvxFontItem( pFontItem->GetFamily(), pFontItem->GetFamilyName(), pFontItem->GetStyleName(), pFontItem->GetPitch(), pFontItem->GetCharSet(), rNewFont.Which() );
367 0 : bRet = sal_True;
368 : }
369 0 : delete pDlg;
370 : }
371 0 : return bRet;
372 : }
373 :
374 0 : bool ScViewUtil::IsFullScreen( SfxViewShell& rViewShell )
375 : {
376 0 : SfxBindings& rBindings = rViewShell.GetViewFrame()->GetBindings();
377 0 : SfxPoolItem* pItem = 0;
378 0 : bool bIsFullScreen = false;
379 :
380 0 : if (rBindings.QueryState( SID_WIN_FULLSCREEN, pItem ) >= SFX_ITEM_DEFAULT)
381 0 : bIsFullScreen = static_cast< SfxBoolItem* >( pItem )->GetValue();
382 0 : return bIsFullScreen;
383 : }
384 :
385 0 : void ScViewUtil::SetFullScreen( SfxViewShell& rViewShell, bool bSet )
386 : {
387 0 : if( IsFullScreen( rViewShell ) != bSet )
388 : {
389 0 : SfxBoolItem aItem( SID_WIN_FULLSCREEN, bSet );
390 0 : rViewShell.GetDispatcher()->Execute( SID_WIN_FULLSCREEN, SFX_CALLMODE_RECORD, &aItem, 0L );
391 : }
392 0 : }
393 :
394 : //------------------------------------------------------------------
395 :
396 0 : ScUpdateRect::ScUpdateRect( SCCOL nX1, SCROW nY1, SCCOL nX2, SCROW nY2 )
397 : {
398 0 : PutInOrder( nX1, nX2 );
399 0 : PutInOrder( nY1, nY2 );
400 :
401 0 : nOldStartX = nX1;
402 0 : nOldStartY = nY1;
403 0 : nOldEndX = nX2;
404 0 : nOldEndY = nY2;
405 0 : }
406 :
407 0 : void ScUpdateRect::SetNew( SCCOL nX1, SCROW nY1, SCCOL nX2, SCROW nY2 )
408 : {
409 0 : PutInOrder( nX1, nX2 );
410 0 : PutInOrder( nY1, nY2 );
411 :
412 0 : nNewStartX = nX1;
413 0 : nNewStartY = nY1;
414 0 : nNewEndX = nX2;
415 0 : nNewEndY = nY2;
416 0 : }
417 :
418 0 : sal_Bool ScUpdateRect::GetDiff( SCCOL& rX1, SCROW& rY1, SCCOL& rX2, SCROW& rY2 )
419 : {
420 0 : if ( nNewStartX == nOldStartX && nNewEndX == nOldEndX &&
421 : nNewStartY == nOldStartY && nNewEndY == nOldEndY )
422 : {
423 0 : rX1 = nNewStartX;
424 0 : rY1 = nNewStartY;
425 0 : rX2 = nNewStartX;
426 0 : rY2 = nNewStartY;
427 0 : return false;
428 : }
429 :
430 0 : rX1 = Min(nNewStartX,nOldStartX);
431 0 : rY1 = Min(nNewStartY,nOldStartY);
432 0 : rX2 = Max(nNewEndX,nOldEndX);
433 0 : rY2 = Max(nNewEndY,nOldEndY);
434 :
435 0 : if ( nNewStartX == nOldStartX && nNewEndX == nOldEndX )
436 : {
437 0 : if ( nNewStartY == nOldStartY )
438 : {
439 0 : rY1 = Min( nNewEndY, nOldEndY );
440 0 : rY2 = Max( nNewEndY, nOldEndY );
441 : }
442 0 : else if ( nNewEndY == nOldEndY )
443 : {
444 0 : rY1 = Min( nNewStartY, nOldStartY );
445 0 : rY2 = Max( nNewStartY, nOldStartY );
446 : }
447 : }
448 0 : else if ( nNewStartY == nOldStartY && nNewEndY == nOldEndY )
449 : {
450 0 : if ( nNewStartX == nOldStartX )
451 : {
452 0 : rX1 = Min( nNewEndX, nOldEndX );
453 0 : rX2 = Max( nNewEndX, nOldEndX );
454 : }
455 0 : else if ( nNewEndX == nOldEndX )
456 : {
457 0 : rX1 = Min( nNewStartX, nOldStartX );
458 0 : rX2 = Max( nNewStartX, nOldStartX );
459 : }
460 : }
461 :
462 0 : return sal_True;
463 15 : }
464 :
465 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|