| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "core/events/InputEvent.h" | 5 #include "core/events/InputEvent.h" |
| 6 | 6 |
| 7 #include "core/dom/Range.h" | 7 #include "core/dom/Range.h" |
| 8 #include "core/events/EventDispatcher.h" | 8 #include "core/events/EventDispatcher.h" |
| 9 #include "public/platform/WebEditingCommandType.h" | 9 #include "public/platform/WebEditingCommandType.h" |
| 10 | 10 |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 {InputEvent::InputType::InsertHorizontalRule, "insertHorizontalRule"}, | 25 {InputEvent::InputType::InsertHorizontalRule, "insertHorizontalRule"}, |
| 26 {InputEvent::InputType::InsertFromPaste, "insertFromPaste"}, | 26 {InputEvent::InputType::InsertFromPaste, "insertFromPaste"}, |
| 27 {InputEvent::InputType::InsertFromDrop, "insertFromDrop"}, | 27 {InputEvent::InputType::InsertFromDrop, "insertFromDrop"}, |
| 28 {InputEvent::InputType::InsertReplacementText, "insertReplacementText"}, | 28 {InputEvent::InputType::InsertReplacementText, "insertReplacementText"}, |
| 29 {InputEvent::InputType::DeleteComposedCharacterForward, | 29 {InputEvent::InputType::DeleteComposedCharacterForward, |
| 30 "deleteComposedCharacterForward"}, | 30 "deleteComposedCharacterForward"}, |
| 31 {InputEvent::InputType::DeleteComposedCharacterBackward, | 31 {InputEvent::InputType::DeleteComposedCharacterBackward, |
| 32 "deleteComposedCharacterBackward"}, | 32 "deleteComposedCharacterBackward"}, |
| 33 {InputEvent::InputType::DeleteWordBackward, "deleteWordBackward"}, | 33 {InputEvent::InputType::DeleteWordBackward, "deleteWordBackward"}, |
| 34 {InputEvent::InputType::DeleteWordForward, "deleteWordForward"}, | 34 {InputEvent::InputType::DeleteWordForward, "deleteWordForward"}, |
| 35 {InputEvent::InputType::DeleteLineBackward, "deleteLineBackward"}, | 35 {InputEvent::InputType::DeleteSoftLineBackward, "deleteSoftLineBackward"}, |
| 36 {InputEvent::InputType::DeleteLineForward, "deleteLineForward"}, | 36 {InputEvent::InputType::DeleteSoftLineBackward, "deleteSoftLineForward"}, |
| 37 {InputEvent::InputType::DeleteContent, "deleteContent"}, |
| 37 {InputEvent::InputType::DeleteContentBackward, "deleteContentBackward"}, | 38 {InputEvent::InputType::DeleteContentBackward, "deleteContentBackward"}, |
| 38 {InputEvent::InputType::DeleteContentForward, "deleteContentForward"}, | 39 {InputEvent::InputType::DeleteContentForward, "deleteContentForward"}, |
| 39 {InputEvent::InputType::DeleteByCut, "deleteByCut"}, | 40 {InputEvent::InputType::DeleteByCut, "deleteByCut"}, |
| 40 {InputEvent::InputType::DeleteByDrag, "deleteByDrag"}, | 41 {InputEvent::InputType::DeleteByDrag, "deleteByDrag"}, |
| 41 {InputEvent::InputType::HistoryUndo, "historyUndo"}, | 42 {InputEvent::InputType::HistoryUndo, "historyUndo"}, |
| 42 {InputEvent::InputType::HistoryRedo, "historyRedo"}, | 43 {InputEvent::InputType::HistoryRedo, "historyRedo"}, |
| 43 {InputEvent::InputType::FormatBold, "formatBold"}, | 44 {InputEvent::InputType::FormatBold, "formatBold"}, |
| 44 {InputEvent::InputType::FormatItalic, "formatItalic"}, | 45 {InputEvent::InputType::FormatItalic, "formatItalic"}, |
| 45 {InputEvent::InputType::FormatUnderline, "formatUnderline"}, | 46 {InputEvent::InputType::FormatUnderline, "formatUnderline"}, |
| 46 {InputEvent::InputType::FormatStrikeThrough, "formatStrikeThrough"}, | 47 {InputEvent::InputType::FormatStrikeThrough, "formatStrikeThrough"}, |
| (...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 137 inputEventInit.setIsComposing(isComposing == IsComposing); | 138 inputEventInit.setIsComposing(isComposing == IsComposing); |
| 138 if (ranges) | 139 if (ranges) |
| 139 inputEventInit.setRanges(*ranges); | 140 inputEventInit.setRanges(*ranges); |
| 140 inputEventInit.setComposed(true); | 141 inputEventInit.setComposed(true); |
| 141 return InputEvent::create(EventTypeNames::beforeinput, inputEventInit); | 142 return InputEvent::create(EventTypeNames::beforeinput, inputEventInit); |
| 142 } | 143 } |
| 143 | 144 |
| 144 /* static */ | 145 /* static */ |
| 145 InputEvent* InputEvent::createInput(InputType inputType, | 146 InputEvent* InputEvent::createInput(InputType inputType, |
| 146 const String& data, | 147 const String& data, |
| 147 EventIsComposing isComposing, | 148 EventIsComposing isComposing) { |
| 148 const RangeVector* ranges) { | |
| 149 InputEventInit inputEventInit; | 149 InputEventInit inputEventInit; |
| 150 | 150 |
| 151 inputEventInit.setBubbles(true); | 151 inputEventInit.setBubbles(true); |
| 152 inputEventInit.setCancelable(false); | 152 inputEventInit.setCancelable(false); |
| 153 // TODO(ojan): We should find a way to prevent conversion like | 153 // TODO(ojan): We should find a way to prevent conversion like |
| 154 // String->enum->String just in order to use initializer. | 154 // String->enum->String just in order to use initializer. |
| 155 // See InputEvent::InputEvent() for the second conversion. | 155 // See InputEvent::InputEvent() for the second conversion. |
| 156 inputEventInit.setInputType(convertInputTypeToString(inputType)); | 156 inputEventInit.setInputType(convertInputTypeToString(inputType)); |
| 157 inputEventInit.setData(data); | 157 inputEventInit.setData(data); |
| 158 inputEventInit.setIsComposing(isComposing == IsComposing); | 158 inputEventInit.setIsComposing(isComposing == IsComposing); |
| 159 if (ranges) | |
| 160 inputEventInit.setRanges(*ranges); | |
| 161 inputEventInit.setComposed(true); | 159 inputEventInit.setComposed(true); |
| 162 return InputEvent::create(EventTypeNames::input, inputEventInit); | 160 return InputEvent::create(EventTypeNames::input, inputEventInit); |
| 163 } | 161 } |
| 164 | 162 |
| 165 String InputEvent::inputType() const { | 163 String InputEvent::inputType() const { |
| 166 return convertInputTypeToString(m_inputType); | 164 return convertInputTypeToString(m_inputType); |
| 167 } | 165 } |
| 168 | 166 |
| 169 StaticRangeVector InputEvent::getTargetRanges() const { | 167 StaticRangeVector InputEvent::getTargetRanges() const { |
| 170 StaticRangeVector staticRanges; | 168 StaticRangeVector staticRanges; |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 217 // 3. We don't want authors to hold live |Range| indefinitely by holding | 215 // 3. We don't want authors to hold live |Range| indefinitely by holding |
| 218 // |InputEvent|, so we clear them after dispatch. | 216 // |InputEvent|, so we clear them after dispatch. |
| 219 // Authors should explicitly call |getTargetRanges()|->|toRange()| if they | 217 // Authors should explicitly call |getTargetRanges()|->|toRange()| if they |
| 220 // want to keep a copy of |Range|. See Editing TF meeting notes: | 218 // want to keep a copy of |Range|. See Editing TF meeting notes: |
| 221 // https://docs.google.com/document/d/1hCj6QX77NYIVY0RWrMHT1Yra6t8_Qu8PopaWLG0
AM58/edit?usp=sharing | 219 // https://docs.google.com/document/d/1hCj6QX77NYIVY0RWrMHT1Yra6t8_Qu8PopaWLG0
AM58/edit?usp=sharing |
| 222 event().m_ranges.clear(); | 220 event().m_ranges.clear(); |
| 223 return result; | 221 return result; |
| 224 } | 222 } |
| 225 | 223 |
| 226 } // namespace blink | 224 } // namespace blink |
| OLD | NEW |