Add support for resizing the popup window using touch events (#1471)

This commit is contained in:
toasted-nutbread 2021-02-28 17:13:11 -05:00 committed by GitHub
parent c192b4a4c1
commit 90da87f378
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -108,6 +108,7 @@ class Display extends EventDispatcher {
this._definitionTextScanner = null;
this._frameResizeToken = null;
this._frameResizeHandle = document.querySelector('#frame-resizer-handle');
this._frameResizeTouchIdentifier = null;
this._frameResizeStartSize = null;
this._frameResizeStartOffset = null;
this._frameResizeEventListeners = new EventListenerCollection();
@ -245,6 +246,7 @@ class Display extends EventDispatcher {
if (this._frameResizeHandle !== null) {
this._frameResizeHandle.addEventListener('mousedown', this._onFrameResizerMouseDown.bind(this), false);
this._frameResizeHandle.addEventListener('touchstart', this._onFrameResizerTouchStart.bind(this), false);
}
}
@ -1784,6 +1786,11 @@ class Display extends EventDispatcher {
this._startFrameResize(e);
}
_onFrameResizerTouchStart(e) {
e.preventDefault();
this._startFrameResizeTouch(e);
}
_onFrameResizerMouseUp() {
this._stopFrameResize();
}
@ -1802,6 +1809,24 @@ class Display extends EventDispatcher {
}
}
_onFrameResizerTouchEnd(e) {
if (this._getTouch(e.changedTouches, this._frameResizeTouchIdentifier) === null) { return; }
this._stopFrameResize();
}
_onFrameResizerTouchCancel(e) {
if (this._getTouch(e.changedTouches, this._frameResizeTouchIdentifier) === null) { return; }
this._stopFrameResize();
}
_onFrameResizerTouchMove(e) {
if (this._frameResizeStartSize === null) { return; }
const primaryTouch = this._getTouch(e.changedTouches, this._frameResizeTouchIdentifier);
if (primaryTouch === null) { return; }
const {clientX: x, clientY: y} = primaryTouch;
this._updateFrameSize(x, y);
}
_getSearchContext() {
return {optionsContext: this.getOptionsContext()};
}
@ -1825,6 +1850,27 @@ class Display extends EventDispatcher {
this._initializeFrameResize(token);
}
_startFrameResizeTouch(e) {
if (this._frameResizeToken !== null) { return; }
const {clientX: x, clientY: y, identifier} = e.changedTouches[0];
const token = {};
this._frameResizeToken = token;
this._frameResizeStartOffset = {x, y};
this._frameResizeTouchIdentifier = identifier;
this._frameResizeEventListeners.addEventListener(window, 'touchend', this._onFrameResizerTouchEnd.bind(this), false);
this._frameResizeEventListeners.addEventListener(window, 'touchcancel', this._onFrameResizerTouchCancel.bind(this), false);
this._frameResizeEventListeners.addEventListener(window, 'blur', this._onFrameResizerWindowBlur.bind(this), false);
this._frameResizeEventListeners.addEventListener(window, 'touchmove', this._onFrameResizerTouchMove.bind(this), false);
const {documentElement} = document;
if (documentElement !== null) {
documentElement.dataset.isResizing = 'true';
}
this._initializeFrameResize(token);
}
async _initializeFrameResize(token) {
const size = await this._invokeContentOrigin('getFrameSize');
if (this._frameResizeToken !== token) { return; }
@ -1837,6 +1883,7 @@ class Display extends EventDispatcher {
this._frameResizeEventListeners.removeAllEventListeners();
this._frameResizeStartSize = null;
this._frameResizeStartOffset = null;
this._frameResizeTouchIdentifier = null;
this._frameResizeToken = null;
const {documentElement} = document;
@ -1855,6 +1902,15 @@ class Display extends EventDispatcher {
await this._invokeContentOrigin('setFrameSize', {width, height});
}
_getTouch(touchList, identifier) {
for (const touch of touchList) {
if (touch.identifier === identifier) {
return touch;
}
}
return null;
}
_updateHotkeys(options) {
this._hotkeyHandler.setHotkeys(this._pageType, options.inputs.hotkeys);
}