Chromium Code Reviews| Index: content/public/android/java/src/org/chromium/content/browser/input/DateDialogNormalizer.java |
| diff --git a/content/public/android/java/src/org/chromium/content/browser/input/DateDialogNormalizer.java b/content/public/android/java/src/org/chromium/content/browser/input/DateDialogNormalizer.java |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..3395ca5ed6c7e71a1b7d11c9f27e7936b8cfcecf |
| --- /dev/null |
| +++ b/content/public/android/java/src/org/chromium/content/browser/input/DateDialogNormalizer.java |
| @@ -0,0 +1,48 @@ |
| +// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
|
bulach
2013/05/21 17:26:35
nit: add a \n
Miguel Garcia
2013/05/23 12:16:48
Done.
|
| +package org.chromium.content.browser.input; |
| + |
| +import android.widget.DatePicker; |
| +import android.widget.DatePicker.OnDateChangedListener; |
| + |
| +import java.util.Calendar; |
| + |
| +/** |
| + * Normalize a date dialog so that it respect min and max. |
| + */ |
| +public class DateDialogNormalizer { |
|
bulach
2013/05/21 17:26:35
nit: it looks like it can be package-private, ditt
Miguel Garcia
2013/05/23 12:16:48
Done.
|
| + static long ONE_DAY_MILLIS = 3600 * 24 * 1000; |
|
bulach
2013/05/21 17:26:35
nit: final, and also I think it'd be clearer in ho
Miguel Garcia
2013/05/23 12:16:48
Done.
|
| + |
| + private static void setLimits(DatePicker picker, long min, long max) { |
| + // DatePicker intervals are non inclusive |
| + long minTime = min > 0 ? min -1 : 0; |
|
bulach
2013/05/21 17:26:35
nit: space after -
Miguel Garcia
2013/05/23 12:16:48
Done.
|
| + long maxTime = (max - ONE_DAY_MILLIS) >= (Long.MAX_VALUE - ONE_DAY_MILLIS) |
| + ? Long.MAX_VALUE : max + ONE_DAY_MILLIS; |
| + picker.setMaxDate(maxTime); |
| + picker.setMinDate(minTime); |
| + } |
| + |
| + /** |
| + * Create a verified DateDialogPicker |
|
bulach
2013/05/21 17:26:35
I don't think it "creates" a dialog, but rather, e
Miguel Garcia
2013/05/23 12:16:48
Done.
|
| + */ |
| + public static void normalize(DatePicker picker, OnDateChangedListener callBack, |
|
bulach
2013/05/21 17:26:35
nit: s/callBack/listener/
Miguel Garcia
2013/05/23 12:16:48
Done.
|
| + int year, int month, int day, long min, long max) { |
| + Calendar calendar = Calendar.getInstance(); |
| + calendar.clear(); |
| + calendar.set(year, month, day); |
| + if (calendar.getTimeInMillis() < min) { |
| + calendar.clear(); |
| + calendar.setTimeInMillis(min); |
| + } else if (calendar.getTimeInMillis() > max) { |
| + calendar.clear(); |
| + calendar.setTimeInMillis(max); |
| + } |
| + picker.init( |
| + calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH), |
| + calendar.get(Calendar.DAY_OF_MONTH), callBack); |
| + |
| + // DatePicker intervals are non inclusive |
| + setLimits(picker, min, max); |
| + } |
| +} |