summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKurt Zenker <kz@openoffice.org>2008-03-05 15:35:07 +0000
committerKurt Zenker <kz@openoffice.org>2008-03-05 15:35:07 +0000
commit0789c3d9ece3862b50cda8de945d376375b13d77 (patch)
treecde4d8d31516a17d3fbe4e347b74f43a0a0751d6
parent14bc62ad0d9e0179f4178d2913ebba7abf99755e (diff)
INTEGRATION: CWS aquafilepicker02_DEV300 (1.2.40); FILE MERGED
2008/02/14 17:28:45 fheckl 1.2.40.3: Further changes concerning Autoextension 2008/01/14 08:23:23 fheckl 1.2.40.2: Code cleanup and some implementation details 2008/01/02 18:25:58 fheckl 1.2.40.1: issue #80399 more Cocoa
-rw-r--r--fpicker/source/aqua/ControlHelper.hxx141
1 files changed, 96 insertions, 45 deletions
diff --git a/fpicker/source/aqua/ControlHelper.hxx b/fpicker/source/aqua/ControlHelper.hxx
index 4d499e3fa2dd..2d6e623b069c 100644
--- a/fpicker/source/aqua/ControlHelper.hxx
+++ b/fpicker/source/aqua/ControlHelper.hxx
@@ -4,9 +4,9 @@
*
* $RCSfile: ControlHelper.hxx,v $
*
- * $Revision: 1.2 $
+ * $Revision: 1.3 $
*
- * last change: $Author: ihi $ $Date: 2007-07-11 10:57:54 $
+ * last change: $Author: kz $ $Date: 2008-03-05 16:35:07 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
@@ -36,23 +36,33 @@
#ifndef _CONTROLHELPER_HXX_
#define _CONTROLHELPER_HXX_
-#ifndef _RTL_USTRING_H_
+#ifndef _RTL_USTRING_HXX_
#include <rtl/ustring.hxx>
#endif
+
#ifndef _COM_SUN_STAR_UNO_ANY_HXX_
#include <com/sun/star/uno/Any.hxx>
#endif
#include <list>
+#include <map>
#include <premac.h>
-#include <Carbon/Carbon.h>
+#include <Cocoa/Cocoa.h>
#include <postmac.h>
#ifndef _SALAQUACONSTANTS_H_
#include "SalAquaConstants.h"
#endif
+#ifndef _FILTERHELPER_HXX_
+#include "FilterHelper.hxx"
+#endif
+
+#ifndef _AQUAFILEPICKERDELEGATE_HXX_
+#include "AquaFilePickerDelegate.hxx"
+#endif
+
using namespace com::sun::star;
using namespace rtl;
@@ -69,35 +79,25 @@ public:
//------------------------------------------------
// XInitialization delegate
//------------------------------------------------
- void initialize(sal_Int16 templateId);
+ void initialize( sal_Int16 templateId );
//------------------------------------------------------------------------------------
// XFilePickerControlAccess function delegates
//------------------------------------------------------------------------------------
void setValue( sal_Int16 nControlId, sal_Int16 nControlAction, const uno::Any& rValue );
- uno::Any getValue(sal_Int16 nControlId, sal_Int16 nControlAction);
- void enableControl(sal_Int16 nControlId, sal_Bool bEnable);
- OUString getLabel(sal_Int16 nControlId);
- void setLabel( sal_Int16 nControlId, const CFStringRef aLabel );
+ uno::Any getValue( sal_Int16 nControlId, sal_Int16 nControlAction ) const;
+ void enableControl( sal_Int16 nControlId, sal_Bool bEnable ) const;
+ OUString getLabel( sal_Int16 nControlId );
+ void setLabel( sal_Int16 nControlId, const NSString* aLabel );
//------------------------------------------------------------------------------------
- // NavigationServices callback delegates
+ // other stuff
//------------------------------------------------------------------------------------
- void handleStart(NavCBRecPtr callBackParms);
- void handleCustomize(NavCBRecPtr callBackParms);
- void handleEvent(NavCBRecPtr callBackParms, NavEventCallbackMessage aLatestEvent);
- void handleAdjustRect(NavCBRecPtr callBackParms);
+ void updateFilterUI();
//------------------------------------------------------------------------------------
// Type definitions
//------------------------------------------------------------------------------------
- enum ControlType {
- NONE
- , CHECKBOX
- , POPUPMENU
- , USERPANE
- };
-
enum ToggleType {
AUTOEXTENSION, //but autoextension is handled differently on MacOSX
PASSWORD,
@@ -119,58 +119,109 @@ public:
//------------------------------------------------------------------------------------
// inline functions
//------------------------------------------------------------------------------------
- inline ControlRef getUserPane() {
+ inline NSView* getUserPane() {
+ if (m_bIsUserPaneLaidOut == false) {
+ createUserPane();
+ }
return m_pUserPane;
}
- inline bool getVisibility(ToggleType tToggle) {
+ inline bool getVisibility(ToggleType tToggle) {
return m_bToggleVisibility[tToggle];
}
- inline void setPopupPresent(bool bPresent) {
- m_bIsFilterPopupPresent = bPresent;
+ inline void setFilterControlNeeded(bool bNeeded) {
+ m_bIsFilterControlNeeded = bNeeded;
+ if (bNeeded == true) {
+ m_bUserPaneNeeded = true;
+ }
+ }
+
+ inline void setFilterHelper(FilterHelper* pFilterHelper) {
+ m_pFilterHelper = pFilterHelper;
+ }
+
+ inline void setFilePickerDelegate(AquaFilePickerDelegate* pDelegate) {
+ m_pDelegate = pDelegate;
+ }
+
+ inline bool isAutoExtensionEnabled() {
+ return m_bAutoFilenameExtension;
}
private:
//------------------------------------------------------------------------------------
// private member variables
//------------------------------------------------------------------------------------
- ControlRef m_pUserPane;
- int m_nLastCustomizeTryWidth;
- int m_nLastCustomizeTryHeight;
+ /** the native view object */
+ NSView* m_pUserPane;
+
+ /** the checkbox controls */
+ NSControl* m_pToggles[ TOGGLE_LAST ];
- ControlRef m_pToggles[ TOGGLE_LAST ];
+ /** the visibility flags for the checkboxes */
bool m_bToggleVisibility[TOGGLE_LAST];
-// enum tButtonType {
-// PLAY,
-// BUTTON_LAST
-// };
-//
-// ControlRef m_pButtons[ BUTTON_LAST ];
+ /** the special filter control */
+ NSPopUpButton *m_pFilterControl;
+
+ /** the popup menu controls (except for the filter control) */
+ NSControl* m_pListControls[ LIST_LAST ];
+
+ /** a map to store a control's label text */
+ ::std::map<NSControl *, NSString *> m_aMapListLabels;
+
+ /** a map to store a popup menu's label text field */
+ ::std::map<NSPopUpButton *, NSTextField *> m_aMapListLabelFields;
- ControlRef m_pListControls[ LIST_LAST ];
+ /** the visibility flags for the popup menus */
bool m_bListVisibility[ LIST_LAST ];
+ /** indicates if a user pane is needed */
bool m_bUserPaneNeeded;
- ::std::list<ControlRef> m_aActiveControls;
+ /** indicates if the user pane was laid out already */
+ bool m_bIsUserPaneLaidOut;
- bool m_bIsFilterPopupPresent;
+ /** indicates if a filter control is needed */
+ bool m_bIsFilterControlNeeded;
+
+ /*
+ * With issue #78852 the GUI option to set automatic filename extension was removed but
+ * so far the setting is still in effect and so the value for has to be saved and possibly be restored
+ * also.
+ * But with issue #FILLME users were starting to get confused on Windows so we decided to have
+ * autoextension always on and have it selectable for the user again.
+ */
+ /** indicates if a filename extension is to automatically be appended to a user entered file name */
+ bool m_bAutoFilenameExtension;
+
+ /** a list with all actively used controls */
+ ::std::list<NSControl*> m_aActiveControls;
+
+ /** the filter helper */
+ FilterHelper *m_pFilterHelper;
+
+ /** the save or open panel's delegate */
+ AquaFilePickerDelegate *m_pDelegate;
//------------------------------------------------------------------------------------
// private methods
//------------------------------------------------------------------------------------
- void HandleSetListValue(const ControlRef pControl, const sal_Int16 nControlAction, const uno::Any& rValue);
- uno::Any HandleGetListValue(const ControlRef pControl, const sal_Int16 nControlAction) const;
+ void HandleSetListValue(const NSControl* pControl, const sal_Int16 nControlAction, const uno::Any& rValue);
+ uno::Any HandleGetListValue(const NSControl* pControl, const sal_Int16 nControlAction) const;
+
+ void createControls();
+ void createFilterControl();
+ void createUserPane();
+ NSTextField* createLabelWithString(const NSString* label);
- void createControls();
- void createUserPane(WindowRef parent);
- int getControlElementName(ControlType type, int nControlId);
- ControlRef getControl( const sal_Int16 nControlId );
+ int getControlElementName(const Class clazz, const int nControlId) const;
+ NSControl* getControl( const sal_Int16 nControlId ) const;
+ static int getVerticalDistance(const NSControl* first, const NSControl* second);
- void layoutControls();
+ void layoutControls();
};
#endif //_CONTROLHELPER_HXX_