| /************************************************************** |
| * |
| * 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. |
| * |
| *************************************************************/ |
| |
| |
| package com.sun.star.wizards.report; |
| |
| import com.sun.star.beans.PropertyValue; |
| import com.sun.star.uno.Type; |
| import com.sun.star.text.XTextDocument; |
| import com.sun.star.wizards.common.Properties; |
| import com.sun.star.sdb.application.XDatabaseDocumentUI; |
| import com.sun.star.wizards.common.NamedValueCollection; |
| import com.sun.star.wizards.common.PropertyNames; |
| import java.util.logging.Level; |
| import java.util.logging.Logger; |
| |
| /** This class capsulates the class, that implements the minimal component, a |
| * factory for creating the service (<CODE>__getServiceFactory</CODE>). |
| * @author Bertram Nolte |
| */ |
| public class CallReportWizard |
| { |
| |
| static boolean bWizardstartedalready; |
| |
| /* public static void main(String args[]) |
| { |
| String ConnectStr = "uno:pipe,name=fs93730;urp;StarOffice.ServiceManager"; |
| try |
| { |
| XMultiServiceFactory orb = Desktop.connect(ConnectStr); |
| if ( orb != null ) |
| { |
| PropertyValue[] curproperties = new PropertyValue[1]; |
| curproperties[0] = Properties.createProperty("DataSourceName", "countries"); |
| |
| ReportWizard wizard = new ReportWizard( orb, curproperties ); |
| wizard.startReportWizard(); |
| } |
| } |
| catch (java.lang.Exception jexception) |
| { |
| jexception.printStackTrace(System.out); |
| } |
| }*/ |
| |
| /** Gives a factory for creating the service. |
| * This method is called by the <code>JavaLoader</code> |
| * <p> |
| * @return Returns a <code>XSingleServiceFactory</code> for creating the |
| * component. |
| * @see com.sun.star.comp.loader.JavaLoader# |
| * @param stringImplementationName The implementation name of the component. |
| * @param xMSF The service manager, who gives access to every |
| * known service. |
| * @param xregistrykey Makes structural information (except regarding tree |
| * structures) of a single |
| * registry key accessible. |
| */ |
| public static com.sun.star.lang.XSingleServiceFactory __getServiceFactory(String stringImplementationName, com.sun.star.lang.XMultiServiceFactory xMSF, com.sun.star.registry.XRegistryKey xregistrykey) |
| { |
| com.sun.star.lang.XSingleServiceFactory xsingleservicefactory = null; |
| if (stringImplementationName.equals( |
| ReportWizardImplementation.class.getName())) |
| { |
| xsingleservicefactory = com.sun.star.comp.loader.FactoryHelper.getServiceFactory( |
| ReportWizardImplementation.class, |
| ReportWizardImplementation.__serviceName, |
| xMSF, |
| xregistrykey); |
| } |
| return xsingleservicefactory; |
| } |
| |
| /** This class implements the component. At least the interfaces XServiceInfo, |
| * XTypeProvider, and XInitialization should be provided by the service. |
| */ |
| public static class ReportWizardImplementation extends com.sun.star.lib.uno.helper.PropertySet implements com.sun.star.lang.XInitialization, com.sun.star.lang.XServiceInfo, com.sun.star.lang.XTypeProvider, com.sun.star.task.XJobExecutor |
| { |
| |
| private PropertyValue[] m_wizardContext; |
| |
| /** The constructor of the inner class has a XMultiServiceFactory parameter. |
| * @param xmultiservicefactoryInitialization A special service factory |
| * could be introduced while initializing. |
| */ |
| public ReportWizardImplementation(com.sun.star.lang.XMultiServiceFactory xmultiservicefactoryInitialization) |
| { |
| super(); |
| xmultiservicefactory = xmultiservicefactoryInitialization; |
| } |
| |
| public void trigger(String sEvent) |
| { |
| try |
| { |
| if (sEvent.compareTo(PropertyNames.START) == 0) |
| { |
| if (!bWizardstartedalready) |
| { |
| ReportWizard CurReportWizard = new ReportWizard( xmultiservicefactory, m_wizardContext ); |
| CurReportWizard.startReportWizard(); |
| } |
| bWizardstartedalready = false; |
| } |
| else if (sEvent.compareTo("fill") == 0) |
| { |
| Dataimport CurDataimport = new Dataimport(xmultiservicefactory); |
| if (m_wizardContext != null) |
| { |
| NamedValueCollection context = new NamedValueCollection( m_wizardContext ); |
| XTextDocument textDocument = context.queryOrDefault( "TextDocument", null, XTextDocument.class ); |
| XDatabaseDocumentUI documentUI = context.queryOrDefault( "DocumentUI", null, XDatabaseDocumentUI.class ); |
| if ( textDocument != null ) |
| { |
| CurDataimport.createReport(xmultiservicefactory, documentUI, textDocument, m_wizardContext); |
| } |
| } |
| } |
| } |
| catch (Exception e) |
| { |
| Logger.getLogger(CallReportWizard.class.getName()).log(Level.SEVERE, null, e); |
| } |
| System.gc(); |
| } |
| /** The service name, that must be used to get an instance of this service. |
| */ |
| private static final String __serviceName = "com.sun.star.wizards.report.CallReportWizard"; |
| /** The service manager, that gives access to all registered services. |
| */ |
| private com.sun.star.lang.XMultiServiceFactory xmultiservicefactory; |
| |
| /** This method is a member of the interface for initializing an object |
| * directly after its creation. |
| * @param object This array of arbitrary objects will be passed to the |
| * component after its creation. |
| * @throws com.sun.star.uno.Exception Every exception will not be handled, but will be |
| * passed to the caller. |
| */ |
| public void initialize(Object[] object) throws com.sun.star.uno.Exception |
| { |
| this.m_wizardContext = Properties.convertToPropertyValueArray(object); |
| |
| // xmultiservicefactory = (XMultiservicefactory) UnoRuntime.queryInterface(XMultiServiceFactory.class, object[0]); |
| } |
| |
| /** This method returns an array of all supported service names. |
| * @return Array of supported service names. |
| */ |
| public java.lang.String[] getSupportedServiceNames() |
| { |
| String[] stringSupportedServiceNames = new String[1]; |
| |
| stringSupportedServiceNames[ 0] = __serviceName; |
| |
| return (stringSupportedServiceNames); |
| } |
| |
| /** This method returns true, if the given service will be |
| * supported by the component. |
| * @param stringService Service name. |
| * @return True, if the given service name will be supported. |
| */ |
| public boolean supportsService(String stringService) |
| { |
| boolean booleanSupportsService = false; |
| |
| if (stringService.equals(__serviceName)) |
| { |
| booleanSupportsService = true; |
| } |
| return (booleanSupportsService); |
| } |
| |
| /** This method returns an array of bytes, that can be used to |
| * unambiguously distinguish between two sets of types, e.g. |
| * to realise hashing functionality when the object is introspected. |
| * Two objects that return the same ID also have to return |
| * the same set of types in getTypes(). If an unique |
| * implementation Id cannot be provided this method has to |
| * return an empty sequence. Important: If the object |
| * aggregates other objects the ID has to be unique for the |
| * whole combination of objects. |
| * @return Array of bytes, in order to distinguish between two sets. |
| */ |
| public byte[] getImplementationId() |
| { |
| byte[] byteReturn = |
| { |
| }; |
| |
| try |
| { |
| byteReturn = (PropertyNames.EMPTY_STRING + this.hashCode()).getBytes(); |
| } |
| catch (Exception e) |
| { |
| Logger.getLogger(CallReportWizard.class.getName()).log(Level.SEVERE, null, e); |
| } |
| |
| return (byteReturn); |
| } |
| |
| /** Return the class name of the component. |
| * @return Class name of the component. |
| */ |
| public java.lang.String getImplementationName() |
| { |
| return (ReportWizardImplementation.class.getName()); |
| } |
| |
| /** Provides a sequence of all types (usually interface types) |
| * provided by the object. |
| * @return Sequence of all types (usually interface types) provided by the |
| * service. |
| */ |
| public Type[] getTypes() |
| { |
| Type[] typeReturn = |
| { |
| }; |
| |
| try |
| { |
| typeReturn = new Type[] |
| { |
| new Type(com.sun.star.task.XJobExecutor.class), |
| new Type(com.sun.star.lang.XTypeProvider.class), |
| new Type(com.sun.star.lang.XServiceInfo.class), |
| new Type(com.sun.star.lang.XInitialization.class) |
| }; |
| } |
| catch (Exception e) |
| { |
| Logger.getLogger(CallReportWizard.class.getName()).log(Level.SEVERE, null, e); |
| } |
| |
| return (typeReturn); |
| } |
| } |
| } |
| |