Touch and pen input updates (#2172)

* Remove unnecessary return

* Move touch start input filtering

* Refactor

* Add scanOnTouchPress

* Add preventPenScrolling

* Rename scanOnPenPress to scanOnPenMove

* Rename scanOnPenRelease to scanOnPenReleaseHover

* Simplify

* Refactor _searchAtFromPen early exit

* Merge _penPointerPressed and _penPointerReleased into a single variable

* Add more options

* Simplify pen pointer coordinates

* Implement scanOnPenPress and scanOnPenRelease

* Implement scanOnTouchRelease

* Fix tests

* Don't search on touch cancel

* Cancel touch if the touch action is used for scrolling or other gestures

* Fix incorrect scroll prevention options being used

* Organize options

* Fix typos
This commit is contained in:
toasted-nutbread 2022-06-03 17:11:32 -04:00 committed by GitHub
parent e61edc387c
commit c966d9b1eb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 216 additions and 71 deletions

View File

@ -1714,9 +1714,12 @@ code.anki-field-marker {
.scan-input-prefix-cell[data-property=search-options] { .scan-input-prefix-cell[data-property=search-options] {
grid-area: 4/2/5/3; grid-area: 4/2/5/3;
} }
.scan-input-prefix-cell[data-property=touch-pen-options] { .scan-input-prefix-cell[data-property=touch-options] {
grid-area: 5/2/6/3; grid-area: 5/2/6/3;
} }
.scan-input-prefix-cell[data-property=pen-options] {
grid-area: 6/2/7/3;
}
.scan-input-content-cell[data-property=include] { .scan-input-content-cell[data-property=include] {
grid-area: 1/3/2/4; grid-area: 1/3/2/4;
} }
@ -1735,12 +1738,18 @@ code.anki-field-marker {
flex-flow: row wrap; flex-flow: row wrap;
align-items: center; align-items: center;
} }
.scan-input-content-cell[data-property=touch-pen-options] { .scan-input-content-cell[data-property=touch-options] {
grid-area: 5/3/6/4; grid-area: 5/3/6/4;
display: flex; display: flex;
flex-flow: column nowrap; flex-flow: column nowrap;
align-items: flex-start; align-items: flex-start;
} }
.scan-input-content-cell[data-property=pen-options] {
grid-area: 6/3/7/4;
display: flex;
flex-flow: column nowrap;
align-items: flex-start;
}
.scan-input-options-cell { .scan-input-options-cell {
padding: 0.25em 0; padding: 0.25em 0;
align-self: start; align-self: start;

View File

@ -457,10 +457,15 @@
"searchTerms": true, "searchTerms": true,
"searchKanji": true, "searchKanji": true,
"scanOnTouchMove": true, "scanOnTouchMove": true,
"scanOnTouchPress": true,
"scanOnTouchRelease": false,
"scanOnPenMove": true,
"scanOnPenHover": true, "scanOnPenHover": true,
"scanOnPenReleaseHover": false,
"scanOnPenPress": true, "scanOnPenPress": true,
"scanOnPenRelease": false, "scanOnPenRelease": false,
"preventTouchScrolling": false "preventTouchScrolling": false,
"preventPenScrolling": false
} }
}, },
{ {
@ -476,10 +481,15 @@
"searchTerms": true, "searchTerms": true,
"searchKanji": true, "searchKanji": true,
"scanOnTouchMove": true, "scanOnTouchMove": true,
"scanOnTouchPress": true,
"scanOnTouchRelease": false,
"scanOnPenMove": true,
"scanOnPenHover": true, "scanOnPenHover": true,
"scanOnPenReleaseHover": false,
"scanOnPenPress": true, "scanOnPenPress": true,
"scanOnPenRelease": false, "scanOnPenRelease": false,
"preventTouchScrolling": true "preventTouchScrolling": true,
"preventPenScrolling": true
} }
} }
], ],
@ -528,10 +538,12 @@
"searchTerms", "searchTerms",
"searchKanji", "searchKanji",
"scanOnTouchMove", "scanOnTouchMove",
"scanOnTouchPress",
"scanOnPenMove",
"scanOnPenHover", "scanOnPenHover",
"scanOnPenPress", "scanOnPenReleaseHover",
"scanOnPenRelease", "preventTouchScrolling",
"preventTouchScrolling" "preventPenScrolling"
], ],
"properties": { "properties": {
"showAdvanced": { "showAdvanced": {
@ -550,10 +562,26 @@
"type": "boolean", "type": "boolean",
"default": true "default": true
}, },
"scanOnTouchPress": {
"type": "boolean",
"default": true
},
"scanOnTouchRelease": {
"type": "boolean",
"default": false
},
"scanOnPenMove": {
"type": "boolean",
"default": true
},
"scanOnPenHover": { "scanOnPenHover": {
"type": "boolean", "type": "boolean",
"default": true "default": true
}, },
"scanOnPenReleaseHover": {
"type": "boolean",
"default": false
},
"scanOnPenPress": { "scanOnPenPress": {
"type": "boolean", "type": "boolean",
"default": true "default": true
@ -565,6 +593,10 @@
"preventTouchScrolling": { "preventTouchScrolling": {
"type": "boolean", "type": "boolean",
"default": true "default": true
},
"preventPenScrolling": {
"type": "boolean",
"default": true
} }
} }
} }

