upgrade Material Design lib and use their new time picker (#2077)
This commit is contained in:
parent
09317d9235
commit
13392258f6
4 changed files with 34 additions and 67 deletions
|
@ -134,7 +134,7 @@ dependencies {
|
||||||
implementation "androidx.room:room-rxjava2:$roomVersion"
|
implementation "androidx.room:room-rxjava2:$roomVersion"
|
||||||
kapt "androidx.room:room-compiler:$roomVersion"
|
kapt "androidx.room:room-compiler:$roomVersion"
|
||||||
|
|
||||||
implementation "com.google.android.material:material:1.2.1"
|
implementation "com.google.android.material:material:1.3.0"
|
||||||
|
|
||||||
implementation "com.squareup.retrofit2:retrofit:$retrofitVersion"
|
implementation "com.squareup.retrofit2:retrofit:$retrofitVersion"
|
||||||
implementation "com.squareup.retrofit2:converter-gson:$retrofitVersion"
|
implementation "com.squareup.retrofit2:converter-gson:$retrofitVersion"
|
||||||
|
|
|
@ -18,7 +18,6 @@ package com.keylesspalace.tusky.components.compose
|
||||||
import android.Manifest
|
import android.Manifest
|
||||||
import android.app.Activity
|
import android.app.Activity
|
||||||
import android.app.ProgressDialog
|
import android.app.ProgressDialog
|
||||||
import android.app.TimePickerDialog
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.content.SharedPreferences
|
import android.content.SharedPreferences
|
||||||
|
@ -61,6 +60,7 @@ import com.keylesspalace.tusky.adapter.OnEmojiSelectedListener
|
||||||
import com.keylesspalace.tusky.components.compose.dialog.makeCaptionDialog
|
import com.keylesspalace.tusky.components.compose.dialog.makeCaptionDialog
|
||||||
import com.keylesspalace.tusky.components.compose.dialog.showAddPollDialog
|
import com.keylesspalace.tusky.components.compose.dialog.showAddPollDialog
|
||||||
import com.keylesspalace.tusky.components.compose.view.ComposeOptionsListener
|
import com.keylesspalace.tusky.components.compose.view.ComposeOptionsListener
|
||||||
|
import com.keylesspalace.tusky.components.compose.view.ComposeScheduleView
|
||||||
import com.keylesspalace.tusky.db.AccountEntity
|
import com.keylesspalace.tusky.db.AccountEntity
|
||||||
import com.keylesspalace.tusky.db.DraftAttachment
|
import com.keylesspalace.tusky.db.DraftAttachment
|
||||||
import com.keylesspalace.tusky.di.Injectable
|
import com.keylesspalace.tusky.di.Injectable
|
||||||
|
@ -90,7 +90,7 @@ class ComposeActivity : BaseActivity(),
|
||||||
OnEmojiSelectedListener,
|
OnEmojiSelectedListener,
|
||||||
Injectable,
|
Injectable,
|
||||||
InputConnectionCompat.OnCommitContentListener,
|
InputConnectionCompat.OnCommitContentListener,
|
||||||
TimePickerDialog.OnTimeSetListener {
|
ComposeScheduleView.OnTimeSetListener {
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
lateinit var viewModelFactory: ViewModelFactory
|
lateinit var viewModelFactory: ViewModelFactory
|
||||||
|
@ -348,6 +348,7 @@ class ComposeActivity : BaseActivity(),
|
||||||
composeHideMediaButton.setOnClickListener { toggleHideMedia() }
|
composeHideMediaButton.setOnClickListener { toggleHideMedia() }
|
||||||
composeScheduleButton.setOnClickListener { onScheduleClick() }
|
composeScheduleButton.setOnClickListener { onScheduleClick() }
|
||||||
composeScheduleView.setResetOnClickListener { resetSchedule() }
|
composeScheduleView.setResetOnClickListener { resetSchedule() }
|
||||||
|
composeScheduleView.setListener(this)
|
||||||
atButton.setOnClickListener { atButtonClicked() }
|
atButton.setOnClickListener { atButtonClicked() }
|
||||||
hashButton.setOnClickListener { hashButtonClicked() }
|
hashButton.setOnClickListener { hashButtonClicked() }
|
||||||
|
|
||||||
|
@ -992,9 +993,8 @@ class ComposeActivity : BaseActivity(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onTimeSet(view: TimePicker, hourOfDay: Int, minute: Int) {
|
override fun onTimeSet(time: String) {
|
||||||
composeScheduleView.onTimeSet(hourOfDay, minute)
|
viewModel.updateScheduledAt(time)
|
||||||
viewModel.updateScheduledAt(composeScheduleView.time)
|
|
||||||
if (verifyScheduledTime()) {
|
if (verifyScheduledTime()) {
|
||||||
scheduleBehavior.state = BottomSheetBehavior.STATE_HIDDEN
|
scheduleBehavior.state = BottomSheetBehavior.STATE_HIDDEN
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -17,7 +17,6 @@ package com.keylesspalace.tusky.components.compose.view;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.Bundle;
|
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
@ -31,8 +30,9 @@ import androidx.core.content.ContextCompat;
|
||||||
import com.google.android.material.datepicker.CalendarConstraints;
|
import com.google.android.material.datepicker.CalendarConstraints;
|
||||||
import com.google.android.material.datepicker.DateValidatorPointForward;
|
import com.google.android.material.datepicker.DateValidatorPointForward;
|
||||||
import com.google.android.material.datepicker.MaterialDatePicker;
|
import com.google.android.material.datepicker.MaterialDatePicker;
|
||||||
|
import com.google.android.material.timepicker.MaterialTimePicker;
|
||||||
|
import com.google.android.material.timepicker.TimeFormat;
|
||||||
import com.keylesspalace.tusky.R;
|
import com.keylesspalace.tusky.R;
|
||||||
import com.keylesspalace.tusky.fragment.TimePickerFragment;
|
|
||||||
|
|
||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
|
@ -44,6 +44,12 @@ import java.util.TimeZone;
|
||||||
|
|
||||||
public class ComposeScheduleView extends ConstraintLayout {
|
public class ComposeScheduleView extends ConstraintLayout {
|
||||||
|
|
||||||
|
public interface OnTimeSetListener {
|
||||||
|
void onTimeSet(String time);
|
||||||
|
}
|
||||||
|
|
||||||
|
private OnTimeSetListener listener;
|
||||||
|
|
||||||
private DateFormat dateFormat;
|
private DateFormat dateFormat;
|
||||||
private DateFormat timeFormat;
|
private DateFormat timeFormat;
|
||||||
private SimpleDateFormat iso8601;
|
private SimpleDateFormat iso8601;
|
||||||
|
@ -92,6 +98,10 @@ public class ComposeScheduleView extends ConstraintLayout {
|
||||||
setEditIcons();
|
setEditIcons();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setListener(OnTimeSetListener listener) {
|
||||||
|
this.listener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
private void setScheduledDateTime() {
|
private void setScheduledDateTime() {
|
||||||
if (scheduleDateTime == null) {
|
if (scheduleDateTime == null) {
|
||||||
scheduledDateTimeView.setText("");
|
scheduledDateTimeView.setText("");
|
||||||
|
@ -144,13 +154,20 @@ public class ComposeScheduleView extends ConstraintLayout {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void openPickTimeDialog() {
|
private void openPickTimeDialog() {
|
||||||
TimePickerFragment picker = new TimePickerFragment();
|
MaterialTimePicker.Builder pickerBuilder = new MaterialTimePicker.Builder();
|
||||||
if (scheduleDateTime != null) {
|
if (scheduleDateTime != null) {
|
||||||
Bundle args = new Bundle();
|
pickerBuilder.setHour(scheduleDateTime.get(Calendar.HOUR_OF_DAY))
|
||||||
args.putInt(TimePickerFragment.PICKER_TIME_HOUR, scheduleDateTime.get(Calendar.HOUR_OF_DAY));
|
.setMinute(scheduleDateTime.get(Calendar.MINUTE));
|
||||||
args.putInt(TimePickerFragment.PICKER_TIME_MINUTE, scheduleDateTime.get(Calendar.MINUTE));
|
|
||||||
picker.setArguments(args);
|
|
||||||
}
|
}
|
||||||
|
if (android.text.format.DateFormat.is24HourFormat(this.getContext())) {
|
||||||
|
pickerBuilder.setTimeFormat(TimeFormat.CLOCK_24H);
|
||||||
|
} else {
|
||||||
|
pickerBuilder.setTimeFormat(TimeFormat.CLOCK_12H);
|
||||||
|
}
|
||||||
|
|
||||||
|
MaterialTimePicker picker = pickerBuilder.build();
|
||||||
|
picker.addOnPositiveButtonClickListener(v -> onTimeSet(picker.getHour(), picker.getMinute()));
|
||||||
|
|
||||||
picker.show(((AppCompatActivity) getContext()).getSupportFragmentManager(), "time_picker");
|
picker.show(((AppCompatActivity) getContext()).getSupportFragmentManager(), "time_picker");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,11 +217,14 @@ public class ComposeScheduleView extends ConstraintLayout {
|
||||||
openPickTimeDialog();
|
openPickTimeDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onTimeSet(int hourOfDay, int minute) {
|
private void onTimeSet(int hourOfDay, int minute) {
|
||||||
initializeSuggestedTime();
|
initializeSuggestedTime();
|
||||||
scheduleDateTime.set(Calendar.HOUR_OF_DAY, hourOfDay);
|
scheduleDateTime.set(Calendar.HOUR_OF_DAY, hourOfDay);
|
||||||
scheduleDateTime.set(Calendar.MINUTE, minute);
|
scheduleDateTime.set(Calendar.MINUTE, minute);
|
||||||
setScheduledDateTime();
|
setScheduledDateTime();
|
||||||
|
if (listener != null) {
|
||||||
|
listener.onTimeSet(getTime());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getTime() {
|
public String getTime() {
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
/* Copyright 2019 kyori19
|
|
||||||
*
|
|
||||||
* This file is a part of Tusky.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify it under the terms of the
|
|
||||||
* GNU General Public License as published by the Free Software Foundation; either version 3 of the
|
|
||||||
* License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* Tusky is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
|
|
||||||
* the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
|
|
||||||
* Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along with Tusky; if not,
|
|
||||||
* see <http://www.gnu.org/licenses>. */
|
|
||||||
|
|
||||||
package com.keylesspalace.tusky.fragment;
|
|
||||||
|
|
||||||
import android.app.Dialog;
|
|
||||||
import android.app.TimePickerDialog;
|
|
||||||
import android.os.Bundle;
|
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.fragment.app.DialogFragment;
|
|
||||||
|
|
||||||
import com.keylesspalace.tusky.components.compose.ComposeActivity;
|
|
||||||
|
|
||||||
import java.util.Calendar;
|
|
||||||
import java.util.TimeZone;
|
|
||||||
|
|
||||||
public class TimePickerFragment extends DialogFragment {
|
|
||||||
|
|
||||||
public static final String PICKER_TIME_HOUR = "picker_time_hour";
|
|
||||||
public static final String PICKER_TIME_MINUTE = "picker_time_minute";
|
|
||||||
|
|
||||||
@Override
|
|
||||||
@NonNull
|
|
||||||
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
|
||||||
Bundle args = getArguments();
|
|
||||||
Calendar calendar = Calendar.getInstance(TimeZone.getDefault());
|
|
||||||
if (args != null) {
|
|
||||||
calendar.set(Calendar.HOUR_OF_DAY, args.getInt(PICKER_TIME_HOUR));
|
|
||||||
calendar.set(Calendar.MINUTE, args.getInt(PICKER_TIME_MINUTE));
|
|
||||||
}
|
|
||||||
|
|
||||||
return new TimePickerDialog(getContext(),
|
|
||||||
android.R.style.Theme_DeviceDefault_Dialog,
|
|
||||||
(ComposeActivity) getActivity(),
|
|
||||||
calendar.get(Calendar.HOUR_OF_DAY),
|
|
||||||
calendar.get(Calendar.MINUTE),
|
|
||||||
true);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in a new issue