Package com.rim.samples.device.blackberrymaildemo

Source Code of com.rim.samples.device.blackberrymaildemo.BlackBerryMailDemoScreen

/*
* BlackBerryMailDemoScreen.java
*
* Copyright � 1998-2011 Research In Motion Limited
*
* Licensed 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.
*
* Note: For the sake of simplicity, this sample application may not leverage
* resource bundles and resource strings.  However, it is STRONGLY recommended
* that application developers make use of the localization features available
* within the BlackBerry development platform to ensure a seamless application
* experience across a variety of languages and geographies.  For more information
* on localizing your application, please refer to the BlackBerry Java Development
* Environment Development Guide associated with this release.
*/

package com.rim.samples.device.blackberrymaildemo;

import net.rim.blackberry.api.mail.Message;
import net.rim.blackberry.api.mail.ServiceConfiguration;
import net.rim.blackberry.api.mail.Session;
import net.rim.blackberry.api.mail.Store;
import net.rim.device.api.command.Command;
import net.rim.device.api.command.CommandHandler;
import net.rim.device.api.command.ReadOnlyCommandMetadata;
import net.rim.device.api.servicebook.ServiceBook;
import net.rim.device.api.servicebook.ServiceRecord;
import net.rim.device.api.system.Application;
import net.rim.device.api.system.Characters;
import net.rim.device.api.ui.MenuItem;
import net.rim.device.api.ui.UiApplication;
import net.rim.device.api.ui.component.Dialog;
import net.rim.device.api.ui.component.ListField;
import net.rim.device.api.ui.component.Menu;
import net.rim.device.api.ui.container.MainScreen;
import net.rim.device.api.util.StringProvider;

/**
* The parent class for MessagesListScreen and FoldersViewScreen. This class
* implements a menu system that allows the user to view/edit messages, switch
* mailing services if available, change message views, and compose messages.
*
* This class is to be subclassed by the MessageViewScreen and FolderViewScreen
* classes. The major feature inherited by these two classes are the menu items
* common to both view screens. This class contains four methods which its
* subclasses may implement to provide proper menu functionality. These methods
* act as listeners and are called through menu or keypad actions. They are:
* openAction(), updateScreen(), getSelectedItem() and messageServiceChanged().
*
* This class also contains a constructor to initialize the application by
* setting up the messaging service store accessed by this demo.
*/
public class BlackBerryMailDemoScreen extends MainScreen {
    protected static final int MESSAGES_VIEW_MODE = 0;
    protected static final int FOLDERS_VIEW_MODE = 1;

    protected static int _currentDisplayMode;
    protected static Store _store;

    private static ServiceRecord[] _mailServiceRecords;
    private MessagesViewScreen _messagesViewScreen;

    protected MenuItem _changeViewMenuItem;
    protected ListField _listField;

    /**
     * Default Constructor for subclasses
     */
    protected BlackBerryMailDemoScreen() {
        initializeMenuItems();
    }

    /**
     * Initialize menu item objects
     */
    private void initializeMenuItems() {
        _composeMenuItem =
                new MenuItem(new StringProvider("Compose Email"), 0x230030, 2);
        _composeMenuItem.setCommand(new Command(new CommandHandler() {
            /**
             * @see net.rim.device.api.command.CommandHandler#execute(ReadOnlyCommandMetadata,
             *      Object)
             */
            public void execute(final ReadOnlyCommandMetadata metadata,
                    final Object context) {
                final ComposeScreen composeScreen =
                        new ComposeScreen(null, _store);
                UiApplication.getUiApplication().pushScreen(composeScreen);
                updateScreen();
            }
        }));

        _openMenuItem =
                new MenuItem(new StringProvider("Open Item"), 0x230010, 0);
        _openMenuItem.setCommand(new Command(new CommandHandler() {
            /**
             * @see net.rim.device.api.command.CommandHandler#execute(ReadOnlyCommandMetadata,
             *      Object)
             */
            public void execute(final ReadOnlyCommandMetadata metadata,
                    final Object context) {
                openAction();
            }
        }));

        _editMenuItem = new MenuItem(new StringProvider("Edit"), 0x230020, 1);
        _editMenuItem.setCommand(new Command(new CommandHandler() {
            /**
             * @see net.rim.device.api.command.CommandHandler#execute(ReadOnlyCommandMetadata,
             *      Object)
             */
            public void execute(final ReadOnlyCommandMetadata metadata,
                    final Object context) {
                final Message msg = (Message) getSelectedItem();
                final MessageScreen messageScreen =
                        new MessageScreen(msg, true);
                UiApplication.getUiApplication().pushScreen(messageScreen);
                updateScreen();
            }
        }));
    }

    /**
     * Constructor to initialize the application
     *
     * @param title
     *            Screen title
     */
    public BlackBerryMailDemoScreen(final String title) {
        initializeMenuItems();

        _selectServiceMenuItem =
                new MenuItem(new StringProvider("Choose Message Service"),
                        0x230040, 3);
        _selectServiceMenuItem.setCommand(new Command(new CommandHandler() {
            /**
             * @see net.rim.device.api.command.CommandHandler#execute(ReadOnlyCommandMetadata,
             *      Object)
             */
            public void execute(final ReadOnlyCommandMetadata metadata,
                    final Object context) {
                if (_currentDisplayMode == MESSAGES_VIEW_MODE) {
                    _store.removeFolderListener(_messagesViewScreen);
                }

                selectServiceDialog();
                messageServiceChanged();
            }
        }));

        setTitle(title);
        _currentDisplayMode = MESSAGES_VIEW_MODE;

        Application.getApplication().invokeLater(new Runnable() {
            public void run() {
                initialize();
            }
        });
    }

