/* -*- 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 "fileopendialog.hxx" #include #include "pppoptimizertoken.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace ::rtl; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::container; using namespace ::com::sun::star::view; using namespace ::com::sun::star::ui::dialogs; FileOpenDialog::FileOpenDialog( const Reference< XComponentContext >& rxContext ) { mxFilePicker = FilePicker::createWithMode( rxContext, TemplateDescription::FILESAVE_AUTOEXTENSION); mxFilePicker->setMultiSelectionMode( sal_False ); Reference< XFilePickerControlAccess > xAccess( mxFilePicker, UNO_QUERY ); if ( xAccess.is() ) { Any aValue( static_cast< sal_Bool >( sal_True ) ); try { xAccess->setValue( ExtendedFilePickerElementIds::CHECKBOX_AUTOEXTENSION, 0, aValue ); } catch( com::sun::star::uno::Exception& ) {} } // collecting a list of impress filters Reference< XNameAccess > xFilters( rxContext->getServiceManager()->createInstanceWithContext( OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.document.FilterFactory" ) ), rxContext ), UNO_QUERY_THROW ); Sequence< OUString > aFilterList( xFilters->getElementNames() ); for ( int i = 0; i < aFilterList.getLength(); i++ ) { try { Sequence< PropertyValue > aFilterProperties; if ( xFilters->getByName( aFilterList[ i ] ) >>= aFilterProperties ) { FilterEntry aFilterEntry; sal_Bool bImpressFilter = sal_False; for ( int j = 0; j < aFilterProperties.getLength(); j++ ) { PropertyValue& rProperty( aFilterProperties[ j ] ); switch( TKGet( rProperty.Name ) ) { case TK_DocumentService : { rtl::OUString sDocumentService; rProperty.Value >>= sDocumentService; if ( sDocumentService == "com.sun.star.presentation.PresentationDocument" ) bImpressFilter = sal_True; else j = aFilterProperties.getLength(); } break; case TK_Name : rProperty.Value >>= aFilterEntry.maName; break; case TK_UIName : rProperty.Value >>= aFilterEntry.maUIName; break; case TK_Type : rProperty.Value >>= aFilterEntry.maType; break; case TK_Flags : rProperty.Value >>= aFilterEntry.maFlags; break; default : break; } } if ( bImpressFilter && ( ( aFilterEntry.maFlags & 3 ) == 3 ) ) { aFilterEntryList.push_back( aFilterEntry ); } } } catch( Exception& ) { } } Reference< XNameAccess > xTypes( rxContext->getServiceManager()->createInstanceWithContext( OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.document.TypeDetection" ) ), rxContext ), UNO_QUERY_THROW ); Sequence< OUString > aTypeList( xFilters->getElementNames() ); // mxFilePicker->setDefaultName( ); std::vector< FilterEntry >::iterator aIter( aFilterEntryList.begin() ); while( aIter != aFilterEntryList.end() ) { Sequence< PropertyValue > aTypeProperties; try { if ( xTypes->getByName( aIter->maType ) >>= aTypeProperties ) { Sequence< OUString > aExtensions; for ( int i = 0; i < aTypeProperties.getLength(); i++ ) { switch( TKGet( aTypeProperties[ i ].Name ) ) { case TK_Extensions : aTypeProperties[ i ].Value >>= aExtensions; break; default: break; } } if ( aExtensions.getLength() ) { mxFilePicker->appendFilter( aIter->maUIName, aExtensions[ 0 ] ); if ( aIter->maFlags & 0x100 ) mxFilePicker->setCurrentFilter( aIter->maUIName ); } } } catch ( const Exception& ) { } aIter++; } } FileOpenDialog::~FileOpenDialog() { } sal_Int16 FileOpenDialog::execute() { return mxFilePicker->execute(); } void FileOpenDialog::setDefaultName( const rtl::OUString& rDefaultName ) { mxFilePicker->setDefaultName( rDefaultName ); } ::rtl::OUString FileOpenDialog::getURL() const { Sequence< OUString > aFileSeq( mxFilePicker->getFiles() ); return aFileSeq.getLength() ? aFileSeq[ 0 ] : OUString(); }; ::rtl::OUString FileOpenDialog::getFilterName() const { rtl::OUString aFilterName; Reference< XFilterManager > xFilterManager( mxFilePicker, UNO_QUERY_THROW ); rtl::OUString aUIName( xFilterManager->getCurrentFilter() ); std::vector< FilterEntry >::const_iterator aIter( aFilterEntryList.begin() ); while( aIter != aFilterEntryList.end() ) { if ( aIter->maUIName == aUIName ) { aFilterName = aIter->maName; break; } aIter++; } return aFilterName; }; /* vim:set shiftwidth=4 softtabstop=4 expandtab: */