/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * 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 #include #include #include #include #include "fmobj.hxx" #include #include #include "fmpgeimp.hxx" #include #include #include #include #include #include #include "fmprop.hrc" #include "fmundo.hxx" #include "svx/fmtools.hxx" using namespace ::svxform; #include using com::sun::star::uno::Reference; using com::sun::star::uno::UNO_QUERY; using com::sun::star::container::XChild; using com::sun::star::container::XNameContainer; TYPEINIT1(FmFormPage, SdrPage); FmFormPage::FmFormPage(FmFormModel& rModel, bool bMasterPage) :SdrPage(rModel, bMasterPage) ,m_pImpl( new FmFormPageImpl( *this ) ) { } FmFormPage::FmFormPage(const FmFormPage& rPage) :SdrPage(rPage) ,m_pImpl(new FmFormPageImpl( *this ) ) { } void FmFormPage::lateInit(const FmFormPage& rPage, FmFormModel* const pNewModel) { SdrPage::lateInit( rPage, pNewModel ); m_pImpl->initFrom( rPage.GetImpl() ); m_sPageName = rPage.m_sPageName; } FmFormPage::~FmFormPage() { delete m_pImpl; } void FmFormPage::SetModel(SdrModel* pNewModel) { /* #35055# */ // we want to call the super's "SetModel" method even if the model is the // same, in case code somewhere in the system depends on it. But our code // doesn't, so get the old model to do a check. SdrModel *pOldModel = GetModel(); SdrPage::SetModel( pNewModel ); /* #35055# */ if ( ( pOldModel != pNewModel ) && m_pImpl ) { try { Reference< css::form::XForms > xForms( m_pImpl->getForms( false ) ); if ( xForms.is() ) { // we want to keep the current collection, just reset the model // with which it's associated. FmFormModel* pDrawModel = static_cast( GetModel() ); SfxObjectShell* pObjShell = pDrawModel->GetObjectShell(); if ( pObjShell ) xForms->setParent( pObjShell->GetModel() ); } } catch( ::com::sun::star::uno::Exception const& ) { OSL_FAIL( "UNO Exception caught resetting model for m_pImpl (FmFormPageImpl) in FmFormPage::SetModel" ); } } } SdrPage* FmFormPage::Clone() const { return Clone(0); } SdrPage* FmFormPage::Clone(SdrModel* const pNewModel) const { FmFormPage* const pNewPage = new FmFormPage(*this); FmFormModel* pFormModel = 0; if (pNewModel) { pFormModel = dynamic_cast(pNewModel); assert(pFormModel); } pNewPage->lateInit(*this, pFormModel); return pNewPage; } void FmFormPage::InsertObject(SdrObject* pObj, size_t nPos, const SdrInsertReason* pReason) { SdrPage::InsertObject( pObj, nPos, pReason ); if (GetModel() && (!pReason || pReason->GetReason() != SDRREASON_STREAMING)) static_cast(GetModel())->GetUndoEnv().Inserted(pObj); } const Reference< css::form::XForms > & FmFormPage::GetForms( bool _bForceCreate ) const { const SdrPage& rMasterPage( *this ); const FmFormPage* pFormPage = dynamic_cast< const FmFormPage* >( &rMasterPage ); OSL_ENSURE( pFormPage, "FmFormPage::GetForms: referenced page is no FmFormPage - is this allowed?!" ); if ( !pFormPage ) pFormPage = this; return pFormPage->m_pImpl->getForms( _bForceCreate ); } bool FmFormPage::RequestHelp( vcl::Window* pWindow, SdrView* pView, const HelpEvent& rEvt ) { if( pView->IsAction() ) return false; Point aPos = rEvt.GetMousePosPixel(); aPos = pWindow->ScreenToOutputPixel( aPos ); aPos = pWindow->PixelToLogic( aPos ); SdrObject* pObj = NULL; SdrPageView* pPV = NULL; if ( !pView->PickObj( aPos, 0, pObj, pPV, SdrSearchOptions::DEEP ) ) return false; FmFormObj* pFormObject = FmFormObj::GetFormObject( pObj ); if ( !pFormObject ) return false; OUString aHelpText; ::com::sun::star::uno::Reference< ::com::sun::star::beans::XPropertySet > xSet( pFormObject->GetUnoControlModel(), ::com::sun::star::uno::UNO_QUERY ); if (xSet.is()) { if (::comphelper::hasProperty(FM_PROP_HELPTEXT, xSet)) aHelpText = ::comphelper::getString(xSet->getPropertyValue(FM_PROP_HELPTEXT)).getStr(); if (aHelpText.isEmpty() && ::comphelper::hasProperty(FM_PROP_TARGET_URL, xSet)) { OUString aText = ::comphelper::getString(xSet->getPropertyValue(FM_PROP_TARGET_URL)); INetURLObject aUrl(aText); // testen, ob es ein Protokoll-Typ ist, den ich anzeigen will INetProtocol aProtocol = aUrl.GetProtocol(); static const INetProtocol s_aQuickHelpSupported[] = { INetProtocol::Ftp, INetProtocol::Http, INetProtocol::File, INetProtocol::Mailto, INetProtocol::Https, INetProtocol::Javascript, INetProtocol::Ldap }; for (sal_uInt16 i=0; iGetCurrentBoundRect(); aItemRect = pWindow->LogicToPixel( aItemRect ); Point aPt = pWindow->OutputToScreenPixel( aItemRect.TopLeft() ); aItemRect.Left() = aPt.X(); aItemRect.Top() = aPt.Y(); aPt = pWindow->OutputToScreenPixel( aItemRect.BottomRight() ); aItemRect.Right() = aPt.X(); aItemRect.Bottom() = aPt.Y(); if( rEvt.GetMode() == HelpEventMode::BALLOON ) Help::ShowBalloon( pWindow, aItemRect.Center(), aItemRect, aHelpText); else Help::ShowQuickHelp( pWindow, aItemRect, aHelpText ); } return true; } SdrObject* FmFormPage::RemoveObject(size_t nObjNum) { SdrObject* pObj = SdrPage::RemoveObject(nObjNum); if (pObj && GetModel()) static_cast(GetModel())->GetUndoEnv().Removed(pObj); return pObj; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */