Bind connect and disconnect to the whole cards.

Use snackbars to give early feedback to the user (colors are wrong now, waiting for a change in master).
Removed hintTextView for good
This commit is contained in:
Daniele Gobbetti 2016-10-29 18:20:53 +02:00
parent a4b7b87b24
commit 8fdb233ef0
7 changed files with 121 additions and 104 deletions

View File

@ -52,8 +52,6 @@ public class ControlCenterv2 extends AppCompatActivity
private DeviceManager deviceManager; private DeviceManager deviceManager;
private ImageView background; private ImageView background;
//hidden temporarily?
//private TextView hintTextView;
private List<GBDevice> deviceList; private List<GBDevice> deviceList;
private GBDeviceAdapterv2 mGBDeviceAdapter; private GBDeviceAdapterv2 mGBDeviceAdapter;
@ -106,7 +104,6 @@ public class ControlCenterv2 extends AppCompatActivity
//end of material design boilerplate //end of material design boilerplate
deviceManager = GBApplication.getDeviceManager(); deviceManager = GBApplication.getDeviceManager();
// hintTextView = (TextView) findViewById(R.id.hintTextView);
deviceListView = (RecyclerView) findViewById(R.id.deviceListView); deviceListView = (RecyclerView) findViewById(R.id.deviceListView);
deviceListView.setHasFixedSize(true); deviceListView.setHasFixedSize(true);
@ -246,13 +243,6 @@ public class ControlCenterv2 extends AppCompatActivity
background.setVisibility(View.INVISIBLE); background.setVisibility(View.INVISIBLE);
} }
// if (connectedDevice != null) {
// DeviceCoordinator coordinator = DeviceHelper.getInstance().getCoordinator(connectedDevice);
// hintTextView.setText(coordinator.getTapString());
// } else if (!deviceList.isEmpty()) {
// hintTextView.setText(R.string.tap_a_device_to_connect);
// }
mGBDeviceAdapter.notifyDataSetChanged(); mGBDeviceAdapter.notifyDataSetChanged();
} }

View File

