diff options
author | Michael Stahl <mstahl@redhat.com> | 2014-05-26 17:43:14 +0200 |
---|---|---|
committer | Michael Stahl <mstahl@redhat.com> | 2014-05-27 11:13:02 +0200 |
commit | 35029b250318b3a4f02cef5194abdd3f68311c43 (patch) | |
tree | 5026ab2dab620dcdcae84e574483ce3c325e5a78 /sw/source/uibase/inc/mailmergewizard.hxx | |
parent | f8d26c68e48e52265d4f20a1527bf52828c046ad (diff) |
sw: move sw/source/core/uibase to sw/source/uibase
It's too confusing to have UI code inside of core; the important part is
that it's separated from the optional UI code in swui library.
Change-Id: I640a52723d5802faf08f3b8eaa03cd937fd93449
Diffstat (limited to 'sw/source/uibase/inc/mailmergewizard.hxx')
-rw-r--r-- | sw/source/uibase/inc/mailmergewizard.hxx | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/sw/source/uibase/inc/mailmergewizard.hxx b/sw/source/uibase/inc/mailmergewizard.hxx new file mode 100644 index 000000000000..8154aac7964e --- /dev/null +++ b/sw/source/uibase/inc/mailmergewizard.hxx @@ -0,0 +1,97 @@ +/* -*- 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 . + */ +#ifndef INCLUDED_SW_SOURCE_CORE_UIBASE_INC_MAILMERGEWIZARD_HXX +#define INCLUDED_SW_SOURCE_CORE_UIBASE_INC_MAILMERGEWIZARD_HXX + +#include <svtools/roadmapwizard.hxx> +#include <rtl/ustring.hxx> + +class SwView; +class SwMailMergeConfigItem; + +#define MM_DOCUMENTSELECTPAGE 0 +#define MM_OUTPUTTYPETPAGE 1 +#define MM_ADDRESSBLOCKPAGE 2 +#define MM_GREETINGSPAGE 3 +#define MM_LAYOUTPAGE 4 +#define MM_PREPAREMERGEPAGE 5 +#define MM_MERGEPAGE 6 +#define MM_OUTPUTPAGE 7 + +class SwMailMergeWizard : public ::svt::RoadmapWizard +{ + SwView* m_pSwView; + OUString sDocumentURL; + bool m_bDocumentLoad; + + SwMailMergeConfigItem& m_rConfigItem; + + OUString m_sStarting; + OUString m_sDocumentType; + OUString m_sAddressBlock; + OUString m_sAddressList; + OUString m_sGreetingsLine; + OUString m_sLayout; + OUString m_sPrepareMerge; + OUString m_sMerge; + OUString m_sOutput; + OUString m_sFinish; + + sal_uInt16 m_nRestartPage; + + using svt::OWizardMachine::skipUntil; + +protected: + virtual svt::OWizardPage* createPage(WizardState _nState) SAL_OVERRIDE; + virtual void enterState( WizardState _nState ) SAL_OVERRIDE; + +// roadmap feature ?? +// virtual sal_Bool prepareLeaveCurrentState( CommitPageReason _eReason ); + virtual OUString getStateDisplayName( WizardState _nState ) const SAL_OVERRIDE; + +public: + SwMailMergeWizard(SwView& rView, SwMailMergeConfigItem& rConfigItem); + virtual ~SwMailMergeWizard(); + + SwView* GetSwView() {return m_pSwView;} + SwMailMergeConfigItem& GetConfigItem() { return m_rConfigItem;} + + void SetReloadDocument(const OUString& rURL) {sDocumentURL = rURL;} + OUString GetReloadDocument() const {return sDocumentURL;} + + //next step requires loading of document + void SetDocumentLoad(bool bSet) {m_bDocumentLoad = bSet;} + + void UpdateRoadmap(); + void CreateTargetDocument(); + + sal_uInt16 GetRestartPage() const {return m_nRestartPage;} + void SetRestartPage(sal_uInt16 nPage) { m_nRestartPage = nPage;} + + bool skipUntil( sal_uInt16 nPage) + {return ::svt::RoadmapWizard::skipUntil(WizardState(nPage));} + + void updateRoadmapItemLabel( WizardState _nState ); + + virtual short Execute() SAL_OVERRIDE; + virtual void StartExecuteModal( const Link& rEndDialogHdl ) SAL_OVERRIDE; +}; +#endif + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |