1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
package it.niedermann.nextcloud.deck.ui.branding;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import androidx.annotation.ColorInt;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import com.wdullaer.materialdatetimepicker.time.TimePickerDialog;
import java.util.Calendar;
import it.niedermann.nextcloud.deck.Application;
import it.niedermann.nextcloud.deck.util.ColorUtil;
public class BrandedTimePickerDialog extends TimePickerDialog implements Branded {
@Override
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
@Nullable Context context = getContext();
if (context != null) {
setThemeDark(Application.getAppTheme(context));
if (Application.isBrandingEnabled(context)) {
@ColorInt final int mainColor = Application.readBrandMainColor(context);
@ColorInt final int textColor = Application.readBrandTextColor(context);
applyBrand(mainColor, textColor);
}
}
return super.onCreateView(inflater, container, savedInstanceState);
}
@Override
public void applyBrand(int mainColor, int textColor) {
@ColorInt final int buttonTextColor = BrandedActivity.getSecondaryForegroundColorDependingOnTheme(requireContext(), mainColor);
setOkColor(buttonTextColor);
setCancelColor(buttonTextColor);
// Text in picker title is always white
setAccentColor(ColorUtil.contrastRatioIsSufficient(Color.WHITE, mainColor) ? mainColor : textColor);
}
/**
* Create a new TimePickerDialog instance with a given intial selection
*
* @param callback How the parent is notified that the time is set.
* @param hourOfDay The initial hour of the dialog.
* @param minute The initial minute of the dialog.
* @param second The initial second of the dialog.
* @param is24HourMode True to render 24 hour mode, false to render AM / PM selectors.
* @return a new TimePickerDialog instance.
*/
@SuppressWarnings({"SameParameterValue"})
public static TimePickerDialog newInstance(OnTimeSetListener callback,
int hourOfDay, int minute, int second, boolean is24HourMode) {
TimePickerDialog ret = new BrandedTimePickerDialog();
ret.initialize(callback, hourOfDay, minute, second, is24HourMode);
return ret;
}
/**
* Create a new TimePickerDialog instance with a given initial selection
*
* @param callback How the parent is notified that the time is set.
* @param hourOfDay The initial hour of the dialog.
* @param minute The initial minute of the dialog.
* @param is24HourMode True to render 24 hour mode, false to render AM / PM selectors.
* @return a new TimePickerDialog instance.
*/
public static TimePickerDialog newInstance(OnTimeSetListener callback,
int hourOfDay, int minute, boolean is24HourMode) {
return newInstance(callback, hourOfDay, minute, 0, is24HourMode);
}
/**
* Create a new TimePickerDialog instance initialized to the current system time
*
* @param callback How the parent is notified that the time is set.
* @param is24HourMode True to render 24 hour mode, false to render AM / PM selectors.
* @return a new TimePickerDialog instance.
*/
@SuppressWarnings({"unused", "SameParameterValue"})
public static TimePickerDialog newInstance(OnTimeSetListener callback, boolean is24HourMode) {
Calendar now = Calendar.getInstance();
return newInstance(callback, now.get(Calendar.HOUR_OF_DAY), now.get(Calendar.MINUTE), is24HourMode);
}
}
|