Home | History | Annotate | Download | only in activity
      1 /*
      2  * Copyright (C) 2008 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *      http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 package com.android.email.activity;
     18 
     19 import com.android.email.R;
     20 import com.android.email.provider.EmailContent;
     21 import com.android.email.provider.EmailContent.Account;
     22 import com.android.email.provider.EmailContent.Mailbox;
     23 
     24 import android.app.ListActivity;
     25 import android.content.Context;
     26 import android.content.Intent;
     27 import android.database.Cursor;
     28 import android.os.Bundle;
     29 import android.os.Parcelable;
     30 import android.view.View;
     31 import android.widget.AdapterView;
     32 import android.widget.ListView;
     33 import android.widget.SimpleCursorAdapter;
     34 import android.widget.TextView;
     35 import android.widget.AdapterView.OnItemClickListener;
     36 
     37 /**
     38  *
     39  * This class implements a launcher shortcut for directly accessing a single account.
     40  *
     41  * This is simply a lightweight version of Accounts, and should almost certainly be merged with it
     42  * (or, one could be a base class of the other).
     43  */
     44 public class AccountShortcutPicker extends ListActivity implements OnItemClickListener {
     45 
     46     /**
     47      * Support for list adapter
     48      */
     49     private final static String[] FROM_COLUMNS = new String[] {
     50             EmailContent.AccountColumns.DISPLAY_NAME,
     51             EmailContent.AccountColumns.EMAIL_ADDRESS,
     52             EmailContent.RECORD_ID
     53     };
     54     private final static int[] TO_IDS = new int[] {
     55             R.id.description,
     56             R.id.email,
     57             R.id.new_message_count
     58     };
     59 
     60     @Override
     61     public void onCreate(Bundle icicle) {
     62         super.onCreate(icicle);
     63 
     64         // finish() immediately if we aren't supposed to be here
     65         if (!Intent.ACTION_CREATE_SHORTCUT.equals(getIntent().getAction())) {
     66             finish();
     67             return;
     68         }
     69 
     70         // finish() immediately if no accounts are configured
     71         // TODO: lightweight projection with only those columns needed for this display
     72         // TODO: query outside of UI thread
     73         Cursor c = this.managedQuery(
     74                 EmailContent.Account.CONTENT_URI,
     75                 EmailContent.Account.CONTENT_PROJECTION,
     76                 null, null, null);
     77         if (c.getCount() == 0) {
     78             finish();
     79             return;
     80         }
     81 
     82         setContentView(R.layout.accounts);
     83         ListView listView = getListView();
     84         listView.setOnItemClickListener(this);
     85         listView.setItemsCanFocus(false);
     86         listView.setEmptyView(findViewById(R.id.empty));
     87 
     88         AccountsAdapter a = new AccountsAdapter(this,
     89                 R.layout.accounts_item, c, FROM_COLUMNS, TO_IDS);
     90         listView.setAdapter(a);
     91     }
     92 
     93     public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
     94         Cursor cursor = (Cursor)parent.getItemAtPosition(position);
     95         Account account = new Account().restore(cursor);
     96         setupShortcut(account);
     97         finish();
     98     }
     99 
    100     private static class AccountsAdapter extends SimpleCursorAdapter {
    101 
    102         public AccountsAdapter(Context context, int layout, Cursor c, String[] from, int[] to) {
    103             super(context, layout, c, from, to);
    104             setViewBinder(new MyViewBinder());
    105         }
    106 
    107         /**
    108          * This is only used for the unread messages count.  Most of the views are handled
    109          * normally by SimpleCursorAdapter.
    110          */
    111         private static class MyViewBinder implements SimpleCursorAdapter.ViewBinder {
    112 
    113             public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
    114                 if (view.getId() == R.id.new_message_count) {
    115 
    116                     int unreadMessageCount = 0;     // TODO get unread count from Account
    117                     if (unreadMessageCount <= 0) {
    118                         view.setVisibility(View.GONE);
    119                     } else {
    120                         ((TextView)view).setText(String.valueOf(unreadMessageCount));
    121                     }
    122                     return true;
    123                 }
    124 
    125                 return false;
    126             }
    127         }
    128     }
    129 
    130     /**
    131      * This function creates a shortcut and returns it to the caller.  There are actually two
    132      * intents that you will send back.
    133      *
    134      * The first intent serves as a container for the shortcut and is returned to the launcher by
    135      * setResult().  This intent must contain three fields:
    136      *
    137      * <ul>
    138      * <li>{@link android.content.Intent#EXTRA_SHORTCUT_INTENT} The shortcut intent.</li>
    139      * <li>{@link android.content.Intent#EXTRA_SHORTCUT_NAME} The text that will be displayed with
    140      * the shortcut.</li>
    141      * <li>{@link android.content.Intent#EXTRA_SHORTCUT_ICON} The shortcut's icon, if provided as a
    142      * bitmap, <i>or</i> {@link android.content.Intent#EXTRA_SHORTCUT_ICON_RESOURCE} if provided as
    143      * a drawable resource.</li>
    144      * </ul>
    145      *
    146      * If you use a simple drawable resource, note that you must wrapper it using
    147      * {@link android.content.Intent.ShortcutIconResource}, as shown below.  This is required so
    148      * that the launcher can access resources that are stored in your application's .apk file.  If
    149      * you return a bitmap, such as a thumbnail, you can simply put the bitmap into the extras
    150      * bundle using {@link android.content.Intent#EXTRA_SHORTCUT_ICON}.
    151      *
    152      * The shortcut intent can be any intent that you wish the launcher to send, when the user
    153      * clicks on the shortcut.  Typically this will be {@link android.content.Intent#ACTION_VIEW}
    154      * with an appropriate Uri for your content, but any Intent will work here as long as it
    155      * triggers the desired action within your Activity.
    156      */
    157     private void setupShortcut(Account account) {
    158         // First, set up the shortcut intent.
    159 
    160         Intent shortcutIntent = MessageList.createAccountIntentForShortcut(
    161                 this, account, Mailbox.TYPE_INBOX);
    162 
    163         // Then, set up the container intent (the response to the caller)
    164 
    165         Intent intent = new Intent();
    166         intent.putExtra(Intent.EXTRA_SHORTCUT_INTENT, shortcutIntent);
    167         intent.putExtra(Intent.EXTRA_SHORTCUT_NAME, account.getDisplayName());
    168         Parcelable iconResource = Intent.ShortcutIconResource.fromContext(this, R.drawable.icon);
    169         intent.putExtra(Intent.EXTRA_SHORTCUT_ICON_RESOURCE, iconResource);
    170 
    171         // Now, return the result to the launcher
    172 
    173         setResult(RESULT_OK, intent);
    174     }
    175 
    176 
    177 }
    178 
    179 
    180