    /**
     * Initializes the store
     */
    private void initialize() {
        // Open the service book and get the mail service records
        final ServiceBook serviceBook = ServiceBook.getSB();
        _mailServiceRecords = serviceBook.findRecordsByCid("CMIME");

        // Determine if there is more than one CMIME (email) service book
        if (_mailServiceRecords.length > 1) {
            selectServiceDialog();
        } else if (_mailServiceRecords.length == 1) {
            // There is only one message service, so just work with that.
            // Get the default mail store.
            _store = Session.getDefaultInstance().getStore();
        } else {
            // No email message services were found. We have nothing to display
            Dialog.alert("No email message services found");
            close();
        }

        // Open the messages view using the message store
        _messagesViewScreen = new MessagesViewScreen();
        UiApplication.getUiApplication().pushScreen(_messagesViewScreen);
        close();
    }

    /**
     * Spawns a dialog to allow a user to choose a specific mail service
     */
    private void selectServiceDialog() {
        // Get the name of the ServiceRecords
        final String[] names = new String[_mailServiceRecords.length];
        for (int count = _mailServiceRecords.length - 1; count >= 0; --count) {
            names[count] = _mailServiceRecords[count].getName();
        }

        // Create a Dialog to ask the user to choose a mailbox to open
        final int choice = Dialog.ask("Select a Mailbox", names, 0);

        // If the user pressed escape, close the program
        if (choice == Dialog.CANCEL) {
            Dialog.alert("Goodbye");
            close();
        }

        // Open the ServiceConfiguration
        final ServiceConfiguration sc =
                new ServiceConfiguration(_mailServiceRecords[choice]);

        // Get the mail store
        _store = Session.getInstance(sc).getStore();
    }

    /**
     * Handles opening the selected item. To be overidden by subclasses.
     */
    protected void openAction() {
    }

    /**
     * Updates the screen. To be overiden by subclasses.
     */
    protected void updateScreen() {
    }

    /**
     * Gets the selected item in the list field. To be overiden by subclasses.
     *
     * @return The selected item
     */
    protected Object getSelectedItem() {
        return null;
    }

    /**
     * A listener called when the message service is changed. To be overiden by
     * subclasses.
     */
    protected void messageServiceChanged() {
    }

    /**
     * Displays the message to edit if it is in the process of being composed.
     * If the message is not being composed then this method opens a read only
     * view of the message.
     *
     * @param message
     *            The message to view/edit
     */
    protected void openMessage(final Message message) {
        // If the message is still in the process of being composed, then open
        // the composing screen. If not, then open the message in a read only
        // screen.
        MessageScreen messageScreen;
        if (message.getStatus() == Message.Status.TX_COMPOSING) {
            messageScreen = new ComposeScreen(message, _store);
        } else {
            messageScreen = new MessageScreen(message, false);
        }

        // Show the message screen
        UiApplication.getUiApplication().pushScreen(messageScreen);
        updateScreen();
    }

    /**
     * Menu item to push a ComposeScreen
     */
    private MenuItem _composeMenuItem;

    /**
     * Menu item to open folder
     */
    private MenuItem _openMenuItem;

    /**
     * Menu item to open a message for editing
     */
    private MenuItem _editMenuItem;

    /**
     * Menu item allows user to choose message service
     */
    private MenuItem _selectServiceMenuItem;

    /**
     * @see net.rim.device.api.ui.Screen#makeMenu(Menu, int)
     */
    protected void makeMenu(final Menu menu, final int instance) {
        menu.add(_composeMenuItem);

        // If there are messages in the list, add the menu item for viewing
        // different messages.
        if (!_listField.isEmpty()) {
            // Allow the user to change the view modes
            menu.add(_changeViewMenuItem);

            // If the selected item is a message then allow the user to open it
            final Object obj = getSelectedItem();
            if (obj instanceof Message) {
                final Message msg = (Message) obj;

                // If the message is a saved message allow the user to edit it
                if (msg.getStatus() == Message.Status.TX_COMPOSING) {
                    menu.add(_editMenuItem);
                } else // Allow the user to view the message
                {
                    menu.add(_openMenuItem);
                }
            } else // Allow the user to open the non-message object
            {
                menu.add(_openMenuItem);
            }

            menu.addSeparator();
        }

        // Add a menu item to select the message service if there is more than
        // one CMIME service book.
        if (_mailServiceRecords != null) {
            menu.add(_selectServiceMenuItem);
        }

        super.makeMenu(menu, instance);
    }

    /**
     * @see net.rim.device.api.ui.Screen#invokeAction(int)
     */
    protected boolean invokeAction(final int action) {
        if (action == ACTION_INVOKE) {
            openAction();
            return true;
        }

        return super.invokeAction(action);
    }

    /**
     * @see net.rim.device.api.ui.Screen#keyChar(char, int, int)
     */
    public boolean keyChar(final char c, final int status, final int time) {
        if (c == Characters.ENTER) {
            openAction();
            return true;
        }

        return super.keyChar(c, status, time);
    }

    /**
     * Prevent the save dialog from being displayed.
     *
     * @see net.rim.device.api.ui.container.MainScreen#onSavePrompt()
     */
    public boolean onSavePrompt() {
        return true;
    }
}
TOP

Related Classes of com.rim.samples.device.blackberrymaildemo.BlackBerryMailDemoScreen

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.