summaryrefslogtreecommitdiff
path: root/svx/source/gallery2/galbrws.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'svx/source/gallery2/galbrws.cxx')
-rw-r--r--svx/source/gallery2/galbrws.cxx285
1 files changed, 285 insertions, 0 deletions
diff --git a/svx/source/gallery2/galbrws.cxx b/svx/source/gallery2/galbrws.cxx
new file mode 100644
index 000000000000..b048da9bf022
--- /dev/null
+++ b/svx/source/gallery2/galbrws.cxx
@@ -0,0 +1,285 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_svx.hxx"
+
+#include <vcl/split.hxx>
+#include <vcl/ctrl.hxx>
+#include <unotools/pathoptions.hxx>
+#include <sfx2/app.hxx>
+#include <sfx2/sfxsids.hrc>
+#include "gallery.hrc"
+#include "svx/galmisc.hxx"
+#include "svx/gallery1.hxx"
+#include "galbrws1.hxx"
+#include "galbrws2.hxx"
+#include "galbrws.hxx"
+
+// -------------------
+// - GallerySplitter -
+// -------------------
+
+class GallerySplitter : public Splitter
+{
+protected:
+
+ virtual void DataChanged( const DataChangedEvent& rDCEvt );
+
+public:
+
+ GallerySplitter( Window* pParent, const ResId& rResId );
+ virtual ~GallerySplitter();
+};
+
+// -----------------------------------------------------------------------------
+
+GallerySplitter::GallerySplitter( Window* pParent, const ResId& rResId ) :
+ Splitter( pParent, rResId )
+{
+}
+
+// -----------------------------------------------------------------------------
+
+GallerySplitter::~GallerySplitter()
+{
+}
+
+// -----------------------------------------------------------------------------
+
+void GallerySplitter::DataChanged( const DataChangedEvent& rDCEvt )
+{
+ Splitter::DataChanged( rDCEvt );
+ static_cast< GalleryBrowser* >( GetParent() )->InitSettings();
+}
+
+// -------------------------
+// - SvxGalleryChildWindow -
+// -------------------------
+
+GalleryChildWindow::GalleryChildWindow( Window* _pParent, USHORT nId, SfxBindings* pBindings, SfxChildWinInfo* pInfo ) :
+ SfxChildWindow( _pParent, nId )
+{
+ pWindow = new GalleryBrowser( pBindings, this, _pParent, GAL_RESID( RID_SVXDLG_GALLERYBROWSER ) );
+ eChildAlignment = SFX_ALIGN_TOP;
+ ( (GalleryBrowser*) pWindow )->Initialize( pInfo );
+};
+
+// -----------------------------------------------------------------------------
+
+GalleryChildWindow::~GalleryChildWindow()
+{
+}
+
+// -----------------------------------------------------------------------------
+
+SFX_IMPL_DOCKINGWINDOW( GalleryChildWindow, SID_GALLERY )
+
+// ------------------
+// - GalleryBrowser -
+// ------------------
+
+GalleryBrowser::GalleryBrowser( SfxBindings* _pBindings, SfxChildWindow* pCW,
+ Window* pParent, const ResId& rResId ) :
+ SfxDockingWindow( _pBindings, pCW, pParent, rResId )
+{
+ mpGallery = Gallery::GetGalleryInstance();
+ mpBrowser1 = new GalleryBrowser1( this, GAL_RESID( GALLERY_BROWSER1 ), mpGallery );
+ mpSplitter = new GallerySplitter( this, GAL_RESID( GALLERY_SPLITTER ) );
+ mpBrowser2 = new GalleryBrowser2( this, GAL_RESID( GALLERY_BROWSER2 ), mpGallery );
+
+ FreeResource();
+ SetMinOutputSizePixel( maLastSize = GetOutputSizePixel() );
+
+ mpBrowser1->SelectTheme( 0 );
+ mpBrowser1->Show( TRUE );
+ mpBrowser2->Show( TRUE );
+
+ mpSplitter->SetSplitHdl( LINK( this, GalleryBrowser, SplitHdl ) );
+ mpSplitter->Show( TRUE );
+
+ InitSettings();
+}
+
+// -----------------------------------------------------------------------------
+
+GalleryBrowser::~GalleryBrowser()
+{
+ delete mpBrowser2;
+ delete mpSplitter;
+ delete mpBrowser1;
+}
+
+// -----------------------------------------------------------------------------
+
+void GalleryBrowser::InitSettings()
+{
+ SetBackground( Wallpaper( GALLERY_DLG_COLOR ) );
+ SetControlBackground( GALLERY_DLG_COLOR );
+ SetControlForeground( GALLERY_DLG_COLOR );
+
+ mpSplitter->SetBackground( Wallpaper( GALLERY_DLG_COLOR ) );
+ mpSplitter->SetControlBackground( GALLERY_DLG_COLOR );
+ mpSplitter->SetControlForeground( GALLERY_DLG_COLOR );
+
+ mpBrowser1->SetBackground( Wallpaper( GALLERY_DLG_COLOR ) );
+ mpBrowser1->SetControlBackground( GALLERY_DLG_COLOR );
+ mpBrowser1->SetControlForeground( GALLERY_DLG_COLOR );
+
+ mpBrowser2->SetBackground( Wallpaper( GALLERY_DLG_COLOR ) );
+ mpBrowser2->SetControlBackground( GALLERY_DLG_COLOR );
+ mpBrowser2->SetControlForeground( GALLERY_DLG_COLOR );
+}
+
+// -----------------------------------------------------------------------------
+
+void GalleryBrowser::Resize()
+{
+ SfxDockingWindow::Resize();
+
+ const long nFrameWidth = LogicToPixel( Size( 3, 0 ), MAP_APPFONT ).Width();
+ const long nFrameWidth2 = nFrameWidth << 1;
+ Size aMinSize( GetMinOutputSizePixel() );
+ Size aNewSize( GetOutputSizePixel() );
+ Point aSplitPos( mpSplitter->GetPosPixel() );
+ const Size aSplitSize( mpSplitter->GetOutputSizePixel() );
+
+ mpBrowser1->SetPosSizePixel( Point( nFrameWidth, nFrameWidth ),
+ Size( aSplitPos.X() - nFrameWidth, aNewSize.Height() - nFrameWidth2 ) );
+
+ mpSplitter->SetPosSizePixel( aSplitPos, Size( aSplitSize.Width(), aNewSize.Height() ) );
+ mpSplitter->SetDragRectPixel( Rectangle( Point( nFrameWidth2, 0 ), Size( aNewSize.Width() - ( nFrameWidth2 << 1 ) - aSplitSize.Width(), aNewSize.Height() ) ) );
+
+ mpBrowser2->SetPosSizePixel( Point( aSplitPos.X() + aSplitSize.Width(), nFrameWidth ),
+ Size( aNewSize.Width() - aSplitSize.Width() - aSplitPos.X() - nFrameWidth, aNewSize.Height() - nFrameWidth2 ) );
+
+ maLastSize = aNewSize;
+}
+
+// -----------------------------------------------------------------------------
+
+BOOL GalleryBrowser::KeyInput( const KeyEvent& rKEvt, Window* )
+{
+ const USHORT nCode = rKEvt.GetKeyCode().GetCode();
+ BOOL bRet = ( !rKEvt.GetKeyCode().IsMod1() &&
+ ( ( KEY_TAB == nCode ) || ( KEY_F6 == nCode && rKEvt.GetKeyCode().IsMod2() ) ) );
+
+ if( bRet )
+ {
+ if( !rKEvt.GetKeyCode().IsShift() )
+ {
+ if( mpBrowser1->mpThemes->HasChildPathFocus( TRUE ) )
+ mpBrowser2->GetViewWindow()->GrabFocus();
+ else if( mpBrowser2->GetViewWindow()->HasFocus() )
+ mpBrowser2->maViewBox.GrabFocus();
+ else if( mpBrowser2->maViewBox.HasFocus() )
+ mpBrowser1->maNewTheme.GrabFocus();
+ else
+ mpBrowser1->mpThemes->GrabFocus();
+ }
+ else
+ {
+ if( mpBrowser1->mpThemes->HasChildPathFocus( TRUE ) )
+ mpBrowser1->maNewTheme.GrabFocus();
+ else if( mpBrowser1->maNewTheme.HasFocus() )
+ mpBrowser2->maViewBox.GrabFocus();
+ else if( mpBrowser2->maViewBox.HasFocus() )
+ mpBrowser2->GetViewWindow()->GrabFocus();
+ else
+ mpBrowser1->mpThemes->GrabFocus();
+ }
+ }
+
+ return bRet;
+}
+
+// -----------------------------------------------------------------------------
+
+BOOL GalleryBrowser::Close()
+{
+ return SfxDockingWindow::Close();
+}
+
+// -----------------------------------------------------------------------------
+
+void GalleryBrowser::GetFocus()
+{
+ SfxDockingWindow::GetFocus();
+ mpBrowser1->GrabFocus();
+}
+
+// -----------------------------------------------------------------------------
+
+void GalleryBrowser::ThemeSelectionHasChanged()
+{
+ mpBrowser2->SelectTheme( mpBrowser1->GetSelectedTheme() );
+}
+
+// -----------------------------------------------------------------------------
+
+INetURLObject GalleryBrowser::GetURL() const
+{
+ return mpBrowser2->GetURL();
+}
+
+// -----------------------------------------------------------------------------
+
+String GalleryBrowser::GetFilterName() const
+{
+ return mpBrowser2->GetFilterName();
+}
+
+// -----------------------------------------------------------------------------
+
+Graphic GalleryBrowser::GetGraphic() const
+{
+ return mpBrowser2->GetGraphic();
+}
+
+// -----------------------------------------------------------------------------
+
+BOOL GalleryBrowser::GetVCDrawModel( FmFormModel& rModel ) const
+{
+ return mpBrowser2->GetVCDrawModel( rModel );
+}
+
+// -----------------------------------------------------------------------------
+
+BOOL GalleryBrowser::IsLinkage() const
+{
+ return mpBrowser2->IsLinkage();
+}
+
+// -----------------------------------------------------------------------------
+
+IMPL_LINK( GalleryBrowser, SplitHdl, void*, EMPTYARG )
+{
+ mpSplitter->SetPosPixel( Point( mpSplitter->GetSplitPosPixel(), mpSplitter->GetPosPixel().Y() ) );
+ Resize();
+
+ return 0L;
+}