mirror of
https://github.com/aljazceru/Android-nRF-Toolbox.git
synced 2025-12-22 08:54:21 +01:00
Notification channels for Android Oreo
This commit is contained in:
@@ -0,0 +1,67 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2017, Nordic Semiconductor
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
|
||||||
|
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package no.nordicsemi.android.nrftoolbox;
|
||||||
|
|
||||||
|
import android.app.Application;
|
||||||
|
import android.app.Notification;
|
||||||
|
import android.app.NotificationChannel;
|
||||||
|
import android.app.NotificationManager;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Build;
|
||||||
|
|
||||||
|
import no.nordicsemi.android.dfu.DfuServiceInitiator;
|
||||||
|
|
||||||
|
public class ToolboxApplication extends Application {
|
||||||
|
public static final String CONNECTED_DEVICE_CHANNEL = "connected_device_channel";
|
||||||
|
public static final String FILE_SAVED_CHANNEL = "file_saved_channel";
|
||||||
|
public static final String PROXIMITY_WARNINGS_CHANNEL = "proximity_warnings_channel";
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate() {
|
||||||
|
super.onCreate();
|
||||||
|
|
||||||
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
|
||||||
|
DfuServiceInitiator.createDfuNotificationChannel(this);
|
||||||
|
|
||||||
|
final NotificationChannel channel = new NotificationChannel(CONNECTED_DEVICE_CHANNEL, getString(R.string.channel_connected_devices_title), NotificationManager.IMPORTANCE_LOW);
|
||||||
|
channel.setDescription(getString(R.string.channel_connected_devices_description));
|
||||||
|
channel.setShowBadge(false);
|
||||||
|
channel.setLockscreenVisibility(Notification.VISIBILITY_PUBLIC);
|
||||||
|
|
||||||
|
final NotificationChannel fileChannel = new NotificationChannel(FILE_SAVED_CHANNEL, getString(R.string.channel_files_title), NotificationManager.IMPORTANCE_LOW);
|
||||||
|
fileChannel.setDescription(getString(R.string.channel_files_description));
|
||||||
|
fileChannel.setShowBadge(false);
|
||||||
|
fileChannel.setLockscreenVisibility(Notification.VISIBILITY_PRIVATE);
|
||||||
|
|
||||||
|
final NotificationChannel proximityChannel = new NotificationChannel(PROXIMITY_WARNINGS_CHANNEL, getString(R.string.channel_proximity_warnings_title), NotificationManager.IMPORTANCE_LOW);
|
||||||
|
proximityChannel.setDescription(getString(R.string.channel_proximity_warnings_description));
|
||||||
|
proximityChannel.setShowBadge(false);
|
||||||
|
proximityChannel.setLockscreenVisibility(Notification.VISIBILITY_PUBLIC);
|
||||||
|
|
||||||
|
final NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
|
||||||
|
notificationManager.createNotificationChannel(channel);
|
||||||
|
notificationManager.createNotificationChannel(fileChannel);
|
||||||
|
notificationManager.createNotificationChannel(proximityChannel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,13 +8,14 @@ import android.content.BroadcastReceiver;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.NotificationCompat;
|
|
||||||
import android.util.SparseArray;
|
import android.util.SparseArray;
|
||||||
|
|
||||||
import no.nordicsemi.android.log.Logger;
|
import no.nordicsemi.android.log.Logger;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
|
|
||||||
@@ -177,7 +178,7 @@ public class CGMService extends BleProfileService implements CGMSManagerCallback
|
|||||||
|
|
||||||
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.CONNECTED_DEVICE_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent);
|
builder.setContentIntent(pendingIntent);
|
||||||
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_cgms);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_cgms);
|
||||||
|
|||||||
@@ -33,11 +33,12 @@ import android.content.IntentFilter;
|
|||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
|
|
||||||
import no.nordicsemi.android.log.Logger;
|
import no.nordicsemi.android.log.Logger;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
import no.nordicsemi.android.nrftoolbox.csc.settings.SettingsFragment;
|
import no.nordicsemi.android.nrftoolbox.csc.settings.SettingsFragment;
|
||||||
@@ -204,7 +205,7 @@ public class CSCService extends BleProfileService implements CSCManagerCallbacks
|
|||||||
|
|
||||||
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.CONNECTED_DEVICE_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent);
|
builder.setContentIntent(pendingIntent);
|
||||||
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_csc);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_csc);
|
||||||
|
|||||||
@@ -30,12 +30,13 @@ import android.content.BroadcastReceiver;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.NotificationCompat;
|
|
||||||
|
|
||||||
import no.nordicsemi.android.log.Logger;
|
import no.nordicsemi.android.log.Logger;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
|
|
||||||
@@ -132,7 +133,7 @@ public class HTSService extends BleProfileService implements HTSManagerCallbacks
|
|||||||
|
|
||||||
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.CONNECTED_DEVICE_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent);
|
builder.setContentIntent(pendingIntent);
|
||||||
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_hts);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_hts);
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ import android.media.RingtoneManager;
|
|||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.support.v4.app.NotificationManagerCompat;
|
import android.support.v4.app.NotificationManagerCompat;
|
||||||
import android.support.v4.content.ContextCompat;
|
import android.support.v4.content.ContextCompat;
|
||||||
import android.support.v7.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
@@ -47,6 +47,7 @@ import java.util.List;
|
|||||||
import no.nordicsemi.android.log.LogContract;
|
import no.nordicsemi.android.log.LogContract;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.multiconnect.BleMulticonnectProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.multiconnect.BleMulticonnectProfileService;
|
||||||
|
|
||||||
@@ -411,7 +412,7 @@ public class ProximityService extends BleMulticonnectProfileService implements P
|
|||||||
// Both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// Both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
|
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.PROXIMITY_WARNINGS_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent).setAutoCancel(false);
|
builder.setContentIntent(pendingIntent).setAutoCancel(false);
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_proximity);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_proximity);
|
||||||
return builder;
|
return builder;
|
||||||
|
|||||||
@@ -32,11 +32,12 @@ import android.content.Intent;
|
|||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
|
|
||||||
import no.nordicsemi.android.log.Logger;
|
import no.nordicsemi.android.log.Logger;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
|
|
||||||
@@ -183,7 +184,7 @@ public class RSCService extends BleProfileService implements RSCManagerCallbacks
|
|||||||
|
|
||||||
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.CONNECTED_DEVICE_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent);
|
builder.setContentIntent(pendingIntent);
|
||||||
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_rsc);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_rsc);
|
||||||
|
|||||||
@@ -31,11 +31,12 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
|
|
||||||
import no.nordicsemi.android.log.Logger;
|
import no.nordicsemi.android.log.Logger;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
|
|
||||||
@@ -138,7 +139,7 @@ public class TemplateService extends BleProfileService implements TemplateManage
|
|||||||
|
|
||||||
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.CONNECTED_DEVICE_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent);
|
builder.setContentIntent(pendingIntent);
|
||||||
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_template);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_template);
|
||||||
|
|||||||
@@ -51,10 +51,10 @@ import android.support.annotation.NonNull;
|
|||||||
import android.support.design.widget.Snackbar;
|
import android.support.design.widget.Snackbar;
|
||||||
import android.support.v4.app.ActivityCompat;
|
import android.support.v4.app.ActivityCompat;
|
||||||
import android.support.v4.app.DialogFragment;
|
import android.support.v4.app.DialogFragment;
|
||||||
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.support.v4.content.ContextCompat;
|
import android.support.v4.content.ContextCompat;
|
||||||
import android.support.v4.widget.SlidingPaneLayout;
|
import android.support.v4.widget.SlidingPaneLayout;
|
||||||
import android.support.v7.app.AlertDialog;
|
import android.support.v7.app.AlertDialog;
|
||||||
import android.support.v7.app.NotificationCompat;
|
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
@@ -88,6 +88,7 @@ import java.io.StringWriter;
|
|||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
import no.nordicsemi.android.nrftoolbox.dfu.adapter.FileBrowserAppsAdapter;
|
import no.nordicsemi.android.nrftoolbox.dfu.adapter.FileBrowserAppsAdapter;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileServiceReadyActivity;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileServiceReadyActivity;
|
||||||
@@ -754,7 +755,7 @@ public class UARTActivity extends BleProfileServiceReadyActivity<UARTService.UAR
|
|||||||
intent.setDataAndType(Uri.fromFile(file), "text/xml");
|
intent.setDataAndType(Uri.fromFile(file), "text/xml");
|
||||||
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivity(this, 420, intent, 0);
|
final PendingIntent pendingIntent = PendingIntent.getActivity(this, 420, intent, 0);
|
||||||
final Notification notification = new NotificationCompat.Builder(this).setContentIntent(pendingIntent).setContentTitle(fileName).setContentText(getText(R.string.uart_configuration_export_succeeded))
|
final Notification notification = new NotificationCompat.Builder(this, ToolboxApplication.FILE_SAVED_CHANNEL).setContentIntent(pendingIntent).setContentTitle(fileName).setContentText(getText(R.string.uart_configuration_export_succeeded))
|
||||||
.setAutoCancel(true).setShowWhen(true).setTicker(getText(R.string.uart_configuration_export_succeeded_ticker)).setSmallIcon(android.R.drawable.stat_notify_sdcard).build();
|
.setAutoCancel(true).setShowWhen(true).setTicker(getText(R.string.uart_configuration_export_succeeded_ticker)).setSmallIcon(android.R.drawable.stat_notify_sdcard).build();
|
||||||
final NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
|
final NotificationManager nm = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
|
||||||
nm.notify(fileName, 823, notification);
|
nm.notify(fileName, 823, notification);
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ import android.content.Intent;
|
|||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.support.annotation.NonNull;
|
import android.support.annotation.NonNull;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v7.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
@@ -45,6 +45,7 @@ import com.google.android.gms.wearable.Wearable;
|
|||||||
import no.nordicsemi.android.log.Logger;
|
import no.nordicsemi.android.log.Logger;
|
||||||
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
import no.nordicsemi.android.nrftoolbox.FeaturesActivity;
|
||||||
import no.nordicsemi.android.nrftoolbox.R;
|
import no.nordicsemi.android.nrftoolbox.R;
|
||||||
|
import no.nordicsemi.android.nrftoolbox.ToolboxApplication;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
import no.nordicsemi.android.nrftoolbox.profile.BleManager;
|
||||||
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
import no.nordicsemi.android.nrftoolbox.profile.BleProfileService;
|
||||||
import no.nordicsemi.android.nrftoolbox.wearable.common.Constants;
|
import no.nordicsemi.android.nrftoolbox.wearable.common.Constants;
|
||||||
@@ -236,7 +237,7 @@ public class UARTService extends BleProfileService implements UARTManagerCallbac
|
|||||||
|
|
||||||
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
// both activities above have launchMode="singleTask" in the AndroidManifest.xml file, so if the task is already running, it will be resumed
|
||||||
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
final PendingIntent pendingIntent = PendingIntent.getActivities(this, OPEN_ACTIVITY_REQ, new Intent[] { parentIntent, targetIntent }, PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this);
|
final NotificationCompat.Builder builder = new NotificationCompat.Builder(this, ToolboxApplication.CONNECTED_DEVICE_CHANNEL);
|
||||||
builder.setContentIntent(pendingIntent);
|
builder.setContentIntent(pendingIntent);
|
||||||
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
builder.setContentTitle(getString(R.string.app_name)).setContentText(getString(messageResId, getDeviceName()));
|
||||||
builder.setSmallIcon(R.drawable.ic_stat_notify_uart);
|
builder.setSmallIcon(R.drawable.ic_stat_notify_uart);
|
||||||
|
|||||||
@@ -23,4 +23,11 @@
|
|||||||
<resources>
|
<resources>
|
||||||
<string name="bonding">Bonding with the device…</string>
|
<string name="bonding">Bonding with the device…</string>
|
||||||
<string name="bonded">The device is now bonded.</string>
|
<string name="bonded">The device is now bonded.</string>
|
||||||
|
|
||||||
|
<string name="channel_connected_devices_title">Background connections</string>
|
||||||
|
<string name="channel_connected_devices_description">Shows a notification when a device is connected in background.</string>
|
||||||
|
<string name="channel_files_title">Files</string>
|
||||||
|
<string name="channel_files_description">Shows notifications when new files has been saved.</string>
|
||||||
|
<string name="channel_proximity_warnings_title">Proximity warnings</string>
|
||||||
|
<string name="channel_proximity_warnings_description">Shows notifications when a proximity device got out of range.</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|||||||
Reference in New Issue
Block a user