| /************************************************************** |
| * |
| * 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 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| *************************************************************/ |
| |
| |
| |
| #ifndef FPICKER_WIN32_VISTA_FILEPICKER_EVENTHANDLER_HXX |
| #define FPICKER_WIN32_VISTA_FILEPICKER_EVENTHANDLER_HXX |
| |
| //----------------------------------------------------------------------------- |
| // includes |
| //----------------------------------------------------------------------------- |
| |
| #if defined(_MSC_VER) && (_MSC_VER >= 1400) |
| #pragma warning( disable : 4917 ) |
| #endif |
| |
| #include "comptr.hxx" |
| #include "vistatypes.h" |
| #include "IVistaFilePickerInternalNotify.hxx" |
| |
| #include <com/sun/star/ui/dialogs/XFilePickerListener.hpp> |
| #include <com/sun/star/uno/Reference.hxx> |
| |
| #include <cppuhelper/basemutex.hxx> |
| #include <cppuhelper/interfacecontainer.h> |
| #include <osl/interlck.h> |
| |
| #include <shobjidl.h> |
| |
| //----------------------------------------------------------------------------- |
| // namespace |
| //----------------------------------------------------------------------------- |
| |
| #ifdef css |
| #error "Clash on using CSS as namespace define." |
| #else |
| #define css ::com::sun::star |
| #endif |
| |
| namespace fpicker{ |
| namespace win32{ |
| namespace vista{ |
| |
| //----------------------------------------------------------------------------- |
| // types, const etcpp. |
| //----------------------------------------------------------------------------- |
| |
| //----------------------------------------------------------------------------- |
| /** todo document me |
| */ |
| class VistaFilePickerEventHandler : public ::cppu::BaseMutex |
| , public IFileDialogEvents |
| , public IFileDialogControlEvents |
| { |
| public: |
| |
| //------------------------------------------------------------------------------------ |
| // ctor/dtor |
| //------------------------------------------------------------------------------------ |
| |
| VistaFilePickerEventHandler(IVistaFilePickerInternalNotify* pInternalNotify); |
| virtual ~VistaFilePickerEventHandler(); |
| |
| //------------------------------------------------------------------------------------ |
| // IUnknown |
| //------------------------------------------------------------------------------------ |
| virtual HRESULT STDMETHODCALLTYPE QueryInterface(REFIID rIID , |
| void** ppObject); |
| virtual ULONG STDMETHODCALLTYPE AddRef(); |
| virtual ULONG STDMETHODCALLTYPE Release(); |
| |
| //------------------------------------------------------------------------------------ |
| // IFileDialogEvents |
| //------------------------------------------------------------------------------------ |
| |
| STDMETHODIMP OnFileOk(IFileDialog* pDialog); |
| |
| STDMETHODIMP OnFolderChanging(IFileDialog* pDialog, |
| IShellItem* pFolder); |
| |
| STDMETHODIMP OnFolderChange(IFileDialog* pDialog); |
| |
| STDMETHODIMP OnSelectionChange(IFileDialog* pDialog); |
| |
| STDMETHODIMP OnShareViolation(IFileDialog* pDialog , |
| IShellItem* pItem , |
| FDE_SHAREVIOLATION_RESPONSE* pResponse); |
| |
| STDMETHODIMP OnTypeChange(IFileDialog* pDialog); |
| |
| STDMETHODIMP OnOverwrite(IFileDialog* pDialog , |
| IShellItem* pItem , |
| FDE_OVERWRITE_RESPONSE* pResponse); |
| |
| //------------------------------------------------------------------------------------ |
| // IFileDialogControlEvents |
| //------------------------------------------------------------------------------------ |
| |
| STDMETHODIMP OnItemSelected(IFileDialogCustomize* pCustomize, |
| DWORD nIDCtl , |
| DWORD nIDItem ); |
| |
| STDMETHODIMP OnButtonClicked(IFileDialogCustomize* pCustomize, |
| DWORD nIDCtl ); |
| |
| STDMETHODIMP OnCheckButtonToggled(IFileDialogCustomize* pCustomize, |
| DWORD nIDCtl , |
| BOOL bChecked ); |
| |
| STDMETHODIMP OnControlActivating(IFileDialogCustomize* pCustomize, |
| DWORD nIDCtl ); |
| |
| //------------------------------------------------------------------------------------ |
| // XFilePickerNotifier |
| //------------------------------------------------------------------------------------ |
| |
| virtual void SAL_CALL addFilePickerListener( const css::uno::Reference< css::ui::dialogs::XFilePickerListener >& xListener ) |
| throw( css::uno::RuntimeException ); |
| |
| virtual void SAL_CALL removeFilePickerListener( const css::uno::Reference< css::ui::dialogs::XFilePickerListener >& xListener ) |
| throw( css::uno::RuntimeException ); |
| |
| //------------------------------------------------------------------------------------ |
| // native interface |
| //------------------------------------------------------------------------------------ |
| |
| //------------------------------------------------------------------------------------ |
| /** start listening for file picker events on the given file open dialog COM object. |
| * |
| * The broadcaster will be cached internaly so deregistration will be easy. |
| * Further all needed informations are capsulated within this class (e.g. the listener handler). |
| * Nobody outside must know such informations. |
| * |
| * Nothing will happen if an inconsistent state will be detected |
| * (means: double registration will be ignored). |
| * |
| * @param pBroadcaster |
| * reference to the dialog, where we should start listening. |
| */ |
| void startListening( const TFileDialog& pBroadcaster ); |
| |
| //------------------------------------------------------------------------------------ |
| /** stop listening for file picker events on the internaly cached dialog COM object. |
| * |
| * The COM dialog provided on the startListeneing() call was cached internaly. |
| * And now its used to deregister this listener. Doing so the also internaly cached |
| * listener handle is used. If listener was not already registered - nothing will happen. |
| */ |
| void stopListening(); |
| |
| public: |
| |
| enum EEventType |
| { |
| E_FILE_SELECTION_CHANGED, |
| E_DIRECTORY_CHANGED, |
| E_HELP_REQUESTED, |
| E_CONTROL_STATE_CHANGED, |
| E_DIALOG_SIZE_CHANGED |
| }; |
| |
| private: |
| |
| //------------------------------------------------------------------------------------ |
| /// @todo document me |
| void impl_sendEvent( EEventType eEventType, |
| ::sal_Int16 nControlID); |
| |
| private: |
| |
| //------------------------------------------------------------------------------------ |
| /// ref count for AddRef/Release() |
| oslInterlockedCount m_nRefCount; |
| |
| //------------------------------------------------------------------------------------ |
| /// unique handle for this listener provided by the broadcaster on registration time |
| DWORD m_nListenerHandle; |
| |
| //------------------------------------------------------------------------------------ |
| /// cached file dialog instance (there we listen for events) |
| TFileDialog m_pDialog; |
| |
| //--------------------------------------------------------------------- |
| IVistaFilePickerInternalNotify* m_pInternalNotify; |
| |
| //--------------------------------------------------------------------- |
| /** used to inform file picker listener asynchronously. |
| * Those listener must be called asynchronously .. because |
| * every request will block the caller thread. Mostly that will be |
| * the main thread of the office. Further the global SolarMutex will |
| * be locked during this time. If we call our listener back now synchronously .. |
| * we will block on SolarMutex.acquire() forever .-)) |
| */ |
| ::cppu::OMultiTypeInterfaceContainerHelper m_lListener; |
| }; |
| |
| } // namespace vista |
| } // namespace win32 |
| } // namespace fpicker |
| |
| #undef css |
| |
| #endif // FPICKER_WIN32_VISTA_FILEPICKER_EVENTHANDLER_HXX |