2018-04-16 18:38:35 +00:00
|
|
|
/// <reference path="../crypto/sha.ts" />
|
|
|
|
|
|
|
|
namespace helpers {
|
|
|
|
export function hashPassword(password: string) : Promise<string> {
|
|
|
|
return new Promise<string>((resolve, reject) => {
|
|
|
|
sha.sha1(password).then(result => {
|
|
|
|
resolve(btoa(String.fromCharCode.apply(null, new Uint8Array(result))));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2018-09-30 19:50:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
class LaterPromise<T> extends Promise<T> {
|
|
|
|
private _handle: Promise<T>;
|
|
|
|
private _resolve: ($: T) => any;
|
|
|
|
private _reject: ($: any) => any;
|
|
|
|
private _time: number;
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
super((resolve, reject) => {});
|
|
|
|
this._handle = new Promise<T>((resolve, reject) => {
|
|
|
|
this._resolve = resolve;
|
|
|
|
this._reject = reject;
|
|
|
|
});
|
|
|
|
this._time = Date.now();
|
|
|
|
}
|
|
|
|
|
|
|
|
resolved(object: T) {
|
|
|
|
this._resolve(object);
|
|
|
|
}
|
|
|
|
|
|
|
|
rejected(reason) {
|
|
|
|
this._reject(reason);
|
|
|
|
}
|
|
|
|
|
|
|
|
function_rejected() {
|
|
|
|
return error => this.rejected(error);
|
|
|
|
}
|
|
|
|
|
|
|
|
time() { return this._time; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attaches callbacks for the resolution and/or rejection of the Promise.
|
|
|
|
* @param onfulfilled The callback to execute when the Promise is resolved.
|
|
|
|
* @param onrejected The callback to execute when the Promise is rejected.
|
|
|
|
* @returns A Promise for the completion of which ever callback is executed.
|
|
|
|
*/
|
|
|
|
then<TResult1 = T, TResult2 = never>(onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null,
|
|
|
|
onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null): Promise<TResult1 | TResult2> {
|
|
|
|
return this._handle.then(onfulfilled, onrejected);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Attaches a callback for only the rejection of the Promise.
|
|
|
|
* @param onrejected The callback to execute when the Promise is rejected.
|
|
|
|
* @returns A Promise for the completion of the callback.
|
|
|
|
*/
|
|
|
|
catch<TResult = never>(onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | undefined | null): Promise<T | TResult> {
|
|
|
|
return this._handle.then(onrejected);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const copy_to_clipboard = str => {
|
2019-05-25 15:54:26 +00:00
|
|
|
console.log(tr("Copy text to clipboard: %s"), str);
|
2018-09-30 19:50:59 +00:00
|
|
|
const el = document.createElement('textarea');
|
|
|
|
el.value = str;
|
|
|
|
el.setAttribute('readonly', '');
|
|
|
|
el.style.position = 'absolute';
|
|
|
|
el.style.left = '-9999px';
|
|
|
|
document.body.appendChild(el);
|
|
|
|
const selected =
|
|
|
|
document.getSelection().rangeCount > 0
|
|
|
|
? document.getSelection().getRangeAt(0)
|
|
|
|
: false;
|
|
|
|
el.select();
|
|
|
|
document.execCommand('copy');
|
|
|
|
document.body.removeChild(el);
|
|
|
|
if (selected) {
|
|
|
|
document.getSelection().removeAllRanges();
|
|
|
|
document.getSelection().addRange(selected);
|
|
|
|
}
|
|
|
|
};
|