cosmos-explorer/src/libs/utils.ts

207 lines
4.4 KiB
TypeScript
Raw Normal View History

2023-04-26 16:18:50 +00:00
export function getLocalObject(name: string) {
2023-05-06 14:56:04 +00:00
const text = localStorage.getItem(name);
if (text) {
return JSON.parse(text);
}
return null;
2023-04-26 16:18:50 +00:00
}
export function getLocalChains() {
2023-05-06 14:56:04 +00:00
return 'osmosis';
2023-04-26 16:18:50 +00:00
}
export const percent = (num: number) => {
2023-05-06 14:56:04 +00:00
return parseFloat((num * 100).toFixed(2));
};
2023-04-26 16:18:50 +00:00
2023-12-25 06:55:47 +00:00
export function stringToUint8Array(str: string) {
const arr = [];
for (let i = 0, j = str.length; i < j; ++i) {
arr.push(str.charCodeAt(i));
}
return new Uint8Array(arr);
}
export function uint8ArrayToString(arr: Uint8Array) {
let str = '';
for (let i = 0, j = arr.length; i < j; ++i) {
str += String.fromCharCode(arr[i]);
}
return str;
}
2023-05-06 14:56:04 +00:00
const COUNT_ABBRS = [
'',
'K',
'M',
'B',
't',
'q',
's',
'S',
'o',
'n',
'd',
'U',
'D',
'T',
'Qt',
'Qd',
'Sd',
'St',
];
2023-04-26 16:18:50 +00:00
2023-05-06 14:56:04 +00:00
export function formatNumber(count: number, withAbbr = false, decimals = 2) {
const i = count === 0 ? count : Math.floor(Math.log(count) / Math.log(1000));
let result: any = parseFloat((count / 1000 ** i).toFixed(decimals));
if (withAbbr && COUNT_ABBRS[i]) {
result += `${COUNT_ABBRS[i]}`;
}
return result;
2023-04-26 16:18:50 +00:00
}
2023-05-06 14:56:04 +00:00
export function formatTokenAmount(
assets: any,
tokenAmount: any,
decimals = 2,
tokenDenom = 'uatom',
format = true
) {
2023-06-08 02:02:47 +00:00
const denom = typeof tokenDenom === 'string'
? tokenDenom
// @ts-ignore
: tokenDenom?.denom_trace?.base_denom;
2023-05-06 14:56:04 +00:00
let amount = 0;
const asset = assets.find((a: any) => a.base === denom);
let exp = asset
? asset.exponent
: String(denom).startsWith('gravity')
? 18
: 6;
const config = Object.values(getLocalChains());
amount = Number(Number(tokenAmount)) / 10 ** exp;
if (amount > 10) {
if (format) {
return numberWithCommas(parseFloat(amount.toFixed(decimals)));
2023-04-26 16:18:50 +00:00
}
2023-05-06 14:56:04 +00:00
return parseFloat(amount.toFixed(decimals));
}
return parseFloat(amount.toFixed(exp));
2023-04-26 16:18:50 +00:00
}
export function numberWithCommas(x: any) {
2023-05-06 14:56:04 +00:00
const parts = x.toString().split('.');
parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',');
return parts.join('.');
2023-04-26 16:18:50 +00:00
}
2023-04-27 14:43:30 +00:00
export function isToken(value: string) {
2023-05-06 14:56:04 +00:00
let is = false;
if (Array.isArray(value)) {
is = value.findIndex((x) => Object.keys(x).includes('denom')) > -1;
} else {
is = Object.keys(value).includes('denom');
2023-04-27 14:43:30 +00:00
}
2023-05-06 14:56:04 +00:00
return is;
}
export function isStringArray(value: any) {
let is = false;
if (Array.isArray(value)) {
is = value.findIndex((x) => typeof x === 'string') > -1;
2023-04-27 14:43:30 +00:00
}
2023-05-06 14:56:04 +00:00
return is;
}
2023-04-27 14:43:30 +00:00
2023-05-06 14:56:04 +00:00
export function isHexAddress(v: any) {
// const re = /^[A-Z\d]{40}$/
// return re.test(v)
return v.length === 28;
}
2023-06-08 13:16:43 +00:00
2023-06-12 06:59:24 +00:00
export function isBech32Address(v?: string) {
if(!v) return ""
const pattern = /^[a-z\d]+1[a-z\d]{38}$/g
2023-06-15 10:47:44 +00:00
return String(v).search(pattern) > -1
2023-06-12 06:59:24 +00:00
}
2023-06-17 02:35:06 +00:00
export function formatSeconds(value?: string) {
if(!value) return ''
const duration = Number(value.replace(/s/, ''))
if(duration > 24*60*60) {
2023-06-20 11:45:49 +00:00
return `${(duration / ( 24 * 60 * 60)).toFixed()} days`
2023-06-17 02:35:06 +00:00
}
if(duration > 60*60) {
2023-06-21 01:52:28 +00:00
return `${(duration / (60 * 60)).toFixed()} hours`
2023-06-17 02:35:06 +00:00
}
if(duration > 60) {
return `${duration / 60} mins`
}
return value
}
2023-06-08 13:16:43 +00:00
export function hexToRgb(hex: string) {
// remove '#'
hex = hex.replace('#', '');
// red
const r = parseInt(hex.substring(0, 2), 16);
// green
const g = parseInt(hex.substring(2, 4), 16);
// blue
const b = parseInt(hex.substring(4, 6), 16);
return {
color: 'rgb(' + r + ', ' + g + ', ' + b + ')',
r,
g,
b,
};
}
export function rgbToHsl(color: string) {
color = color.replace('rgb(', '');
color = color.replace(')', '');
const colorList = color.split(',') || [0, 0, 0];
// console.log(colorList, 'colorList')
const r = parseInt(colorList?.[0]) / 255;
const g = parseInt(colorList?.[1]) / 255;
const b = parseInt(colorList?.[2]) / 255;
// console.log(r,g,b, '88')
const max = Math.max(r, g, b);
const min = Math.min(r, g, b);
2023-06-09 05:47:25 +00:00
let h = 0,
s = 0,
2023-06-08 13:16:43 +00:00
l = (max + min) / 2;
if (max == min) {
h = 0;
s = 0;
} else {
var d = max - min;
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
switch (max) {
case r:
h = (g - b) / d + (g < b ? 6 : 0);
break;
case g:
h = (b - r) / d + 2;
break;
case b:
h = (r - g) / d + 4;
break;
}
h = h / 6;
}
h = Math.round(h * 360);
s = Math.round(s * 100);
l = Math.round(l * 100);
return {
color: 'hsl(' + h + ', ' + s + '%, ' + l + '%)',
value: h + ' ' + s + ' ' + l,
h,
s,
l,
};
}