/** * ContactLinkingDemo.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.contactlinkingdemo; import net.rim.blackberry.api.menuitem.ApplicationMenuItem; import net.rim.blackberry.api.pdap.contactlinking.LinkedContactConstants; import net.rim.blackberry.api.pdap.contactlinking.LinkedContactUtilities; import net.rim.device.api.system.Application; import net.rim.device.api.system.ApplicationDescriptor; import net.rim.device.api.system.EncodedImage; import net.rim.device.api.ui.UiApplication; import net.rim.device.api.ui.component.Dialog; import net.rim.device.api.ui.image.Image; import net.rim.device.api.ui.image.ImageFactory; /** * A sample application demonstrating the ability to link application specific * contacts with contacts in the BlackBerry address book. Note that an address * book contact can be linked to by more than one application. */ public final class ContactLinkingDemo extends UiApplication { /** * The application id for this application */ public static final long APPLICATION_ID = 0x819417e94b6ca3b7L; // com.rim.samples.device.contactlinkingdemo.APPLICATION_ID /** * Entry point for application * * @param args * Command line args */ public static void main(final String[] args) { if (args != null && args.length > 0) { if (args[0].equals("autostartup")) { // Create image final EncodedImage encodedImage = EncodedImage .getEncodedImageResource("img/logo_blue.jpg"); final Image image = ImageFactory.createImage(encodedImage); // Create an application descriptor for this application final ApplicationDescriptor applicationDescriptor = new ApplicationDescriptor(ApplicationDescriptor .currentApplicationDescriptor(), "Contact Linking Demo", new String[] { "menu-invoked" }); final ApplicationMenuItem[] items = new ApplicationMenuItem[2]; items[0] = new SampleMenuItem(APPLICATION_ID, image); items[1] = new SampleMenuItem(APPLICATION_ID, image) { public String toString() { return "Test item 2"; } }; LinkedContactUtilities.registerMenuItems(items, APPLICATION_ID, LinkedContactConstants.COMPOSE_SN_MENU_GROUP, applicationDescriptor); // Register info provider LinkedContactUtilities.registerLinkedContactInfoProvider( new SampleLinkedContactInfoProvider(image, "Demo App"), APPLICATION_ID, LinkedContactConstants.COMPOSE_SN_MENU_GROUP); } else if (args[0].equals("menu-invoked")) { // Create a new instance of the application and make the // currently // running thread the application's event dispatch thread. final Application app = new ContactLinkingDemo(true); app.enterEventDispatcher(); } } else { // Create a new instance of the application and make the currently // running thread the application's event dispatch thread. final Application app = new ContactLinkingDemo(false); app.enterEventDispatcher(); } } /** * Creates a new ContactLinkingDemo object * * @param menuInvoked * True if invoked from ApplicationMenuItem, otherwise false */ public ContactLinkingDemo(final boolean menuInvoked) { if (!menuInvoked) { // If we were launched from the home screen, push a UI screen pushScreen(new ContactListScreen()); } } /** * Presents a dialog to the user with a given message * * @param message * The text to display */ public static void errorDialog(final String message) { UiApplication.getUiApplication().invokeLater(new Runnable() { public void run() { Dialog.alert(message); } }); } }