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

Commit 9f1cd009 authored by Nancy Chen's avatar Nancy Chen Committed by Android Git Automerger
Browse files

am 179f49b0: Merge "Call duration should be verbalized as hours, minutes,...

am 179f49b0: Merge "Call duration should be verbalized as hours, minutes, seconds." into lmp-mr1-dev

* commit '179f49b03bd5f95de448996b2aef1d97dcd17287':
  Call duration should be verbalized as hours, minutes, seconds.
parents 6e3cb305 6a918d7c
Loading
Loading
Loading
Loading
+6 −1
Original line number Diff line number Diff line
@@ -32,6 +32,7 @@ import android.telecom.DisconnectCause;
import android.telecom.VideoProfile;
import android.telephony.PhoneNumberUtils;
import android.text.TextUtils;
import android.text.format.DateUtils;
import android.view.Display;
import android.view.LayoutInflater;
import android.view.View;
@@ -47,6 +48,7 @@ import android.view.animation.AnimationUtils;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.TextView;

import com.android.contacts.common.util.MaterialColorMapUtils.MaterialPalette;
import com.android.contacts.common.widget.FloatingActionButtonController;
import com.android.incallui.service.PhoneNumberService;
@@ -592,12 +594,15 @@ public class CallCardFragment extends BaseFragment<CallCardPresenter, CallCardPr
    }

    @Override
    public void setPrimaryCallElapsedTime(boolean show, String callTimeElapsed) {
    public void setPrimaryCallElapsedTime(boolean show, long duration) {
        if (show) {
            if (mElapsedTime.getVisibility() != View.VISIBLE) {
                AnimUtils.fadeIn(mElapsedTime, AnimUtils.DEFAULT_DURATION);
            }
            String callTimeElapsed = DateUtils.formatElapsedTime(duration / 1000);
            String durationDescription = InCallDateUtils.formatDetailedDuration(duration);
            mElapsedTime.setText(callTimeElapsed);
            mElapsedTime.setContentDescription(durationDescription);
        } else {
            // hide() animation has no effect if it is already hidden.
            AnimUtils.fadeOut(mElapsedTime, AnimUtils.DEFAULT_DURATION);
+4 −5
Original line number Diff line number Diff line
@@ -33,7 +33,6 @@ import android.telecom.VideoProfile;
import android.telephony.PhoneNumberUtils;
import android.telephony.TelephonyManager;
import android.text.TextUtils;
import android.text.format.DateUtils;

import com.android.incallui.ContactInfoCache.ContactCacheEntry;
import com.android.incallui.ContactInfoCache.ContactInfoCacheCallback;
@@ -226,7 +225,7 @@ public class CallCardPresenter extends Presenter<CallCardPresenter.CallCardUi>
        } else {
            Log.d(this, "Canceling the calltime timer");
            mCallTimer.cancel();
            ui.setPrimaryCallElapsedTime(false, null);
            ui.setPrimaryCallElapsedTime(false, 0);
        }

        // Set the call state
@@ -357,13 +356,13 @@ public class CallCardPresenter extends Presenter<CallCardPresenter.CallCardUi>

        if (ui == null || mPrimary == null || mPrimary.getState() != Call.State.ACTIVE) {
            if (ui != null) {
                ui.setPrimaryCallElapsedTime(false, null);
                ui.setPrimaryCallElapsedTime(false, 0);
            }
            mCallTimer.cancel();
        } else {
            final long callStart = mPrimary.getConnectTimeMillis();
            final long duration = System.currentTimeMillis() - callStart;
            ui.setPrimaryCallElapsedTime(true, DateUtils.formatElapsedTime(duration / 1000));
            ui.setPrimaryCallElapsedTime(true, duration);
        }
    }

@@ -734,7 +733,7 @@ public class CallCardPresenter extends Presenter<CallCardPresenter.CallCardUi>
        void setCallState(int state, int videoState, int sessionModificationState,
                DisconnectCause disconnectCause, String connectionLabel,
                Drawable connectionIcon, String gatewayNumber);
        void setPrimaryCallElapsedTime(boolean show, String duration);
        void setPrimaryCallElapsedTime(boolean show, long duration);
        void setPrimaryName(String name, boolean nameIsNumber);
        void setPrimaryImage(Drawable image);
        void setPrimaryPhoneNumber(String phoneNumber);
+56 −0
Original line number Diff line number Diff line
package com.android.incallui;

import android.content.res.Resources;

/**
 * Methods to parse time and date information in the InCallUi
 */
public class InCallDateUtils {
    public InCallDateUtils() {

    }

    /**
     * Return given duration in a human-friendly format. For example, "4
     * minutes 3 seconds" or "3 hours 1 second". Returns the hours, minutes and seconds in that
     * order if they exist.
     */
    public static String formatDetailedDuration(long millis) {
        int hours = 0;
        int minutes = 0;
        int seconds = 0;
        int elapsedSeconds = (int) (millis / 1000);
        if (elapsedSeconds >= 3600) {
            hours = elapsedSeconds / 3600;
            elapsedSeconds -= hours * 3600;
        }
        if (elapsedSeconds >= 60) {
            minutes = elapsedSeconds / 60;
            elapsedSeconds -= minutes * 60;
        }
        seconds = elapsedSeconds;

        final Resources res = Resources.getSystem();
        StringBuilder duration = new StringBuilder();
        if (hours > 0) {
            duration.append(res.getQuantityString(
                    com.android.internal.R.plurals.duration_hours, hours, hours));
        }
        if (minutes > 0) {
            if (hours > 0) {
                duration.append(' ');
            }
            duration.append(res.getQuantityString(
                    com.android.internal.R.plurals.duration_minutes, minutes, minutes));
        }
        if (seconds > 0) {
            if (hours > 0 || minutes > 0) {
                duration.append(' ');
            }
            duration.append(res.getQuantityString(
                    com.android.internal.R.plurals.duration_seconds, seconds, seconds));
        }
        return duration.toString();
    }

}