License and linting fixes.
This commit is contained in:
parent
774774c365
commit
8e5c3f01b4
1 changed files with 23 additions and 7 deletions
|
@ -1,10 +1,26 @@
|
||||||
|
/*
|
||||||
|
Copyright 2017 New Vector Ltd
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
import Promise from "bluebird";
|
import Promise from "bluebird";
|
||||||
|
|
||||||
|
|
||||||
function defer() {
|
function defer() {
|
||||||
let resolve, reject;
|
let resolve;
|
||||||
|
let reject;
|
||||||
let isPending = true;
|
let isPending = true;
|
||||||
let promise = new Promise(function(...args) {
|
const promise = new Promise(function(...args) {
|
||||||
resolve = args[0];
|
resolve = args[0];
|
||||||
reject = args[1];
|
reject = args[1];
|
||||||
});
|
});
|
||||||
|
@ -55,18 +71,18 @@ export default class PostMessageApi {
|
||||||
if (this._onMsgCallback) {
|
if (this._onMsgCallback) {
|
||||||
return this._onMsgCallback;
|
return this._onMsgCallback;
|
||||||
}
|
}
|
||||||
let self = this;
|
const self = this;
|
||||||
this._onMsgCallback = function(ev) {
|
this._onMsgCallback = function(ev) {
|
||||||
// THIS IS ALL UNSAFE EXECUTION.
|
// THIS IS ALL UNSAFE EXECUTION.
|
||||||
// We do not verify who the sender of `ev` is!
|
// We do not verify who the sender of `ev` is!
|
||||||
let payload = ev.data;
|
const payload = ev.data;
|
||||||
// NOTE: Workaround for running in a mobile WebView where a
|
// NOTE: Workaround for running in a mobile WebView where a
|
||||||
// postMessage immediately triggers this callback even though it is
|
// postMessage immediately triggers this callback even though it is
|
||||||
// not the response.
|
// not the response.
|
||||||
if (payload.response === undefined) {
|
if (payload.response === undefined) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let deferred = self._pending[payload._id];
|
const deferred = self._pending[payload._id];
|
||||||
if (!deferred) {
|
if (!deferred) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -83,7 +99,7 @@ export default class PostMessageApi {
|
||||||
this._counter += 1;
|
this._counter += 1;
|
||||||
target = target || "*";
|
target = target || "*";
|
||||||
action._id = Date.now() + "-" + Math.random().toString(36) + "-" + this._counter;
|
action._id = Date.now() + "-" + Math.random().toString(36) + "-" + this._counter;
|
||||||
let d = defer();
|
const d = defer();
|
||||||
this._pending[action._id] = d;
|
this._pending[action._id] = d;
|
||||||
this._window.postMessage(action, target);
|
this._window.postMessage(action, target);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue