mirror of https://github.com/tasks/tasks
Make radius configurable per location
parent
49fe296a61
commit
b405e87b49
@ -0,0 +1,109 @@
|
||||
package org.tasks.dialogs;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.Dialog;
|
||||
import android.os.Bundle;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.TextView;
|
||||
import androidx.annotation.NonNull;
|
||||
import butterknife.BindView;
|
||||
import butterknife.ButterKnife;
|
||||
import com.rey.material.widget.Slider;
|
||||
import javax.inject.Inject;
|
||||
import org.tasks.R;
|
||||
import org.tasks.injection.InjectingNativeDialogFragment;
|
||||
import org.tasks.injection.NativeDialogFragmentComponent;
|
||||
import org.tasks.locale.Locale;
|
||||
import org.tasks.themes.Theme;
|
||||
|
||||
public class NativeSeekBarDialog extends InjectingNativeDialogFragment {
|
||||
|
||||
private static final String EXTRA_LAYOUT = "extra_layout";
|
||||
private static final String EXTRA_INITIAL_VALUE = "extra_initial_value";
|
||||
private static final String EXTRA_MIN = "extra_min";
|
||||
private static final String EXTRA_MAX = "extra_max";
|
||||
private static final String EXTRA_REQUEST_CODE = "extra_request_code";
|
||||
|
||||
@BindView(R.id.slider)
|
||||
Slider slider;
|
||||
|
||||
@BindView(R.id.min)
|
||||
TextView min;
|
||||
|
||||
@BindView(R.id.max)
|
||||
TextView max;
|
||||
|
||||
@Inject DialogBuilder dialogBuilder;
|
||||
@Inject Theme theme;
|
||||
@Inject Locale locale;
|
||||
private int requestCode;
|
||||
private SeekBarCallback callback;
|
||||
|
||||
public static NativeSeekBarDialog newSeekBarDialog(
|
||||
int layout, int min, int max, int initial, int requestCode) {
|
||||
NativeSeekBarDialog dialog = new NativeSeekBarDialog();
|
||||
Bundle args = new Bundle();
|
||||
args.putInt(EXTRA_LAYOUT, layout);
|
||||
args.putInt(EXTRA_MIN, min);
|
||||
args.putInt(EXTRA_MAX, max);
|
||||
args.putInt(EXTRA_INITIAL_VALUE, initial);
|
||||
args.putInt(EXTRA_REQUEST_CODE, requestCode);
|
||||
dialog.setArguments(args);
|
||||
return dialog;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
||||
Bundle arguments = getArguments();
|
||||
requestCode = arguments.getInt(EXTRA_REQUEST_CODE);
|
||||
int initial =
|
||||
savedInstanceState == null
|
||||
? arguments.getInt(EXTRA_INITIAL_VALUE)
|
||||
: savedInstanceState.getInt(EXTRA_INITIAL_VALUE);
|
||||
int layout = arguments.getInt(EXTRA_LAYOUT);
|
||||
|
||||
LayoutInflater layoutInflater = theme.getLayoutInflater(getActivity());
|
||||
View view = layoutInflater.inflate(layout, null);
|
||||
ButterKnife.bind(this, view);
|
||||
|
||||
slider.setValueDescriptionProvider(value -> locale.formatNumber(value));
|
||||
slider.setValueRange(arguments.getInt(EXTRA_MIN), arguments.getInt(EXTRA_MAX), false);
|
||||
slider.setValue(initial, true);
|
||||
min.setText(locale.formatNumber(slider.getMinValue()));
|
||||
max.setText(locale.formatNumber(slider.getMaxValue()));
|
||||
return dialogBuilder
|
||||
.newDialog()
|
||||
.setView(view)
|
||||
.setPositiveButton(
|
||||
android.R.string.ok,
|
||||
(dialogInterface, i) -> callback.valueSelected(slider.getValue(), requestCode))
|
||||
.setNegativeButton(android.R.string.cancel, null)
|
||||
.create();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onAttach(Activity activity) {
|
||||
super.onAttach(activity);
|
||||
|
||||
callback = (SeekBarCallback) activity;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSaveInstanceState(Bundle outState) {
|
||||
super.onSaveInstanceState(outState);
|
||||
|
||||
outState.putInt(EXTRA_INITIAL_VALUE, slider.getValue());
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void inject(NativeDialogFragmentComponent component) {
|
||||
component.inject(this);
|
||||
}
|
||||
|
||||
public interface SeekBarCallback {
|
||||
|
||||
void valueSelected(int value, int requestCode);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,47 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content">
|
||||
|
||||
<com.rey.material.widget.Slider xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
android:id="@+id/slider"
|
||||
style="@style/Material.Widget.Slider.Discrete"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:paddingStart="@dimen/keyline_first"
|
||||
android:paddingEnd="@dimen/keyline_first"
|
||||
android:paddingLeft="@dimen/keyline_first"
|
||||
android:paddingRight="@dimen/keyline_first"
|
||||
android:gravity="center"
|
||||
android:minHeight="?attr/listPreferredItemHeight"
|
||||
app:sl_discreteMode="true"
|
||||
app:sl_stepValue="25"
|
||||
app:sl_travelAnimDuration="100"/>
|
||||
|
||||
<TextView
|
||||
android:id="@+id/min"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentLeft="true"
|
||||
android:layout_alignParentStart="true"
|
||||
android:layout_below="@id/slider"
|
||||
android:paddingTop="5dp"
|
||||
android:paddingStart="@dimen/keyline_first"
|
||||
android:paddingEnd="@dimen/keyline_first"
|
||||
android:paddingLeft="@dimen/keyline_first"
|
||||
android:paddingRight="@dimen/keyline_first"/>
|
||||
|
||||
<TextView
|
||||
android:id="@+id/max"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentEnd="true"
|
||||
android:layout_alignParentRight="true"
|
||||
android:layout_below="@id/slider"
|
||||
android:paddingTop="5dp"
|
||||
android:paddingStart="@dimen/keyline_first"
|
||||
android:paddingEnd="@dimen/keyline_first"
|
||||
android:paddingLeft="@dimen/keyline_first"
|
||||
android:paddingRight="@dimen/keyline_first"/>
|
||||
|
||||
</RelativeLayout>
|
||||
Loading…
Reference in New Issue