summaryrefslogtreecommitdiffstats
path: root/sw/inc/authfld.hxx
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
commit267c6f2ac71f92999e969232431ba04678e7437e (patch)
tree358c9467650e1d0a1d7227a21dac2e3d08b622b2 /sw/inc/authfld.hxx
parentInitial commit. (diff)
downloadlibreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz
libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'sw/inc/authfld.hxx')
-rw-r--r--sw/inc/authfld.hxx245
1 files changed, 245 insertions, 0 deletions
diff --git a/sw/inc/authfld.hxx b/sw/inc/authfld.hxx
new file mode 100644
index 0000000000..6996f5090b
--- /dev/null
+++ b/sw/inc/authfld.hxx
@@ -0,0 +1,245 @@
+/* -*- 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_INC_AUTHFLD_HXX
+#define INCLUDED_SW_INC_AUTHFLD_HXX
+
+#include <sal/config.h>
+
+#include "swdllapi.h"
+#include "fldbas.hxx"
+#include "toxe.hxx"
+#include <rtl/ref.hxx>
+#include <sal/log.hxx>
+#include <salhelper/simplereferenceobject.hxx>
+
+#include <memory>
+#include <vector>
+
+class SwTOXInternational;
+class SwTextAttr;
+class SwForm;
+
+class SwAuthEntry final : public salhelper::SimpleReferenceObject
+{
+friend class SwAuthorityFieldType;
+ OUString m_aAuthFields[AUTH_FIELD_END];
+public:
+ SwAuthEntry() = default;
+ SwAuthEntry( const SwAuthEntry& rCopy );
+ bool operator==(const SwAuthEntry& rComp) const;
+
+ inline OUString const & GetAuthorField(ToxAuthorityField ePos) const;
+ inline void SetAuthorField(ToxAuthorityField ePos,
+ const OUString& rField);
+ void dumpAsXml(xmlTextWriterPtr pWriter) const;
+};
+
+struct SwTOXSortKey
+{
+ ToxAuthorityField eField;
+ bool bSortAscending;
+ SwTOXSortKey() :
+ eField(AUTH_FIELD_END),
+ bSortAscending(true){}
+};
+
+typedef std::vector<SwTOXSortKey> SortKeyArr;
+typedef std::vector<rtl::Reference<SwAuthEntry>> SwAuthDataArr;
+
+class SW_DLLPUBLIC SwAuthorityFieldType final : public SwFieldType
+{
+ SwDoc* m_pDoc;
+ SwAuthDataArr m_DataArr;
+ std::vector<SwAuthEntry*> m_SequArr;
+ std::vector<SwAuthEntry*> m_SequArrRLHidden; ///< hidden redlines
+ SortKeyArr m_SortKeyArr;
+ sal_Unicode m_cPrefix;
+ sal_Unicode m_cSuffix;
+ bool m_bIsSequence :1;
+ bool m_bSortByDocument :1;
+ LanguageType m_eLanguage;
+ OUString m_sSortAlgorithm;
+
+ virtual void SwClientNotify(const SwModify&, const SfxHint&) override;
+
+public:
+ SwAuthorityFieldType(SwDoc* pDoc);
+ virtual ~SwAuthorityFieldType() override;
+
+ virtual std::unique_ptr<SwFieldType> Copy() const override;
+
+ virtual void QueryValue( css::uno::Any& rVal, sal_uInt16 nWhichId ) const override;
+ virtual void PutValue( const css::uno::Any& rVal, sal_uInt16 nWhichId ) override;
+
+ void SetDoc(SwDoc* pNewDoc) { m_pDoc = pNewDoc; }
+ SwDoc* GetDoc(){ return m_pDoc; }
+ void RemoveField(const SwAuthEntry* nHandle);
+ SwAuthEntry* AddField(std::u16string_view rFieldContents);
+ void DelSequenceArray()
+ {
+ m_SequArr.clear();
+ m_SequArrRLHidden.clear();
+ }
+
+ void GetAllEntryIdentifiers( std::vector<OUString>& rToFill ) const;
+ SwAuthEntry* GetEntryByIdentifier(std::u16string_view rIdentifier) const;
+
+ bool ChangeEntryContent(const SwAuthEntry* pNewEntry);
+ // import interface
+ SwAuthEntry* AppendField(const SwAuthEntry& rInsert);
+
+ sal_uInt16 GetSequencePos(const SwAuthEntry* pAuthEntry, SwRootFrame const* pLayout);
+ std::unique_ptr<SwTOXInternational> CreateTOXInternational() const;
+
+ bool IsSequence() const {return m_bIsSequence;}
+ void SetSequence(bool bSet)
+ {
+ DelSequenceArray();
+ m_bIsSequence = bSet;
+ }
+
+ void SetPreSuffix( sal_Unicode cPre, sal_Unicode cSuf)
+ {
+ m_cPrefix = cPre;
+ m_cSuffix = cSuf;
+ }
+ sal_Unicode GetPrefix() const { return m_cPrefix;}
+ sal_Unicode GetSuffix() const { return m_cSuffix;}
+
+ bool IsSortByDocument() const {return m_bSortByDocument;}
+ void SetSortByDocument(bool bSet)
+ {
+ DelSequenceArray();
+ m_bSortByDocument = bSet;
+ }
+
+ sal_uInt16 GetSortKeyCount() const ;
+ const SwTOXSortKey* GetSortKey(sal_uInt16 nIdx) const ;
+ void SetSortKeys(sal_uInt16 nKeyCount, SwTOXSortKey const nKeys[]);
+
+ //initui.cxx
+ static OUString const & GetAuthFieldName(ToxAuthorityField eType);
+ static OUString const & GetAuthTypeName(ToxAuthorityType eType);
+
+ LanguageType GetLanguage() const {return m_eLanguage;}
+ void SetLanguage(LanguageType nLang) {m_eLanguage = nLang;}
+
+ const OUString& GetSortAlgorithm() const {return m_sSortAlgorithm;}
+ void SetSortAlgorithm(const OUString& rSet) {m_sSortAlgorithm = rSet;}
+ void dumpAsXml(xmlTextWriterPtr pWriter) const override;
+
+};
+
+/** Represents an inserted bibliography entry, created using Insert -> Table of Contents and Index
+ -> Bibliography Entry.
+
+ invariant for SwAuthorityField is that it is always registered at its
+ SwAuthorityFieldType via AddField()/RemoveField() & therefore has m_nHandle
+ set - but it's possible that multiple SwAuthorityField have the same
+ m_nHandle & so the number of instances is an upper bound on
+ SwAuthorityField::m_DataArr.size() - it's not clear to me if more than one
+ one of the instances with the same m_nHandle is actually in the document,
+ they're all cloned via CopyField()...
+ */
+class SW_DLLPUBLIC SwAuthorityField final : public SwField
+{
+ rtl::Reference<SwAuthEntry> m_xAuthEntry;
+ mutable sal_IntPtr m_nTempSequencePos;
+ mutable sal_IntPtr m_nTempSequencePosRLHidden; ///< hidden redlines
+
+ virtual OUString ExpandImpl(SwRootFrame const* pLayout) const override;
+ virtual std::unique_ptr<SwField> Copy() const override;
+
+public:
+ enum TargetType : sal_uInt16
+ {
+ UseDisplayURL = 0,
+ UseTargetURL = 1,
+ None = 2,
+ BibliographyTableRow = 3,
+ // BibliographyTablePage = 4, // TODO: implement
+ };
+
+
+ /// For internal use only, in general continue using ExpandField() instead.
+ OUString ConditionalExpandAuthIdentifier(SwRootFrame const* pLayout) const;
+
+ //To handle Citation
+ OUString ExpandCitation(ToxAuthorityField eField, SwRootFrame const* pLayout) const;
+
+ SwAuthorityField(SwAuthorityFieldType* pType, std::u16string_view rFieldContents);
+ SwAuthorityField(SwAuthorityFieldType* pType, SwAuthEntry* pAuthEntry);
+ virtual ~SwAuthorityField() override;
+
+ const OUString & GetFieldText(ToxAuthorityField eField) const;
+
+ virtual void SetPar1(const OUString& rStr) override;
+ virtual SwFieldType* ChgTyp( SwFieldType* ) override;
+
+ virtual bool QueryValue( css::uno::Any& rVal, sal_uInt16 nWhichId ) const override;
+ virtual bool PutValue( const css::uno::Any& rVal, sal_uInt16 nWhichId ) override;
+
+ SwAuthEntry* GetAuthEntry() const { return m_xAuthEntry.get(); }
+
+ virtual OUString GetDescription() const override;
+
+ /**
+ * Returns the line matching the source's default row in the ToX.
+ *
+ * \param pLayout layout to be used
+ * \param pTOX bibliography table to take the format of the string from
+ * \return entry formatted as the appropriate authority type in the table
+ */
+ OUString GetAuthority(const SwRootFrame *pLayout,
+ const SwForm *pTOX = nullptr) const;
+
+ /**
+ * Returns which target should be used when the entry
+ * (the standalone field, such as '[ASDF]', not in the table) is clicked.
+ */
+ TargetType GetTargetType() const;
+ /**
+ * Returns absolute target URL in case there is one (GetTargetType() should be checked).
+ * If there isn't one, the result is undefined.
+ */
+ OUString GetAbsoluteURL() const;
+
+ /**
+ * Returns relative URI for the URL
+ */
+ OUString GetRelativeURI() const;
+
+ void dumpAsXml(xmlTextWriterPtr pWriter) const override;
+};
+
+inline OUString const & SwAuthEntry::GetAuthorField(ToxAuthorityField ePos) const
+{
+ SAL_WARN_IF(AUTH_FIELD_END <= ePos, "sw", "wrong index");
+ return m_aAuthFields[ePos];
+}
+inline void SwAuthEntry::SetAuthorField(ToxAuthorityField ePos, const OUString& rField)
+{
+ SAL_WARN_IF(AUTH_FIELD_END <= ePos, "sw", "wrong index");
+ if(AUTH_FIELD_END > ePos)
+ m_aAuthFields[ePos] = rField;
+}
+
+#endif
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */