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

Commit 0e03dfdd authored by Automerger Merge Worker's avatar Automerger Merge Worker
Browse files

Merge "[Wi-Fi] Implement ConnectedWifiEntryPreference to show gear icon" into...

Merge "[Wi-Fi] Implement ConnectedWifiEntryPreference to show gear icon" into rvc-dev am: 858cf425

Change-Id: I445496aac0d27a95e64a2c46c1b6ca965e96888a
parents f77db13f 858cf425
Loading
Loading
Loading
Loading
+92 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2020 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.settings.wifi;

import android.content.Context;
import android.view.View;

import androidx.fragment.app.Fragment;
import androidx.preference.PreferenceViewHolder;

import com.android.settingslib.R;
import com.android.settingslib.wifi.LongPressWifiEntryPreference;
import com.android.wifitrackerlib.WifiEntry;

/**
 * An AP preference for the currently connected AP.
 */
public class ConnectedWifiEntryPreference extends LongPressWifiEntryPreference implements
        View.OnClickListener {

    private OnGearClickListener mOnGearClickListener;

    public ConnectedWifiEntryPreference(Context context, WifiEntry wifiEntry, Fragment fragment) {
        super(context, wifiEntry, fragment);
        setWidgetLayoutResource(R.layout.preference_widget_gear_optional_background);
    }

    @Override
    public void refresh() {
        super.refresh();

        if (getWifiEntry().canSignIn()) {
            setSummary(R.string.wifi_tap_to_sign_in);
        }
    }

    /**
     * Set gear icon click callback listener.
     */
    public void setOnGearClickListener(OnGearClickListener l) {
        mOnGearClickListener = l;
        notifyChanged();
    }

    @Override
    public void onBindViewHolder(PreferenceViewHolder holder) {
        super.onBindViewHolder(holder);

        final View gear = holder.findViewById(R.id.settings_button);
        gear.setOnClickListener(this);

        final boolean canSignIn = getWifiEntry().canSignIn();
        holder.findViewById(R.id.settings_button_no_background).setVisibility(
                canSignIn ? View.INVISIBLE : View.VISIBLE);
        gear.setVisibility(canSignIn ? View.VISIBLE : View.INVISIBLE);
        holder.findViewById(R.id.two_target_divider).setVisibility(
                canSignIn ? View.VISIBLE : View.INVISIBLE);
    }

    @Override
    public void onClick(View v) {
        if (v.getId() == R.id.settings_button) {
            if (mOnGearClickListener != null) {
                mOnGearClickListener.onGearClick(this);
            }
        }
    }

    /**
     * Gear Icon click callback interface.
     */
    public interface OnGearClickListener {
        /**
         * The callback triggered when gear icon is clicked.
         */
        void onGearClick(ConnectedWifiEntryPreference p);
    }

}
+5 −2
Original line number Diff line number Diff line
@@ -711,8 +711,8 @@ public class WifiSettings2 extends RestrictedSettingsFragment
                    mConnectedWifiEntryPreferenceCategory.findPreference(connectedEntry.getKey());
            if (connectedPref == null || connectedPref.getWifiEntry() != connectedEntry) {
                mConnectedWifiEntryPreferenceCategory.removeAll();
                final LongPressWifiEntryPreference pref =
                        createLongPressWifiEntryPreference(connectedEntry);
                final ConnectedWifiEntryPreference pref =
                        new ConnectedWifiEntryPreference(getPrefContext(), connectedEntry, this);
                pref.setKey(connectedEntry.getKey());
                pref.refresh();
                mConnectedWifiEntryPreferenceCategory.addPreference(pref);
@@ -724,6 +724,9 @@ public class WifiSettings2 extends RestrictedSettingsFragment
                    }
                    return true;
                });
                pref.setOnGearClickListener(preference -> {
                    launchNetworkDetailsFragment(pref);
                });
            }
        } else {
            mConnectedWifiEntryPreferenceCategory.removeAll();
+82 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2020 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.settings.wifi;

import static com.google.common.truth.Truth.assertThat;

import static org.mockito.Mockito.never;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;

import android.content.Context;
import android.view.View;

import com.android.settings.R;
import com.android.wifitrackerlib.WifiEntry;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;

@RunWith(RobolectricTestRunner.class)
public class ConnectedWifiEntryPreferenceTest {

    @Mock
    private WifiEntry mWifiEntry;
    @Mock
    private View mView;
    @Mock
    private ConnectedWifiEntryPreference.OnGearClickListener mOnGearClickListener;
    private Context mContext;
    private ConnectedWifiEntryPreference mConnectedWifiEntryPreference;

    @Before
    public void setUp() {
        MockitoAnnotations.initMocks(this);

        mContext = RuntimeEnvironment.application;
        mConnectedWifiEntryPreference = new ConnectedWifiEntryPreference(mContext, mWifiEntry,
                null /* fragment */);
        mConnectedWifiEntryPreference.setOnGearClickListener(mOnGearClickListener);
    }

    @Test
    public void testOnClick_gearClicked_listenerInvoked() {
        when(mView.getId()).thenReturn(R.id.settings_button);

        mConnectedWifiEntryPreference.onClick(mView);

        verify(mOnGearClickListener).onGearClick(mConnectedWifiEntryPreference);
    }

    @Test
    public void testOnClick_gearNotClicked_listenerNotInvoked() {
        mConnectedWifiEntryPreference.onClick(mView);

        verify(mOnGearClickListener, never()).onGearClick(mConnectedWifiEntryPreference);
    }

    @Test
    public void testWidgetLayoutPreference() {
        assertThat(mConnectedWifiEntryPreference.getWidgetLayoutResource())
            .isEqualTo(R.layout.preference_widget_gear_optional_background);
    }
}