/* * 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 . */ package org.openoffice.test.tools; /**************************************************************************/ import com.sun.star.beans.PropertyValue; import com.sun.star.frame.XController; import com.sun.star.frame.XDispatch; import com.sun.star.frame.XDispatchProvider; import com.sun.star.lang.XMultiServiceFactory; import com.sun.star.uno.UnoRuntime; import com.sun.star.util.URL; import com.sun.star.util.XURLTransformer; /**************************************************************************/ /** provides a small wrapper around a document view */ public class OfficeDocumentView { private final XMultiServiceFactory m_orb; private final XController m_controller; /* ------------------------------------------------------------------ */ final public XController getController() { return m_controller; } /* ------------------------------------------------------------------ */ public OfficeDocumentView( XMultiServiceFactory orb, XController controller ) { m_orb = orb; m_controller = controller; } /* ------------------------------------------------------------------ */ /** retrieves a dispatcher for the given URL, obtained at the current view of the document @param aURL a one-element array. The first element must contain a valid URL::Complete value. Upon return, the URL is correctly parsed. @return the dispatcher for the URL in question */ private XDispatch getDispatcher( URL[] aURL ) throws com.sun.star.uno.Exception { XDispatch xReturn = null; // go get the dispatch provider of its frame XDispatchProvider xProvider = UnoRuntime.queryInterface( XDispatchProvider.class, m_controller.getFrame() ); if ( null != xProvider ) { // need a URLTransformer XURLTransformer xTransformer = UnoRuntime.queryInterface( XURLTransformer.class, m_orb.createInstance( "com.sun.star.util.URLTransformer" ) ); xTransformer.parseStrict( aURL ); xReturn = xProvider.queryDispatch( aURL[0], "", 0 ); } return xReturn; } /* ------------------------------------------------------------------ */ /** dispatches the given URL into the view, if there's a dispatcher for it @return if the URL was successfully dispatched */ public boolean dispatch( String i_url ) throws com.sun.star.uno.Exception { return dispatch( i_url, new PropertyValue[0] ); } /* ------------------------------------------------------------------ */ private boolean dispatch( final String i_url, final PropertyValue[] i_arguments ) throws com.sun.star.uno.Exception { URL[] completeURL = new URL[] { new URL() }; completeURL[0].Complete = i_url; XDispatch dispatcher = getDispatcher( completeURL ); if ( dispatcher == null ) return false; dispatcher.dispatch( completeURL[0], i_arguments ); return true; } }