@ -6,7 +6,9 @@ import android.app.ProgressDialog;
import android.content.Context; import android.content.Context;
import android.content.DialogInterface; import android.content.DialogInterface;
import android.content.Intent; import android.content.Intent;
import android.support.design.widget.Snackbar;
import android.support.v4.content.LocalBroadcastManager; import android.support.v4.content.LocalBroadcastManager;
import android.support.v7.widget.CardView;
import android.support.v7.widget.RecyclerView; import android.support.v7.widget.RecyclerView;
import android.transition.TransitionManager; import android.transition.TransitionManager;
import android.view.LayoutInflater; import android.view.LayoutInflater;
@ -62,31 +64,33 @@ public class GBDeviceAdapterv2 extends RecyclerView.Adapter<GBDeviceAdapterv2.Vi
final GBDevice device = deviceList.get(position); final GBDevice device = deviceList.get(position);
DeviceCoordinator coordinator = DeviceHelper.getInstance().getCoordinator(device); DeviceCoordinator coordinator = DeviceHelper.getInstance().getCoordinator(device);
holder.deviceImageView.setImageResource(R.drawable.level_list_device); holder.container.setOnClickListener(new View.OnClickListener() {
//level-list does not allow negative values, hence we always add 100 to the key.
holder.deviceImageView.setImageLevel(device.getType().getKey() + 100 + (device.isInitialized() ? 100 : 0));
holder.deviceImageView.setOnClickListener(new View.OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
//TODO: move somewhere else? if (device.isInitialized() || device.isConnected()) {
showTransientSnackbar(R.string.controlcenter_snackbar_need_longpress);
} else {
showTransientSnackbar(R.string.controlcenter_snackbar_connecting);
GBApplication.deviceService().connect(device); GBApplication.deviceService().connect(device);
} }
}
}); });
holder.deviceImageView.setOnLongClickListener(new View.OnLongClickListener() {
holder.container.setOnLongClickListener(new View.OnLongClickListener() {
@Override @Override
public boolean onLongClick(View v) { public boolean onLongClick(View v) {
//TODO: move somewhere else? showTransientSnackbar(R.string.controlcenter_snackbar_disconnecting);
GBApplication.deviceService().disconnect(); GBApplication.deviceService().disconnect();
return true; return true;
} }
}); });
holder.deviceImageView.setImageResource(R.drawable.level_list_device);
//level-list does not allow negative values, hence we always add 100 to the key.
holder.deviceImageView.setImageLevel(device.getType().getKey() + 100 + (device.isInitialized() ? 100 : 0));
holder.deviceNameLabel.setText(getUniqueDeviceName(device)); holder.deviceNameLabel.setText(getUniqueDeviceName(device));
//TODO: snackbar!
if (device.isBusy()) { if (device.isBusy()) {
holder.deviceStatusLabel.setText(device.getBusyTask()); holder.deviceStatusLabel.setText(device.getBusyTask());
holder.busyIndicator.setVisibility(View.VISIBLE); holder.busyIndicator.setVisibility(View.VISIBLE);
@ -118,6 +122,7 @@ public class GBDeviceAdapterv2 extends RecyclerView.Adapter<GBDeviceAdapterv2.Vi
{ {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
showTransientSnackbar(R.string.busy_task_fetch_activity_data);
GBApplication.deviceService().onFetchActivityData(); GBApplication.deviceService().onFetchActivityData();
} }
} }
@ -131,6 +136,7 @@ public class GBDeviceAdapterv2 extends RecyclerView.Adapter<GBDeviceAdapterv2.Vi
{ {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
showTransientSnackbar(R.string.controlcenter_snackbar_requested_screenshot);
GBApplication.deviceService().onScreenshotReq(); GBApplication.deviceService().onScreenshotReq();
} }
} }
@ -276,6 +282,8 @@ public class GBDeviceAdapterv2 extends RecyclerView.Adapter<GBDeviceAdapterv2.Vi
static class ViewHolder extends RecyclerView.ViewHolder { static class ViewHolder extends RecyclerView.ViewHolder {
CardView container;
ImageView deviceImageView; ImageView deviceImageView;
TextView deviceNameLabel; TextView deviceNameLabel;
TextView deviceStatusLabel; TextView deviceStatusLabel;
@ -301,6 +309,8 @@ public class GBDeviceAdapterv2 extends RecyclerView.Adapter<GBDeviceAdapterv2.Vi
ViewHolder(View view) { ViewHolder(View view) {
super(view); super(view);
container = (CardView) view.findViewById(R.id.card_view);
deviceImageView = (ImageView) view.findViewById(R.id.device_image); deviceImageView = (ImageView) view.findViewById(R.id.device_image);
deviceNameLabel = (TextView) view.findViewById(R.id.device_name); deviceNameLabel = (TextView) view.findViewById(R.id.device_name);
deviceStatusLabel = (TextView) view.findViewById(R.id.device_status); deviceStatusLabel = (TextView) view.findViewById(R.id.device_status);
@ -374,4 +384,18 @@ public class GBDeviceAdapterv2 extends RecyclerView.Adapter<GBDeviceAdapterv2.Vi
} }
return true; return true;
} }
private void showTransientSnackbar(int resource) {
Snackbar snackbar = Snackbar.make(parent, resource, Snackbar.LENGTH_SHORT);
View snackbarView = snackbar.getView();
// change snackbar text color
int snackbarTextId = android.support.design.R.id.snackbar_text;
TextView textView = (TextView) snackbarView.findViewById(snackbarTextId);
//textView.setTextColor();
//snackbarView.setBackgroundColor(Color.MAGENTA);
snackbar.show();
}
} }

View File

@ -23,19 +23,6 @@
<include layout="@layout/activity_controlcenterv2_content_main" /> <include layout="@layout/activity_controlcenterv2_content_main" />
<!-- <TextView
android:id="@+id/hintTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|center"
android:layout_centerHorizontal="true"
android:layout_marginBottom="10dp"
android:textAppearance="?android:attr/textAppearanceSmall"
android:textColor="@color/secondarytext"
android:textStyle="italic"
android:text="@string/tap_connected_device_for_app_mananger"
android:elevation="0dp" />
-->
<android.support.design.widget.FloatingActionButton <android.support.design.widget.FloatingActionButton
android:id="@+id/fab" android:id="@+id/fab"
android:layout_width="wrap_content" android:layout_width="wrap_content"