View File

@ -953,9 +953,25 @@ class OptionsUtil {
// Version 19 changes: // Version 19 changes:
// Added anki.noteGuiMode. // Added anki.noteGuiMode.
// Added anki.apiKey. // Added anki.apiKey.
// Renamed scanning.inputs[].options.scanOnPenPress to scanOnPenMove.
// Renamed scanning.inputs[].options.scanOnPenRelease to scanOnPenReleaseHover.
// Added scanning.inputs[].options.scanOnTouchPress.
// Added scanning.inputs[].options.scanOnTouchRelease.
// Added scanning.inputs[].options.scanOnPenPress.
// Added scanning.inputs[].options.scanOnPenRelease.
// Added scanning.inputs[].options.preventPenScrolling.
for (const profile of options.profiles) { for (const profile of options.profiles) {
profile.options.anki.noteGuiMode = 'browse'; profile.options.anki.noteGuiMode = 'browse';
profile.options.anki.apiKey = ''; profile.options.anki.apiKey = '';
for (const input of profile.options.scanning.inputs) {
input.options.scanOnPenMove = input.options.scanOnPenPress;
input.options.scanOnPenReleaseHover = input.options.scanOnPenRelease;
input.options.scanOnTouchPress = true;
input.options.scanOnTouchRelease = false;
input.options.scanOnPenPress = input.options.scanOnPenMove;
input.options.scanOnPenRelease = false;
input.options.preventPenScrolling = input.options.preventTouchScrolling;
}
} }
return options; return options;
} }

View File

@ -1516,10 +1516,15 @@ class Display extends EventDispatcher {
searchTerms: true, searchTerms: true,
searchKanji: true, searchKanji: true,
scanOnTouchMove: false, scanOnTouchMove: false,
scanOnTouchPress: false,
scanOnTouchRelease: false,
scanOnPenMove: false,
scanOnPenHover: false, scanOnPenHover: false,
scanOnPenReleaseHover: false,
scanOnPenPress: false, scanOnPenPress: false,
scanOnPenRelease: false, scanOnPenRelease: false,
preventTouchScrolling: false preventTouchScrolling: false,
preventPenScrolling: false
} }
}], }],
deepContentScan: scanningOptions.deepDomScan, deepContentScan: scanningOptions.deepDomScan,

View File

