/************************************************************** * * 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. * *************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sd.hxx" #include "PaneDockingWindow.hxx" #include "Window.hxx" #include "ViewShellBase.hxx" #include "framework/FrameworkHelper.hxx" #include "sdresid.hxx" #include "res_bmp.hrc" #include #include #include #include #include #include #include using namespace ::com::sun::star; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::drawing::framework; using ::sfx2::TitledDockingWindow; namespace sd { PaneDockingWindow::PaneDockingWindow( SfxBindings *_pBindings, SfxChildWindow *pChildWindow, ::Window* pParent, const ResId& rResId, const ::rtl::OUString& rsTitle ) :TitledDockingWindow( _pBindings, pChildWindow, pParent, rResId ) { SetTitle( rsTitle ); } PaneDockingWindow::~PaneDockingWindow (void) { } void PaneDockingWindow::StateChanged( StateChangedType nType ) { switch (nType) { case STATE_CHANGE_INITSHOW: Resize(); GetContentWindow().SetStyle(GetContentWindow().GetStyle() | WB_DIALOGCONTROL); break; case STATE_CHANGE_VISIBLE: // The visibility of the docking window has changed. Tell the // ConfigurationController so that it can activate or deactivate // a/the view for the pane. // Without this the side panes remain empty after closing an // in-place slide show. ViewShellBase* pBase = ViewShellBase::GetViewShellBase( GetBindings().GetDispatcher()->GetFrame()); if (pBase != NULL) { framework::FrameworkHelper::Instance(*pBase)->UpdateConfiguration(); } break; } SfxDockingWindow::StateChanged (nType); } void PaneDockingWindow::MouseButtonDown (const MouseEvent& rEvent) { if (rEvent.GetButtons() == MOUSE_LEFT) { // For some strange reason we have to set the WB_DIALOGCONTROL at // the content window in order to have it pass focus to its content // window. Without setting this flag here that works only on views // that have not been taken from the cash and relocated to this pane // docking window. GetContentWindow().SetStyle(GetContentWindow().GetStyle() | WB_DIALOGCONTROL); GetContentWindow().GrabFocus(); } SfxDockingWindow::MouseButtonDown(rEvent); } void PaneDockingWindow::SetValidSizeRange (const Range aValidSizeRange) { SplitWindow* pSplitWindow = dynamic_cast(GetParent()); if (pSplitWindow != NULL) { const sal_uInt16 nId (pSplitWindow->GetItemId(static_cast< ::Window*>(this))); const sal_uInt16 nSetId (pSplitWindow->GetSet(nId)); // Because the PaneDockingWindow paints its own decoration, we have // to compensate the valid size range for that. const SvBorder aBorder (GetDecorationBorder()); sal_Int32 nCompensation (pSplitWindow->IsHorizontal() ? mnTitleBarHeight + aBorder.Top() + aBorder.Bottom() : aBorder.Left() + aBorder.Right()); pSplitWindow->SetItemSizeRange( nSetId, Range( aValidSizeRange.Min() + nCompensation, aValidSizeRange.Max() + nCompensation)); } } PaneDockingWindow::Orientation PaneDockingWindow::GetOrientation (void) const { SplitWindow* pSplitWindow = dynamic_cast(GetParent()); if (pSplitWindow == NULL) return UnknownOrientation; else if (pSplitWindow->IsHorizontal()) return HorizontalOrientation; else return VerticalOrientation; } } // end of namespace ::sd