1998-09-09 00:52:38 +00:00
|
|
|
/* -*- Mode: java; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
1999-11-02 01:51:54 +00:00
|
|
|
* The contents of this file are subject to the Mozilla Public
|
|
|
|
* License Version 1.1 (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.mozilla.org/MPL/
|
1998-09-09 00:52:38 +00:00
|
|
|
*
|
1999-11-02 01:51:54 +00:00
|
|
|
* 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.
|
1998-09-09 00:52:38 +00:00
|
|
|
*
|
|
|
|
* The Original Code is the Grendel mail/news client.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape Communications
|
1999-11-02 01:51:54 +00:00
|
|
|
* Corporation. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1997 Netscape Communications Corporation. All
|
|
|
|
* Rights Reserved.
|
1999-03-07 01:30:52 +00:00
|
|
|
*
|
1999-11-02 01:51:54 +00:00
|
|
|
* Contributor(s): Jeff Galyan <talisman@anamorphic.com>
|
1998-09-09 00:52:38 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
package grendel.integrator;
|
|
|
|
|
|
|
|
import java.awt.Image;
|
|
|
|
import java.awt.Toolkit;
|
|
|
|
import java.util.Enumeration;
|
|
|
|
import java.util.Vector;
|
|
|
|
|
1999-01-09 03:55:32 +00:00
|
|
|
import javax.swing.event.ChangeEvent;
|
|
|
|
import javax.swing.event.ChangeListener;
|
|
|
|
import javax.swing.event.EventListenerList;
|
|
|
|
|
|
|
|
//import netscape.shell.IShellIntegrator;
|
|
|
|
//import netscape.shell.IShellView;
|
|
|
|
//import netscape.shell.IShellViewCtx;
|
|
|
|
//import netscape.shell.ShellViewCtxListener;
|
1998-09-09 00:52:38 +00:00
|
|
|
|
|
|
|
import javax.activation.DataHandler;
|
|
|
|
import javax.mail.Folder;
|
|
|
|
import javax.mail.MessagingException;
|
|
|
|
import javax.mail.Session;
|
|
|
|
import javax.mail.Store;
|
|
|
|
|
|
|
|
import grendel.prefs.Prefs;
|
|
|
|
import grendel.view.ViewedFolder;
|
|
|
|
import grendel.view.ViewedStore;
|
|
|
|
|
|
|
|
import grendel.ui.StoreFactory;
|
|
|
|
|
|
|
|
public class Shell implements IShellViewCtx {
|
|
|
|
IShellIntegrator fIntegrator;
|
|
|
|
Vector fChildren = new Vector();
|
|
|
|
IShellViewCtx fParent;
|
|
|
|
EventListenerList fListeners = new EventListenerList();
|
|
|
|
DataHandler fDataHandler;
|
|
|
|
|
|
|
|
StoreChangeListener fStoreChangeListener;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes this view e.g., the Integrator calls this first so you can
|
|
|
|
* identify the view.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public void initialize( IShellIntegrator shell, IShellViewCtx aParent ) {
|
|
|
|
fIntegrator = shell;
|
|
|
|
fParent = aParent;
|
|
|
|
|
|
|
|
// ###HACKHACKHACK Remove me when javamail fixes their stuff.
|
|
|
|
java.io.File mailcapfile = new java.io.File("mailcap");
|
|
|
|
if (!mailcapfile.exists()) {
|
|
|
|
try {
|
|
|
|
(new java.io.RandomAccessFile(mailcapfile, "rw")).close();
|
|
|
|
System.out.println("*** Created empty mailcap file in current");
|
|
|
|
System.out.println("*** directory (to work around buggy javamail");
|
|
|
|
System.out.println("*** software from JavaSoft).");
|
|
|
|
} catch (java.io.IOException e) {
|
|
|
|
System.out.println("*** Couldn't create empty mailcap file: " + e);
|
|
|
|
System.out.println("*** Immanent crash is likely due to buggy");
|
|
|
|
System.out.println("*** javamail software from JavaSoft.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
initChildren();
|
|
|
|
|
|
|
|
fStoreChangeListener = new StoreChangeListener();
|
|
|
|
StoreFactory.Instance().addChangeListener(fStoreChangeListener);
|
|
|
|
|
|
|
|
// Tweek some UI behaviors
|
|
|
|
grendel.ui.GeneralFrame.SetExternalShell(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides an enumeration for the subviews in this view.
|
|
|
|
*
|
|
|
|
* @param iFlags Flags determining which items to iclude in the enumeration
|
|
|
|
* @see #FOLDERS
|
|
|
|
* @see #NONFOLDERS
|
|
|
|
* @see #INCLUDEHIDDEN
|
|
|
|
*
|
|
|
|
* @return An Enumeration for the view context's children
|
|
|
|
*/
|
|
|
|
public Enumeration children( int iFlags ) {
|
|
|
|
return fChildren.elements();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides an array of the view context's children
|
|
|
|
*
|
|
|
|
* @param iFlags Flags determining which items to iclude in the array
|
|
|
|
* @see #FOLDERS
|
|
|
|
* @see #NONFOLDERS
|
|
|
|
* @see #INCLUDEHIDDEN
|
|
|
|
*
|
|
|
|
* @return An array of the view context's children
|
|
|
|
*/
|
|
|
|
public IShellViewCtx[] getChildren( int iFlags ) {
|
|
|
|
IShellViewCtx res[] = new IShellViewCtx[fChildren.size()];
|
|
|
|
fChildren.copyInto(res);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the number of children for the view context.
|
|
|
|
*
|
|
|
|
* @param iFlags Flags determining which items to iclude in the array
|
|
|
|
* @see #FOLDERS
|
|
|
|
* @see #NONFOLDERS
|
|
|
|
* @see #INCLUDEHIDDEN
|
|
|
|
*
|
|
|
|
* @return the number of children for the view context
|
|
|
|
*/
|
|
|
|
public int getChildCount( int iFlags ) {
|
|
|
|
return fChildren.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the view context's direct parent view context.
|
|
|
|
*
|
|
|
|
* @return the view context's parent.
|
|
|
|
*/
|
|
|
|
public IShellViewCtx getParent() {
|
|
|
|
return fParent;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the view context's parent.
|
|
|
|
*
|
|
|
|
* @param viewCtx the parent of this view context.
|
|
|
|
*/
|
|
|
|
public void setParent( IShellViewCtx viewCtx ) {
|
|
|
|
fParent = viewCtx;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Compares two subviews.
|
|
|
|
*
|
|
|
|
* @param subview1 identifies the first subview to compare
|
|
|
|
* @param subview2 identifies the second subview to compare
|
|
|
|
*
|
|
|
|
* @return Less than zero - The first subview should precede the second
|
|
|
|
* Greater than zero - The first subview should follow the second
|
|
|
|
* Zero - The two subviews are the same
|
|
|
|
*/
|
|
|
|
public int compareIDs( IShellViewCtx subview1, IShellViewCtx subview2 ) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an IShellView object. Note the object created must be different
|
|
|
|
* than this view i.e., different references, because the Integrator may
|
|
|
|
* instruct this view to create more than one independent view.
|
|
|
|
*
|
|
|
|
* @return an IShellView object representing this view
|
|
|
|
*/
|
|
|
|
public IShellView createView(Object aObject) {
|
|
|
|
return new SessionView();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the view's preferences that display in the shell's shared
|
|
|
|
* preference window.
|
|
|
|
*
|
|
|
|
* @return an object specifying property information for the view's
|
|
|
|
* preferences. Note the property information is found via introspection.
|
|
|
|
* @see java.beans.BeanInfo
|
|
|
|
*/
|
|
|
|
public Object getGlobalPreferences() {
|
|
|
|
return new Prefs();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns attributes of this view.
|
|
|
|
*
|
|
|
|
* @return one or more flags describing the specified subview's attributes
|
|
|
|
* @see #CANCOPY
|
|
|
|
* @see #CANDELETE
|
|
|
|
* @see #CANMOVE
|
|
|
|
* @see #CANRENAME
|
|
|
|
* @see #READONLY
|
|
|
|
* @see #HASSUBFOLDER
|
|
|
|
* @see #FOLDER
|
|
|
|
*/
|
|
|
|
public int getAttributes() {
|
|
|
|
return FOLDER|HASSUBFOLDER|READONLY;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Supplies an icon for this view
|
|
|
|
*
|
|
|
|
* @param iTypeFlags one or more flags specifying the requested icon's type
|
|
|
|
* @see java.beans.BeanInfo#ICON_COLOR_16x16
|
|
|
|
* @see java.beans.BeanInfo#ICON_MONO_16x16
|
|
|
|
* @see java.beans.BeanInfo#ICON_COLOR_32x32
|
|
|
|
* @see java.beans.BeanInfo#ICON_MONO_32x32
|
|
|
|
* @see #OPEN
|
|
|
|
*
|
|
|
|
* @return an icon for the subview
|
|
|
|
*/
|
|
|
|
public Image getIcon( int iTypeFlags ) {
|
|
|
|
Image res = null;
|
|
|
|
|
|
|
|
switch (iTypeFlags) {
|
|
|
|
case java.beans.BeanInfo.ICON_COLOR_16x16:
|
|
|
|
case java.beans.BeanInfo.ICON_MONO_16x16:
|
|
|
|
res = (Image) Toolkit.getDefaultToolkit().getImage(ClassLoader.getSystemResource("grendel/ui/images/GrendelIcon16.gif"));
|
|
|
|
break;
|
|
|
|
|
|
|
|
case java.beans.BeanInfo.ICON_COLOR_32x32:
|
|
|
|
case java.beans.BeanInfo.ICON_MONO_32x32:
|
|
|
|
res = (Image) Toolkit.getDefaultToolkit().getImage(ClassLoader.getSystemResource("grendel/ui/images/GrendelIcon32.gif"));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a human readable name for this view
|
|
|
|
*
|
|
|
|
* @return a string representation of this view
|
|
|
|
*/
|
|
|
|
public String getDisplayName() {
|
|
|
|
return "Grendel";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the display name for the specified subview
|
|
|
|
*
|
|
|
|
* @param name the new display name for this view
|
|
|
|
*/
|
|
|
|
public void setDisplayName( String name ) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a change listener for monitoring changes on the ctx.
|
|
|
|
* e.g., the view ctx child state may have changed.
|
|
|
|
*/
|
|
|
|
public void addShellViewCtxListener( ShellViewCtxListener l ) {
|
|
|
|
fListeners.add(ShellViewCtxListener.class, l);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes a change listener for monitoring changes on the ctx.
|
|
|
|
*/
|
|
|
|
public void removeShellViewCtxListener( ShellViewCtxListener l ) {
|
|
|
|
fListeners.remove(ShellViewCtxListener.class, l);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setDataHandler(DataHandler aHandler) {
|
|
|
|
fDataHandler = aHandler;
|
|
|
|
}
|
|
|
|
|
|
|
|
public DataHandler getDataHandler() {
|
|
|
|
return fDataHandler;
|
|
|
|
}
|
|
|
|
|
|
|
|
void initChildren() {
|
|
|
|
ViewedStore stores[] = StoreFactory.Instance().getStores();
|
|
|
|
|
|
|
|
fChildren.removeAllElements();
|
|
|
|
|
|
|
|
try {
|
|
|
|
for (int i = 0; i < stores.length; i++) {
|
|
|
|
StoreCtx child = new StoreCtx(stores[i]);
|
|
|
|
child.initialize(fIntegrator, this);
|
|
|
|
fChildren.addElement(child);
|
|
|
|
}
|
|
|
|
} catch (Exception e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class StoreChangeListener implements ChangeListener {
|
|
|
|
public void stateChanged(ChangeEvent aEvent) {
|
|
|
|
initChildren();
|
|
|
|
notifyChange();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void notifyChange() {
|
|
|
|
Object[] listeners = fListeners.getListenerList();
|
|
|
|
ChangeEvent event = null;
|
|
|
|
for (int i = 0; i < listeners.length - 1; i += 2) {
|
|
|
|
// Lazily create the event:
|
|
|
|
if (event == null)
|
|
|
|
event = new ChangeEvent(this);
|
|
|
|
((ShellViewCtxListener)listeners[i+1]).childrenChanged(event);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|