1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
19 #ifndef INCLUDED_UNOTOOLS_VIEWOPTIONS_HXX
20 #define INCLUDED_UNOTOOLS_VIEWOPTIONS_HXX
22 #include <unotools/unotoolsdllapi.h>
23 #include <com/sun/star/uno/Sequence.hxx>
24 #include <sal/types.h>
25 #include <rtl/ustring.hxx>
27 namespace com::sun::star::beans
{ struct NamedValue
; }
28 namespace com::sun::star::container
{ class XNameAccess
; }
30 /*-************************************************************************************************************
31 @descr Use these enum values to specify right list in configuration in which your view data are saved.
32 *//*-*************************************************************************************************************/
42 /*-************************************************************************************************************
43 @short collect information about view features
44 @descr We support different basetypes of views like dialogs, tab-dialogs, tab-pages and normal windows.
45 You must specify your basetype by using right enum value and must give us a valid name for your
46 subkey in registry! We support some fix features for some bastypes and user data as string for all!
47 see also configuration package "org.openoffice.Office.Views/..." for further information.
49 template of configuration:
52 /UserData [set of any scalar types]
55 /UserData [set of any scalar types]
59 /UserData [set of any scalar types]
62 /UserData [set of any scalar types]
65 structure of configuration:
67 org.openoffice.Office.Views [package]
69 /Dialog_FileOpen [DialogType]
70 /Dialog_ImportGraphics [DialogType]
72 /Dialog_<YourName> [DialogType]
75 /TabDialog_001 [TabDialogType]
76 /TabDialog_Blubber [TabDialogType]
78 /TabDialog_<YourName> [TabDialogType]
81 /TabPage_XXX [TabPageType]
82 /TabPage_Date [TabPageType]
84 /TabPage_<YourName> [TabPageType]
87 /Window_User [WindowType]
88 /Window_Options [WindowType]
90 /Window_<YourName> [WindowType]
91 @devstatus ready to use
92 *//*-*************************************************************************************************************/
94 class SAL_WARN_UNUSED UNOTOOLS_DLLPUBLIC SvtViewOptions final
101 // constructor / destructor
103 /*-****************************************************************************************************
104 @short standard constructor and destructor
105 @descr This will de-/initialize an instance with default values.
106 You must give us the basic type of your view and a name which specify right entry
107 in dynamical configuration list. If entry not exist, we create a new one!
109 @seealso enum EViewType
111 @param "eType" specify type of your view and is used to use right data container!
112 @param "sViewName" specify the name of your view and is the key name in data list too.
113 @onerror An assertion is thrown in debug version. Otherwise we do nothing!
114 *//*-*****************************************************************************************************/
116 SvtViewOptions( EViewType eType
, OUString sViewName
);
120 /*-****************************************************************************************************
121 @short use it to get information about existing entries in configuration
122 @descr The methods to set/get the position or size will create a new entry automatically if
123 it not already exist and work with default values!
124 If this a problem for you - you MUST call these method before and
125 you must make up your own mind about that.
126 @onerror No error should occur.
127 *//*-*****************************************************************************************************/
131 /*-****************************************************************************************************
132 @short use it to delete an entry of dynamic view set
133 @descr You can use this method to delete an existing node in configuration.
134 But if you call a Set- or Get- method again on this instance
135 the item is created again! If you do nothing after this call
136 your view will die relay in configuration...
138 @seealso method Exist()
139 *//*-*****************************************************************************************************/
143 /*-****************************************************************************************************
144 @short use it to set/get the window state of your view
145 @descr These value describe position/size and some other states of a window.
146 Use it with right vcl methods directly. Normally it's not necessary to
150 *//*-*****************************************************************************************************/
152 OUString
GetWindowState( ) const;
153 void SetWindowState( const OUString
& sState
);
155 /*-****************************************************************************************************
156 @short use it to set/get the page number which was the last active one
157 @descr It's only supported for: - tab-dialogs
158 If you call it for other ones you will get an assertion in debug version.
159 In a product version we do nothing!
160 @onerror An assertion is thrown in debug version. Otherwise we do nothing!
161 *//*-*****************************************************************************************************/
163 OUString
GetPageID() const;
164 void SetPageID(const OUString
& rID
);
166 /*-****************************************************************************************************
167 @short use it to set/get the visual state of a window
168 @descr It's only supported for: - windows
169 If you call it for other ones you will get an assertion in debug version.
170 In a product version we do nothing!
171 @onerror An assertion is thrown in debug version. Otherwise we do nothing!
172 *//*-*****************************************************************************************************/
174 bool IsVisible ( ) const;
175 void SetVisible( bool bState
);
177 /** Return true if the "Visible" property actually has a non-nil value
179 (IsVisible will somewhat arbitrarily return false if the property is
182 bool HasVisible() const;
184 /*-****************************************************************************************************
185 @short use it to set/get the extended user data (consisting of a set of named scalar values)
186 @descr It's supported for ALL types!
187 Every view can handle its own user defined data set.
188 @onerror In the non-product version, an assertion is made. In a product version, errors are silently ignored.
189 *//*-*****************************************************************************************************/
190 css::uno::Sequence
< css::beans::NamedValue
> GetUserData( ) const;
191 void SetUserData( const css::uno::Sequence
< css::beans::NamedValue
>& lData
);
193 /*-****************************************************************************************************
194 @short use it to set/get ONE special user data item directly
195 @descr Normally you can work on full user data list by using "Set/GetUserData()".
196 With this function you have an access on special list entries directly without any
197 @onerror In the non-product version, an assertion is made. In a product version, errors are silently ignored.
198 *//*-*****************************************************************************************************/
200 css::uno::Any
GetUserItem( const OUString
& sName
) const;
201 void SetUserItem( const OUString
& sName
,
202 const css::uno::Any
& aValue
);
205 enum State
{ STATE_NONE
, STATE_FALSE
, STATE_TRUE
};
207 css::uno::Reference
< css::uno::XInterface
> impl_getSetNode( const OUString
& sNode
,
208 bool bCreateIfMissing
) const;
209 State
GetVisible() const;
211 /// specify which list of views in configuration is used! This can't be a static value!!!
212 /// ... because we need this value to work with right static data container.
213 EViewType m_eViewType
;
214 OUString m_sViewName
;
216 OUString m_sListName
;
217 css::uno::Reference
< css::container::XNameAccess
> m_xRoot
;
218 css::uno::Reference
< css::container::XNameAccess
> m_xSet
;
219 }; // class SvtViewOptions
221 #endif // INCLUDED_UNOTOOLS_VIEWOPTIONS_HXX
223 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */