2020-08-25 21:08:42 +03:00
|
|
|
import * as Constants from "~/common/constants";
|
|
|
|
|
2020-04-09 00:29:13 +03:00
|
|
|
const MINUTE = 60;
|
|
|
|
const HOUR = MINUTE * 60;
|
|
|
|
const DAY = HOUR * 24;
|
|
|
|
const WEEK = DAY * 7;
|
|
|
|
const MONTH = (DAY * 365) / 12;
|
|
|
|
const YEAR = DAY * 365;
|
|
|
|
|
2020-10-29 22:48:45 +03:00
|
|
|
export const generateRandomString = () => {
|
2020-11-28 04:19:30 +03:00
|
|
|
return Math.random().toString(36).substr(2, 5);
|
2020-10-29 22:48:45 +03:00
|
|
|
};
|
|
|
|
|
2020-07-29 02:08:38 +03:00
|
|
|
export const getKey = (text) => {
|
|
|
|
if (isEmpty(text)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return text.replace("Basic ", "");
|
|
|
|
};
|
|
|
|
|
2020-09-09 07:12:54 +03:00
|
|
|
export const getPresentationSlateName = (slate) => {
|
|
|
|
if (!isEmpty(slate.data.name)) {
|
|
|
|
return slate.data.name;
|
|
|
|
}
|
|
|
|
|
|
|
|
return slate.slatename;
|
|
|
|
};
|
|
|
|
|
2020-09-02 11:33:39 +03:00
|
|
|
export const getPresentationName = (user) => {
|
|
|
|
if (!isEmpty(user.data.name)) {
|
|
|
|
return user.data.name;
|
|
|
|
}
|
|
|
|
|
|
|
|
return user.username;
|
|
|
|
};
|
|
|
|
|
2020-09-09 11:29:21 +03:00
|
|
|
export const zeroPad = (num, places) => {
|
|
|
|
var zero = places - num.toString().length + 1;
|
|
|
|
return Array(+(zero > 0 && zero)).join("0") + num;
|
|
|
|
};
|
|
|
|
|
2020-08-25 21:08:42 +03:00
|
|
|
export const getCIDGatewayURL = (cid) => {
|
2020-09-12 06:43:28 +03:00
|
|
|
return `${Constants.gateways.ipfs}/${cid}`;
|
2020-08-25 21:08:42 +03:00
|
|
|
};
|
|
|
|
|
2020-09-25 03:37:09 +03:00
|
|
|
// NOTE(jsign): Each epoch is 30s, then divide by 60 for getting mins, by 60 to get hours, then by 24 to get days
|
|
|
|
export const getDaysFromEpoch = (epoch) => {
|
2020-10-18 22:53:59 +03:00
|
|
|
const number = (epoch * 30) / DAY;
|
|
|
|
const formatted = number.toFixed(2);
|
|
|
|
return `${formatted} days`;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const toDateSinceEpoch = (epoch) => {
|
|
|
|
return toDate(new Date().getTime() - epoch);
|
2020-09-25 03:37:09 +03:00
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const getCIDGatewayURLWithExtension = (cid, name) => {
|
|
|
|
const url = getCIDGatewayURL(cid);
|
|
|
|
const extension = getFileExtension(name);
|
|
|
|
if (!isEmpty(extension)) {
|
|
|
|
return `${url}.${getFileExtension(name)}`;
|
2020-09-06 20:24:58 +03:00
|
|
|
}
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
return url;
|
|
|
|
};
|
2020-09-06 20:24:58 +03:00
|
|
|
|
2020-11-17 06:17:56 +03:00
|
|
|
export const getURLFromPath = (path) => {
|
|
|
|
return `${window.location.protocol}//${window.location.hostname}${
|
|
|
|
window.location.port ? ":" + window.location.port : ""
|
|
|
|
}${path}`;
|
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const getFileExtension = (name) => {
|
2020-11-11 04:44:21 +03:00
|
|
|
if (!name || isEmpty(name)) {
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
// if (name.lastIndexOf(".") !== -1) {
|
|
|
|
// return name.slice(name.lastIndexOf("."));
|
|
|
|
// } else {
|
|
|
|
// return "";
|
|
|
|
// }
|
|
|
|
if (name.lastIndexOf(".") !== -1) {
|
|
|
|
return name.slice(((name.lastIndexOf(".") - 1) >>> 0) + 2);
|
|
|
|
}
|
|
|
|
return "";
|
2020-09-14 00:38:44 +03:00
|
|
|
};
|
2020-09-06 20:24:58 +03:00
|
|
|
|
2020-11-17 05:10:43 +03:00
|
|
|
export const createQueryParams = (params) => {
|
|
|
|
let query = "?";
|
|
|
|
let first = true;
|
|
|
|
for (const [key, value] of Object.entries(params)) {
|
|
|
|
if (!first) {
|
|
|
|
query += "&";
|
|
|
|
}
|
|
|
|
query += `${key}=${value}`;
|
|
|
|
first = false;
|
|
|
|
}
|
|
|
|
return query;
|
|
|
|
};
|
|
|
|
|
2020-09-14 03:34:58 +03:00
|
|
|
export const getCIDFromIPFS = (url) => {
|
|
|
|
// NOTE(andrew)
|
|
|
|
const cid = url.includes("/ipfs/")
|
|
|
|
? // pull cid from a path format gateway
|
|
|
|
url.split("/ipfs/")[1]
|
|
|
|
: // pull cid from a subdomain format gateway
|
|
|
|
url.match(
|
|
|
|
// regex here performs https://{cid}.ipfs.slate.textile.io => [https://{cid}, {cid}]
|
|
|
|
/(?:http[s]*\:\/\/)*(.*?)\.(?=[^\/]*\..{2,5})/i
|
|
|
|
)[1];
|
|
|
|
|
|
|
|
return cid;
|
|
|
|
};
|
|
|
|
|
2020-10-31 02:12:20 +03:00
|
|
|
export const formatAsUploadMessage = (added, skipped, slate = false) => {
|
|
|
|
let message = `${added || 0} file${added !== 1 ? "s" : ""} uploaded${slate ? " to slate" : ""}. `;
|
|
|
|
if (skipped) {
|
|
|
|
message += `${skipped || 0} duplicate / existing file${
|
|
|
|
added !== 1 ? "s were" : " was"
|
|
|
|
} skipped.`;
|
|
|
|
}
|
|
|
|
return message;
|
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const pluralize = (text, count) => {
|
|
|
|
return count > 1 || count === 0 ? `${text}s` : text;
|
|
|
|
};
|
2020-09-06 20:24:58 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const toDate = (data) => {
|
|
|
|
const date = new Date(data);
|
|
|
|
return `${date.getMonth() + 1}-${date.getDate()}-${date.getFullYear()}`;
|
2020-09-06 20:24:58 +03:00
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const formatNumber = (x) => {
|
|
|
|
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
|
|
|
|
};
|
|
|
|
|
|
|
|
export const elide = (string, length = 140, emptyState = "...") => {
|
|
|
|
if (isEmpty(string)) {
|
|
|
|
return emptyState;
|
2020-09-06 20:24:58 +03:00
|
|
|
}
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
if (string.length < length) {
|
|
|
|
return string.trim();
|
|
|
|
}
|
|
|
|
|
|
|
|
return `${string.substring(0, length)}...`;
|
2020-09-06 20:24:58 +03:00
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const isEmpty = (string) => {
|
|
|
|
// NOTE(jim): This is not empty when its coerced into a string.
|
|
|
|
if (string === 0) {
|
|
|
|
return false;
|
2020-07-27 04:51:51 +03:00
|
|
|
}
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
if (!string) {
|
|
|
|
return true;
|
|
|
|
}
|
2020-07-27 04:51:51 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
if (typeof string === "object") {
|
|
|
|
return true;
|
|
|
|
}
|
2020-07-27 04:51:51 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
if (string.length === 0) {
|
|
|
|
return true;
|
2020-04-09 00:29:13 +03:00
|
|
|
}
|
2020-09-14 00:38:44 +03:00
|
|
|
|
|
|
|
string = string.toString();
|
|
|
|
|
|
|
|
return !string.trim();
|
2020-04-09 00:29:13 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
export const bytesToSize = (bytes, decimals = 2) => {
|
2020-06-19 06:57:57 +03:00
|
|
|
if (bytes === 0) return "0 Bytes";
|
2020-04-09 00:29:13 +03:00
|
|
|
|
|
|
|
const k = 1024;
|
|
|
|
const dm = decimals < 0 ? 0 : decimals;
|
2020-06-19 06:57:57 +03:00
|
|
|
const sizes = ["Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
|
2020-04-09 00:29:13 +03:00
|
|
|
|
|
|
|
const i = Math.floor(Math.log(bytes) / Math.log(k));
|
|
|
|
|
2020-09-17 02:26:15 +03:00
|
|
|
return `${(bytes / Math.pow(k, i)).toFixed(dm)} ${sizes[i]}`;
|
2020-04-09 00:29:13 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
export const getRemainingTime = (seconds) => {
|
|
|
|
seconds = seconds > 0 ? seconds : 1;
|
|
|
|
|
|
|
|
let [value, unit] =
|
|
|
|
seconds < MINUTE
|
2020-06-19 06:57:57 +03:00
|
|
|
? [Math.round(seconds), "second"]
|
2020-04-09 00:29:13 +03:00
|
|
|
: seconds < HOUR
|
2020-06-19 06:57:57 +03:00
|
|
|
? [Math.round(seconds / MINUTE), "minute"]
|
2020-04-09 00:29:13 +03:00
|
|
|
: seconds < DAY
|
2020-06-19 06:57:57 +03:00
|
|
|
? [Math.round(seconds / HOUR), "hour"]
|
2020-04-09 00:29:13 +03:00
|
|
|
: seconds < WEEK
|
2020-06-19 06:57:57 +03:00
|
|
|
? [Math.round(seconds / DAY), "day"]
|
2020-04-09 00:29:13 +03:00
|
|
|
: seconds < MONTH
|
2020-06-19 06:57:57 +03:00
|
|
|
? [Math.round(seconds / WEEK), "week"]
|
2020-04-09 00:29:13 +03:00
|
|
|
: seconds < YEAR
|
2020-06-19 06:57:57 +03:00
|
|
|
? [Math.round(seconds / MONTH), "month"]
|
|
|
|
: [Math.round(seconds / YEAR), "year"];
|
2020-04-09 00:29:13 +03:00
|
|
|
|
|
|
|
unit = pluralize(unit, value);
|
|
|
|
|
|
|
|
return `${value} ${unit} remaining`;
|
|
|
|
};
|
|
|
|
|
2020-10-05 00:30:28 +03:00
|
|
|
export const urlToCid = (url) => {
|
|
|
|
return url
|
|
|
|
.replace(`${Constants.gateways.ipfs}/`, "")
|
|
|
|
.replace("https://", "")
|
|
|
|
.replace(".ipfs.slate.textile.io", "")
|
|
|
|
.replace("hub.textile.io/ipfs/", "");
|
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const hexToRGBA = (hex, alpha = 1) => {
|
|
|
|
hex = hex.replace("#", "");
|
2020-09-16 11:40:03 +03:00
|
|
|
var r = parseInt(hex.length == 3 ? hex.slice(0, 1).repeat(2) : hex.slice(0, 2), 16);
|
|
|
|
var g = parseInt(hex.length == 3 ? hex.slice(1, 2).repeat(2) : hex.slice(2, 4), 16);
|
|
|
|
var b = parseInt(hex.length == 3 ? hex.slice(2, 3).repeat(2) : hex.slice(4, 6), 16);
|
2020-09-14 00:38:44 +03:00
|
|
|
if (alpha) {
|
|
|
|
return "rgba(" + r + ", " + g + ", " + b + ", " + alpha + ")";
|
|
|
|
} else {
|
|
|
|
return "rgb(" + r + ", " + g + ", " + b + ")";
|
|
|
|
}
|
2020-04-09 00:29:13 +03:00
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
export const copyText = (str) => {
|
|
|
|
const el = document.createElement("textarea");
|
|
|
|
el.value = str;
|
|
|
|
el.setAttribute("readonly", "");
|
|
|
|
el.style.position = "absolute";
|
|
|
|
el.style.left = "-9999px";
|
|
|
|
el.style.visibility = "hidden";
|
|
|
|
el.style.opacity = "0";
|
|
|
|
document.body.appendChild(el);
|
|
|
|
el.select();
|
|
|
|
document.execCommand("copy");
|
|
|
|
document.body.removeChild(el);
|
2020-02-19 09:30:47 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
return true;
|
2020-02-19 09:30:47 +03:00
|
|
|
};
|
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
// SOURCE(jim):
|
|
|
|
// https://gist.github.com/mathewbyrne/1280286
|
|
|
|
// modified to support chinese characters, base case, and german.
|
|
|
|
export const createSlug = (text, base = "untitled") => {
|
|
|
|
if (isEmpty(text)) {
|
|
|
|
return base;
|
2020-02-19 09:30:47 +03:00
|
|
|
}
|
|
|
|
|
2020-11-28 04:19:30 +03:00
|
|
|
text = text.toString().toLowerCase().trim();
|
2020-02-19 09:30:47 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
const sets = [
|
|
|
|
{ to: "a", from: "[ÀÁÂÃÅÆĀĂĄẠẢẤẦẨẪẬẮẰẲẴẶ]" },
|
|
|
|
{ to: "ae", from: "[Ä]" },
|
|
|
|
{ to: "c", from: "[ÇĆĈČ]" },
|
|
|
|
{ to: "d", from: "[ÐĎĐÞ]" },
|
|
|
|
{ to: "e", from: "[ÈÉÊËĒĔĖĘĚẸẺẼẾỀỂỄỆ]" },
|
|
|
|
{ to: "g", from: "[ĜĞĢǴ]" },
|
|
|
|
{ to: "h", from: "[ĤḦ]" },
|
|
|
|
{ to: "i", from: "[ÌÍÎÏĨĪĮİỈỊ]" },
|
|
|
|
{ to: "j", from: "[Ĵ]" },
|
|
|
|
{ to: "ij", from: "[IJ]" },
|
|
|
|
{ to: "k", from: "[Ķ]" },
|
|
|
|
{ to: "l", from: "[ĹĻĽŁ]" },
|
|
|
|
{ to: "m", from: "[Ḿ]" },
|
|
|
|
{ to: "n", from: "[ÑŃŅŇ]" },
|
|
|
|
{ to: "o", from: "[ÒÓÔÕØŌŎŐỌỎỐỒỔỖỘỚỜỞỠỢǪǬƠ]" },
|
|
|
|
{ to: "oe", from: "[΅]" },
|
|
|
|
{ to: "p", from: "[ṕ]" },
|
|
|
|
{ to: "r", from: "[ŔŖŘ]" },
|
|
|
|
{ to: "s", from: "[ŚŜŞŠ]" },
|
|
|
|
{ to: "ss", from: "[ß]" },
|
|
|
|
{ to: "t", from: "[ŢŤ]" },
|
|
|
|
{ to: "u", from: "[ÙÚÛŨŪŬŮŰŲỤỦỨỪỬỮỰƯ]" },
|
|
|
|
{ to: "ue", from: "[Ü]" },
|
|
|
|
{ to: "w", from: "[ẂŴẀẄ]" },
|
|
|
|
{ to: "x", from: "[ẍ]" },
|
|
|
|
{ to: "y", from: "[ÝŶŸỲỴỶỸ]" },
|
|
|
|
{ to: "z", from: "[ŹŻŽ]" },
|
|
|
|
{ to: "-", from: "[·/_,:;']" },
|
|
|
|
];
|
2020-02-19 09:30:47 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
sets.forEach((set) => {
|
|
|
|
text = text.replace(new RegExp(set.from, "gi"), set.to);
|
|
|
|
});
|
2020-04-09 00:29:13 +03:00
|
|
|
|
2020-09-14 00:38:44 +03:00
|
|
|
text = text
|
|
|
|
.toString()
|
|
|
|
.toLowerCase()
|
|
|
|
.replace(/\s+/g, "-") // Replace spaces with -
|
|
|
|
.replace(/&/g, "-and-") // Replace & with 'and'
|
|
|
|
.replace(/[^a-zA-Z0-9_\u3400-\u9FBF\s-]/g, "") // Remove all non-word chars
|
|
|
|
.replace(/\--+/g, "-") // Replace multiple - with single -
|
|
|
|
.replace(/^-+/, "") // Trim - from start of text
|
|
|
|
.replace(/-+$/, ""); // Trim - from end of text
|
|
|
|
|
|
|
|
return text;
|
2020-04-09 00:29:13 +03:00
|
|
|
};
|