material-components_materia.../lib/java/com/google/android/material/picker/MaterialDatePickerDialogFragment.java
ldjesper f2bc99b468 Switch from a pass through click listener to a listener pattern on MaterialCalendar.
This pattern keeps change notification near the change and is more resilient to code based selection changes.

PiperOrigin-RevId: 244081299
2019-04-19 21:37:09 -04:00

68 lines
2.2 KiB
Java

/*
* Copyright 2019 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.google.android.material.picker;
import com.google.android.material.R;
import android.app.Dialog;
import android.os.Bundle;
import androidx.annotation.RestrictTo;
import androidx.annotation.RestrictTo.Scope;
import com.google.android.material.picker.selector.DateGridSelector;
import java.util.Calendar;
/**
* A {@link Dialog} with a header, {@link MaterialCalendar<Calendar>}, and set of actions.
*
* @hide
*/
@RestrictTo(Scope.LIBRARY_GROUP)
public class MaterialDatePickerDialogFragment extends MaterialPickerDialogFragment<Calendar> {
public static MaterialDatePickerDialogFragment newInstance() {
return newInstance(0);
}
public static MaterialDatePickerDialogFragment newInstance(int themeResId) {
MaterialDatePickerDialogFragment materialDatePickerDialogFragment =
new MaterialDatePickerDialogFragment();
Bundle args = new Bundle();
addThemeToBundle(args, themeResId);
materialDatePickerDialogFragment.setArguments(args);
return materialDatePickerDialogFragment;
}
@Override
protected int getDefaultThemeAttr() {
return R.attr.materialDatePickerDialogTheme;
}
@Override
protected DateGridSelector createGridSelector() {
return new DateGridSelector();
}
@Override
protected String getHeaderText(Calendar selection) {
if (selection == null) {
return getContext().getResources().getString(R.string.mtrl_picker_header_prompt);
}
String startString = getSimpleDateFormat().format(selection.getTime());
return getContext().getResources().getString(R.string.mtrl_picker_header_selected, startString);
}
}