2016-05-02 08:51:47 +03:00
|
|
|
let lastId = 0;
|
2017-07-22 18:57:38 +03:00
|
|
|
export function uniqueId(prefix: string = 'id'): string {
|
2020-05-24 02:08:24 +03:00
|
|
|
return `${prefix}${++lastId}`;
|
2016-05-02 08:51:47 +03:00
|
|
|
}
|
2016-07-29 20:14:52 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {object} obj
|
2019-11-27 11:03:32 +02:00
|
|
|
* @param {Array} keys
|
2016-07-29 20:14:52 +03:00
|
|
|
*
|
2019-11-27 11:03:32 +02:00
|
|
|
* @returns {object}
|
2016-07-29 20:14:52 +03:00
|
|
|
*/
|
2020-05-24 02:08:24 +03:00
|
|
|
export function omit(obj: { [key: string]: any }, keys: Array<string>): { [key: string]: any } {
|
|
|
|
const newObj = { ...obj };
|
2016-07-29 20:14:52 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
keys.forEach((key) => {
|
|
|
|
Reflect.deleteProperty(newObj, key);
|
|
|
|
});
|
2016-07-29 20:14:52 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return newObj;
|
2016-07-29 20:14:52 +03:00
|
|
|
}
|
2016-07-31 16:53:16 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Asynchronously loads script
|
|
|
|
*
|
|
|
|
* @param {string} src
|
|
|
|
*
|
2019-11-27 11:03:32 +02:00
|
|
|
* @returns {Promise}
|
2016-07-31 16:53:16 +03:00
|
|
|
*/
|
2019-12-07 13:28:52 +02:00
|
|
|
export function loadScript(src: string): Promise<void> {
|
2020-05-24 02:08:24 +03:00
|
|
|
const script = document.createElement('script');
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
script.async = true;
|
|
|
|
script.defer = true;
|
|
|
|
script.src = src;
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
script.onload = () => resolve();
|
|
|
|
script.onerror = reject;
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
if (document && document.body) {
|
|
|
|
document.body.appendChild(script);
|
|
|
|
}
|
|
|
|
});
|
2016-07-31 16:53:16 +03:00
|
|
|
}
|
2016-08-14 12:01:04 +03:00
|
|
|
|
2017-01-03 07:56:38 +02:00
|
|
|
/**
|
|
|
|
* Returns a function, that, as long as it continues to be invoked, will not
|
|
|
|
* be triggered. The function will be called after it stops being called for
|
|
|
|
* N milliseconds. If `immediate` is passed, trigger the function on the
|
|
|
|
* leading edge, instead of the trailing. The function also has a property 'clear'
|
|
|
|
* that is a function which will clear the timer to prevent previously scheduled executions.
|
|
|
|
*
|
|
|
|
* @source https://github.com/component/debounce
|
|
|
|
*
|
2019-11-27 11:03:32 +02:00
|
|
|
* @param {Function} function - function to wrap
|
2017-01-03 07:56:38 +02:00
|
|
|
* @param {number} [timeout=100] - timeout in ms
|
|
|
|
* @param {bool} [immediate=false] - whether to execute at the beginning
|
|
|
|
*/
|
2017-07-22 18:57:38 +03:00
|
|
|
export { default as debounce } from 'debounce';
|
2017-01-06 07:34:39 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} jwt
|
|
|
|
*
|
|
|
|
* @throws {Error} If can not decode token
|
|
|
|
*
|
2019-11-27 11:03:32 +02:00
|
|
|
* @returns {object} - decoded jwt payload
|
2017-01-06 07:34:39 +02:00
|
|
|
*/
|
2019-11-27 11:03:32 +02:00
|
|
|
export function getJwtPayloads(
|
2020-05-24 02:08:24 +03:00
|
|
|
jwt: string,
|
2019-11-27 11:03:32 +02:00
|
|
|
): {
|
2020-05-24 02:08:24 +03:00
|
|
|
sub: string;
|
|
|
|
jti: number;
|
|
|
|
exp: number;
|
2019-05-20 16:32:07 +03:00
|
|
|
} {
|
2020-05-24 02:08:24 +03:00
|
|
|
const parts = (jwt || '').split('.');
|
2017-01-06 07:34:39 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
if (parts.length !== 3) {
|
|
|
|
throw new Error('Invalid jwt token');
|
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
try {
|
|
|
|
return JSON.parse(atob(parts[1]));
|
|
|
|
} catch (err) {
|
|
|
|
throw new Error('Can not decode jwt token');
|
|
|
|
}
|
2017-01-06 07:34:39 +02:00
|
|
|
}
|