summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--filter/AllLangResTarget_xsltdlg.mk1
-rw-r--r--filter/Module_filter.mk1
-rw-r--r--filter/UI_xsltdlg.mk16
-rw-r--r--filter/source/xsltdialog/hidother.src8
-rw-r--r--filter/source/xsltdialog/xmlfiltercommon.hrc9
-rw-r--r--filter/source/xsltdialog/xmlfilterdialogcomponent.cxx27
-rw-r--r--filter/source/xsltdialog/xmlfilterdialogstrings.hrc2
-rw-r--r--filter/source/xsltdialog/xmlfilterdialogstrings.src5
-rw-r--r--filter/source/xsltdialog/xmlfilterhelpids.hrc8
-rw-r--r--filter/source/xsltdialog/xmlfiltersettingsdialog.cxx280
-rw-r--r--filter/source/xsltdialog/xmlfiltersettingsdialog.hrc34
-rw-r--r--filter/source/xsltdialog/xmlfiltersettingsdialog.hxx70
-rw-r--r--filter/source/xsltdialog/xmlfiltersettingsdialog.src123
-rw-r--r--filter/source/xsltdialog/xmlfiltertabdialog.cxx1
-rw-r--r--filter/uiconfig/ui/xmlfiltersettings.ui182
-rw-r--r--svtools/inc/svtools/treelist.hxx14
-rw-r--r--svtools/inc/svtools/treelistbox.hxx16
-rw-r--r--svtools/source/contnr/treelistbox.cxx70
18 files changed, 472 insertions, 395 deletions
diff --git a/filter/AllLangResTarget_xsltdlg.mk b/filter/AllLangResTarget_xsltdlg.mk
index 22cbffebb190..30d73ba85b64 100644
--- a/filter/AllLangResTarget_xsltdlg.mk
+++ b/filter/AllLangResTarget_xsltdlg.mk
@@ -34,7 +34,6 @@ $(eval $(call gb_SrsTarget_set_include,filter/xsltdlg,\
))
$(eval $(call gb_SrsTarget_add_files,filter/xsltdlg,\
- filter/source/xsltdialog/xmlfiltersettingsdialog.src \
filter/source/xsltdialog/xmlfiltertabdialog.src \
filter/source/xsltdialog/xmlfiltertabpagebasic.src \
filter/source/xsltdialog/xmlfiltertabpagexslt.src \
diff --git a/filter/Module_filter.mk b/filter/Module_filter.mk
index 463af633763b..2f02504ddd48 100644
--- a/filter/Module_filter.mk
+++ b/filter/Module_filter.mk
@@ -64,6 +64,7 @@ $(eval $(call gb_Module_add_targets,filter,\
Package_inc \
Package_docbook \
Package_xslt \
+ UI_xsltdlg \
))
ifneq (,$(filter DESKTOP,$(BUILD_TYPE)))
diff --git a/filter/UI_xsltdlg.mk b/filter/UI_xsltdlg.mk
new file mode 100644
index 000000000000..8d9887662281
--- /dev/null
+++ b/filter/UI_xsltdlg.mk
@@ -0,0 +1,16 @@
+# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
+#
+# 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/.
+#
+
+$(eval $(call gb_UI_UI,filter))
+
+$(eval $(call gb_UI_add_uifiles,filter,\
+ filter/uiconfig/ui/xmlfiltersettings \
+))
+
+# vim: set noet sw=4 ts=4:
diff --git a/filter/source/xsltdialog/hidother.src b/filter/source/xsltdialog/hidother.src
index 84ec50de6415..cf2816dbc45c 100644
--- a/filter/source/xsltdialog/hidother.src
+++ b/filter/source/xsltdialog/hidother.src
@@ -20,15 +20,7 @@
hidspecial HID_XML_SOURCE_FILE_DIALOG { HelpId = HID_XML_SOURCE_FILE_DIALOG; };
hidspecial HID_XML_SOURCE_FILE_VALIDATE { HelpId = HID_XML_SOURCE_FILE_VALIDATE; };
-hidspecial HID_XML_FILTER_SETTINGS_DIALOG { HelpId = HID_XML_FILTER_SETTINGS_DIALOG; };
hidspecial HID_XML_FILTER_LIST { HelpId = HID_XML_FILTER_LIST; };
-hidspecial HID_XML_FILTER_NEW { HelpId = HID_XML_FILTER_NEW; };
-hidspecial HID_XML_FILTER_EDIT { HelpId = HID_XML_FILTER_EDIT; };
-hidspecial HID_XML_FILTER_TEST { HelpId = HID_XML_FILTER_TEST; };
-hidspecial HID_XML_FILTER_DELETE { HelpId = HID_XML_FILTER_DELETE; };
-hidspecial HID_XML_FILTER_SAVE { HelpId = HID_XML_FILTER_SAVE; };
-hidspecial HID_XML_FILTER_OPEN { HelpId = HID_XML_FILTER_OPEN; };
-hidspecial HID_XML_FILTER_CLOSE { HelpId = HID_XML_FILTER_CLOSE; };
hidspecial HID_XML_FILTER_TABDIALOG { HelpId = HID_XML_FILTER_TABDIALOG; };
hidspecial HID_XML_FILTER_TABPAGE_BASIC { HelpId = HID_XML_FILTER_TABPAGE_BASIC; };
diff --git a/filter/source/xsltdialog/xmlfiltercommon.hrc b/filter/source/xsltdialog/xmlfiltercommon.hrc
index 991f6d9e77ea..ad1be04e9b55 100644
--- a/filter/source/xsltdialog/xmlfiltercommon.hrc
+++ b/filter/source/xsltdialog/xmlfiltercommon.hrc
@@ -21,10 +21,9 @@
#include "filter.hrc"
#define DLG_XML_SOURCE_FILE_DIALOG (RID_XSLT_DIALOG_START+0)
-#define DLG_XML_FILTER_SETTINGS_DIALOG (RID_XSLT_DIALOG_START+1)
-#define DLG_XML_FILTER_TABDIALOG (RID_XSLT_DIALOG_START+2)
-#define RID_XML_FILTER_TABPAGE_BASIC (RID_XSLT_DIALOG_START+3)
-#define RID_XML_FILTER_TABPAGE_XSLT (RID_XSLT_DIALOG_START+4)
-#define DLG_XML_FILTER_TEST_DIALOG (RID_XSLT_DIALOG_START+5)
+#define DLG_XML_FILTER_TABDIALOG (RID_XSLT_DIALOG_START+1)
+#define RID_XML_FILTER_TABPAGE_BASIC (RID_XSLT_DIALOG_START+2)
+#define RID_XML_FILTER_TABPAGE_XSLT (RID_XSLT_DIALOG_START+3)
+#define DLG_XML_FILTER_TEST_DIALOG (RID_XSLT_DIALOG_START+4)
#endif
diff --git a/filter/source/xsltdialog/xmlfilterdialogcomponent.cxx b/filter/source/xsltdialog/xmlfilterdialogcomponent.cxx
index 3d9a3406c6a6..773219e2fc2f 100644
--- a/filter/source/xsltdialog/xmlfilterdialogcomponent.cxx
+++ b/filter/source/xsltdialog/xmlfilterdialogcomponent.cxx
@@ -105,13 +105,20 @@ private:
com::sun::star::uno::Reference<com::sun::star::awt::XWindow> mxParent; /// parent window
com::sun::star::uno::Reference< XMultiServiceFactory > mxMSF;
- static ResMgr* mpResMgr;
XMLFilterSettingsDialog* mpDialog;
};
//-------------------------------------------------------------------------
-ResMgr* XMLFilterDialogComponent::mpResMgr = NULL;
+namespace
+{
+ static ResMgr* pXSLTResMgr = NULL;
+}
+
+ResMgr* getXSLTDialogResMgr()
+{
+ return pXSLTResMgr;
+}
XMLFilterDialogComponent::XMLFilterDialogComponent( const com::sun::star::uno::Reference< XMultiServiceFactory >& rxMSF ) :
OComponentHelper( maMutex ),
@@ -291,10 +298,10 @@ void SAL_CALL XMLFilterDialogComponent::disposing()
mpDialog = NULL;
}
- if( mpResMgr )
+ if (pXSLTResMgr)
{
- delete mpResMgr;
- mpResMgr = NULL;
+ delete pXSLTResMgr;
+ pXSLTResMgr = NULL;
}
}
@@ -335,9 +342,9 @@ sal_Int16 SAL_CALL XMLFilterDialogComponent::execute( ) throw(RuntimeException)
{
::SolarMutexGuard aGuard;
- if( NULL == mpResMgr )
+ if( NULL == pXSLTResMgr )
{
- mpResMgr = ResMgr::CreateResMgr( "xsltdlg", Application::GetSettings().GetUILocale() );
+ pXSLTResMgr = ResMgr::CreateResMgr( "xsltdlg", Application::GetSettings().GetUILocale() );
}
if( NULL == mpDialog )
@@ -351,12 +358,12 @@ sal_Int16 SAL_CALL XMLFilterDialogComponent::execute( ) throw(RuntimeException)
}
Reference< XComponent > xComp( this );
- mpDialog = new XMLFilterSettingsDialog( pParent, *mpResMgr, mxMSF );
- mpDialog->ShowWindow();
+ mpDialog = new XMLFilterSettingsDialog(pParent, mxMSF);
+ mpDialog->Execute();
}
else if( !mpDialog->IsVisible() )
{
- mpDialog->ShowWindow();
+ mpDialog->Execute();
}
mpDialog->ToTop();
diff --git a/filter/source/xsltdialog/xmlfilterdialogstrings.hrc b/filter/source/xsltdialog/xmlfilterdialogstrings.hrc
index ec0f45f86dab..2e34787cc7af 100644
--- a/filter/source/xsltdialog/xmlfilterdialogstrings.hrc
+++ b/filter/source/xsltdialog/xmlfilterdialogstrings.hrc
@@ -60,4 +60,6 @@
#define STR_APPL_NAME_OASIS_IMPRESS (RID_XSLT_DIALOG_START + 36)
#define STR_APPL_NAME_OASIS_DRAW (RID_XSLT_DIALOG_START + 37)
+#define STR_XML_FILTER_LISTBOX (RID_XSLT_DIALOG_START + 38)
+
#endif
diff --git a/filter/source/xsltdialog/xmlfilterdialogstrings.src b/filter/source/xsltdialog/xmlfilterdialogstrings.src
index 18c5246dfeb1..ec0d9b65d936 100644
--- a/filter/source/xsltdialog/xmlfilterdialogstrings.src
+++ b/filter/source/xsltdialog/xmlfilterdialogstrings.src
@@ -183,3 +183,8 @@ String STR_NO_FILTERS_FOUND
{
Text [ en-US ] = "No XML filter could be installed because the package '%s' does not contain any XML filters.";
};
+
+String STR_XML_FILTER_LISTBOX
+{
+ Text [ en-US ] = "XML Filter List";
+};
diff --git a/filter/source/xsltdialog/xmlfilterhelpids.hrc b/filter/source/xsltdialog/xmlfilterhelpids.hrc
index d4ea134087b6..712a8ef0f4b0 100644
--- a/filter/source/xsltdialog/xmlfilterhelpids.hrc
+++ b/filter/source/xsltdialog/xmlfilterhelpids.hrc
@@ -20,15 +20,7 @@
#define HID_XML_SOURCE_FILE_DIALOG "FILTER_HID_XML_SOURCE_FILE_DIALOG"
#define HID_XML_SOURCE_FILE_VALIDATE "FILTER_HID_XML_SOURCE_FILE_VALIDATE"
-#define HID_XML_FILTER_SETTINGS_DIALOG "FILTER_HID_XML_FILTER_SETTINGS_DIALOG"
#define HID_XML_FILTER_LIST "FILTER_HID_XML_FILTER_LIST"
-#define HID_XML_FILTER_NEW "FILTER_HID_XML_FILTER_NEW"
-#define HID_XML_FILTER_EDIT "FILTER_HID_XML_FILTER_EDIT"
-#define HID_XML_FILTER_TEST "FILTER_HID_XML_FILTER_TEST"
-#define HID_XML_FILTER_DELETE "FILTER_HID_XML_FILTER_DELETE"
-#define HID_XML_FILTER_SAVE "FILTER_HID_XML_FILTER_SAVE"
-#define HID_XML_FILTER_OPEN "FILTER_HID_XML_FILTER_OPEN"
-#define HID_XML_FILTER_CLOSE "FILTER_HID_XML_FILTER_CLOSE"
#define HID_XML_FILTER_TABDIALOG "FILTER_HID_XML_FILTER_TABDIALOG"
#define HID_XML_FILTER_TABPAGE_BASIC "FILTER_HID_XML_FILTER_TABPAGE_BASIC"
diff --git a/filter/source/xsltdialog/xmlfiltersettingsdialog.cxx b/filter/source/xsltdialog/xmlfiltersettingsdialog.cxx
index 64f1baa0d32d..fc04e65495e7 100644
--- a/filter/source/xsltdialog/xmlfiltersettingsdialog.cxx
+++ b/filter/source/xsltdialog/xmlfiltersettingsdialog.cxx
@@ -38,7 +38,6 @@
#include "xmlfilterdialogstrings.hrc"
#include "xmlfiltersettingsdialog.hxx"
-#include "xmlfiltersettingsdialog.hrc"
#include "xmlfiltertabdialog.hxx"
#include "xmlfiltertestdialog.hxx"
#include "xmlfilterjar.hxx"
@@ -56,43 +55,38 @@ using namespace com::sun::star::util;
using ::rtl::OUString;
using ::rtl::Uri;
-ResMgr* XMLFilterSettingsDialog::mpResMgr = NULL;
-
-XMLFilterSettingsDialog::XMLFilterSettingsDialog( Window* pParent, ResMgr& rResMgr, const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxMSF ) :
- WorkWindow( pParent, ResId( DLG_XML_FILTER_SETTINGS_DIALOG, rResMgr ) ),
- mxMSF( rxMSF ),
- maCtrlFilterList( this, ResId( CTRL_XML_FILTER_LIST, rResMgr ) ),
- maPBNew( this, ResId( PB_XML_FILTER_NEW, rResMgr ) ),
- maPBEdit( this, ResId( PB_XML_FILTER_EDIT, rResMgr ) ),
- maPBTest( this, ResId( PB_XML_FILTER_TEST, rResMgr ) ),
- maPBDelete( this, ResId( PB_XML_FILTER_DELETE, rResMgr ) ),
- maPBSave( this, ResId( PB_XML_FILTER_SAVE, rResMgr ) ),
- maPBOpen( this, ResId( PB_XML_FILTER_OPEN, rResMgr ) ),
- maPBHelp( this, ResId( BTN_XML_FILTER_HELP, rResMgr ) ),
- maPBClose( this, ResId( PB_XML_FILTER_CLOSE, rResMgr ) ),
- mbIsClosable(true),
- sTemplatePath( RTL_CONSTASCII_USTRINGPARAM( "$(user)/template/") ),
- sDocTypePrefix( RTL_CONSTASCII_USTRINGPARAM( "doctype:") )
+XMLFilterSettingsDialog::XMLFilterSettingsDialog(Window* pParent,
+ const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxMSF)
+ : Dialog(pParent, "XMLFilterSettingsDialog", "filter/ui/xmlfiltersettings.ui")
+ , mxMSF( rxMSF )
+ , m_bIsClosable(true)
+ , m_sTemplatePath("$(user)/template/")
+ , m_sDocTypePrefix("doctype:")
{
- mpResMgr = &rResMgr;
-
- mpFilterListBox = new XMLFilterListBox( &maCtrlFilterList );
- mpFilterListBox->SetSelectHdl( LINK( this, XMLFilterSettingsDialog, SelectionChangedHdl_Impl ) );
- mpFilterListBox->SetDeselectHdl( LINK( this, XMLFilterSettingsDialog, SelectionChangedHdl_Impl ) );
- mpFilterListBox->SetDoubleClickHdl( LINK( this, XMLFilterSettingsDialog, DoubleClickHdl_Impl ) );
- mpFilterListBox->SetAccessibleName(RESIDSTR(STR_XML_FILTER_LISTBOX));
- maCtrlFilterList.SetAccessibleName(RESIDSTR(STR_XML_FILTER_LISTBOX));
- mpFilterListBox->SetHelpId( HID_XML_FILTER_LIST );
-
- FreeResource();
-
- maPBNew.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
- maPBEdit.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
- maPBTest.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
- maPBDelete.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
- maPBSave.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
- maPBOpen.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
- maPBClose.SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ get(m_pCtrlFilterList, "filterlist");
+ get(m_pPBNew, "new");
+ get(m_pPBEdit, "edit");
+ get(m_pPBTest, "test");
+ get(m_pPBDelete, "delete");
+ get(m_pPBSave, "save");
+ get(m_pPBOpen, "open");
+ get(m_pPBClose, "close");
+
+ m_pFilterListBox = m_pCtrlFilterList->getListBox();
+ m_pFilterListBox->SetSelectHdl( LINK( this, XMLFilterSettingsDialog, SelectionChangedHdl_Impl ) );
+ m_pFilterListBox->SetDeselectHdl( LINK( this, XMLFilterSettingsDialog, SelectionChangedHdl_Impl ) );
+ m_pFilterListBox->SetDoubleClickHdl( LINK( this, XMLFilterSettingsDialog, DoubleClickHdl_Impl ) );
+ m_pFilterListBox->SetAccessibleName(RESIDSTR(STR_XML_FILTER_LISTBOX));
+ m_pCtrlFilterList->SetAccessibleName(RESIDSTR(STR_XML_FILTER_LISTBOX));
+ m_pFilterListBox->SetHelpId( HID_XML_FILTER_LIST );
+
+ m_pPBNew->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ m_pPBEdit->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ m_pPBTest->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ m_pPBDelete->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ m_pPBSave->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ m_pPBOpen->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
+ m_pPBClose->SetClickHdl(LINK( this, XMLFilterSettingsDialog, ClickHdl_Impl ) );
try
{
@@ -103,7 +97,7 @@ XMLFilterSettingsDialog::XMLFilterSettingsDialog( Window* pParent, ResMgr& rResM
Reference< XConfigManager > xCfgMgr( mxMSF->createInstance(OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.config.SpecialConfigManager" )) ), UNO_QUERY );
if( xCfgMgr.is() )
{
- sTemplatePath = xCfgMgr->substituteVariables( sTemplatePath );
+ m_sTemplatePath = xCfgMgr->substituteVariables( m_sTemplatePath );
}
}
catch(const Exception&)
@@ -114,47 +108,40 @@ XMLFilterSettingsDialog::XMLFilterSettingsDialog( Window* pParent, ResMgr& rResM
// -----------------------------------------------------------------------
-XMLFilterSettingsDialog::~XMLFilterSettingsDialog()
-{
- delete mpFilterListBox;
-}
-
-// -----------------------------------------------------------------------
-
IMPL_LINK(XMLFilterSettingsDialog, ClickHdl_Impl, PushButton *, pButton )
{
- mbIsClosable = false;
+ m_bIsClosable = false;
- if( &maPBNew == pButton )
+ if (m_pPBNew == pButton)
{
onNew();
}
- else if( &maPBEdit == pButton )
+ else if (m_pPBEdit == pButton)
{
onEdit();
}
- else if( &maPBTest == pButton )
+ else if (m_pPBTest == pButton)
{
onTest();
}
- else if( &maPBDelete == pButton )
+ else if (m_pPBDelete == pButton)
{
onDelete();
}
- else if( &maPBSave == pButton )
+ else if (m_pPBSave == pButton)
{
onSave();
}
- else if( &maPBOpen == pButton )
+ else if (m_pPBOpen == pButton)
{
onOpen();
}
- else if( &maPBClose == pButton )
+ else if (m_pPBClose == pButton)
{
onClose();
}
- mbIsClosable = true;
+ m_bIsClosable = true;
return 0;
}
@@ -176,32 +163,31 @@ IMPL_LINK_NOARG(XMLFilterSettingsDialog, DoubleClickHdl_Impl)
bool XMLFilterSettingsDialog::isClosable()
{
- return mbIsClosable;
+ return m_bIsClosable;
}
// -----------------------------------------------------------------------
-void XMLFilterSettingsDialog::ShowWindow()
+short XMLFilterSettingsDialog::Execute()
{
- maCtrlFilterList.GrabFocus();
+ m_pCtrlFilterList->GrabFocus();
disposeFilterList();
- mpFilterListBox->Clear();
+ m_pFilterListBox->Clear();
initFilterList();
updateStates();
- mpFilterListBox->Reset();
- WorkWindow::Show( sal_True );
+ return Dialog::Execute();
}
// -----------------------------------------------------------------------
void XMLFilterSettingsDialog::updateStates()
{
- SvTreeListEntry* pSelectedEntry = mpFilterListBox->FirstSelected();
+ SvTreeListEntry* pSelectedEntry = m_pFilterListBox->FirstSelected();
bool bHasSelection = pSelectedEntry != NULL;
- bool bMultiSelection = bHasSelection && (mpFilterListBox->NextSelected( pSelectedEntry ) != NULL );
+ bool bMultiSelection = bHasSelection && (m_pFilterListBox->NextSelected( pSelectedEntry ) != NULL );
bool bIsReadonly = false;
bool bIsDefault = false;
if(pSelectedEntry)
@@ -221,10 +207,10 @@ void XMLFilterSettingsDialog::updateStates()
++nFact;
}
}
- maPBEdit.Enable( bHasSelection && !bMultiSelection && !bIsReadonly);
- maPBTest.Enable( bHasSelection && !bMultiSelection );
- maPBDelete.Enable( bHasSelection && !bMultiSelection && !bIsReadonly && !bIsDefault);
- maPBSave.Enable( bHasSelection );
+ m_pPBEdit->Enable( bHasSelection && !bMultiSelection && !bIsReadonly);
+ m_pPBTest->Enable( bHasSelection && !bMultiSelection );
+ m_pPBDelete->Enable( bHasSelection && !bMultiSelection && !bIsReadonly && !bIsDefault);
+ m_pPBSave->Enable( bHasSelection );
}
// -----------------------------------------------------------------------
@@ -248,7 +234,7 @@ void XMLFilterSettingsDialog::onNew()
aTempInfo.maDocumentService = OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.text.TextDocument" ));
// execute XML Filter Dialog
- XMLFilterTabDialog aDlg( this, *mpResMgr, mxMSF, &aTempInfo );
+ XMLFilterTabDialog aDlg( this, *getXSLTDialogResMgr(), mxMSF, &aTempInfo );
if ( aDlg.Execute() == RET_OK )
{
// insert the new filter
@@ -262,14 +248,14 @@ void XMLFilterSettingsDialog::onNew()
void XMLFilterSettingsDialog::onEdit()
{
// get selected filter entry
- SvTreeListEntry* pEntry = mpFilterListBox->FirstSelected();
+ SvTreeListEntry* pEntry = m_pFilterListBox->FirstSelected();
if( pEntry )
{
// get its filter info
filter_info_impl* pOldInfo = (filter_info_impl*)pEntry->GetUserData();
// execute XML Filter Dialog
- XMLFilterTabDialog aDlg( this, *mpResMgr, mxMSF, pOldInfo );
+ XMLFilterTabDialog aDlg( this, *getXSLTDialogResMgr(), mxMSF, pOldInfo );
if ( aDlg.Execute() == RET_OK )
{
filter_info_impl* pNewInfo = aDlg.getNewFilterInfo();
@@ -497,12 +483,12 @@ bool XMLFilterSettingsDialog::insertOrEdit( filter_info_impl* pNewInfo, const fi
// check if we need to copy the template
if( !pFilterEntry->maImportTemplate.isEmpty() )
{
- if( !pFilterEntry->maImportTemplate.matchIgnoreAsciiCase( sTemplatePath ) )
+ if( !pFilterEntry->maImportTemplate.matchIgnoreAsciiCase( m_sTemplatePath ) )
{
INetURLObject aSourceURL( pFilterEntry->maImportTemplate );
if( !aSourceURL.GetName().isEmpty() )
{
- OUString aDestURL( sTemplatePath );
+ OUString aDestURL( m_sTemplatePath );
aDestURL += pFilterEntry->maFilterName;
aDestURL += OUString( sal_Unicode('/') );
if( createDirectory( aDestURL ) )
@@ -607,16 +593,16 @@ bool XMLFilterSettingsDialog::insertOrEdit( filter_info_impl* pNewInfo, const fi
aValues[0].Value <<= pFilterEntry->maInterfaceName;
aValues[1].Name = OUString( RTL_CONSTASCII_USTRINGPARAM( "ClipboardFormat" ) );
OUString aDocType;
- if( !pFilterEntry->maDocType.match( sDocTypePrefix ) )
+ if( !pFilterEntry->maDocType.match( m_sDocTypePrefix ) )
{
- aDocType = sDocTypePrefix;
+ aDocType = m_sDocTypePrefix;
aDocType += pFilterEntry->maDocType;
}
else
{
aDocType = pFilterEntry->maDocType;
}
- if (aDocType == sDocTypePrefix)
+ if (aDocType == m_sDocTypePrefix)
aValues[1].Value <<= OUString();
else
aValues[1].Value <<= aDocType;
@@ -628,7 +614,7 @@ bool XMLFilterSettingsDialog::insertOrEdit( filter_info_impl* pNewInfo, const fi
aValues[3].Value <<= createExtensionsSequence( pFilterEntry->maExtension );
// the detect service will only be registered, if a doctype/search token was specified
- if (aDocType.getLength() > sDocTypePrefix.getLength())
+ if (aDocType.getLength() > m_sDocTypePrefix.getLength())
{
aValues.realloc(5);
aValues[4].Name = OUString( RTL_CONSTASCII_USTRINGPARAM( "DetectService" ) );
@@ -774,11 +760,11 @@ bool XMLFilterSettingsDialog::insertOrEdit( filter_info_impl* pNewInfo, const fi
{
if( pOldInfo )
{
- mpFilterListBox->changeEntry( pFilterEntry );
+ m_pFilterListBox->changeEntry( pFilterEntry );
}
else
{
- mpFilterListBox->addFilterEntry( pFilterEntry );
+ m_pFilterListBox->addFilterEntry( pFilterEntry );
maFilterVector.push_back( pFilterEntry );
}
}
@@ -792,12 +778,12 @@ bool XMLFilterSettingsDialog::insertOrEdit( filter_info_impl* pNewInfo, const fi
void XMLFilterSettingsDialog::onTest()
{
// get the first selected filter
- SvTreeListEntry* pEntry = mpFilterListBox->FirstSelected();
+ SvTreeListEntry* pEntry = m_pFilterListBox->FirstSelected();
if( pEntry )
{
filter_info_impl* pInfo = (filter_info_impl*)pEntry->GetUserData();
- XMLFilterTestDialog aDlg( this, *mpResMgr, mxMSF );
+ XMLFilterTestDialog aDlg( this, *getXSLTDialogResMgr(), mxMSF );
aDlg.test( *pInfo );
}
}
@@ -806,7 +792,7 @@ void XMLFilterSettingsDialog::onTest()
void XMLFilterSettingsDialog::onDelete()
{
- SvTreeListEntry* pEntry = mpFilterListBox->FirstSelected();
+ SvTreeListEntry* pEntry = m_pFilterListBox->FirstSelected();
if( pEntry )
{
filter_info_impl* pInfo = (filter_info_impl*)pEntry->GetUserData();
@@ -876,7 +862,7 @@ void XMLFilterSettingsDialog::onDelete()
xFlushable->flush();
// now remove entry from ui
- mpFilterListBox->RemoveSelection();
+ m_pFilterListBox->RemoveSelection();
// and delete the filter entry
maFilterVector.erase(std::find( maFilterVector.begin(), maFilterVector.end(), pInfo ));
@@ -902,12 +888,12 @@ void XMLFilterSettingsDialog::onSave()
int nFilters = 0;
- SvTreeListEntry* pEntry = mpFilterListBox->FirstSelected();
+ SvTreeListEntry* pEntry = m_pFilterListBox->FirstSelected();
while( pEntry )
{
filter_info_impl* pInfo = (filter_info_impl*)pEntry->GetUserData();
aFilters.push_back( pInfo );
- pEntry = mpFilterListBox->NextSelected( pEntry );
+ pEntry = m_pFilterListBox->NextSelected( pEntry );
nFilters++;
}
@@ -1030,7 +1016,7 @@ void XMLFilterSettingsDialog::onClose()
long XMLFilterSettingsDialog::Notify( NotifyEvent& rNEvt )
{
// Zuerst Basisklasse rufen wegen TabSteuerung
- long nRet = WorkWindow::Notify( rNEvt );
+ long nRet = Dialog::Notify( rNEvt );
if ( !nRet )
{
if ( rNEvt.GetType() == EVENT_KEYINPUT )
@@ -1062,7 +1048,7 @@ void XMLFilterSettingsDialog::disposeFilterList()
}
maFilterVector.clear();
- mpFilterListBox->Clear();
+ m_pFilterListBox->Clear();
}
// -----------------------------------------------------------------------
@@ -1184,8 +1170,8 @@ void XMLFilterSettingsDialog::initFilterList()
OUString aDocType;
pValues2->Value >>= aDocType;
- if( aDocType.match( sDocTypePrefix ) )
- aDocType = aDocType.copy( sDocTypePrefix.getLength() );
+ if( aDocType.match( m_sDocTypePrefix ) )
+ aDocType = aDocType.copy( m_sDocTypePrefix.getLength() );
pTempFilter->maDocType = aDocType;
}
@@ -1229,7 +1215,7 @@ void XMLFilterSettingsDialog::initFilterList()
// add entry to internal container and to ui filter list box
maFilterVector.push_back( pTempFilter );
- mpFilterListBox->addFilterEntry( pTempFilter );
+ m_pFilterListBox->addFilterEntry( pTempFilter );
pTempFilter = new filter_info_impl;
@@ -1244,9 +1230,9 @@ void XMLFilterSettingsDialog::initFilterList()
delete pTempFilter;
}
- SvTreeListEntry* pEntry = mpFilterListBox->GetEntry( 0 );
+ SvTreeListEntry* pEntry = m_pFilterListBox->GetEntry( 0 );
if( pEntry )
- mpFilterListBox->Select( pEntry );
+ m_pFilterListBox->Select( pEntry );
}
// -----------------------------------------------------------------------
@@ -1371,83 +1357,88 @@ OUString getApplicationUIName( const OUString& rServiceName )
}
}
-// -----------------------------------------------------------------------
+SvxPathControl::SvxPathControl(Window* pParent)
+ : VclVBox(pParent)
+ , bHasBeenShown(false)
+{
+ m_pHeaderBar = new HeaderBar(this, WB_BOTTOMBORDER);
+ m_pHeaderBar->set_height_request(16);
-ResMgr* getXSLTDialogResMgr()
+ m_pFocusCtrl = new XMLFilterListBox(this);
+ m_pFocusCtrl->set_fill(true);
+ m_pFocusCtrl->set_expand(true);
+}
+
+#define ITEMID_NAME 1
+#define ITEMID_TYPE 2
+
+void SvxPathControl::setAllocation(const Size &rAllocation)
{
- return XMLFilterSettingsDialog::mpResMgr;
+ VclVBox::setAllocation(rAllocation);
+
+ if (!bHasBeenShown)
+ bHasBeenShown = IsReallyShown();
+
+ if (!bHasBeenShown)
+ {
+ std::vector<long> aWidths;
+ m_pFocusCtrl->getPreferredDimensions(aWidths);
+ long nFirstColumnWidth = aWidths[1];
+ m_pHeaderBar->SetItemSize(ITEMID_NAME, nFirstColumnWidth);
+ m_pHeaderBar->SetItemSize(ITEMID_TYPE, 0xFFFF);
+ long nTabs[] = {2, 0, nFirstColumnWidth};
+ m_pFocusCtrl->SetTabs(&nTabs[0], MAP_PIXEL);
+ }
}
-// -----------------------------------------------------------------------
+SvxPathControl::~SvxPathControl()
+{
+ delete m_pFocusCtrl;
+ delete m_pHeaderBar;
+}
-// -----------------------------------------------------------------------
+extern "C" SAL_DLLPUBLIC_EXPORT Window* SAL_CALL makeSvxPathControl(Window *pParent, VclBuilder::stringmap &)
+{
+ return new SvxPathControl(pParent);
+}
-long SvxPathControl_Impl::Notify( NotifyEvent& rNEvt )
+long SvxPathControl::Notify(NotifyEvent& rNEvt)
{
- long nRet = Control::Notify( rNEvt );
+ long nRet = VclVBox::Notify(rNEvt);
if ( m_pFocusCtrl && rNEvt.GetWindow() != m_pFocusCtrl && rNEvt.GetType() == EVENT_GETFOCUS )
m_pFocusCtrl->GrabFocus();
+
return nRet;
}
-#define ITEMID_NAME 1
-#define ITEMID_TYPE 2
-
-XMLFilterListBox::XMLFilterListBox( SvxPathControl_Impl * pParent )
-: SvTabListBox( pParent, WB_SORT | WB_HSCROLL | WB_CLIPCHILDREN | WB_TABSTOP ),
- mbFirstPaint( true )
+XMLFilterListBox::XMLFilterListBox(SvxPathControl* pParent)
+ : SvTabListBox(pParent, WB_SORT | WB_HSCROLL | WB_CLIPCHILDREN | WB_TABSTOP)
+ , mbFirstPaint(true)
+ , m_pHeaderBar(pParent->getHeaderBar())
{
Size aBoxSize( pParent->GetOutputSizePixel() );
- mpHeaderBar = new HeaderBar( pParent, /*WB_BUTTONSTYLE | */ WB_BOTTOMBORDER );
- mpHeaderBar->SetPosSizePixel( Point( 0, 0 ), Size( aBoxSize.Width(), 16 ) );
- mpHeaderBar->SetEndDragHdl( LINK( this, XMLFilterListBox, HeaderEndDrag_Impl ) );
+ m_pHeaderBar->SetEndDragHdl( LINK( this, XMLFilterListBox, HeaderEndDrag_Impl ) );
OUString aStr1(RESIDSTR(STR_COLUMN_HEADER_NAME));
OUString aStr2(RESIDSTR(STR_COLUMN_HEADER_TYPE));
long nTabSize = aBoxSize.Width() / 2;
- mpHeaderBar->InsertItem( ITEMID_NAME, aStr1, nTabSize,
+ m_pHeaderBar->InsertItem( ITEMID_NAME, aStr1, nTabSize,
HIB_LEFT | HIB_VCENTER );
- mpHeaderBar->InsertItem( ITEMID_TYPE, aStr2, nTabSize,
+ m_pHeaderBar->InsertItem( ITEMID_TYPE, aStr2, nTabSize,
HIB_LEFT | HIB_VCENTER );
- static long nTabs[] = {3, 0, nTabSize, 2*nTabSize };
- Size aHeadSize( mpHeaderBar->GetSizePixel() );
+ static long nTabs[] = {2, 0, nTabSize };
- pParent->SetFocusControl( this );
-// SetDoubleClickHdl( aLink );
-// SetSelectHdl( LINK( this, SvxPathTabPage, PathSelect_Impl ) );
SetSelectionMode( MULTIPLE_SELECTION );
- SetPosSizePixel( Point( 0, aHeadSize.Height() ), Size( aBoxSize.Width(), aBoxSize.Height() - aHeadSize.Height() ) );
SetTabs( &nTabs[0], MAP_PIXEL );
SetScrolledHdl( LINK( this, XMLFilterListBox, TabBoxScrollHdl_Impl ) );
SetHighlightRange();
-// SetHelpId( HID_OPTPATH_CTL_PATH );
-// mpHeaderBar->SetHelpId( HID_OPTPATH_HEADERBAR );
Show();
- mpHeaderBar->Show();
-}
-
-// -----------------------------------------------------------------------
-
-XMLFilterListBox::~XMLFilterListBox()
-{
- delete mpHeaderBar;
-}
-
-// -----------------------------------------------------------------------
-
-void XMLFilterListBox::Reset()
-{
- Size aBoxSize( Window::GetParent()->GetOutputSizePixel() );
- long nTabSize = aBoxSize.Width() / 2;
- static long nTabs[] = {3, 0, nTabSize, 2*nTabSize };
- SetTabs( &nTabs[0], MAP_PIXEL );
- mpHeaderBar->SetItemSize( ITEMID_NAME, nTabSize );
- mpHeaderBar->SetItemSize( ITEMID_TYPE, nTabSize );
+ m_pHeaderBar->Show();
}
// -----------------------------------------------------------------------
@@ -1465,7 +1456,7 @@ void XMLFilterListBox::Paint( const Rectangle& rRect )
IMPL_LINK( XMLFilterListBox, TabBoxScrollHdl_Impl, SvTabListBox*, /* pList */ )
{
- mpHeaderBar->SetOffset( -GetXOffset() );
+ m_pHeaderBar->SetOffset( -GetXOffset() );
return 0;
}
@@ -1476,22 +1467,22 @@ IMPL_LINK( XMLFilterListBox, HeaderEndDrag_Impl, HeaderBar*, pBar )
if ( pBar && !pBar->GetCurItemId() )
return 0;
- if ( !mpHeaderBar->IsItemMode() )
+ if ( !m_pHeaderBar->IsItemMode() )
{
Size aSz;
- sal_uInt16 nTabs = mpHeaderBar->GetItemCount();
+ sal_uInt16 nTabs = m_pHeaderBar->GetItemCount();
long nTmpSz = 0;
- long nWidth = mpHeaderBar->GetItemSize(ITEMID_NAME);
- long nBarWidth = mpHeaderBar->GetSizePixel().Width();
+ long nWidth = m_pHeaderBar->GetItemSize(ITEMID_NAME);
+ long nBarWidth = m_pHeaderBar->GetSizePixel().Width();
if(nWidth < 30)
- mpHeaderBar->SetItemSize( ITEMID_TYPE, 30);
+ m_pHeaderBar->SetItemSize( ITEMID_TYPE, 30);
else if ( ( nBarWidth - nWidth ) < 30 )
- mpHeaderBar->SetItemSize( ITEMID_TYPE, nBarWidth - 30 );
+ m_pHeaderBar->SetItemSize( ITEMID_TYPE, nBarWidth - 30 );
for ( sal_uInt16 i = 1; i <= nTabs; ++i )
{
- long nW = mpHeaderBar->GetItemSize(i);
+ long nW = m_pHeaderBar->GetItemSize(i);
aSz.Width() = nW + nTmpSz;
nTmpSz += nW;
SetTab( i, PixelToLogic( aSz, MapMode(MAP_APPFONT) ).Width(), MAP_APPFONT );
@@ -1533,7 +1524,6 @@ String XMLFilterListBox::getEntryString( const filter_info_impl* pInfo ) const
{
String aEntryStr( pInfo->maFilterName );
aEntryStr += '\t';
- // aEntryStr += String( getApplicationUIName( pInfo->maDocumentService ) );
if ( !pInfo->maExportService.isEmpty() )
aEntryStr += String( getApplicationUIName( pInfo->maExportService ) );
else
diff --git a/filter/source/xsltdialog/xmlfiltersettingsdialog.hrc b/filter/source/xsltdialog/xmlfiltersettingsdialog.hrc
deleted file mode 100644
index 3f10ab5c8812..000000000000
--- a/filter/source/xsltdialog/xmlfiltersettingsdialog.hrc
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * 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 _XMLFILTERSETTINGSDIALOG_HRC_
-#define _XMLFILTERSETTINGSDIALOG_HRC_
-
-#include "xmlfiltercommon.hrc"
-
-#define CTRL_XML_FILTER_LIST 1
-#define PB_XML_FILTER_NEW 2
-#define PB_XML_FILTER_EDIT 3
-#define PB_XML_FILTER_TEST 4
-#define PB_XML_FILTER_DELETE 5
-#define PB_XML_FILTER_SAVE 6
-#define PB_XML_FILTER_OPEN 7
-#define BTN_XML_FILTER_HELP 8
-#define PB_XML_FILTER_CLOSE 9
-#define STR_XML_FILTER_LISTBOX 10
-#endif
diff --git a/filter/source/xsltdialog/xmlfiltersettingsdialog.hxx b/filter/source/xsltdialog/xmlfiltersettingsdialog.hxx
index 57330ef6b0fe..006d4e0544ec 100644
--- a/filter/source/xsltdialog/xmlfiltersettingsdialog.hxx
+++ b/filter/source/xsltdialog/xmlfiltersettingsdialog.hxx
@@ -23,9 +23,9 @@
#include <com/sun/star/lang/XMultiServiceFactory.hpp>
#include <com/sun/star/container/XHierarchicalName.hpp>
#include <com/sun/star/container/XNameContainer.hpp>
-#include <vcl/wrkwin.hxx>
-
#include <vcl/button.hxx>
+#include <vcl/dialog.hxx>
+#include <vcl/layout.hxx>
#include <svtools/svtabbx.hxx>
#include <svl/poolitem.hxx>
#include <unotools/moduleoptions.hxx>
@@ -34,16 +34,22 @@
// --------------------------------------------------------------------
-class SvxPathControl_Impl : public Control
+class HeaderBar;
+class XMLFilterListBox;
+
+class SvxPathControl : public VclVBox
{
private:
- Control* m_pFocusCtrl;
-
+ bool bHasBeenShown;
+ HeaderBar* m_pHeaderBar;
+ XMLFilterListBox* m_pFocusCtrl;
+protected:
+ virtual void setAllocation(const Size &rAllocation);
public:
- SvxPathControl_Impl( Window* pParent, const ResId& rId ) :
- Control( pParent, rId ), m_pFocusCtrl( NULL ) {}
-
- void SetFocusControl( Control* pCtrl ) { m_pFocusCtrl = pCtrl; }
+ SvxPathControl(Window* pParent);
+ HeaderBar* getHeaderBar() { return m_pHeaderBar; }
+ XMLFilterListBox* getListBox() { return m_pFocusCtrl; }
+ ~SvxPathControl();
virtual long Notify( NotifyEvent& rNEvt );
};
@@ -56,7 +62,7 @@ class XMLFilterListBox : public SvTabListBox
{
private:
bool mbFirstPaint;
- HeaderBar* mpHeaderBar;
+ HeaderBar* m_pHeaderBar;
DECL_LINK( TabBoxScrollHdl_Impl, SvTabListBox* );
DECL_LINK( HeaderEndDrag_Impl, HeaderBar* );
@@ -64,10 +70,7 @@ private:
String getEntryString( const filter_info_impl* pInfo ) const;
public:
- XMLFilterListBox( SvxPathControl_Impl* pParent );
- ~XMLFilterListBox();
-
- void Reset();
+ XMLFilterListBox(SvxPathControl* pParent);
/** adds a new filter info entry to the ui filter list */
void addFilterEntry( const filter_info_impl* pInfo );
@@ -79,17 +82,17 @@ public:
// --------------------------------------------------------------------
-class XMLFilterSettingsDialog : public WorkWindow
+class XMLFilterSettingsDialog : public Dialog
{
public:
- XMLFilterSettingsDialog( Window* pParent, ResMgr& rResMgr, const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxMSF );
- virtual ~XMLFilterSettingsDialog();
+ XMLFilterSettingsDialog(Window* pParent,
+ const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxMSF);
DECL_LINK(ClickHdl_Impl, PushButton * );
DECL_LINK(SelectionChangedHdl_Impl, void * );
DECL_LINK(DoubleClickHdl_Impl, void * );
- void ShowWindow();
+ virtual short Execute();
void onNew();
void onEdit();
@@ -105,8 +108,6 @@ public:
bool isClosable();
- static ResMgr* mpResMgr;
-
private:
void initFilterList();
void disposeFilterList();
@@ -126,21 +127,20 @@ private:
std::vector< filter_info_impl* > maFilterVector;
- XMLFilterListBox* mpFilterListBox;
- SvxPathControl_Impl maCtrlFilterList;
- PushButton maPBNew;
- PushButton maPBEdit;
- PushButton maPBTest;
- PushButton maPBDelete;
- PushButton maPBSave;
- PushButton maPBOpen;
- HelpButton maPBHelp;
- PushButton maPBClose;
-
- bool mbIsClosable;
-
- ::rtl::OUString sTemplatePath;
- ::rtl::OUString sDocTypePrefix;
+ XMLFilterListBox* m_pFilterListBox;
+ SvxPathControl* m_pCtrlFilterList;
+ PushButton* m_pPBNew;
+ PushButton* m_pPBEdit;
+ PushButton* m_pPBTest;
+ PushButton* m_pPBDelete;
+ PushButton* m_pPBSave;
+ PushButton* m_pPBOpen;
+ PushButton* m_pPBClose;
+
+ bool m_bIsClosable;
+
+ OUString m_sTemplatePath;
+ OUString m_sDocTypePrefix;
SvtModuleOptions maModuleOpt;
};
diff --git a/filter/source/xsltdialog/xmlfiltersettingsdialog.src b/filter/source/xsltdialog/xmlfiltersettingsdialog.src
deleted file mode 100644
index 77d1d789f61b..000000000000
--- a/filter/source/xsltdialog/xmlfiltersettingsdialog.src
+++ /dev/null
@@ -1,123 +0,0 @@
-/*
- * 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 .
- */
-
-#include "xmlfiltersettingsdialog.hrc"
-#include "xmlfilterhelpids.hrc"
-
-#define BUTTONS_LEFT 248
-#define BUTTONS_TOP 6
-#define BUTTONS_SPACEING 3
-#define BUTTONS_WIDTH 66
-#define BUTTONS_HEIGHT 14
-
-WorkWindow DLG_XML_FILTER_SETTINGS_DIALOG
-{
- Size = MAP_APPFONT( 320, 154 );
- HelpId = HID_XML_FILTER_SETTINGS_DIALOG;
- OutputSize = TRUE ;
- SVLook = TRUE ;
- Moveable = TRUE ;
- Closeable = TRUE ;
- Sizeable = FALSE;
- DialogControl = TRUE ;
- Text [ en-US ] = "XML Filter Settings" ;
-
- Control CTRL_XML_FILTER_LIST
- {
- Pos = MAP_APPFONT ( 6 , 6 ) ;
- Size = MAP_APPFONT ( 235 , 142 );
- Border = TRUE ;
- TabStop = TRUE ;
- };
-
- PushButton PB_XML_FILTER_NEW
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 0 * BUTTONS_HEIGHT + 0 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_NEW;
- TabStop = TRUE ;
- Text [ en-US ] = "~New...";
- };
-
- PushButton PB_XML_FILTER_EDIT
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 1 * BUTTONS_HEIGHT + 1 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_EDIT;
- TabStop = TRUE ;
- Text [ en-US ] = "~Edit...";
- };
-
- PushButton PB_XML_FILTER_TEST
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 2 * BUTTONS_HEIGHT + 2 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_TEST;
- TabStop = TRUE ;
- Text [ en-US ] = "~Test XSLTs...";
- };
-
- PushButton PB_XML_FILTER_DELETE
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 3 * BUTTONS_HEIGHT + 4 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_DELETE;
- TabStop = TRUE ;
- Text [ en-US ] = "~Delete...";
- };
-
- PushButton PB_XML_FILTER_SAVE
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 4 * BUTTONS_HEIGHT + 6 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_SAVE;
- TabStop = TRUE ;
- Text [ en-US ] = "~Save as Package...";
- };
-
- PushButton PB_XML_FILTER_OPEN
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 5 * BUTTONS_HEIGHT + 7 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_OPEN;
- TabStop = TRUE ;
- Text [ en-US ] = "~Open Package...";
- TabStop = TRUE ;
- };
-
- HelpButton BTN_XML_FILTER_HELP
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT, BUTTONS_TOP + 6 * BUTTONS_HEIGHT + 9 * BUTTONS_SPACEING );
- Size = MAP_APPFONT ( BUTTONS_WIDTH, BUTTONS_HEIGHT );
- };
-
- PushButton PB_XML_FILTER_CLOSE
- {
- Pos = MAP_APPFONT ( BUTTONS_LEFT , BUTTONS_TOP + 7 * BUTTONS_HEIGHT + 10 * BUTTONS_SPACEING ) ;
- Size = MAP_APPFONT ( BUTTONS_WIDTH , BUTTONS_HEIGHT ) ;
- HelpId = HID_XML_FILTER_CLOSE;
- TabStop = TRUE ;
- Text [ en-US ] = "~Close";
- };
-
- String STR_XML_FILTER_LISTBOX
- {
- Text [ en-US ] = "XML Filter List";
- };
-
-};
diff --git a/filter/source/xsltdialog/xmlfiltertabdialog.cxx b/filter/source/xsltdialog/xmlfiltertabdialog.cxx
index ddd50412d916..a9152ddfd076 100644
--- a/filter/source/xsltdialog/xmlfiltertabdialog.cxx
+++ b/filter/source/xsltdialog/xmlfiltertabdialog.cxx
@@ -31,7 +31,6 @@
#include "xmlfiltertabpagebasic.hxx"
#include "xmlfiltertabpagexslt.hxx"
#include "xmlfiltersettingsdialog.hxx"
-#include "xmlfiltersettingsdialog.hrc"
#include "xmlfilterhelpids.hrc"
using namespace com::sun::star::uno;
diff --git a/filter/uiconfig/ui/xmlfiltersettings.ui b/filter/uiconfig/ui/xmlfiltersettings.ui
new file mode 100644
index 000000000000..6b95c7e6db5c
--- /dev/null
+++ b/filter/uiconfig/ui/xmlfiltersettings.ui
@@ -0,0 +1,182 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<interface>
+ <!-- interface-requires gtk+ 3.0 -->
+ <object class="GtkDialog" id="XMLFilterSettingsDialog">
+ <property name="can_focus">False</property>
+ <property name="border_width">5</property>
+ <property name="title" translatable="yes">XML Filter Settings</property>
+ <property name="type_hint">dialog</property>
+ <child internal-child="vbox">
+ <object class="GtkBox" id="dialog-vbox1">
+ <property name="can_focus">False</property>
+ <property name="spacing">2</property>
+ <child internal-child="action_area">
+ <object class="GtkButtonBox" id="dialog-action_area1">
+ <property name="can_focus">False</property>
+ <property name="orientation">vertical</property>
+ <property name="homogeneous">True</property>
+ <property name="layout_style">start</property>
+ <child>
+ <object class="GtkButton" id="new">
+ <property name="label">_New...</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_underline">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="edit">
+ <property name="label">_Edit...</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_underline">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">1</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="test">
+ <property name="label">_Test XSLTs...</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_underline">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">2</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="delete">
+ <property name="label">_Delete...</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_underline">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">3</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="save">
+ <property name="label">_Save as Package...</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_underline">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">4</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="open">
+ <property name="label">_Open Package...</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_underline">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">5</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="help">
+ <property name="label">gtk-help</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_stock">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">6</property>
+ </packing>
+ </child>
+ <child>
+ <object class="GtkButton" id="close">
+ <property name="label">gtk-close</property>
+ <property name="use_action_appearance">False</property>
+ <property name="visible">True</property>
+ <property name="can_focus">True</property>
+ <property name="can_default">True</property>
+ <property name="has_default">True</property>
+ <property name="receives_default">True</property>
+ <property name="use_action_appearance">False</property>
+ <property name="use_stock">True</property>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="position">8</property>
+ </packing>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">False</property>
+ <property name="fill">True</property>
+ <property name="pack_type">end</property>
+ <property name="position">0</property>
+ </packing>
+ </child>
+ <child>
+ <object class="xsltdlglo:SvxPathControl" id="filterlist">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="height_request">100</property>
+ </object>
+ <packing>
+ <property name="expand">True</property>
+ <property name="fill">True</property>
+ <property name="position">1</property>
+ </packing>
+ </child>
+ </object>
+ </child>
+ <action-widgets>
+ <action-widget response="0">new</action-widget>
+ <action-widget response="0">edit</action-widget>
+ <action-widget response="0">test</action-widget>
+ <action-widget response="0">delete</action-widget>
+ <action-widget response="0">save</action-widget>
+ <action-widget response="0">open</action-widget>
+ <action-widget response="0">help</action-widget>
+ <action-widget response="0">close</action-widget>
+ </action-widgets>
+ </object>
+</interface>
diff --git a/svtools/inc/svtools/treelist.hxx b/svtools/inc/svtools/treelist.hxx
index 77ad16f9a317..96c78bb6b38b 100644
--- a/svtools/inc/svtools/treelist.hxx
+++ b/svtools/inc/svtools/treelist.hxx
@@ -406,7 +406,7 @@ public:
sal_Bool IsSelected( SvTreeListEntry* pEntry ) const;
sal_Bool HasEntryFocus( SvTreeListEntry* pEntry ) const;
void SetEntryFocus( SvTreeListEntry* pEntry, sal_Bool bFocus );
- const SvViewData* GetViewData( SvTreeListEntry* pEntry ) const;
+ const SvViewData* GetViewData( const SvTreeListEntry* pEntry ) const;
SvViewData* GetViewData( SvTreeListEntry* pEntry );
sal_Bool HasViewData() const
{ return maDataTable.size() > 1; } // There's always a ROOT
@@ -460,26 +460,18 @@ inline void SvListView::SetEntryFocus( SvTreeListEntry* pEntry, sal_Bool bFocus
itr->second->SetFocus(bFocus);
}
-inline const SvViewData* SvListView::GetViewData( SvTreeListEntry* pEntry ) const
+inline const SvViewData* SvListView::GetViewData( const SvTreeListEntry* pEntry ) const
{
-#ifndef DBG_UTIL
- return maDataTable.find( pEntry )->second;
-#else
- SvDataTable::const_iterator itr = maDataTable.find( pEntry );
+ SvDataTable::const_iterator itr = maDataTable.find( const_cast<SvTreeListEntry*>(pEntry) );
DBG_ASSERT(itr != maDataTable.end(),"Entry not in model or wrong view");
return itr->second;
-#endif
}
inline SvViewData* SvListView::GetViewData( SvTreeListEntry* pEntry )
{
-#ifndef DBG_UTIL
- return maDataTable.find( pEntry )->second;
-#else
SvDataTable::iterator itr = maDataTable.find( pEntry );
DBG_ASSERT(itr != maDataTable.end(),"Entry not in model or wrong view");
return itr->second;
-#endif
}
#endif
diff --git a/svtools/inc/svtools/treelistbox.hxx b/svtools/inc/svtools/treelistbox.hxx
index fda95eb6cbbf..308b2b255f5a 100644
--- a/svtools/inc/svtools/treelistbox.hxx
+++ b/svtools/inc/svtools/treelistbox.hxx
@@ -23,6 +23,7 @@
#include "svtools/svtdllapi.h"
#include <deque>
+#include <vector>
#include <vcl/ctrl.hxx>
#include <vcl/seleng.hxx>
@@ -165,10 +166,10 @@ public:
SvLBoxItem();
virtual ~SvLBoxItem();
virtual sal_uInt16 GetType() const = 0;
- const Size& GetSize( SvTreeListBox* pView, SvTreeListEntry* pEntry );
- const Size& GetSize( SvViewDataEntry* pData, sal_uInt16 nItemPos )
+ const Size& GetSize(const SvTreeListBox* pView, const SvTreeListEntry* pEntry) const;
+ const Size& GetSize(const SvViewDataEntry* pData, sal_uInt16 nItemPos) const
{
- SvViewDataItem* pIData=pData->pItemData+nItemPos;
+ const SvViewDataItem* pIData = pData->pItemData + nItemPos;
return pIData->aSize;
}
@@ -411,7 +412,8 @@ public:
sal_uLong GetLevelChildCount( SvTreeListEntry* pParent ) const;
SvViewDataEntry* GetViewDataEntry( SvTreeListEntry* pEntry ) const { return (SvViewDataEntry*)SvListView::GetViewData(pEntry); }
- SvViewDataItem* GetViewDataItem( SvTreeListEntry*, SvLBoxItem* ) const;
+ SvViewDataItem* GetViewDataItem(SvTreeListEntry*, SvLBoxItem*);
+ const SvViewDataItem* GetViewDataItem(const SvTreeListEntry*, const SvLBoxItem*) const;
bool IsInplaceEditingEnabled() const { return ((nImpFlags & SVLBOX_EDT_ENABLED) != 0); }
bool IsEditingActive() const { return ((nImpFlags & SVLBOX_IN_EDT) != 0); }
@@ -787,9 +789,13 @@ public:
void EnableContextMenuHandling( void );
void EnableContextMenuHandling( sal_Bool bEnable );
- sal_Bool IsContextMenuHandlingEnabled( void ) const;
+ sal_Bool IsContextMenuHandlingEnabled( void ) const;
void EnableList( bool _bEnable );
+
+ long getPreferredDimensions(std::vector<long> &rWidths) const;
+
+ virtual Size GetOptimalSize(WindowSizeType i_eType) const;
};
#define SV_LBOX_DD_FORMAT "SV_LBOX_DD_FORMAT"
diff --git a/svtools/source/contnr/treelistbox.cxx b/svtools/source/contnr/treelistbox.cxx
index 86fb6a5e57b9..bf9493d5b16b 100644
--- a/svtools/source/contnr/treelistbox.cxx
+++ b/svtools/source/contnr/treelistbox.cxx
@@ -359,10 +359,10 @@ SvLBoxItem::~SvLBoxItem()
DBG_DTOR(SvLBoxItem,0);
}
-const Size& SvLBoxItem::GetSize( SvTreeListBox* pView,SvTreeListEntry* pEntry )
+const Size& SvLBoxItem::GetSize(const SvTreeListBox* pView, const SvTreeListEntry* pEntry) const
{
DBG_CHKTHIS(SvLBoxItem,0);
- SvViewDataItem* pViewData = pView->GetViewDataItem( pEntry, this );
+ const SvViewDataItem* pViewData = pView->GetViewDataItem( pEntry, this );
return pViewData->aSize;
}
@@ -964,14 +964,18 @@ sal_uLong SvTreeListBox::GetLevelChildCount( SvTreeListEntry* _pParent ) const
return nCount;
}
-SvViewDataItem* SvTreeListBox::GetViewDataItem( SvTreeListEntry* pEntry, SvLBoxItem* pItem ) const
+SvViewDataItem* SvTreeListBox::GetViewDataItem(SvTreeListEntry* pEntry, SvLBoxItem* pItem)
{
- SvViewDataEntry* pEntryData =
- (SvViewDataEntry*)SvListView::GetViewData(pEntry);
+ return const_cast<SvViewDataItem*>(static_cast<const SvTreeListBox*>(this)->GetViewDataItem(pEntry, pItem));
+}
+
+const SvViewDataItem* SvTreeListBox::GetViewDataItem(const SvTreeListEntry* pEntry, const SvLBoxItem* pItem) const
+{
+ const SvViewDataEntry* pEntryData = (const SvViewDataEntry*)SvListView::GetViewData(pEntry);
DBG_ASSERT(pEntryData,"Entry not in View");
DBG_ASSERT(pEntryData->pItemData,"No ItemData");
sal_uInt16 nItemPos = pEntry->GetPos(pItem);
- return (pEntryData->pItemData+nItemPos);
+ return (pEntryData->pItemData + nItemPos);
}
SvViewData* SvTreeListBox::CreateViewData( SvTreeListEntry* )
@@ -2914,14 +2918,11 @@ void SvTreeListBox::InvalidateEntry( SvTreeListEntry* pEntry )
}
}
-
long SvTreeListBox::PaintEntry(SvTreeListEntry* pEntry,long nLine,sal_uInt16 nTabFlags)
{
return PaintEntry1(pEntry,nLine,nTabFlags);
}
-#define SV_TAB_BORDER 8
-
long SvTreeListBox::PaintEntry1(SvTreeListEntry* pEntry,long nLine,sal_uInt16 nTabFlags,
sal_Bool bHasClipRegion )
{
@@ -3397,6 +3398,56 @@ SvLBoxItem* SvTreeListBox::GetItem_Impl( SvTreeListEntry* pEntry, long nX,
return pItemClicked;
}
+long SvTreeListBox::getPreferredDimensions(std::vector<long> &rWidths) const
+{
+ long nHeight = 0;
+ rWidths.clear();
+ SvTreeListEntry* pEntry = First();
+ while (pEntry)
+ {
+ sal_uInt16 nCount = pEntry->ItemCount();
+ sal_uInt16 nCurPos = 0;
+ if (nCount > rWidths.size())
+ rWidths.resize(nCount);
+ while (nCurPos < nCount)
+ {
+ SvLBoxItem* pItem = pEntry->GetItem( nCurPos );
+ long nWidth = pItem->GetSize(this, pEntry).Width();
+ if (nWidth)
+ {
+ nWidth += SV_TAB_BORDER * 2;
+ if (nWidth > rWidths[nCurPos])
+ rWidths[nCurPos] = nWidth;
+ }
+ ++nCurPos;
+ }
+ pEntry = Next( pEntry );
+ nHeight += GetEntryHeight();
+ }
+ return nHeight;
+}
+
+Size SvTreeListBox::GetOptimalSize(WindowSizeType eType) const
+{
+ Size aRet;
+ switch (eType)
+ {
+ case WINDOWSIZE_MINIMUM:
+ case WINDOWSIZE_PREFERRED:
+ {
+ std::vector<long> aWidths;
+ aRet.Height() = getPreferredDimensions(aWidths);
+ for (size_t i = 0; i < aWidths.size(); ++i)
+ aRet.Width() += aWidths[i];
+ break;
+ }
+ default:
+ aRet = Control::GetOptimalSize(eType);
+ break;
+ }
+ return aRet;
+}
+
SvLBoxItem* SvTreeListBox::GetItem(SvTreeListEntry* pEntry,long nX,SvLBoxTab** ppTab)
{
return GetItem_Impl( pEntry, nX, ppTab, 0 );
@@ -3685,6 +3736,7 @@ void SvTreeListBox::ModelNotification( sal_uInt16 nActionId, SvTreeListEntry* pE
nContextBmpWidthMax = nMaxWidth;
SetTabs();
}
+ queue_resize();
}
break;