com.google.blockly.model.FieldDate.java Source code

Java tutorial

Introduction

Here is the source code for com.google.blockly.model.FieldDate.java

Source

/*
 * Copyright 2016 Google Inc. All Rights Reserved.
 * 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.blockly.model;

import android.support.annotation.VisibleForTesting;
import android.text.TextUtils;
import android.util.Log;

import com.google.blockly.utils.BlockLoadingException;

import org.json.JSONObject;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * Adds a date picker to an Input. Dates must be in the format "YYYY-MM-DD"
 */
public final class FieldDate extends Field {
    private static final String TAG = "FieldDate";

    // Date format used for serialization.
    private static final DateFormat DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd");

    private final Date mDate = new Date();

    public FieldDate(String name) {
        super(name, TYPE_DATE);
    }

    public FieldDate(String name, long milliseconds) {
        this(name);
        mDate.setTime(milliseconds);
    }

    @VisibleForTesting
    public FieldDate(String name, String dateString) {
        this(name);
        if (!setFromString(dateString)) {
            throw new IllegalArgumentException("Invalid date: " + dateString);
        }
    }

    public static FieldDate fromJson(JSONObject json) throws BlockLoadingException {
        String name = json.optString("name");
        if (TextUtils.isEmpty(name)) {
            throw new BlockLoadingException("field_date \"name\" attribute must not be empty.");
        }
        FieldDate field = new FieldDate(name);
        String dateStr = json.optString("date");
        if (!TextUtils.isEmpty(dateStr) && !field.setFromString(dateStr)) {
            throw new BlockLoadingException("Unable to parse date: " + dateStr);
        }
        return field;
    }

    @Override
    public FieldDate clone() {
        return new FieldDate(getName(), mDate.getTime());
    }

    @Override
    public boolean setFromString(String text) {
        Date date = null;
        try {
            date = DATE_FORMAT.parse(text);
            setDate(date);
            return true;
        } catch (ParseException e) {
            Log.e(TAG, "Unable to parse date " + text, e);
            return false;
        }
    }

    /**
     * @return The date in this field.
     */
    public Date getDate() {
        return mDate;
    }

    /**
     * Sets this field to the specified {@link Date}.
     */
    public void setDate(Date date) {
        if (date == null) {
            throw new IllegalArgumentException("Date may not be null.");
        }
        setTime(date.getTime());
    }

    /**
     * @return The string format for the date in this field.
     */
    public String getLocalizedDateString() {
        return DATE_FORMAT.format(mDate);
    }

    /**
     * Sets this field to a specific time.
     *
     * @param millis The time in millis since UNIX Epoch.
     */
    public void setTime(long millis) {
        long oldTime = mDate.getTime();
        if (millis != oldTime) {
            String oldValue = getSerializedValue();
            mDate.setTime(millis);
            String newValue = getSerializedValue();
            fireValueChanged(oldValue, newValue);
        }
    }

    @Override
    public String getSerializedValue() {
        return DATE_FORMAT.format(mDate);
    }
}