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

Side by Side Diff: Source/core/html/shadow/SpinButtonElement.cpp

Issue 128133002: Update of change event for input type number (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Code review updates Created 6 years, 11 months 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2006, 2008, 2010 Apple Inc. All rights reserved. 2 * Copyright (C) 2006, 2008, 2010 Apple Inc. All rights reserved.
3 * Copyright (C) 2010 Google Inc. All rights reserved. 3 * Copyright (C) 2010 Google Inc. All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions 6 * modification, are permitted provided that the following conditions
7 * are met: 7 * are met:
8 * 1. Redistributions of source code must retain the above copyright 8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright 10 * 2. Redistributions in binary form must reproduce the above copyright
(...skipping 13 matching lines...) Expand all
24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25 */ 25 */
26 26
27 #include "config.h" 27 #include "config.h"
28 #include "core/html/shadow/SpinButtonElement.h" 28 #include "core/html/shadow/SpinButtonElement.h"
29 29
30 #include "HTMLNames.h" 30 #include "HTMLNames.h"
31 #include "core/events/MouseEvent.h" 31 #include "core/events/MouseEvent.h"
32 #include "core/events/ThreadLocalEventNames.h" 32 #include "core/events/ThreadLocalEventNames.h"
33 #include "core/events/WheelEvent.h" 33 #include "core/events/WheelEvent.h"
34 #include "core/html/HTMLInputElement.h"
34 #include "core/html/shadow/ShadowElementNames.h" 35 #include "core/html/shadow/ShadowElementNames.h"
35 #include "core/page/Chrome.h" 36 #include "core/page/Chrome.h"
36 #include "core/page/EventHandler.h" 37 #include "core/page/EventHandler.h"
37 #include "core/frame/Frame.h" 38 #include "core/frame/Frame.h"
38 #include "core/page/Page.h" 39 #include "core/page/Page.h"
39 #include "core/rendering/RenderBox.h" 40 #include "core/rendering/RenderBox.h"
40 #include "platform/scroll/ScrollbarTheme.h" 41 #include "platform/scroll/ScrollbarTheme.h"
41 42
42 namespace WebCore { 43 namespace WebCore {
43 44
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
104 // might change the element state and we might need to 105 // might change the element state and we might need to
105 // cancel the repeating timer by the state change. If we 106 // cancel the repeating timer by the state change. If we
106 // started the timer after doStepAction(), we would have no 107 // started the timer after doStepAction(), we would have no
107 // chance to cancel the timer. 108 // chance to cancel the timer.
108 startRepeatingTimer(); 109 startRepeatingTimer();
109 doStepAction(m_upDownState == Up ? 1 : -1); 110 doStepAction(m_upDownState == Up ? 1 : -1);
110 } 111 }
111 } 112 }
112 event->setDefaultHandled(); 113 event->setDefaultHandled();
113 } 114 }
114 } else if (mouseEvent->type() == EventTypeNames::mouseup && mouseEvent->butt on() == LeftButton) 115 } else if (mouseEvent->type() == EventTypeNames::mouseup && mouseEvent->butt on() == LeftButton) {
115 stopRepeatingTimer(); 116 releaseCapture();
116 else if (event->type() == EventTypeNames::mousemove) { 117 } else if (event->type() == EventTypeNames::mousemove) {
117 if (box->pixelSnappedBorderBoxRect().contains(local)) { 118 if (box->pixelSnappedBorderBoxRect().contains(local)) {
118 if (!m_capturing) { 119 if (!m_capturing) {
119 if (Frame* frame = document().frame()) { 120 if (Frame* frame = document().frame()) {
120 frame->eventHandler().setCapturingMouseEventsNode(this); 121 frame->eventHandler().setCapturingMouseEventsNode(this);
121 m_capturing = true; 122 m_capturing = true;
122 if (Page* page = document().page()) 123 if (Page* page = document().page())
123 page->chrome().registerPopupOpeningObserver(this); 124 page->chrome().registerPopupOpeningObserver(this);
124 } 125 }
125 } 126 }
126 UpDownState oldUpDownState = m_upDownState; 127 UpDownState oldUpDownState = m_upDownState;
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after
191 void SpinButtonElement::releaseCapture() 192 void SpinButtonElement::releaseCapture()
192 { 193 {
193 stopRepeatingTimer(); 194 stopRepeatingTimer();
194 if (m_capturing) { 195 if (m_capturing) {
195 if (Frame* frame = document().frame()) { 196 if (Frame* frame = document().frame()) {
196 frame->eventHandler().setCapturingMouseEventsNode(0); 197 frame->eventHandler().setCapturingMouseEventsNode(0);
197 m_capturing = false; 198 m_capturing = false;
198 if (Page* page = document().page()) 199 if (Page* page = document().page())
199 page->chrome().unregisterPopupOpeningObserver(this); 200 page->chrome().unregisterPopupOpeningObserver(this);
200 } 201 }
202 HTMLInputElement* input = toHTMLInputElement(shadowHost());
tkent 2014/01/16 06:05:19 Please do not add dependency to HTMLInputElement.
Habib Virji 2014/01/16 09:49:18 OK will update code accordingly and send a new pat
203 input->dispatchFormControlChangeEvent();
201 } 204 }
202 } 205 }
203 206
204 bool SpinButtonElement::matchesReadOnlyPseudoClass() const 207 bool SpinButtonElement::matchesReadOnlyPseudoClass() const
205 { 208 {
206 return shadowHost()->matchesReadOnlyPseudoClass(); 209 return shadowHost()->matchesReadOnlyPseudoClass();
207 } 210 }
208 211
209 bool SpinButtonElement::matchesReadWritePseudoClass() const 212 bool SpinButtonElement::matchesReadWritePseudoClass() const
210 { 213 {
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
249 m_upDownState = Indeterminate; 252 m_upDownState = Indeterminate;
250 HTMLDivElement::setHovered(flag); 253 HTMLDivElement::setHovered(flag);
251 } 254 }
252 255
253 bool SpinButtonElement::shouldRespondToMouseEvents() 256 bool SpinButtonElement::shouldRespondToMouseEvents()
254 { 257 {
255 return !m_spinButtonOwner || m_spinButtonOwner->shouldSpinButtonRespondToMou seEvents(); 258 return !m_spinButtonOwner || m_spinButtonOwner->shouldSpinButtonRespondToMou seEvents();
256 } 259 }
257 260
258 } 261 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698