/* -*- 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: */