/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * 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 . */ #include #include #include #include #include #include #include #include "dialog.hrc" // class SfxStyleDialog -------------------------------------------------- SfxStyleDialog::SfxStyleDialog ( vcl::Window* pParent, // Parent const OUString& rID, const OUString& rUIXMLDescription, SfxStyleSheetBase& rStyle // stylesheet to be processed ) /* [Description] Constructor: Add Manage TabPage, set ExampleSet from style. */ : SfxTabDialog(pParent, rID, rUIXMLDescription, rStyle.GetItemSet().Clone(), true) , pStyle( &rStyle ) { // without ParentSupport suppress the standardButton if (!rStyle.HasParentSupport()) RemoveStandardButton(); m_nOrganizerId = AddTabPage("organizer", SfxManageStyleSheetPage::Create, 0); // With new template always set the management page as the current page if( rStyle.GetName().isEmpty() ) SetCurPageId(m_nOrganizerId); else { OUString sTxt = OUString(GetText()) + ": " + rStyle.GetName(); SetText( sTxt ); } delete pExampleSet; // in SfxTabDialog::Ctor() already created pExampleSet = &pStyle->GetItemSet(); GetCancelButton().SetClickHdl( LINK(this, SfxStyleDialog, CancelHdl) ); } SfxStyleDialog::~SfxStyleDialog() { disposeOnce(); } /* [Description] Destructor: set ExampleSet to NULL, so that SfxTabDialog does not delete the Set from Style. */ void SfxStyleDialog::dispose() { pExampleSet = 0; pStyle = 0; SfxTabDialog::dispose(); } void SfxStyleDialog::RefreshInputSet() /* [Description] This is called when returns . */ { SfxTabDialog::RefreshInputSet(); } short SfxStyleDialog::Ok() /* [Description] Override so that always RET_OK is returned. */ { SfxTabDialog::Ok(); return RET_OK; } IMPL_LINK_NOARG_TYPED( SfxStyleDialog, CancelHdl, Button *, void ) /* [Description] If the dialogue was canceled, then all selected attributes must be reset again. */ { SfxTabPage* pPage = GetTabPage(m_nOrganizerId); const SfxItemSet* pInSet = GetInputSetImpl(); SfxWhichIter aIter( *pInSet ); sal_uInt16 nWhich = aIter.FirstWhich(); while ( nWhich ) { SfxItemState eState = pInSet->GetItemState( nWhich, false ); if ( SfxItemState::DEFAULT == eState ) pExampleSet->ClearItem( nWhich ); else pExampleSet->Put( pInSet->Get( nWhich ) ); nWhich = aIter.NextWhich(); } if ( pPage ) pPage->Reset( GetInputSetImpl() ); EndDialog(); } OUString SfxStyleDialog::GenerateUnusedName(SfxStyleSheetBasePool &rPool) { OUString aNoName(SfxResId(STR_NONAME).toString()); sal_uInt16 nNo = 1; OUString aNo(aNoName); aNoName += OUString::number(nNo); while (rPool.Find(aNoName)) { ++nNo; aNoName = aNo; aNoName += OUString::number(nNo); } return aNoName; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */