Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 3ef26ac1 authored by Jean Chalard's avatar Jean Chalard Committed by Android Git Automerger
Browse files

am 6bd267f4: Merge "Add new attributes to our notification" into lmp-dev

* commit '6bd267f4':
  Add new attributes to our notification
parents aadb7a0e 6bd267f4
Loading
Loading
Loading
Loading
+2 −0
Original line number Diff line number Diff line
@@ -82,4 +82,6 @@
    <color name="setup_text_action">@android:color/holo_blue_light</color>
    <color name="setup_step_background">@android:color/background_light</color>
    <color name="setup_welcome_video_margin_color">#FFCCCCCC</color>
    <!-- Accent color for the notification. We need to match this to the OS build -->
    <color name="notification_accent_color">#FF607D8B</color>
</resources>
+83 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2014 The Android Open Source Project
 *
 * 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.
 */

package com.android.inputmethod.compat;

import android.app.Notification;
import android.os.Build;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

public class NotificationCompatUtils {
    // Note that TextInfo.getCharSequence() is supposed to be available in API level 21 and later.
    private static final Method METHOD_setColor =
            CompatUtils.getMethod(Notification.Builder.class, "setColor", int.class);
    private static final Method METHOD_setVisibility =
            CompatUtils.getMethod(Notification.Builder.class, "setVisibility", int.class);
    private static final Method METHOD_setCategory =
            CompatUtils.getMethod(Notification.Builder.class, "setCategory", String.class);
    private static final Method METHOD_setPriority =
            CompatUtils.getMethod(Notification.Builder.class, "setPriority", int.class);
    private static final Method METHOD_build =
            CompatUtils.getMethod(Notification.Builder.class, "build");
    private static final Field FIELD_VISIBILITY_SECRET =
            CompatUtils.getField(Notification.class, "VISIBILITY_SECRET");
    private static final int VISIBILITY_SECRET = null == FIELD_VISIBILITY_SECRET ? 0
            : (Integer) CompatUtils.getFieldValue(null /* receiver */, null /* defaultValue */,
                    FIELD_VISIBILITY_SECRET);
    private static final Field FIELD_CATEGORY_RECOMMENDATION =
            CompatUtils.getField(Notification.class, "CATEGORY_RECOMMENDATION");
    private static final String CATEGORY_RECOMMENDATION = null == FIELD_CATEGORY_RECOMMENDATION ? ""
            : (String) CompatUtils.getFieldValue(null /* receiver */, null /* defaultValue */,
                    FIELD_CATEGORY_RECOMMENDATION);
    private static final Field FIELD_PRIORITY_LOW =
            CompatUtils.getField(Notification.class, "PRIORITY_LOW");
    private static final int PRIORITY_LOW = null == FIELD_PRIORITY_LOW ? 0
            : (Integer) CompatUtils.getFieldValue(null /* receiver */, null /* defaultValue */,
                    FIELD_PRIORITY_LOW);

    private NotificationCompatUtils() {
        // This class is non-instantiable.
    }

    // Sets the accent color
    public static void setColor(final Notification.Builder builder, final int color) {
        CompatUtils.invoke(builder, null, METHOD_setColor, color);
    }

    public static void setVisibilityToSecret(final Notification.Builder builder) {
        CompatUtils.invoke(builder, null, METHOD_setVisibility, VISIBILITY_SECRET);
    }

    public static void setCategoryToRecommendation(final Notification.Builder builder) {
        CompatUtils.invoke(builder, null, METHOD_setCategory, CATEGORY_RECOMMENDATION);
    }

    public static void setPriorityToLow(final Notification.Builder builder) {
        CompatUtils.invoke(builder, null, METHOD_setPriority, PRIORITY_LOW);
    }

    public static Notification build(final Notification.Builder builder) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
            // #build was added in API level 16, JELLY_BEAN
            return (Notification) CompatUtils.invoke(builder, null, METHOD_build);
        } else {
            // #getNotification was deprecated in API level 16, JELLY_BEAN
            return builder.getNotification();
        }
    }
}
+10 −3
Original line number Diff line number Diff line
@@ -31,12 +31,14 @@ import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.ConnectivityManager;
import android.net.Uri;
import android.os.Build;
import android.os.ParcelFileDescriptor;
import android.text.TextUtils;
import android.util.Log;

import com.android.inputmethod.compat.ConnectivityManagerCompatUtils;
import com.android.inputmethod.compat.DownloadManagerCompatUtils;
import com.android.inputmethod.compat.NotificationCompatUtils;
import com.android.inputmethod.latin.R;
import com.android.inputmethod.latin.utils.ApplicationUtils;
import com.android.inputmethod.latin.utils.DebugLogUtils;
@@ -858,7 +860,7 @@ public final class UpdateHandler {
        final String language = (null == locale ? "" : locale.getDisplayLanguage());
        final String titleFormat = context.getString(R.string.dict_available_notification_title);
        final String notificationTitle = String.format(titleFormat, language);
        final Notification notification = new Notification.Builder(context)
        final Notification.Builder builder = new Notification.Builder(context)
                .setAutoCancel(true)
                .setContentIntent(notificationIntent)
                .setContentTitle(notificationTitle)
@@ -866,8 +868,13 @@ public final class UpdateHandler {
                .setTicker(notificationTitle)
                .setOngoing(false)
                .setOnlyAlertOnce(true)
                .setSmallIcon(R.drawable.ic_notify_dictionary)
                .getNotification();
                .setSmallIcon(R.drawable.ic_notify_dictionary);
        NotificationCompatUtils.setColor(builder,
                context.getResources().getColor(R.color.notification_accent_color));
        NotificationCompatUtils.setPriorityToLow(builder);
        NotificationCompatUtils.setVisibilityToSecret(builder);
        NotificationCompatUtils.setCategoryToRecommendation(builder);
        final Notification notification = NotificationCompatUtils.build(builder);
        notificationManager.notify(DICT_AVAILABLE_NOTIFICATION_ID, notification);
    }