Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2753)

Unified Diff: content/renderer/renderer_date_time_picker.cc

Issue 85643002: Transfer date/time value to chooser as double (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@doubledate2
Patch Set: Created 7 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/renderer/renderer_date_time_picker.cc
diff --git a/content/renderer/renderer_date_time_picker.cc b/content/renderer/renderer_date_time_picker.cc
index 074ebe5adaea622e11886289f912f89f7c7013e8..6b69a87d22cf12d439f4708737f6de69ee2b4e80 100644
--- a/content/renderer/renderer_date_time_picker.cc
+++ b/content/renderer/renderer_date_time_picker.cc
@@ -6,45 +6,42 @@
#include "base/strings/string_util.h"
#include "content/common/view_messages.h"
-#include "content/renderer/date_time_formatter.h"
#include "content/renderer/render_view_impl.h"
-
#include "third_party/WebKit/public/web/WebDateTimeChooserCompletion.h"
#include "third_party/WebKit/public/web/WebDateTimeChooserParams.h"
#include "third_party/WebKit/public/web/WebDateTimeInputType.h"
+#include "ui/base/ime/text_input_type.h"
using blink::WebString;
namespace content {
+static ui::TextInputType toTextInputType(int type) {
+ if (type >= blink::WebDateTimeInputTypeDate &&
+ type <= blink::WebDateTimeInputTypeWeek) {
+ return static_cast<ui::TextInputType>(type - blink::WebDateTimeInputTypeDate
+ + ui::TEXT_INPUT_TYPE_DATE);
+ }
+ NOTREACHED();
+ return ui::TEXT_INPUT_TYPE_NONE;
+}
+
RendererDateTimePicker::RendererDateTimePicker(
RenderViewImpl* sender,
const blink::WebDateTimeChooserParams& params,
blink::WebDateTimeChooserCompletion* completion)
: RenderViewObserver(sender),
chooser_params_(params),
- chooser_completion_(completion){
+ chooser_completion_(completion) {
}
RendererDateTimePicker::~RendererDateTimePicker() {
}
bool RendererDateTimePicker::Open() {
- DateTimeFormatter parser(chooser_params_);
ViewHostMsg_DateTimeDialogValue_Params message;
- message.dialog_type = parser.GetType();
- if (message.dialog_type == ui::TEXT_INPUT_TYPE_WEEK) {
- message.year = parser.GetWeekYear();
- message.week = parser.GetWeek();
- } else {
- message.year = parser.GetYear();
- message.month = parser.GetMonth();
- message.day = parser.GetDay();
- message.hour = parser.GetHour();
- message.minute = parser.GetMinute();
- message.second = parser.GetSecond();
- message.milli = parser.GetMilli();
- }
+ message.dialog_type = toTextInputType(chooser_params_.type);
+ message.dialog_value = chooser_params_.doubleValue;
message.minimum = chooser_params_.minimum;
message.maximum = chooser_params_.maximum;
message.step = chooser_params_.step;
@@ -63,28 +60,16 @@ bool RendererDateTimePicker::OnMessageReceived(
return handled;
}
-void RendererDateTimePicker::OnReplaceDateTime(
- const ViewHostMsg_DateTimeDialogValue_Params& value) {
-
- DateTimeFormatter formatter(static_cast<ui::TextInputType>(value.dialog_type),
- value.year,
- value.month,
- value.day,
- value.hour,
- value.minute,
- value.second,
- value.milli,
- value.year,
- value.week);
-
+void RendererDateTimePicker::OnReplaceDateTime(double value) {
if (chooser_completion_)
- chooser_completion_->didChooseValue(WebString::fromUTF8(
- formatter.GetFormattedValue().c_str()));
+ chooser_completion_->didChooseValue(value);
+ static_cast<RenderViewImpl*>(render_view())->DidDismissDateTimeDialog();
}
void RendererDateTimePicker::OnCancel() {
if (chooser_completion_)
chooser_completion_->didCancelChooser();
+ static_cast<RenderViewImpl*>(render_view())->DidDismissDateTimeDialog();
Miguel Garcia 2013/11/26 16:07:08 The method signature is confusing. It seems it sho
keishi 2013/11/27 06:58:38 That seems to be leaking too. I've also found othe
}
} // namespace content
« content/renderer/render_view_impl.cc ('K') | « content/renderer/renderer_date_time_picker.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698