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

Commit 32d88e8e authored by Adrian Roos's avatar Adrian Roos
Browse files

Fix ColorInversionTile for secondary users

Bug: 17626692
Change-Id: I40354a460a7c00f6fd5eb05f7836dc89129fdacb
parent bdc07b69
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -123,7 +123,7 @@ public abstract class QSTile<TState extends State> implements Listenable {
    }

    public void userSwitch(int newUserId) {
        mHandler.obtainMessage(H.USER_SWITCH, newUserId).sendToTarget();
        mHandler.obtainMessage(H.USER_SWITCH, newUserId, 0).sendToTarget();
    }

    public void fireToggleStateChanged(boolean state) {
+17 −7
Original line number Diff line number Diff line
@@ -16,6 +16,7 @@

package com.android.systemui.qs;

import android.app.ActivityManager;
import android.content.Context;
import android.database.ContentObserver;
import android.os.Handler;
@@ -28,32 +29,33 @@ public abstract class SecureSetting extends ContentObserver implements Listenabl
    private final Context mContext;
    private final String mSettingName;

    private boolean mListening;
    private int mUserId;

    protected abstract void handleValueChanged(int value);

    public SecureSetting(Context context, Handler handler, String settingName) {
        super(handler);
        mContext = context;
        mSettingName = settingName;
        rebindForCurrentUser();
    }

    public void rebindForCurrentUser() {
        mUserId = ActivityManager.getCurrentUser();
        setListening(true);
    }

    public int getValue() {
        return Secure.getInt(mContext.getContentResolver(), mSettingName, 0);
        return Secure.getIntForUser(mContext.getContentResolver(), mSettingName, 0, mUserId);
    }

    public void setValue(int value) {
        Secure.putInt(mContext.getContentResolver(), mSettingName, value);
        Secure.putIntForUser(mContext.getContentResolver(), mSettingName, value, mUserId);
    }

    @Override
    public void setListening(boolean listening) {
        mListening = listening;
        if (listening) {
            mContext.getContentResolver().registerContentObserver(
                    Secure.getUriFor(mSettingName), false, this);
                    Secure.getUriFor(mSettingName), false, this, mUserId);
        } else {
            mContext.getContentResolver().unregisterContentObserver(this);
        }
@@ -63,4 +65,12 @@ public abstract class SecureSetting extends ContentObserver implements Listenabl
    public void onChange(boolean selfChange) {
        handleValueChanged(getValue());
    }

    public void setUserId(int userId) {
        mUserId = userId;
        if (mListening) {
            setListening(false);
            setListening(true);
        }
    }
}
+2 −1
Original line number Diff line number Diff line
@@ -71,7 +71,8 @@ public class ColorInversionTile extends QSTile<QSTile.BooleanState> {

    @Override
    protected void handleUserSwitch(int newUserId) {
        mSetting.rebindForCurrentUser();
        mSetting.setUserId(newUserId);
        handleRefreshState(mSetting.getValue());
    }

    @Override