Files
libreoffice/sc/source/ui/collab/sccollaboration.cxx
Stephan Bergmann 24cad6a649 Move MediaDescriptor from comphelper to unotools
...so it will be able to use SvtSecurityOptions internally.

Change-Id: Id7433247e8fc53651935578510bedbcca5aa2ac9
2013-11-14 11:13:24 +01:00

91 lines
2.7 KiB
C++

/* -*- 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/.
*/
#include "sccollaboration.hxx"
#include "docsh.hxx"
#include "sendfunc.hxx"
#include <com/sun/star/document/XDocumentRecovery.hpp>
#include <unotools/mediadescriptor.hxx>
#include <unotools/tempfile.hxx>
#include <unotools/localfilehelper.hxx>
ScCollaboration::ScCollaboration( ScDocShell* pScDocShell ) :
mpScDocShell( pScDocShell )
{
}
ScCollaboration::~ScCollaboration()
{
}
void ScCollaboration::EndCollaboration() const
{
ScDocFuncSend* pSender = GetScDocFuncSend();
if (pSender)
{
delete pSender;
mpScDocShell->SetDocFunc( new ScDocFuncDirect( *mpScDocShell ) );
}
}
void ScCollaboration::PacketReceived( const OString& rPacket ) const
{
ScDocFuncSend* pSender = GetScDocFuncSend();
if (pSender)
return pSender->RecvMessage( rPacket );
}
void ScCollaboration::SaveAndSendFile( TpContact* pContact ) const
{
OUString aTmpPath = utl::TempFile::CreateTempName();
aTmpPath += ".ods";
OUString aFileURL;
::utl::LocalFileHelper::ConvertPhysicalNameToURL( aTmpPath, aFileURL );
utl::MediaDescriptor aDescriptor;
// some issue with hyperlinks:
aDescriptor[utl::MediaDescriptor::PROP_DOCUMENTBASEURL()] <<= OUString();
try {
css::uno::Reference< css::document::XDocumentRecovery > xDocRecovery(
mpScDocShell->GetBaseModel(), css::uno::UNO_QUERY_THROW);
xDocRecovery->storeToRecoveryFile( aFileURL, aDescriptor.getAsConstPropertyValueList() );
} catch (const css::uno::Exception &ex) {
SAL_WARN( "sc.tubes", "Exception when saving file " << aFileURL );
}
SendFile( pContact, aFileURL );
// FIXME: unlink the file after send ...
}
void ScCollaboration::StartCollaboration( TeleConference* pConference )
{
SetConference( pConference );
ScDocFunc* pDocFunc = &mpScDocShell->GetDocFunc();
ScDocFuncSend* pSender = dynamic_cast<ScDocFuncSend*> (pDocFunc);
if (!pSender)
{
// This means pDocFunc has to be ScDocFuncDirect* and we are not collaborating yet.
pSender = new ScDocFuncSend( *mpScDocShell, dynamic_cast<ScDocFuncDirect*> (pDocFunc), this );
mpScDocShell->SetDocFunc( pSender );
}
}
// --- private ---
ScDocFuncSend* ScCollaboration::GetScDocFuncSend() const
{
return dynamic_cast<ScDocFuncSend*> (&mpScDocShell->GetDocFunc());
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */