summaryrefslogtreecommitdiff
path: root/sw/source/uibase/inc/mmconfigitem.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'sw/source/uibase/inc/mmconfigitem.hxx')
-rw-r--r--sw/source/uibase/inc/mmconfigitem.hxx270
1 files changed, 270 insertions, 0 deletions
diff --git a/sw/source/uibase/inc/mmconfigitem.hxx b/sw/source/uibase/inc/mmconfigitem.hxx
new file mode 100644
index 000000000000..b40e189b1c11
--- /dev/null
+++ b/sw/source/uibase/inc/mmconfigitem.hxx
@@ -0,0 +1,270 @@
+/* -*- 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_MMCONFIGITEM_HXX
+#define INCLUDED_SW_SOURCE_CORE_UIBASE_INC_MMCONFIGITEM_HXX
+
+#include <com/sun/star/uno/Sequence.hxx>
+#include <com/sun/star/uno/Reference.hxx>
+#include <tools/resary.hxx>
+#include <swdbdata.hxx>
+#include "swdllapi.h"
+#include "sharedconnection.hxx"
+
+namespace com{namespace sun{namespace star{
+ namespace sdbc{
+ class XDataSource;
+ class XResultSet;
+ }
+ namespace sdbcx{
+ class XColumnsSupplier;
+ }
+}}}
+
+class SwMailMergeConfigItem_Impl;
+class SwView;
+
+struct SwDocMergeInfo
+{
+ long nStartPageInTarget;
+ long nEndPageInTarget;
+ long nDBRow;
+};
+
+class SW_DLLPUBLIC SwMailMergeConfigItem
+{
+// com::sun::star::uno::Sequence< OUString> m_aSavedDocuments;
+ SwMailMergeConfigItem_Impl* m_pImpl;
+ //session information - not stored in configuration
+ bool m_bAddressInserted;
+ bool m_bMergeDone;
+ bool m_bGreetingInserted;
+ sal_Int32 m_nGreetingMoves;
+ OUString m_rAddressBlockFrame;
+ ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any> m_aSelection;
+
+ sal_uInt16 m_nStartPrint;
+ sal_uInt16 m_nEndPrint;
+
+ OUString m_sSelectedPrinter;
+
+ SwView* m_pSourceView;
+ SwView* m_pTargetView;
+public:
+ SwMailMergeConfigItem();
+ ~SwMailMergeConfigItem();
+
+ enum Gender
+ {
+ FEMALE,
+ MALE,
+ NEUTRAL
+ };
+
+ void Commit();
+
+ const ResStringArray& GetDefaultAddressHeaders() const;
+
+ void SetCurrentConnection(
+ ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDataSource> xSource,
+ SharedConnection xConnection,
+ ::com::sun::star::uno::Reference< ::com::sun::star::sdbcx::XColumnsSupplier> xColumnsSupplier,
+ const SwDBData& rDBData);
+
+ ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDataSource>
+ GetSource();
+
+ SharedConnection GetConnection();
+
+ ::com::sun::star::uno::Reference< ::com::sun::star::sdbcx::XColumnsSupplier>
+ GetColumnsSupplier();
+
+ ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XResultSet>
+ GetResultSet() const;
+
+ void DisposeResultSet();
+
+ OUString& GetFilter() const;
+ void SetFilter(OUString&);
+
+ ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any>
+ GetSelection()const;
+ void SetSelection(const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Any >& rSelection);
+
+ void SetCurrentDBData( const SwDBData& rDBData);
+ const SwDBData& GetCurrentDBData() const;
+
+ // move absolute, nTarget == -1 -> goto last record
+ sal_Int32 MoveResultSet(sal_Int32 nTarget);
+ sal_Int32 GetResultSetPosition()const;
+ bool IsResultSetFirstLast(bool& bIsFirst, bool& bIsLast);
+
+ bool IsRecordExcluded(sal_Int32 nRecord);
+ void ExcludeRecord(sal_Int32 nRecord, bool bExclude);
+
+ const com::sun::star::uno::Sequence< OUString>&
+ GetSavedDocuments() const;
+ void AddSavedDocument(const OUString& rName);
+
+ bool IsOutputToLetter()const;
+ void SetOutputToLetter(bool bSet);
+
+ bool IsAddressBlock()const;
+ void SetAddressBlock(bool bSet);
+
+ bool IsHideEmptyParagraphs() const;
+ void SetHideEmptyParagraphs(bool bSet);
+
+ const com::sun::star::uno::Sequence< OUString>
+ GetAddressBlocks() const;
+ void SetAddressBlocks(const com::sun::star::uno::Sequence< OUString>& rBlocks);
+
+ void SetCurrentAddressBlockIndex( sal_Int32 nSet );
+ sal_Int32 GetCurrentAddressBlockIndex() const;
+
+ bool IsIncludeCountry() const;
+ OUString& GetExcludeCountry() const;
+ void SetCountrySettings(bool bSet, const OUString& sCountry);
+
+ bool IsIndividualGreeting(bool bInEMail) const;
+ void SetIndividualGreeting(bool bSet, bool bInEMail);
+
+ bool IsGreetingLine(bool bInEMail) const;
+ void SetGreetingLine(bool bSet, bool bInEMail);
+
+ const com::sun::star::uno::Sequence< OUString>
+ GetGreetings(Gender eType) const;
+ void SetGreetings(Gender eType, const com::sun::star::uno::Sequence< OUString>& rBlocks);
+
+ sal_Int32 GetCurrentGreeting(Gender eType) const;
+ void SetCurrentGreeting(Gender eType, sal_Int32 nIndex);
+
+ //the content of the gender column that marks it as female
+ const OUString& GetFemaleGenderValue() const;
+ void SetFemaleGenderValue(const OUString& rValue);
+
+ //returns the assignment in the order of the default headers (GetDefaultAddressHeaders())
+ com::sun::star::uno::Sequence< OUString >
+ GetColumnAssignment( const SwDBData& rDBData ) const;
+ void SetColumnAssignment(
+ const SwDBData& rDBData,
+ const com::sun::star::uno::Sequence< OUString>& );
+
+ bool IsAddressFieldsAssigned() const;
+ bool IsGreetingFieldsAssigned() const;
+
+ //e-Mail settings:
+ OUString GetMailDisplayName() const;
+ void SetMailDisplayName(const OUString& rName);
+
+ OUString GetMailAddress() const;
+ void SetMailAddress(const OUString& rAddress);
+
+ bool IsMailReplyTo() const;
+ void SetMailReplyTo(bool bSet);
+
+ OUString GetMailReplyTo() const;
+ void SetMailReplyTo(const OUString& rReplyTo);
+
+ OUString GetMailServer() const;
+ void SetMailServer(const OUString& rAddress);
+
+ sal_Int16 GetMailPort() const;
+ void SetMailPort(sal_Int16 nSet);
+
+ bool IsSecureConnection() const;
+ void SetSecureConnection(bool bSet);
+
+ bool IsAuthentication() const;
+ void SetAuthentication(bool bSet);
+
+ OUString GetMailUserName() const;
+ void SetMailUserName(const OUString& rName);
+
+ OUString GetMailPassword() const;
+ void SetMailPassword(const OUString& rPassword);
+
+ bool IsSMTPAfterPOP() const;
+ void SetSMTPAfterPOP(bool bSet);
+
+ OUString GetInServerName() const;
+ void SetInServerName(const OUString& rServer);
+
+ sal_Int16 GetInServerPort() const;
+ void SetInServerPort(sal_Int16 nSet);
+
+ bool IsInServerPOP() const;
+ void SetInServerPOP(bool bSet);
+
+ OUString GetInServerUserName() const;
+ void SetInServerUserName(const OUString& rName);
+
+ OUString GetInServerPassword() const;
+ void SetInServerPassword(const OUString& rPassword);
+
+ //session information
+ bool IsAddressInserted() const { return m_bAddressInserted; }
+ void SetAddressInserted(const OUString& rFrameName)
+ { m_bAddressInserted = true;
+ m_rAddressBlockFrame = rFrameName;
+ }
+
+ bool IsGreetingInserted() const { return m_bGreetingInserted; }
+ void SetGreetingInserted()
+ { m_bGreetingInserted = true; }
+
+ // counts the moves in the layout page
+ void MoveGreeting( sal_Int32 nMove) { m_nGreetingMoves += nMove;}
+ sal_Int32 GetGreetingMoves() const { return m_nGreetingMoves;}
+
+ bool IsMergeDone() const { return m_bMergeDone;}
+ void SetMergeDone( ) { m_bMergeDone = true; }
+
+ // new source document - reset some flags
+ void DocumentReloaded();
+
+ bool IsMailAvailable() const;
+
+ // notify a completed merge, provid the appropriate e-Mail address if available
+ void AddMergedDocument(SwDocMergeInfo& rInfo);
+ //returns the page and database cursor information of each merged document
+ SwDocMergeInfo& GetDocumentMergeInfo(sal_uInt32 nDocument);
+ sal_uInt32 GetMergedDocumentCount() const;
+
+ void SetPrintRange( sal_uInt16 nStartDocument, sal_uInt16 nEndDocument)
+ {m_nStartPrint = nStartDocument; m_nEndPrint = nEndDocument;}
+ sal_uInt16 GetPrintRangeStart() const {return m_nStartPrint;}
+ sal_uInt16 GetPrintRangeEnd() const {return m_nEndPrint;}
+
+ const OUString& GetSelectedPrinter() const {return m_sSelectedPrinter;}
+ void SetSelectedPrinter(const OUString& rSet )
+ {m_sSelectedPrinter = rSet;}
+
+ SwView* GetTargetView();
+ void SetTargetView(SwView* pView);
+
+ SwView* GetSourceView();
+ void SetSourceView(SwView* pView);
+
+ //helper methods
+ OUString GetAssignedColumn(sal_uInt32 nColumn)const;
+};
+
+#endif
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */