1 /************************************************************************* 2 * 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * Copyright 2000, 2010 Oracle and/or its affiliates. 6 * 7 * OpenOffice.org - a multi-platform office productivity suite 8 * 9 * This file is part of OpenOffice.org. 10 * 11 * OpenOffice.org is free software: you can redistribute it and/or modify 12 * it under the terms of the GNU Lesser General Public License version 3 13 * only, as published by the Free Software Foundation. 14 * 15 * OpenOffice.org is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU Lesser General Public License version 3 for more details 19 * (a copy is included in the LICENSE file that accompanied this code). 20 * 21 * You should have received a copy of the GNU Lesser General Public License 22 * version 3 along with OpenOffice.org. If not, see 23 * <http://www.openoffice.org/license.html> 24 * for a copy of the LGPLv3 License. 25 * 26 ************************************************************************/ 27 #include "vbacharts.hxx" 28 #include <basic/sberrors.hxx> 29 #include <com/sun/star/table/XTableChartsSupplier.hpp> 30 31 using namespace ::com::sun::star; 32 using namespace ::ooo::vba; 33 34 35 ScVbaCharts::ScVbaCharts( const css::uno::Reference< ov::XHelperInterface >& _xParent, const css::uno::Reference< css::uno::XComponentContext >& _xContext, const uno::Reference< frame::XModel >& xModel ) : Charts_BASE(_xParent, _xContext, uno::Reference< container::XIndexAccess >()) 36 { 37 xComponent.set( xModel, uno::UNO_QUERY_THROW ); 38 xSpreadsheetDocument.set( xComponent, uno::UNO_QUERY_THROW ); 39 } 40 41 uno::Any SAL_CALL 42 ScVbaCharts::Add() throw (css::script::BasicErrorException, css::uno::RuntimeException) 43 { 44 // Not implemented in the helperapi ( see ChartsImpl.java ) 45 if ( true ) 46 throw script::BasicErrorException( rtl::OUString(), uno::Reference< uno::XInterface >(), SbERR_BAD_METHOD, rtl::OUString() ); 47 return aNULL(); 48 } 49 50 uno::Reference< excel::XChart > SAL_CALL 51 ScVbaCharts::getActiveChart() throw (script::BasicErrorException, uno::RuntimeException) 52 { 53 return xActiveChart; 54 } 55 56 uno::Reference< container::XEnumeration > SAL_CALL 57 ScVbaCharts::createEnumeration() throw (uno::RuntimeException) 58 { 59 // #FIXME not implemented 60 if ( true ) 61 throw script::BasicErrorException( rtl::OUString(), uno::Reference< uno::XInterface >(), SbERR_BAD_METHOD, rtl::OUString() ); 62 return uno::Reference< container::XEnumeration >(); 63 } 64 65 // #FIXME #TODO this method shouldn't appear in this class directly 66 // a XIndexAccess/XNameAccess wrapper should be passed to the base class instead 67 ::sal_Int32 SAL_CALL 68 ScVbaCharts::getCount() throw (uno::RuntimeException) 69 { 70 sal_Int32 ncount = 0; 71 try 72 { 73 uno::Reference< sheet::XSpreadsheets > xSpreadsheets( xSpreadsheetDocument->getSheets() ); 74 uno::Sequence< rtl::OUString > SheetNames = xSpreadsheets->getElementNames(); 75 sal_Int32 nLen = SheetNames.getLength(); 76 for (sal_Int32 i = 0; i < nLen; i++) 77 { 78 uno::Reference< table::XTableChartsSupplier > xTableChartsSupplier( xSpreadsheets->getByName(SheetNames[i]), uno::UNO_QUERY); 79 if ( xTableChartsSupplier.is() ) 80 { 81 uno::Reference< table::XTableCharts > xTableCharts = xTableChartsSupplier->getCharts(); 82 ncount =+ xTableCharts->getElementNames().getLength(); 83 } 84 } 85 } 86 catch (uno::Exception& ) 87 { 88 throw script::BasicErrorException( rtl::OUString(), uno::Reference< uno::XInterface >(), SbERR_METHOD_FAILED, rtl::OUString() ); 89 } 90 return ncount; 91 } 92 93 uno::Any 94 ScVbaCharts::createCollectionObject( const uno::Any& aSource ) 95 { 96 if ( true ) 97 throw script::BasicErrorException( rtl::OUString(), uno::Reference< uno::XInterface >(), SbERR_BAD_METHOD, rtl::OUString() ); 98 // #TODO implementation please 99 return aSource; 100 } 101 102 rtl::OUString& 103 ScVbaCharts::getServiceImplName() 104 { 105 static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaCharts") ); 106 return sImplName; 107 } 108 109 css::uno::Sequence<rtl::OUString> 110 ScVbaCharts::getServiceNames() 111 { 112 static uno::Sequence< rtl::OUString > sNames; 113 if ( sNames.getLength() == 0 ) 114 { 115 sNames.realloc( 1 ); 116 sNames[0] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.Charts") ); 117 } 118 return sNames; 119 } 120 121