All Downloads are FREE. Search and download functionalities are using the official Maven repository.

java.fedora.client.objecteditor.ContentViewer Maven / Gradle / Ivy

Go to download

The Fedora Client is a Java Library that allows API access to a Fedora Repository. The client is typically one part of a full Fedora installation.

The newest version!
/*
 * -----------------------------------------------------------------------------
 *
 * 

License and Copyright: The contents of this file are subject to 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.fedora-commons.org/licenses.

* *

Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for * the specific language governing rights and limitations under the License.

* *

The entire file consists of original code.

*

Copyright © 2008 Fedora Commons, Inc.
*

Copyright © 2002-2007 The Rector and Visitors of the University of * Virginia and Cornell University
* All rights reserved.

* * ----------------------------------------------------------------------------- */ package fedora.client.objecteditor; import java.io.InputStream; import java.io.IOException; import javax.swing.JComponent; /** * Views content of certain types in a JComponent. */ public abstract class ContentViewer { /** * Tells whether this component just does viewing or can do editing as well. * Implementers will simply subclass either ContentViewer or ContentEditor, * and this method will automatically return the correct value. */ public boolean isEditor() { return false; } /** * Get the JComponent. */ public abstract JComponent getComponent(); /** * Gets a new instance of this class, which has been constructed * and immediately thereafter, init(...)'ed. Intended to be called by * ContentHandlerFactory only. */ protected final ContentViewer newInstance(String type, InputStream data, boolean viewOnly) throws IOException { ContentViewer instance=null; try { instance=(ContentViewer) this.getClass().newInstance(); } catch (Exception e) { throw new IOException(e.getMessage()); } instance.init(type, data, viewOnly); return instance; } /** * Returns a list of content types that this component can handle. * This will usually be a list of MIME Types, but may also include * other notions of type known to be understood by the users of * ContentHandlerFactory. */ public abstract String[] getTypes(); /** * Initializes the handler. This should only be called once per instance, * and is guaranteed to have been called when this component is provided * by the ContentHandlerFactory. * * The viewOnly parameter signals to ContentEditor implementations that * editing capabilities are not desired by the caller. */ public abstract void init(String type, InputStream data, boolean viewOnly) throws IOException; /** * Re-initializes the handler given new input data. * The old data can be discarded. */ public abstract void setContent(InputStream data) throws IOException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy