2020-02-01 04:25:41 +00:00
|
|
|
const message1 = "[ Session Name ] Allowed: a-z, A-Z, 0-9, -, _";
|
2020-02-01 02:43:21 +00:00
|
|
|
const message2 = "Allowed: a-z, A-Z, 0-9, -, _ Please try again...\nName too long or none provided; or, unacceptable character used.";
|
|
|
|
const storageApi = browser.storage.local;
|
|
|
|
const tabsApi = browser.tabs;
|
|
|
|
const windowApi = browser.windows;
|
|
|
|
const regexp = /^[a-zA-Z0-9-_]+$/; // Alphanumeric, dash, underscore
|
|
|
|
|
|
|
|
|
2020-02-01 04:25:41 +00:00
|
|
|
const saveSession = (elm = null, name = null, message = message1) => {
|
2020-02-01 02:43:21 +00:00
|
|
|
let inputTag = document.createElement("INPUT");
|
|
|
|
let willReplace = false;
|
|
|
|
inputTag.value = new Date().toLocaleString().split(',')[0].replace(/\//g, '-');
|
|
|
|
|
|
|
|
if (elm !== null) {
|
2020-02-01 04:25:41 +00:00
|
|
|
inputTag.value = name;
|
2020-02-01 02:43:21 +00:00
|
|
|
willReplace = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
windowApi.getAll({ populate: true, windowTypes: ["normal"] }).then((windows) => {
|
|
|
|
let sessionData = getSessionData(windows);
|
|
|
|
let keys = Object.keys(sessionData);
|
|
|
|
let keysLength = Object.keys(sessionData).length;
|
|
|
|
let container = generateSelectionWindow(sessionData, keys, keysLength);
|
2020-02-26 08:21:16 +00:00
|
|
|
let textTag = document.createTextNode(message);
|
|
|
|
let brTag = document.createElement("BR");
|
2020-02-01 02:43:21 +00:00
|
|
|
|
2020-02-26 08:21:16 +00:00
|
|
|
container.prepend(inputTag);
|
|
|
|
container.prepend(brTag);
|
|
|
|
container.prepend(message);
|
|
|
|
|
|
|
|
Swal.fire({
|
|
|
|
html: container,
|
|
|
|
showCloseButton: true,
|
|
|
|
showCancelButton: true,
|
|
|
|
customClass: 'swal-modal',
|
|
|
|
}).then((result) => {
|
|
|
|
if (result.value) {
|
2020-02-01 02:43:21 +00:00
|
|
|
let enteryName = inputTag.value.replace(/ /g, "_");
|
|
|
|
|
|
|
|
if (enteryName.length < 0 || enteryName.length > 54 || enteryName.search(regexp) == -1) {
|
2020-02-01 06:59:29 +00:00
|
|
|
saveSession(elm, name, message2);
|
2020-02-01 02:43:21 +00:00
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log("Saving session...");
|
|
|
|
sessionData = getSelectionData(container, keys, keysLength);
|
2020-02-01 06:59:29 +00:00
|
|
|
saveToStorage(enteryName, JSON.stringify(sessionData), "save", willReplace, elm);
|
2020-02-01 02:43:21 +00:00
|
|
|
} else {
|
|
|
|
messageWindow("warning", "Canceled save...");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-02-01 04:25:41 +00:00
|
|
|
const editSession = (elm = null, name = null, message = message1) => {
|
|
|
|
let id = name;
|
|
|
|
let inputTag = document.createElement("INPUT");
|
2020-02-01 03:34:46 +00:00
|
|
|
let newSessionTag = document.createElement("INPUT");
|
2020-02-01 04:25:41 +00:00
|
|
|
let labelTag = document.createElement("LABEL");
|
|
|
|
let brTag = document.createElement("BR");
|
2020-02-26 08:21:16 +00:00
|
|
|
let brTag2 = document.createElement("BR");
|
2020-02-01 02:43:21 +00:00
|
|
|
|
2020-02-01 04:25:41 +00:00
|
|
|
inputTag.value = id;
|
2020-02-01 03:34:46 +00:00
|
|
|
newSessionTag.type = "checkbox";
|
|
|
|
newSessionTag.id = "newSession";
|
|
|
|
newSessionTag.checked = false;
|
2020-02-01 04:25:41 +00:00
|
|
|
labelTag.innerText = "Create New Session";
|
|
|
|
labelTag.htmlFor = "newSession";
|
2020-02-01 02:43:21 +00:00
|
|
|
|
|
|
|
storageApi.get(id).then((results) => {
|
2020-02-01 06:59:29 +00:00
|
|
|
let json = null;
|
|
|
|
let keys = null;
|
|
|
|
let keysLength = null;
|
|
|
|
|
|
|
|
try {
|
|
|
|
json = JSON.parse(results[id]);
|
|
|
|
keys = Object.keys(json);
|
|
|
|
keysLength = Object.keys(json).length;
|
|
|
|
} catch (e) {
|
|
|
|
messageWindow("warning", "Canceled edit; couldn't load any data...");
|
2020-02-26 08:21:16 +00:00
|
|
|
return ;
|
2020-02-01 06:59:29 +00:00
|
|
|
}
|
2020-02-26 08:21:16 +00:00
|
|
|
|
2020-02-01 02:43:21 +00:00
|
|
|
let container = generateSelectionWindow(json, keys, keysLength);
|
2020-02-26 08:21:16 +00:00
|
|
|
let textTag = document.createTextNode(message);
|
|
|
|
|
2020-02-01 02:43:21 +00:00
|
|
|
container.prepend(labelTag);
|
2020-02-01 03:34:46 +00:00
|
|
|
container.prepend(newSessionTag);
|
2020-02-01 02:43:21 +00:00
|
|
|
container.prepend(brTag);
|
|
|
|
container.prepend(inputTag);
|
2020-02-26 08:21:16 +00:00
|
|
|
container.prepend(brTag2);
|
|
|
|
container.prepend(message);
|
2020-02-01 02:43:21 +00:00
|
|
|
|
|
|
|
console.log("Editing session...");
|
2020-02-26 08:21:16 +00:00
|
|
|
Swal.fire({
|
|
|
|
html: container,
|
|
|
|
showCloseButton: true,
|
|
|
|
showCancelButton: true,
|
|
|
|
customClass: 'swal-modal',
|
|
|
|
}).then((result) => {
|
|
|
|
if (result.value) {
|
2020-02-01 02:43:21 +00:00
|
|
|
let newName = inputTag.value.replace(/ /g, "_");
|
|
|
|
|
|
|
|
if (newName.length < 0 || newName.length > 54 || newName.search(regexp) == -1) {
|
2020-02-01 06:59:29 +00:00
|
|
|
editSession(elm, name, message2);
|
2020-02-01 02:43:21 +00:00
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
2020-02-01 06:59:29 +00:00
|
|
|
json = getSelectionData(container, keys, keysLength);
|
|
|
|
const strData = JSON.stringify(json);
|
2020-02-01 04:25:41 +00:00
|
|
|
if (newSessionTag.checked) { // If creating new session
|
2020-02-01 06:59:29 +00:00
|
|
|
newName = checkSessionListForDuplicate(newName);
|
|
|
|
saveToStorage(newName, strData, "save", false, elm);
|
2020-02-01 02:43:21 +00:00
|
|
|
} else {
|
2020-02-01 04:25:41 +00:00
|
|
|
if (newName == name) { // If not creating new session and are the same name
|
2020-02-01 03:34:46 +00:00
|
|
|
storageApi.get(id).then((results) => {
|
|
|
|
storageApi.remove(id);
|
2020-02-01 06:59:29 +00:00
|
|
|
saveToStorage(newName, strData, "edit", true, elm);
|
|
|
|
}).then(() => {
|
|
|
|
const size = getStoreSize(strData);
|
|
|
|
elm.innerText = size + " | " + newName;
|
|
|
|
elm.setAttribute("name", newName);
|
|
|
|
});
|
2020-02-01 03:34:46 +00:00
|
|
|
} else { // If not creating new session and names are not the same rename
|
2020-02-01 02:43:21 +00:00
|
|
|
storageApi.get(id).then((results) => {
|
2020-02-01 03:34:46 +00:00
|
|
|
newName = checkSessionListForDuplicate(newName);
|
2020-02-01 06:59:29 +00:00
|
|
|
storageApi.remove(id);
|
|
|
|
saveToStorage(newName, strData, "edit", false, elm);
|
|
|
|
}).then(() => {
|
|
|
|
const size = getStoreSize(strData);
|
|
|
|
elm.innerText = size + " | " + newName;
|
|
|
|
elm.setAttribute("name", newName);
|
|
|
|
});
|
2020-02-01 02:43:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
messageWindow("warning", "Canceled edit...");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-02-01 04:25:41 +00:00
|
|
|
const downloadSession = (session = null) => {
|
2020-02-01 02:43:21 +00:00
|
|
|
let pTag = document.createElement("P");
|
|
|
|
let inputTag = document.createElement("INPUT");
|
|
|
|
let chkBoxTag = document.createElement("INPUT");
|
|
|
|
let lblTag = document.createElement("LABEL");
|
|
|
|
let brTag = document.createElement("BR");
|
|
|
|
let aTagElm = document.getElementById('downloadAnchorElem');
|
|
|
|
let text = document.createTextNode("Append Date?");
|
2020-02-01 04:25:41 +00:00
|
|
|
let fileName = "session:" + session + ".json";
|
|
|
|
let id = session;
|
2020-02-01 02:43:21 +00:00
|
|
|
chkBoxTag.type = "checkbox";
|
|
|
|
inputTag.value = fileName;
|
|
|
|
chkBoxTag.id = "chkbx";
|
|
|
|
lblTag.htmlFor = "chkbx";
|
|
|
|
lblTag.append(text);
|
|
|
|
pTag.append(lblTag);
|
|
|
|
pTag.append(chkBoxTag);
|
|
|
|
pTag.append(brTag);
|
|
|
|
pTag.append(inputTag);
|
|
|
|
|
2020-02-26 08:21:16 +00:00
|
|
|
Swal.fire({
|
|
|
|
text: "Download Session?",
|
|
|
|
html: pTag,
|
|
|
|
showCloseButton: true,
|
|
|
|
showCancelButton: true,
|
|
|
|
customClass: 'swal-modal',
|
2020-02-01 02:43:21 +00:00
|
|
|
}).then((willDl) => {
|
2020-02-26 08:21:16 +00:00
|
|
|
if (willDl.value) {
|
2020-02-01 02:43:21 +00:00
|
|
|
if (chkBoxTag.checked) {
|
2020-02-01 04:25:41 +00:00
|
|
|
fileName = "session:" + id + ":" + new Date().toLocaleString()
|
|
|
|
.split(',')[0]
|
|
|
|
.replace(/\//g, "-") + ".json";
|
2020-02-01 02:43:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
storageApi.get(id).then((results) => {
|
|
|
|
let json = JSON.parse(results[id]);
|
|
|
|
let dataStr = "data:text/json;charset=utf-8," + encodeURIComponent(JSON.stringify(json));
|
2020-02-01 04:25:41 +00:00
|
|
|
console.log("Downloading: " + id);
|
2020-02-01 02:43:21 +00:00
|
|
|
doUrlAction(dataStr, fileName, true);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const preLoadSession = (id) => {
|
|
|
|
storageApi.get(id).then(results => {
|
|
|
|
try {
|
|
|
|
let json = JSON.parse(results[id]);
|
|
|
|
let keys = Object.keys(json);
|
|
|
|
let keysLength = Object.keys(json).length;
|
|
|
|
let replaceTabs = document.getElementsByName("replaceTabs")[0];
|
|
|
|
let selectiveOpen = document.getElementsByName("selectiveOpen")[0];
|
|
|
|
|
|
|
|
if (!selectiveOpen.checked) {
|
|
|
|
loadSession(json, replaceTabs.checked);
|
|
|
|
} else {
|
|
|
|
let container = generateSelectionWindow(json, keys, keysLength);
|
2020-02-26 08:21:16 +00:00
|
|
|
Swal.fire({
|
|
|
|
text: "Selective Open",
|
|
|
|
html: container,
|
|
|
|
showCloseButton: true,
|
|
|
|
showCancelButton: true,
|
2020-02-01 02:43:21 +00:00
|
|
|
}).then((willOpen) => {
|
2020-02-26 08:21:16 +00:00
|
|
|
if (willOpen.value) {
|
2020-02-01 02:43:21 +00:00
|
|
|
json = getSelectionData(container, keys, keysLength);
|
|
|
|
keysLength = Object.keys(json).length;
|
|
|
|
if (keysLength > 0) {
|
|
|
|
loadSession(json, replaceTabs.checked);
|
|
|
|
} else {
|
|
|
|
messageWindow("warning", "Canceled Operation: No tabs were selected...");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
messageWindow("error", "Couldn't load session:\n" + e);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const loadSession = (json = null, replaceTabs = false) => {
|
|
|
|
let keys = Object.keys(json);
|
|
|
|
let keysLength = Object.keys(json).length;
|
|
|
|
try {
|
|
|
|
browser.windows.getAll().then(windows => {
|
|
|
|
windowApi.getCurrent({populate: true}).then(currentWindow => {
|
|
|
|
let wasCurrentTabId = null;
|
|
|
|
|
|
|
|
if (replaceTabs) { // Clear all windows but main then load...
|
|
|
|
if (keysLength == 0) {
|
|
|
|
messageWindow("error", "Canceled operation; no tabs in session...");
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (let i = 0; i < windows.length; i++) {
|
|
|
|
if (currentWindow.id != windows[i].id) {
|
|
|
|
windowApi.remove(windows[i].id);
|
|
|
|
} else {
|
|
|
|
let ids = [];
|
|
|
|
currentWindow.tabs.forEach(tab => {
|
|
|
|
if (!tab.active) {
|
|
|
|
ids.push(tab.id);
|
|
|
|
} else {
|
|
|
|
wasCurrentTabId = tab.id;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
tabsApi.remove(ids);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// First load tabs to current window.
|
|
|
|
let store = json[keys[0]];
|
|
|
|
store.forEach(tab => {
|
|
|
|
tabsApi.create({ url: tab.link });
|
|
|
|
});
|
|
|
|
tabsApi.remove(wasCurrentTabId);
|
|
|
|
|
|
|
|
// If more than one window, load tabs to new windows.
|
|
|
|
if (keysLength > 1) {
|
|
|
|
windowMaker(1, keysLength, keys, json)
|
|
|
|
}
|
|
|
|
} else { // Load into new windows...
|
|
|
|
if (keysLength == 1) {
|
|
|
|
windowMaker(0, keysLength, keys, json)
|
|
|
|
} else if (keysLength == 0) {
|
|
|
|
messageWindow("error", "Canceled operation; no tabs in session...");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
} catch (e) {
|
|
|
|
messageWindow("error", "Couldn't load session:\n" + e);
|
|
|
|
}
|
|
|
|
}
|