This source file includes following definitions.
- create
- countUsage
- formControlType
- valueAsDate
- setValueAsDate
- createStepRange
- parseToDateComponentsInternal
- setMillisecondToDateComponents
- isDateTimeLocalField
- formatDateTimeFieldsState
- setupLayoutParameters
- isValidFormat
#include "config.h"
#include "core/html/forms/DateTimeLocalInputType.h"
#include "HTMLNames.h"
#include "InputTypeNames.h"
#include "bindings/v8/ExceptionState.h"
#include "core/html/HTMLInputElement.h"
#include "core/html/forms/DateTimeFieldsState.h"
#include "platform/DateComponents.h"
#include "platform/text/PlatformLocale.h"
#include "wtf/PassOwnPtr.h"
#include "wtf/text/WTFString.h"
namespace WebCore {
using blink::WebLocalizedString;
using namespace HTMLNames;
static const int dateTimeLocalDefaultStep = 60;
static const int dateTimeLocalDefaultStepBase = 0;
static const int dateTimeLocalStepScaleFactor = 1000;
PassRefPtr<InputType> DateTimeLocalInputType::create(HTMLInputElement& element)
{
return adoptRef(new DateTimeLocalInputType(element));
}
void DateTimeLocalInputType::countUsage()
{
countUsageIfVisible(UseCounter::InputTypeDateTimeLocal);
}
const AtomicString& DateTimeLocalInputType::formControlType() const
{
return InputTypeNames::datetime_local;
}
double DateTimeLocalInputType::valueAsDate() const
{
return DateComponents::invalidMilliseconds();
}
void DateTimeLocalInputType::setValueAsDate(double value, ExceptionState& exceptionState) const
{
InputType::setValueAsDate(value, exceptionState);
}
StepRange DateTimeLocalInputType::createStepRange(AnyStepHandling anyStepHandling) const
{
DEFINE_STATIC_LOCAL(const StepRange::StepDescription, stepDescription, (dateTimeLocalDefaultStep, dateTimeLocalDefaultStepBase, dateTimeLocalStepScaleFactor, StepRange::ScaledStepValueShouldBeInteger));
return InputType::createStepRange(anyStepHandling, dateTimeLocalDefaultStepBase, Decimal::fromDouble(DateComponents::minimumDateTime()), Decimal::fromDouble(DateComponents::maximumDateTime()), stepDescription);
}
bool DateTimeLocalInputType::parseToDateComponentsInternal(const String& string, DateComponents* out) const
{
ASSERT(out);
unsigned end;
return out->parseDateTimeLocal(string, 0, end) && end == string.length();
}
bool DateTimeLocalInputType::setMillisecondToDateComponents(double value, DateComponents* date) const
{
ASSERT(date);
return date->setMillisecondsSinceEpochForDateTimeLocal(value);
}
bool DateTimeLocalInputType::isDateTimeLocalField() const
{
return true;
}
#if ENABLE(INPUT_MULTIPLE_FIELDS_UI)
String DateTimeLocalInputType::formatDateTimeFieldsState(const DateTimeFieldsState& dateTimeFieldsState) const
{
if (!dateTimeFieldsState.hasDayOfMonth() || !dateTimeFieldsState.hasMonth() || !dateTimeFieldsState.hasYear()
|| !dateTimeFieldsState.hasHour() || !dateTimeFieldsState.hasMinute() || !dateTimeFieldsState.hasAMPM())
return emptyString();
if (dateTimeFieldsState.hasMillisecond() && dateTimeFieldsState.millisecond()) {
return String::format("%04u-%02u-%02uT%02u:%02u:%02u.%03u",
dateTimeFieldsState.year(),
dateTimeFieldsState.month(),
dateTimeFieldsState.dayOfMonth(),
dateTimeFieldsState.hour23(),
dateTimeFieldsState.minute(),
dateTimeFieldsState.hasSecond() ? dateTimeFieldsState.second() : 0,
dateTimeFieldsState.millisecond());
}
if (dateTimeFieldsState.hasSecond() && dateTimeFieldsState.second()) {
return String::format("%04u-%02u-%02uT%02u:%02u:%02u",
dateTimeFieldsState.year(),
dateTimeFieldsState.month(),
dateTimeFieldsState.dayOfMonth(),
dateTimeFieldsState.hour23(),
dateTimeFieldsState.minute(),
dateTimeFieldsState.second());
}
return String::format("%04u-%02u-%02uT%02u:%02u",
dateTimeFieldsState.year(),
dateTimeFieldsState.month(),
dateTimeFieldsState.dayOfMonth(),
dateTimeFieldsState.hour23(),
dateTimeFieldsState.minute());
}
void DateTimeLocalInputType::setupLayoutParameters(DateTimeEditElement::LayoutParameters& layoutParameters, const DateComponents& date) const
{
if (shouldHaveSecondField(date)) {
layoutParameters.dateTimeFormat = layoutParameters.locale.dateTimeFormatWithSeconds();
layoutParameters.fallbackDateTimeFormat = "yyyy-MM-dd'T'HH:mm:ss";
} else {
layoutParameters.dateTimeFormat = layoutParameters.locale.dateTimeFormatWithoutSeconds();
layoutParameters.fallbackDateTimeFormat = "yyyy-MM-dd'T'HH:mm";
}
if (!parseToDateComponents(element().fastGetAttribute(minAttr), &layoutParameters.minimum))
layoutParameters.minimum = DateComponents();
if (!parseToDateComponents(element().fastGetAttribute(maxAttr), &layoutParameters.maximum))
layoutParameters.maximum = DateComponents();
layoutParameters.placeholderForDay = locale().queryString(WebLocalizedString::PlaceholderForDayOfMonthField);
layoutParameters.placeholderForMonth = locale().queryString(WebLocalizedString::PlaceholderForMonthField);
layoutParameters.placeholderForYear = locale().queryString(WebLocalizedString::PlaceholderForYearField);
}
bool DateTimeLocalInputType::isValidFormat(bool hasYear, bool hasMonth, bool hasWeek, bool hasDay, bool hasAMPM, bool hasHour, bool hasMinute, bool hasSecond) const
{
return hasYear && hasMonth && hasDay && hasAMPM && hasHour && hasMinute;
}
#endif
}