This source file includes following definitions.
- create
- countUsage
- formControlType
- defaultValueForStepUp
- createStepRange
- parseToDateComponentsInternal
- setMillisecondToDateComponents
- isTimeField
- localizeValue
- formatDateTimeFieldsState
- setupLayoutParameters
- isValidFormat
#include "config.h"
#include "core/html/forms/TimeInputType.h"
#include "HTMLNames.h"
#include "InputTypeNames.h"
#include "core/html/HTMLInputElement.h"
#include "core/html/forms/DateTimeFieldsState.h"
#include "platform/DateComponents.h"
#include "platform/text/PlatformLocale.h"
#include "wtf/CurrentTime.h"
#include "wtf/DateMath.h"
#include "wtf/MathExtras.h"
#include "wtf/PassOwnPtr.h"
#include "wtf/text/WTFString.h"
namespace WebCore {
using namespace HTMLNames;
static const int timeDefaultStep = 60;
static const int timeDefaultStepBase = 0;
static const int timeStepScaleFactor = 1000;
TimeInputType::TimeInputType(HTMLInputElement& element)
: BaseTimeInputType(element)
{
}
PassRefPtr<InputType> TimeInputType::create(HTMLInputElement& element)
{
return adoptRef(new TimeInputType(element));
}
void TimeInputType::countUsage()
{
countUsageIfVisible(UseCounter::InputTypeTime);
}
const AtomicString& TimeInputType::formControlType() const
{
return InputTypeNames::time;
}
Decimal TimeInputType::defaultValueForStepUp() const
{
double current = currentTimeMS();
double utcOffset = calculateUTCOffset();
double dstOffset = calculateDSTOffset(current, utcOffset);
int offset = static_cast<int>((utcOffset + dstOffset) / msPerMinute);
current += offset * msPerMinute;
DateComponents date;
date.setMillisecondsSinceMidnight(current);
double milliseconds = date.millisecondsSinceEpoch();
ASSERT(std::isfinite(milliseconds));
return Decimal::fromDouble(milliseconds);
}
StepRange TimeInputType::createStepRange(AnyStepHandling anyStepHandling) const
{
DEFINE_STATIC_LOCAL(const StepRange::StepDescription, stepDescription, (timeDefaultStep, timeDefaultStepBase, timeStepScaleFactor, StepRange::ScaledStepValueShouldBeInteger));
return InputType::createStepRange(anyStepHandling, timeDefaultStepBase, Decimal::fromDouble(DateComponents::minimumTime()), Decimal::fromDouble(DateComponents::maximumTime()), stepDescription);
}
bool TimeInputType::parseToDateComponentsInternal(const String& string, DateComponents* out) const
{
ASSERT(out);
unsigned end;
return out->parseTime(string, 0, end) && end == string.length();
}
bool TimeInputType::setMillisecondToDateComponents(double value, DateComponents* date) const
{
ASSERT(date);
return date->setMillisecondsSinceMidnight(value);
}
bool TimeInputType::isTimeField() const
{
return true;
}
#if ENABLE(INPUT_MULTIPLE_FIELDS_UI)
String TimeInputType::localizeValue(const String& proposedValue) const
{
DateComponents date;
if (!parseToDateComponents(proposedValue, &date))
return proposedValue;
Locale::FormatType formatType = shouldHaveSecondField(date) ? Locale::FormatTypeMedium : Locale::FormatTypeShort;
String localized = element().locale().formatDateTime(date, formatType);
return localized.isEmpty() ? proposedValue : localized;
}
String TimeInputType::formatDateTimeFieldsState(const DateTimeFieldsState& dateTimeFieldsState) const
{
if (!dateTimeFieldsState.hasHour() || !dateTimeFieldsState.hasMinute() || !dateTimeFieldsState.hasAMPM())
return emptyString();
if (dateTimeFieldsState.hasMillisecond() && dateTimeFieldsState.millisecond()) {
return String::format("%02u:%02u:%02u.%03u",
dateTimeFieldsState.hour23(),
dateTimeFieldsState.minute(),
dateTimeFieldsState.hasSecond() ? dateTimeFieldsState.second() : 0,
dateTimeFieldsState.millisecond());
}
if (dateTimeFieldsState.hasSecond() && dateTimeFieldsState.second()) {
return String::format("%02u:%02u:%02u",
dateTimeFieldsState.hour23(),
dateTimeFieldsState.minute(),
dateTimeFieldsState.second());
}
return String::format("%02u:%02u", dateTimeFieldsState.hour23(), dateTimeFieldsState.minute());
}
void TimeInputType::setupLayoutParameters(DateTimeEditElement::LayoutParameters& layoutParameters, const DateComponents& date) const
{
if (shouldHaveSecondField(date)) {
layoutParameters.dateTimeFormat = layoutParameters.locale.timeFormat();
layoutParameters.fallbackDateTimeFormat = "HH:mm:ss";
} else {
layoutParameters.dateTimeFormat = layoutParameters.locale.shortTimeFormat();
layoutParameters.fallbackDateTimeFormat = "HH:mm";
}
if (!parseToDateComponents(element().fastGetAttribute(minAttr), &layoutParameters.minimum))
layoutParameters.minimum = DateComponents();
if (!parseToDateComponents(element().fastGetAttribute(maxAttr), &layoutParameters.maximum))
layoutParameters.maximum = DateComponents();
}
bool TimeInputType::isValidFormat(bool hasYear, bool hasMonth, bool hasWeek, bool hasDay, bool hasAMPM, bool hasHour, bool hasMinute, bool hasSecond) const
{
return hasHour && hasMinute && hasAMPM;
}
#endif
}