/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sfx2.hxx" // include --------------------------------------------------------------- #include #include #ifndef _MSGBOX_HXX //autogen #include #endif #ifndef GCC #endif #include #include #include "sfx2/sfxresid.hxx" #include #include "dialog.hrc" // class SfxStyleDialog -------------------------------------------------- SfxStyleDialog::SfxStyleDialog ( Window* pParent, // Parent const ResId& rResId, // ResId SfxStyleSheetBase& rStyle, // zu bearbeitendes StyleSheet sal_Bool bFreeRes, // Flag Resourcen freigeben const String* pUserBtnTxt ) : /* [Beschreibung] Konstruktor: Verwalten-TabPage zuf"ugen, ExampleSet vom Style setzen. */ SfxTabDialog( pParent, rResId, rStyle.GetItemSet().Clone(), // auch ohne ParentSupport TRUE "ubergeben, aber erweitert // um den StandardButton zu unterdr"ucken rStyle.HasParentSupport() ? sal_True : 2, pUserBtnTxt ), pStyle( &rStyle ) { AddTabPage( ID_TABPAGE_MANAGESTYLES, String( SfxResId( STR_TABPAGE_MANAGESTYLES ) ), SfxManageStyleSheetPage::Create, 0, sal_False, 0 ); // bei neuer Vorlage immer die Verwaltungsseite als aktuelle // Seite setzen if( !rStyle.GetName().Len() ) SetCurPageId( ID_TABPAGE_MANAGESTYLES ); else { String sTxt( GetText() ); sTxt += DEFINE_CONST_UNICODE(": ") ; sTxt += rStyle.GetName(); SetText( sTxt ); } delete pExampleSet; // im SfxTabDialog::Ctor() schon angelegt pExampleSet = &pStyle->GetItemSet(); if ( bFreeRes ) FreeResource(); GetCancelButton().SetClickHdl( LINK(this, SfxStyleDialog, CancelHdl) ); } // ----------------------------------------------------------------------- SfxStyleDialog::~SfxStyleDialog() /* [Beschreibung] Destruktor: ExampleSet auf NULL setzen, damit der SfxTabDialog nicht den Set vom Style l"oscht. */ { pExampleSet = 0; pStyle = 0; delete GetInputSetImpl(); } // ----------------------------------------------------------------------- const SfxItemSet* SfxStyleDialog::GetRefreshedSet() /* [Beschreibung] Diese wird gerufen, wenn liefert. */ { return GetInputSetImpl(); } // ----------------------------------------------------------------------- short SfxStyleDialog::Ok() /* [Beschreibung] "Uberladen, damit immer RET_OK zur"uckgegeben wird. */ { SfxTabDialog::Ok(); return RET_OK; } // ----------------------------------------------------------------------- IMPL_LINK( SfxStyleDialog, CancelHdl, Button *, pButton ) /* [Beschreibung] Wenn der Dialog abgebrochen wurde, m"ussen alle schon eingestellten Attribute wieder zur"uckgesetzt werden. */ { (void)pButton; //unused SfxTabPage* pPage = GetTabPage( ID_TABPAGE_MANAGESTYLES ); const SfxItemSet* pInSet = GetInputSetImpl(); SfxWhichIter aIter( *pInSet ); sal_uInt16 nWhich = aIter.FirstWhich(); while ( nWhich ) { SfxItemState eState = pInSet->GetItemState( nWhich, sal_False ); if ( SFX_ITEM_DEFAULT == eState ) pExampleSet->ClearItem( nWhich ); else pExampleSet->Put( pInSet->Get( nWhich ) ); nWhich = aIter.NextWhich(); } if ( pPage ) pPage->Reset( *GetInputSetImpl() ); EndDialog( RET_CANCEL ); return 0; }