@ -83,8 +83,7 @@ class TextScanner extends EventDispatcher {
this._preventNextMouseDown = false; this._preventNextMouseDown = false;
this._preventNextClick = false; this._preventNextClick = false;
this._preventScroll = false; this._preventScroll = false;
this._penPointerPressed = false; this._penPointerState = 0; // 0 = not active; 1 = hovering; 2 = touching; 3 = hovering after touching
this._penPointerReleased = false;
this._pointerIdTypeMap = new Map(); this._pointerIdTypeMap = new Map();
this._canClearSelection = true; this._canClearSelection = true;
@ -135,8 +134,7 @@ class TextScanner extends EventDispatcher {
this._preventNextMouseDown = false; this._preventNextMouseDown = false;
this._preventNextClick = false; this._preventNextClick = false;
this._preventScroll = false; this._preventScroll = false;
this._penPointerPressed = false; this._penPointerState = 0;
this._penPointerReleased = false;
this._pointerIdTypeMap.clear(); this._pointerIdTypeMap.clear();
this._enabledValue = value; this._enabledValue = value;
@ -168,10 +166,15 @@ class TextScanner extends EventDispatcher {
searchTerms, searchTerms,
searchKanji, searchKanji,
scanOnTouchMove, scanOnTouchMove,
scanOnTouchPress,
scanOnTouchRelease,
scanOnPenMove,
scanOnPenHover, scanOnPenHover,
scanOnPenReleaseHover,
scanOnPenPress, scanOnPenPress,
scanOnPenRelease, scanOnPenRelease,
preventTouchScrolling preventTouchScrolling,
preventPenScrolling
} }
}) => ({ }) => ({
include: this._getInputArray(include), include: this._getInputArray(include),
@ -181,10 +184,15 @@ class TextScanner extends EventDispatcher {
searchTerms, searchTerms,
searchKanji, searchKanji,
scanOnTouchMove, scanOnTouchMove,
scanOnTouchPress,
scanOnTouchRelease,
scanOnPenMove,
scanOnPenHover, scanOnPenHover,
scanOnPenReleaseHover,
scanOnPenPress, scanOnPenPress,
scanOnPenRelease, scanOnPenRelease,
preventTouchScrolling preventTouchScrolling,
preventPenScrolling
} }
})); }));
} }
@ -515,41 +523,60 @@ class TextScanner extends EventDispatcher {
this._primaryTouchIdentifier = identifier; this._primaryTouchIdentifier = identifier;
this._searchAtFromTouchStart(e, x, y); if (this._pendingLookup) { return; }
const inputInfo = this._getMatchingInputGroupFromEvent('touch', 'touchStart', e);
if (inputInfo === null || !inputInfo.input.options.scanOnTouchPress) { return; }
this._searchAtFromTouchStart(x, y, inputInfo);
} }
_onTouchEnd(e) { _onTouchEnd(e) {
if ( if (this._primaryTouchIdentifier === null) { return; }
this._primaryTouchIdentifier === null ||
this._getTouch(e.changedTouches, this._primaryTouchIdentifier) === null const primaryTouch = this._getTouch(e.changedTouches, this._primaryTouchIdentifier);
) { if (primaryTouch === null) { return; }
return;
const {clientX, clientY} = primaryTouch;
this._onPrimaryTouchEnd(e, clientX, clientY, true);
} }
this._onPrimaryTouchEnd(); _onPrimaryTouchEnd(e, x, y, allowSearch) {
}
_onPrimaryTouchEnd() {
this._primaryTouchIdentifier = null; this._primaryTouchIdentifier = null;
this._preventScroll = false; this._preventScroll = false;
this._preventNextClick = false; this._preventNextClick = false;
// Don't revert context menu and mouse down prevention, since these events can occur after the touch has ended. // Don't revert context menu and mouse down prevention, since these events can occur after the touch has ended.
// I.e. this._preventNextContextMenu and this._preventNextMouseDown should not be assigned to false. // I.e. this._preventNextContextMenu and this._preventNextMouseDown should not be assigned to false.
if (!allowSearch) { return; }
const inputInfo = this._getMatchingInputGroupFromEvent('touch', 'touchEnd', e);
if (inputInfo === null || !inputInfo.input.options.scanOnTouchRelease) { return; }
this._searchAtFromTouchEnd(x, y, inputInfo);
} }
_onTouchCancel(e) { _onTouchCancel(e) {
this._onTouchEnd(e); if (this._primaryTouchIdentifier === null) { return; }
const primaryTouch = this._getTouch(e.changedTouches, this._primaryTouchIdentifier);
if (primaryTouch === null) { return; }
this._onPrimaryTouchEnd(e, 0, 0, false);
} }
_onTouchMove(e) { _onTouchMove(e) {
if (!this._preventScroll || !e.cancelable || this._primaryTouchIdentifier === null) { if (this._primaryTouchIdentifier === null) { return; }
if (!e.cancelable) {
this._onPrimaryTouchEnd(e, 0, 0, false);
return; return;
} }
if (!this._preventScroll) { return; }
const primaryTouch = this._getTouch(e.changedTouches, this._primaryTouchIdentifier); const primaryTouch = this._getTouch(e.changedTouches, this._primaryTouchIdentifier);
if (primaryTouch === null) { if (primaryTouch === null) { return; }
return;
}
const inputInfo = this._getMatchingInputGroupFromEvent('touch', 'touchMove', e); const inputInfo = this._getMatchingInputGroupFromEvent('touch', 'touchMove', e);
if (inputInfo === null) { return; } if (inputInfo === null) { return; }
@ -652,7 +679,7 @@ class TextScanner extends EventDispatcher {
_onTouchPointerDown(e) { _onTouchPointerDown(e) {
const {clientX, clientY, pointerId} = e; const {clientX, clientY, pointerId} = e;
return this._onPrimaryTouchStart(e, clientX, clientY, pointerId); this._onPrimaryTouchStart(e, clientX, clientY, pointerId);
} }
_onTouchPointerMove(e) { _onTouchPointerMove(e) {
@ -666,12 +693,13 @@ class TextScanner extends EventDispatcher {
this._searchAt(e.clientX, e.clientY, inputInfo); this._searchAt(e.clientX, e.clientY, inputInfo);
} }
_onTouchPointerUp() { _onTouchPointerUp(e) {
return this._onPrimaryTouchEnd(); const {clientX, clientY} = e;
return this._onPrimaryTouchEnd(e, clientX, clientY, true);
} }
_onTouchPointerCancel() { _onTouchPointerCancel(e) {
return this._onPrimaryTouchEnd(); return this._onPrimaryTouchEnd(e, 0, 0, false);
} }
_onTouchPointerOut() { _onTouchPointerOut() {
@ -689,25 +717,24 @@ class TextScanner extends EventDispatcher {
} }
_onPenPointerOver(e) { _onPenPointerOver(e) {
this._penPointerPressed = false; this._penPointerState = 1;
this._penPointerReleased = false; this._searchAtFromPen(e, 'pointerOver', false);
this._searchAtFromPen(e, e.clientX, e.clientY, 'pointerOver', false);
} }
_onPenPointerDown(e) { _onPenPointerDown(e) {
this._penPointerPressed = true; this._penPointerState = 2;
this._searchAtFromPen(e, e.clientX, e.clientY, 'pointerDown', true); this._searchAtFromPen(e, 'pointerDown', true);
} }
_onPenPointerMove(e) { _onPenPointerMove(e) {
if (this._penPointerPressed && (!this._preventScroll || !e.cancelable)) { return; } if (this._penPointerState === 2 && (!this._preventScroll || !e.cancelable)) { return; }
this._searchAtFromPen(e, e.clientX, e.clientY, 'pointerMove', true); this._searchAtFromPen(e, 'pointerMove', true);
} }
_onPenPointerUp() { _onPenPointerUp(e) {
this._penPointerPressed = false; this._penPointerState = 3;
this._penPointerReleased = true;
this._preventScroll = false; this._preventScroll = false;
this._searchAtFromPen(e, 'pointerUp', false);
} }
_onPenPointerCancel(e) { _onPenPointerCancel(e) {
@ -715,8 +742,7 @@ class TextScanner extends EventDispatcher {
} }
_onPenPointerOut() { _onPenPointerOut() {
this._penPointerPressed = false; this._penPointerState = 0;
this._penPointerReleased = false;
this._preventScroll = false; this._preventScroll = false;
this._preventNextContextMenu = false; this._preventNextContextMenu = false;
this._preventNextMouseDown = false; this._preventNextMouseDown = false;
@ -953,12 +979,7 @@ class TextScanner extends EventDispatcher {
await this._searchAt(x, y, inputInfo); await this._searchAt(x, y, inputInfo);
} }
async _searchAtFromTouchStart(e, x, y) { async _searchAtFromTouchStart(x, y, inputInfo) {
if (this._pendingLookup) { return; }
const inputInfo = this._getMatchingInputGroupFromEvent('touch', 'touchStart', e);
if (inputInfo === null) { return; }
const textSourceCurrentPrevious = this._textSourceCurrent !== null ? this._textSourceCurrent.clone() : null; const textSourceCurrentPrevious = this._textSourceCurrent !== null ? this._textSourceCurrent.clone() : null;
const preventScroll = inputInfo.input.options.preventTouchScrolling; const preventScroll = inputInfo.input.options.preventTouchScrolling;
@ -974,23 +995,22 @@ class TextScanner extends EventDispatcher {
} }
} }
async _searchAtFromPen(e, x, y, eventType, prevent) { async _searchAtFromTouchEnd(x, y, inputInfo) {
await this._searchAt(x, y, inputInfo);
}
async _searchAtFromPen(e, eventType, prevent) {
if (this._pendingLookup) { return; } if (this._pendingLookup) { return; }
const inputInfo = this._getMatchingInputGroupFromEvent('pen', eventType, e); const inputInfo = this._getMatchingInputGroupFromEvent('pen', eventType, e);
if (inputInfo === null) { return; } if (inputInfo === null) { return; }
const {input: {options}} = inputInfo; const {options} = inputInfo.input;
if ( if (!this._isPenEventSupported(eventType, options)) { return; }
(!options.scanOnPenRelease && this._penPointerReleased) ||
!(this._penPointerPressed ? options.scanOnPenPress : options.scanOnPenHover)
) {
return;
}
const preventScroll = inputInfo.input.options.preventTouchScrolling; const preventScroll = options.preventPenScrolling;
await this._searchAt(x, y, inputInfo); await this._searchAt(e.clientX, e.clientY, inputInfo);
if ( if (
prevent && prevent &&
@ -1003,6 +1023,25 @@ class TextScanner extends EventDispatcher {
} }
} }
_isPenEventSupported(eventType, options) {
switch (eventType) {
case 'pointerDown':
return options.scanOnPenPress;
case 'pointerUp':
return options.scanOnPenRelease;
}
switch (this._penPointerState) {
case 1: // hovering
return options.scanOnPenHover;
case 2: // touching
return options.scanOnPenMove;
case 3: // hovering after touching
return options.scanOnPenReleaseHover;
default: // not active
return false;
}
}
_getMatchingInputGroupFromEvent(pointerType, eventType, event) { _getMatchingInputGroupFromEvent(pointerType, eventType, event) {
const modifiers = DocumentUtil.getActiveModifiersAndButtons(event); const modifiers = DocumentUtil.getActiveModifiersAndButtons(event);
const modifierKeys = DocumentUtil.getActiveModifiers(event); const modifierKeys = DocumentUtil.getActiveModifiers(event);

View File

@ -150,10 +150,15 @@ class ScanInputsController {
searchTerms: true, searchTerms: true,
searchKanji: true, searchKanji: true,
scanOnTouchMove: true, scanOnTouchMove: true,
scanOnTouchPress: true,
scanOnTouchRelease: false,
scanOnPenMove: true,
scanOnPenHover: true, scanOnPenHover: true,
scanOnPenReleaseHover: false,
scanOnPenPress: true, scanOnPenPress: true,
scanOnPenRelease: false, scanOnPenRelease: false,
preventTouchScrolling: true preventTouchScrolling: true,
preventPenScrolling: true
} }
}; };
} }

View File

@ -2934,16 +2934,28 @@
</label> </label>
</div> </div>
<div class="scan-input-prefix-cell scan-input-options-cell scan-input-advanced-only" data-property="touch-pen-options"><span>Touch &amp; pen:</span></div> <div class="scan-input-prefix-cell scan-input-options-cell scan-input-advanced-only" data-property="touch-options"><span>Touch options:</span></div>
<div class="scan-input-content-cell scan-input-options-cell scan-input-advanced-only" data-property="touch-pen-options"> <div class="scan-input-content-cell scan-input-options-cell scan-input-advanced-only" data-property="touch-options">
<label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnTouchPress"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on touch press</span>
</label>
<label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnTouchRelease"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on touch release</span>
</label>
<label class="scan-input-checkbox-item"> <label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnTouchMove"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label> <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnTouchMove"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on touch move</span> <span>Scan on touch move</span>
</label> </label>
<label class="scan-input-checkbox-item"> <label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenHover"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label> <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.preventTouchScrolling"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on pen hover</span> <span>Prevent touch scrolling</span>
</label> </label>
</div>
<div class="scan-input-prefix-cell scan-input-options-cell scan-input-advanced-only" data-property="pen-options"><span>Pen options:</span></div>
<div class="scan-input-content-cell scan-input-options-cell scan-input-advanced-only" data-property="pen-options">
<label class="scan-input-checkbox-item"> <label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenPress"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label> <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenPress"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on pen press</span> <span>Scan on pen press</span>
@ -2953,8 +2965,20 @@
<span>Scan on pen release</span> <span>Scan on pen release</span>
</label> </label>
<label class="scan-input-checkbox-item"> <label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.preventTouchScrolling"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label> <label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenMove"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Prevent touch/pen scrolling</span> <span>Scan on pen move (while touched)</span>
</label>
<label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenHover"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on pen hover (before touched)</span>
</label>
<label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.scanOnPenReleaseHover"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Scan on pen hover (after touched)</span>
</label>
<label class="scan-input-checkbox-item">
<label class="checkbox"><input type="checkbox" class="scan-input-settings-checkbox" data-property="options.preventPenScrolling"><span class="checkbox-body"><span class="checkbox-fill"></span><span class="checkbox-border"></span><span class="checkbox-check"></span></span></label>
<span>Prevent pen scrolling</span>
</label> </label>
</div> </div>
</div> </div>

View File

@ -367,10 +367,15 @@ function createProfileOptionsUpdatedTestData1() {
searchTerms: true, searchTerms: true,
searchKanji: true, searchKanji: true,
scanOnTouchMove: true, scanOnTouchMove: true,
scanOnTouchPress: true,
scanOnTouchRelease: false,
scanOnPenMove: true,
scanOnPenHover: true, scanOnPenHover: true,
scanOnPenReleaseHover: false,
scanOnPenPress: true, scanOnPenPress: true,
scanOnPenRelease: false, scanOnPenRelease: false,
preventTouchScrolling: true preventTouchScrolling: true,
preventPenScrolling: true
} }
}, },
{ {
@ -386,10 +391,15 @@ function createProfileOptionsUpdatedTestData1() {
searchTerms: true, searchTerms: true,
searchKanji: true, searchKanji: true,
scanOnTouchMove: true, scanOnTouchMove: true,
scanOnTouchPress: true,
scanOnTouchRelease: false,
scanOnPenMove: true,
scanOnPenHover: true, scanOnPenHover: true,
scanOnPenReleaseHover: false,
scanOnPenPress: true, scanOnPenPress: true,
scanOnPenRelease: false, scanOnPenRelease: false,
preventTouchScrolling: true preventTouchScrolling: true,
preventPenScrolling: true
} }
}, },
{ {
@ -405,10 +415,15 @@ function createProfileOptionsUpdatedTestData1() {
searchTerms: true, searchTerms: true,
searchKanji: true, searchKanji: true,
scanOnTouchMove: true, scanOnTouchMove: true,
scanOnTouchPress: true,
scanOnTouchRelease: false,
scanOnPenMove: true,
scanOnPenHover: true, scanOnPenHover: true,
scanOnPenReleaseHover: false,
scanOnPenPress: true, scanOnPenPress: true,
scanOnPenRelease: false, scanOnPenRelease: false,
preventTouchScrolling: true preventTouchScrolling: true,
preventPenScrolling: true
} }
} }
] ]