summaryrefslogtreecommitdiffstats
path: root/sw/inc/flddropdown.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'sw/inc/flddropdown.hxx')
-rw-r--r--sw/inc/flddropdown.hxx265
1 files changed, 265 insertions, 0 deletions
diff --git a/sw/inc/flddropdown.hxx b/sw/inc/flddropdown.hxx
new file mode 100644
index 0000000000..5c33620721
--- /dev/null
+++ b/sw/inc/flddropdown.hxx
@@ -0,0 +1,265 @@
+/* -*- 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_FLDDROPDOWN_HXX
+#define INCLUDED_SW_INC_FLDDROPDOWN_HXX
+
+#include <com/sun/star/uno/Sequence.h>
+#include "swdllapi.h"
+#include "fldbas.hxx"
+
+#include <vector>
+
+/**
+ Field type for dropdown boxes.
+*/
+class SAL_DLLPUBLIC_RTTI SwDropDownFieldType final : public SwFieldType
+{
+public:
+ /**
+ Constructor
+ */
+ SwDropDownFieldType();
+
+ /**
+ Destructor
+ */
+ virtual ~SwDropDownFieldType() override;
+
+ /**
+ Create a copy of this field type.
+
+ @return a copy of this type
+ */
+ virtual std::unique_ptr<SwFieldType> Copy() const override;
+};
+
+/**
+ Dropdown field.
+
+ The dropdown field contains a list of strings. At most one of them
+ can be selected.
+*/
+class SW_DLLPUBLIC SwDropDownField final : public SwField
+{
+ /**
+ the possible values (aka items) of the dropdown box
+ */
+ std::vector<OUString> m_aValues;
+
+ /**
+ the selected item
+ */
+ OUString m_aSelectedItem;
+
+ /**
+ the name of the field
+ */
+ OUString m_aName;
+
+ /**
+ help text
+ */
+ OUString m_aHelp;
+
+ /**
+ tool tip string
+ */
+ OUString m_aToolTip;
+
+ /**
+ Expands the field.
+
+ The expanded value of the field is the value of the selected
+ item. If no item is selected, an empty string is returned.
+
+ @return the expanded value of the field
+ */
+ virtual OUString ExpandImpl(SwRootFrame const* pLayout) const override;
+
+ /**
+ Creates a copy of this field.
+
+ @return the copy of this field
+ */
+ virtual std::unique_ptr<SwField> Copy() const override;
+
+public:
+ /**
+ Constructor
+
+ @param pTyp field type for this field
+ */
+ SwDropDownField(SwFieldType* pTyp);
+
+ /**
+ Copy constructor
+
+ @param rSrc dropdown field to copy
+ */
+ SwDropDownField(const SwDropDownField& rSrc);
+
+ /**
+ Destructor
+ */
+ virtual ~SwDropDownField() override;
+
+ /**
+ Returns the selected value.
+
+ @see Expand
+
+ @return the selected value
+ */
+ virtual OUString GetPar1() const override;
+
+ /**
+ Returns the name of the field.
+
+ @return the name of the field
+ */
+ virtual OUString GetPar2() const override;
+
+ /**
+ Sets the selected value.
+
+ If rStr is an item of the field that item will be
+ selected. Otherwise no item will be selected, i.e. the
+ resulting selection will be empty.
+ */
+ virtual void SetPar1(const OUString& rStr) override;
+
+ /**
+ Sets the name of the field.
+
+ @param rStr the new name of the field
+ */
+ virtual void SetPar2(const OUString& rStr) override;
+
+ /**
+ Sets the items of the dropdown box.
+
+ After setting the items the selection will be empty.
+
+ @param rItems the new items
+ */
+ void SetItems(std::vector<OUString>&& rItems);
+
+ /**
+ Sets the items of the dropdown box.
+
+ After setting the items the selection will be empty.
+
+ @param rItems the new items
+ */
+ void SetItems(const css::uno::Sequence<OUString>& rItems);
+
+ /**
+ Returns the items of the dropdown box.
+
+ @return the items of the dropdown box
+ */
+ css::uno::Sequence<OUString> GetItemSequence() const;
+
+ /**
+ Returns the selected item.
+
+ @return the selected item
+ */
+ const OUString& GetSelectedItem() const { return m_aSelectedItem; }
+
+ /**
+ Returns the name of the field.
+
+ @return the name of the field
+ */
+ const OUString& GetName() const { return m_aName; }
+
+ /**
+ Returns the help text of the field.
+
+ @return the help text of the field
+ */
+ const OUString& GetHelp() const { return m_aHelp; }
+
+ /**
+ Returns the tool tip of the field.
+
+ @return the tool tip of the field
+ */
+ const OUString& GetToolTip() const { return m_aToolTip; }
+
+ /**
+ Sets the selected item.
+
+ If rItem is found in this dropdown field it is selected. If
+ rItem is not found the selection will be empty.
+
+ @param rItem the item to be set
+ */
+ void SetSelectedItem(const OUString& rItem);
+
+ /**
+ Sets the name of the field.
+
+ @param rName the new name of the field
+ */
+ void SetName(const OUString& rName);
+
+ /**
+ Sets the help text of the field.
+
+ @param rHelp the help text
+ */
+ void SetHelp(const OUString& rHelp);
+
+ /**
+ Sets the tool tip of the field.
+
+ @param rToolTip the tool tip
+ */
+ void SetToolTip(const OUString& rToolTip);
+
+ /**
+ API: Gets a property value from the dropdown field.
+
+ @param rVal return value
+ @param nMId
+ - FIELD_PROP_PAR1 Get selected item (String)
+ - FIELD_PROP_STRINGS Get all items (Sequence)
+ - FIELD_PROP_PAR3 Get the help text of the field.
+ - FIELD_PROP_PAR4 Get the tool tip of the field.
+ */
+ virtual bool QueryValue(css::uno::Any& rVal, sal_uInt16 nWhichId) const override;
+
+ /**
+ API: Sets a property value on the dropdown field.
+
+ @param rVal value to set
+ @param nMId
+ - FIELD_PROP_PAR1 Set selected item (String)
+ - FIELD_PROP_STRINGS Set all items (Sequence)
+ - FIELD_PROP_PAR3 Set the help text of the field.
+ - FIELD_PROP_PAR4 Set the tool tip of the field.
+ */
+ virtual bool PutValue(const css::uno::Any& rVal, sal_uInt16 nWhichId) override;
+};
+
+#endif
+
+/* vim:set shiftwidth=4 softtabstop=4 expandtab: */