View File

@ -23,7 +23,6 @@
android:layout_height="match_parent" android:layout_height="match_parent"
android:layout_alignParentTop="true" android:layout_alignParentTop="true"
android:layout_centerHorizontal="true" android:layout_centerHorizontal="true"
android:paddingBottom="64dp"
android:divider="@null" /> android:divider="@null" />
</RelativeLayout> </RelativeLayout>

View File

@ -19,12 +19,66 @@
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent"> android:layout_height="match_parent">
<RelativeLayout
android:id="@+id/device_item_infos_box"
android:layout_width="match_parent"
android:layout_height="50dp"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginBottom="8dp"
android:focusable="false"
android:visibility="gone">
<ListView
android:id="@+id/device_item_infos"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:focusable="false"
android:layout_alignParentLeft="true"
android:layout_toStartOf="@+id/device_action_remove"
android:scrollbars="none" />
<ImageView
android:id="@+id/device_action_find"
android:layout_width="36dp"
android:layout_height="36dp"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="0dp"
android:layout_marginTop="8dp"
android:clickable="true"
android:tint="?android:textColorTertiary"
android:background="?android:attr/selectableItemBackground"
card_view:srcCompat="@drawable/ic_action_find_lost_device"
android:contentDescription="@string/controlcenter_find_device" />
<ImageView
android:id="@+id/device_action_remove"
android:layout_width="36dp"
android:layout_height="36dp"
android:layout_alignParentRight="true"
android:layout_below="@id/device_action_find"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="0dp"
android:layout_marginTop="8dp"
android:clickable="true"
android:tint="?android:textColorTertiary"
android:background="?android:attr/selectableItemBackground"
card_view:srcCompat="@drawable/ic_remove_device"
android:contentDescription="@string/controlcenter_delete_device" />
</RelativeLayout>
<ImageView <ImageView
android:id="@+id/device_image" android:id="@+id/device_image"
android:layout_width="48dp" android:layout_width="48dp"
android:layout_height="48dp" android:layout_height="48dp"
android:layout_alignParentLeft="true" android:layout_alignParentLeft="true"
android:layout_alignParentTop="true" android:layout_below="@id/device_item_infos_box"
android:contentDescription="@string/candidate_item_device_image" android:contentDescription="@string/candidate_item_device_image"
android:clickable="true" android:clickable="true"
android:longClickable="true" android:longClickable="true"
@ -35,12 +89,14 @@
android:id="@+id/device_name" android:id="@+id/device_name"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_toRightOf="@id/device_image" android:layout_toRightOf="@id/device_image"
android:layout_toLeftOf="@id/device_info_image"
android:layout_below="@id/device_item_infos_box"
android:gravity="center" android:gravity="center"
android:maxLines="1" android:maxLines="1"
android:textAppearance="@style/TextAppearance.AppCompat.Large" android:textAppearance="@style/TextAppearance.AppCompat.Large"
tools:text="My Pebble Watch" /> tools:text="My Pebble Watch"
android:layout_alignParentEnd="true" />
<TextView <TextView
android:id="@+id/device_status" android:id="@+id/device_status"
@ -48,10 +104,28 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_below="@id/device_name" android:layout_below="@id/device_name"
android:layout_toRightOf="@id/device_image" android:layout_toRightOf="@id/device_image"
android:layout_toLeftOf="@id/device_info_image"
android:gravity="center" android:gravity="center"
android:textAppearance="@style/TextAppearance.AppCompat.Subhead" android:textAppearance="@style/TextAppearance.AppCompat.Subhead"
tools:text="@string/connecting" /> tools:text="@string/connecting" />
<ImageView
android:id="@+id/device_info_image"
android:layout_width="36dp"
android:layout_height="36dp"
android:layout_alignParentRight="true"
android:layout_below="@id/device_item_infos_box"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="0dp"
android:layout_marginTop="8dp"
android:clickable="true"
android:contentDescription="@string/candidate_item_device_image"
android:tint="@color/secondarytext"
android:background="?android:attr/selectableItemBackground"
card_view:srcCompat="@drawable/ic_more_vert" />
<LinearLayout <LinearLayout
android:id="@+id/device_battery_status_box" android:id="@+id/device_battery_status_box"
android:layout_width="wrap_content" android:layout_width="wrap_content"
@ -167,75 +241,8 @@
android:background="?android:attr/selectableItemBackground" android:background="?android:attr/selectableItemBackground"
android:contentDescription="@string/controlcenter_start_activitymonitor" /> android:contentDescription="@string/controlcenter_start_activitymonitor" />
<ImageView
android:id="@+id/device_info_image"
android:layout_width="36dp"
android:layout_height="36dp"
android:layout_alignParentRight="true"
android:layout_below="@id/device_image"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="0dp"
android:layout_marginTop="8dp"
android:clickable="true"
android:contentDescription="@string/candidate_item_device_image"
android:tint="@color/secondarytext"
android:background="?android:attr/selectableItemBackground"
card_view:srcCompat="@drawable/ic_more_vert" />
<RelativeLayout
android:id="@+id/device_item_infos_box"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_below="@id/device_info_image"
android:layout_marginTop="8dp"
android:focusable="false"
android:visibility="gone">
<ListView
android:id="@+id/device_item_infos"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:focusable="false"
android:layout_alignParentLeft="true"
android:layout_toStartOf="@+id/device_action_remove"
android:scrollbars="none" />
<ImageView
android:id="@+id/device_action_find"
android:layout_width="36dp"
android:layout_height="36dp"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="0dp"
android:layout_marginTop="8dp"
android:clickable="true"
android:tint="?android:textColorTertiary"
android:background="?android:attr/selectableItemBackground"
card_view:srcCompat="@drawable/ic_action_find_lost_device"
android:contentDescription="@string/controlcenter_find_device" />
<ImageView
android:id="@+id/device_action_remove"
android:layout_width="36dp"
android:layout_height="36dp"
android:layout_alignParentRight="true"
android:layout_below="@id/device_action_find"
android:layout_marginBottom="8dp"
android:layout_marginLeft="8dp"
android:layout_marginRight="0dp"
android:layout_marginTop="8dp"
android:clickable="true"
android:tint="?android:textColorTertiary"
android:background="?android:attr/selectableItemBackground"
card_view:srcCompat="@drawable/ic_remove_device"
android:contentDescription="@string/controlcenter_delete_device" />
</RelativeLayout>
</RelativeLayout> </RelativeLayout>
</android.support.v7.widget.CardView> </android.support.v7.widget.CardView>

View File

@ -16,4 +16,9 @@
android:icon="@drawable/ic_quit" /> android:icon="@drawable/ic_quit" />
</group> </group>
<group android:checkableBehavior="single">
<item
android:id="@+id/external_changelog"
android:title="@string/changelog_title" />
</group>
</menu> </menu>

View File

@ -16,6 +16,11 @@
<string name="controlcenter_delete_device_dialogmessage">This will delete the device and all associated data!</string> <string name="controlcenter_delete_device_dialogmessage">This will delete the device and all associated data!</string>
<string name="controlcenter_navigation_drawer_open">Open navigation drawer</string> <string name="controlcenter_navigation_drawer_open">Open navigation drawer</string>
<string name="controlcenter_navigation_drawer_close">Close navigation drawer</string> <string name="controlcenter_navigation_drawer_close">Close navigation drawer</string>
<string name="controlcenter_snackbar_need_longpress">Long press the card to disconnect</string>
<string name="controlcenter_snackbar_disconnecting">Disconnecting</string>
<string name="controlcenter_snackbar_connecting">Connecting</string>
<string name="controlcenter_snackbar_requested_screenshot">Taking a screenshot of the device</string>
<string name="title_activity_debug">Debug</string> <string name="title_activity_debug">Debug</string>