fdo#74697 Add Bluez 5 support for impress remote.
[LibreOffice.git] / include / sfx2 / filedlghelper.hxx
blob304fd5cdff58feac576136f0e807bdd599ef1341
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
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 _FILEDLGHELPER_HXX
20 #define _FILEDLGHELPER_HXX
22 #include "sal/config.h"
23 #include "sfx2/dllapi.h"
24 #include "sal/types.h"
25 #include <com/sun/star/uno/Reference.hxx>
26 #include <com/sun/star/uno/Sequence.hxx>
27 #include <rtl/ustring.hxx>
28 #include <tools/solar.h>
29 #include <tools/string.hxx>
30 #include <tools/errcode.hxx>
31 #include <vcl/dialog.hxx>
32 #include <vcl/edit.hxx>
33 #include <vcl/button.hxx>
34 #include <vcl/graph.hxx>
35 #include <sfx2/sfxdefs.hxx>
36 #include <sfx2/sfxuno.hxx>
37 #include <sfx2/docfilt.hxx>
39 //-----------------------------------------------------------------------------
41 namespace com
43 namespace sun
45 namespace star
47 namespace ui
49 namespace dialogs
51 class XFilePicker;
52 class XFilePickerListener;
53 struct FilePickerEvent;
54 struct DialogClosedEvent;
61 class SfxItemSet;
62 class Window;
64 // the SFXWB constants are for the nFlags parameter of the constructor
65 #define SFXWB_INSERT 0x04000000L // turn Open into Insert dialog
66 #define SFXWB_EXPORT 0x40000000L // turn Save into Export dialog
67 #define SFXWB_SAVEACOPY 0x00400000L // turn Save into Save a Copy dialog
68 #define SFXWB_MULTISELECTION 0x20000000L
69 #define SFXWB_GRAPHIC 0x00800000L // register graphic formats
71 #define FILEDIALOG_FILTER_ALL "*.*"
73 #define FILE_OPEN_SERVICE_NAME_OOO "com.sun.star.ui.dialogs.OfficeFilePicker"
75 namespace sfx2 {
77 class FileDialogHelper_Impl;
79 class SFX2_DLLPUBLIC FileDialogHelper
81 public:
82 enum Context // context where the FileDialogHelper is used
84 UNKNOWN_CONTEXT, // unknown context
85 SW_INSERT_GRAPHIC, // insert graphic in writer
86 SW_INSERT_SOUND, // insert sound in writer
87 SW_INSERT_VIDEO, // insert video in writer
88 SC_INSERT_GRAPHIC, // insert graphic in calc
89 SC_INSERT_SOUND, // insert sound in calc
90 SC_INSERT_VIDEO, // insert video in calc
91 SD_INSERT_GRAPHIC, // insert graphic in draw
92 SD_INSERT_SOUND, // insert sound in draw
93 SD_INSERT_VIDEO, // insert video in draw
94 SD_EXPORT, // export in draw
95 SI_EXPORT, // export in impress
96 SW_EXPORT // export in writer
99 private:
100 Link m_aDialogClosedLink;
101 ErrCode m_nError;
103 ::com::sun::star::uno::Reference < ::com::sun::star::ui::dialogs::XFilePickerListener > mxImp;
104 FileDialogHelper_Impl *mpImp;
107 public:
108 FileDialogHelper( sal_Int16 nDialogType,
109 sal_Int64 nFlags,
110 Window* _pPreferredParent = NULL );
112 FileDialogHelper( sal_Int16 nDialogType,
113 sal_Int64 nFlags,
114 const String& rFactory,
115 SfxFilterFlags nMust = 0,
116 SfxFilterFlags nDont = 0 );
118 FileDialogHelper( sal_Int16 nDialogType,
119 sal_Int64 nFlags,
120 const String& rFactory,
121 sal_Int16 nDialog,
122 SfxFilterFlags nMust,
123 SfxFilterFlags nDont,
124 const String& rStandardDir,
125 const ::com::sun::star::uno::Sequence< OUString >& rBlackList);
127 FileDialogHelper( sal_Int16 nDialogType,
128 sal_Int64 nFlags,
129 const OUString& aFilterUIName,
130 const OUString& aExtName,
131 const OUString& rStandardDir,
132 const ::com::sun::star::uno::Sequence< OUString >& rBlackList,
133 Window* _pPreferredParent = NULL );
136 virtual ~FileDialogHelper();
138 ErrCode Execute();
139 void StartExecuteModal( const Link& rEndDialogHdl );
140 inline ErrCode GetError() const { return m_nError; }
141 sal_Int16 GetDialogType() const;
142 sal_Bool IsPasswordEnabled() const;
143 String GetRealFilter() const;
145 void SetTitle( const String& rNewTitle );
146 String GetPath() const;
148 /** @deprected: Don't use this method to retrieve the selected files
149 There are file picker which can provide multiple selected file which belong
150 to different folders. As this method always provides the root folder for all selected
151 files this cannot work.
153 ::com::sun::star::uno::Sequence< OUString > GetMPath() const;
155 /** Provides the selected files with full path information */
156 ::com::sun::star::uno::Sequence< OUString > GetSelectedFiles() const;
158 void AddFilter( const String& rFilterName, const String& rExtension );
159 void SetCurrentFilter( const String& rFilter );
161 /** sets an initial display directory/file name
163 @deprecated
164 don't use this method. It contains a lot of magic in determining whether the
165 last segment of the given path/URL denotes a file name or a folder, and by
166 definition, it cannot succeed with this magic *all* the time - there will
167 always be scenarios where it fails.
169 Use SetDisplayFolder and SetFileName.
171 void SetDisplayDirectory( const String& rPath );
173 /** sets a new folder whose content is to be displayed in the file picker
175 @param _rURL
176 specifies the URL of the folder whose content is to be displayed.<br/>
177 If the URL doesn't denote a valid (existent and accessible) folder, the
178 request is silently dropped.
179 @throws ::com::sun::star::uno::RuntimeException
180 if the invocation of any of the file picker or UCB methods throws a RuntimeException.
182 void SetDisplayFolder( const String& _rURL );
184 /** sets an initial file name to display
186 This method is usually used in "save-as" contexts, where the application should
187 suggest an initial name for the file to save.
189 Calling this method is nearly equivalent to calling <code>GetFilePicker().setDefaultName( _rFileName )</code>,
190 with the following differences:
191 <ul><li>The FileDialogHelper remembers the given file name, and upon execution,
192 strips its extension if the dialog is set up for "automatic file name extension".</li>
193 <li>Exceptions thrown from the <code>XFilePicker</code> are caught and silenced.</li>
194 </ul>
196 void SetFileName( const String& _rFileName );
198 String GetCurrentFilter() const;
199 String GetDisplayDirectory() const;
200 ErrCode GetGraphic( Graphic& rGraphic ) const;
202 ::com::sun::star::uno::Reference < ::com::sun::star::ui::dialogs::XFilePicker > GetFilePicker() const;
204 // XFilePickerListener methods
205 virtual void SAL_CALL FileSelectionChanged( const ::com::sun::star::ui::dialogs::FilePickerEvent& aEvent );
206 virtual void SAL_CALL DirectoryChanged( const ::com::sun::star::ui::dialogs::FilePickerEvent& aEvent );
207 virtual void SAL_CALL ControlStateChanged( const ::com::sun::star::ui::dialogs::FilePickerEvent& aEvent );
208 virtual void SAL_CALL DialogSizeChanged();
209 virtual OUString SAL_CALL HelpRequested( const ::com::sun::star::ui::dialogs::FilePickerEvent& aEvent );
211 // XDialogClosedListener methods
212 virtual void SAL_CALL DialogClosed( const ::com::sun::star::ui::dialogs::DialogClosedEvent& _rEvent );
214 /** sets help ids for the controls in the dialog
215 @param _pControlId
216 Pointer to a 0-terminated array of control ids. They must be recruited from the
217 CommonFilePickerElementIds and ExtendedFilePickerElementIds values.
218 @param _pHelpId
219 Pointer to an array of help ids. For each element in _pControlId, there must be
220 a corresponding element herein.
222 void SetControlHelpIds( const sal_Int16* _pControlId, const char** _pHelpId );
223 void CreateMatcher( const String& rName );
225 /** sets the context of the dialog and trigger necessary actions e.g. loading config, setting help id
226 @param _eNewContext
227 New context for the dialog.
229 void SetContext( Context _eNewContext );
231 DECL_LINK( ExecuteSystemFilePicker, void* );
233 ErrCode Execute( std::vector<OUString>& rpURLList,
234 SfxItemSet *& rpSet,
235 String& rFilter,
236 const String& rDirPath );
237 ErrCode Execute( SfxItemSet *& rpSet,
238 String& rFilter );
241 #define SFX2_IMPL_DIALOG_CONFIG 0
242 #define SFX2_IMPL_DIALOG_SYSTEM 1
243 #define SFX2_IMPL_DIALOG_OOO 2
245 ErrCode FileOpenDialog_Impl( sal_Int16 nDialogType,
246 sal_Int64 nFlags,
247 const String& rFact,
248 std::vector<OUString>& rpURLList,
249 String& rFilter,
250 SfxItemSet *& rpSet,
251 const String* pPath = NULL,
252 sal_Int16 nDialog = SFX2_IMPL_DIALOG_CONFIG,
253 const String& rStandardDir = OUString(),
254 const ::com::sun::star::uno::Sequence< OUString >& rBlackList = ::com::sun::star::uno::Sequence< OUString >());
257 ErrCode RequestPassword(const SfxFilter* pCurrentFilter, OUString& aURL, SfxItemSet* pSet);
260 #endif
262 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */