autoformatted syntax

This commit is contained in:
buzz-lightsnack-2007 2024-03-28 11:14:52 +08:00
parent 23625b4ba8
commit 3e475d162a

View file

@ -12,18 +12,19 @@ import logging from "/gui/scripts/logging.JS";
@return {object} the data
*/
export async function read(DATA_NAME, CLOUD = 0, PARAMETER_TEST = null) {
// Initialize the selected pref data.
let DATA = {}, DATA_ALL = {}, DATA_RETURNED = {};
let DATA = {},
DATA_ALL = {},
DATA_RETURNED = {};
// Convert the entered prefname to an array if it is not one.
if (!(typeof DATA_NAME).includes(`object`)) {
// Avoid null
if (((typeof DATA_NAME).includes(`str`)) ? DATA_NAME.trim() : DATA_NAME) {
if ((typeof DATA_NAME).includes(`str`) ? DATA_NAME.trim() : DATA_NAME) {
// Syntax of splitting is by commas.
DATA_NAME = (String(DATA_NAME).trim()).split(",");
DATA_NAME = String(DATA_NAME).trim().split(",");
}
}
};
/*
Find the data now.
@ -46,7 +47,7 @@ export async function read(DATA_NAME, CLOUD = 0, PARAMETER_TEST = null) {
}
});
});
};
}
async function read_database_sync() {
return new Promise((resolve, reject) => {
@ -69,8 +70,8 @@ export async function read(DATA_NAME, CLOUD = 0, PARAMETER_TEST = null) {
data_returned = read_database_local();
}
return(data_returned);
};
return data_returned;
}
/* Recursively find through each data, returning either that value or null when the object is not found.
@ -99,16 +100,27 @@ export async function read(DATA_NAME, CLOUD = 0, PARAMETER_TEST = null) {
// The expected keys are "field" and "test value"
DATA_SELECTED_KEYS = Object.keys(DATA_SELECTED);
if (PARAMETER_TEST[`field`] && PARAMETER_TEST[`test value`]) {
// Perform a sequential search.
for (let DATA_SELECTED_KEY_INDEX = 0; ((DATA_SELECTED_KEY_INDEX < DATA_SELECTED_KEYS.length) || (!QUALIFIED)); DATA_SELECTED_KEY_INDEX++) {
PARAMETER_TEST[`value`] = DATA_SELECTED[DATA_SELECTED_KEYS[DATA_SELECTED_KEY_INDEX]][PARAMETER_TEST[`field`]]
for (
let DATA_SELECTED_KEY_INDEX = 0;
DATA_SELECTED_KEY_INDEX < DATA_SELECTED_KEYS.length || !QUALIFIED;
DATA_SELECTED_KEY_INDEX++
) {
PARAMETER_TEST[`value`] =
DATA_SELECTED[DATA_SELECTED_KEYS[DATA_SELECTED_KEY_INDEX]][
PARAMETER_TEST[`field`]
];
if (PARAMETER_TEST[`value`]) {
QUALIFIED = (((new RegExp(String(PARAMETER_TEST[`value`])).test(PARAMETER_TEST[`test value`])) || (PARAMETER_TEST[`test value`].includes(PARAMETER_TEST[`value`]))));
};
QUALIFIED =
new RegExp(String(PARAMETER_TEST[`value`])).test(
PARAMETER_TEST[`test value`],
) ||
PARAMETER_TEST[`test value`].includes(PARAMETER_TEST[`value`]);
}
if (QUALIFIED) {
DATA_SELECTED = DATA_SELECTED[DATA_SELECTED_KEYS[DATA_SELECTED_KEY_INDEX]];
DATA_SELECTED =
DATA_SELECTED[DATA_SELECTED_KEYS[DATA_SELECTED_KEY_INDEX]];
break;
}
}
@ -124,33 +136,42 @@ export async function read(DATA_NAME, CLOUD = 0, PARAMETER_TEST = null) {
}
// Now return the data.
return (DATA_SELECTED);
return DATA_SELECTED;
}
// Read data from local and sync storage (asynchronous operations)
try {
if (CLOUD <= 0) {
[DATA_ALL[`local`]] = await Promise.all([read_database(-1)]);
};
}
if (CLOUD >= 0) {
[DATA_ALL[`sync`]] = await Promise.all([read_database(1)]);
};
}
} catch ({ name, message }) {
logging.error(name, message);
};
}
// Let's get through everything and then determine which one has…
(Object.keys(DATA_ALL)).forEach((DATA_SOURCE) => {
Object.keys(DATA_ALL).forEach((DATA_SOURCE) => {
if (DATA_ALL[DATA_SOURCE]) {
DATA[DATA_SOURCE] = (DATA_NAME) ? find_data(DATA_ALL[DATA_SOURCE], DATA_NAME, PARAMETER_TEST) : DATA_ALL[DATA_SOURCE];
DATA[DATA_SOURCE] = DATA_NAME
? find_data(DATA_ALL[DATA_SOURCE], DATA_NAME, PARAMETER_TEST)
: DATA_ALL[DATA_SOURCE];
}
});
// Now return the data.
DATA_RETURNED[`source`] = (CLOUD != 0) ? ((CLOUD > 0) ? `sync` : `local`) : (((DATA[`sync`]) ? (DATA[`sync`].length <= 0) : (DATA[`sync`])) ? `sync` : `local`)
DATA_RETURNED[`source`] =
CLOUD != 0
? CLOUD > 0
? `sync`
: `local`
: (DATA[`sync`] ? DATA[`sync`].length <= 0 : DATA[`sync`])
? `sync`
: `local`;
DATA_RETURNED[`value`] = DATA[DATA_RETURNED[`source`]];
return(DATA_RETURNED[`value`]);
return DATA_RETURNED[`value`];
}
/* Write the data on the selected prefname.
@ -174,8 +195,8 @@ export function write(PATH, DATA, CLOUD = -1) {
chrome.storage.sync.set(DATA);
} else if (CLOUD < 0) {
chrome.storage.local.set(DATA);
};
};
}
}
/* Appropriately nest and merge the data.
@ -193,26 +214,33 @@ export function write(PATH, DATA, CLOUD = -1) {
PATH[`target`] = SUBPATH;
if (PATH[`target`].length > 0) {
if (DATABASE[PATH[`current`]] == null) {DATABASE[PATH[`current`]] = {}};
DATABASE[PATH[`current`]] = nest(DATABASE[PATH[`current`]], PATH[`target`], VALUE);
if (DATABASE[PATH[`current`]] == null) {
DATABASE[PATH[`current`]] = {};
}
DATABASE[PATH[`current`]] = nest(
DATABASE[PATH[`current`]],
PATH[`target`],
VALUE,
);
} else {
DATABASE[PATH[`current`]] = VALUE;
};
}
// Return the value.
return (DATABASE);
};
(read(null, CLOUD)).then((DATA_ALL) => {
return DATABASE;
}
read(null, CLOUD).then((DATA_ALL) => {
// handle empty collected data.
if (!DATA_ALL) {DATA_ALL = {};}
if (!DATA_ALL) {
DATA_ALL = {};
}
let DATA_NAME = PATH;
// Convert the entered prefname to an array if it is not one.
if (!(typeof SUBPATH).includes(`object`)) {
// Split what is not an object.
DATA_NAME = (String(PATH).trim()).split(",");
DATA_NAME = String(PATH).trim().split(",");
}
// Merge!
@ -223,7 +251,6 @@ export function write(PATH, DATA, CLOUD = -1) {
});
}
/* Dangerous: Resets all data or a domain's data.
@param {string} preference the preference name to delete
@ -232,7 +259,6 @@ export function write(PATH, DATA, CLOUD = -1) {
@return {boolean} the user's confirmation
*/
export function forget(preference, subpreference, CLOUD = 0) {
let forget_action = false;
(async () => {
@ -261,24 +287,28 @@ export function forget(preference, subpreference, CLOUD = 0) {
chrome.storage.local.set(data, (result) => {});
});
};
}
if (CLOUD >= 0) {
chrome.storage.sync.get(null, (data) => {
delete data[preference];
chrome.storage.sync.set(data, (result) => {});
});
};
};
}
}
} else {
// Clear the data storage.
if (CLOUD >= 0) {chrome.storage.sync.clear();};
if (CLOUD <= 0) {chrome.storage.local.clear();};
};
};
if (CLOUD >= 0) {
chrome.storage.sync.clear();
}
if (CLOUD <= 0) {
chrome.storage.local.clear();
}
}
}
})();
return (forget_action);
return forget_action;
}
/* Initialize the storage.
@ -306,37 +336,49 @@ export function init(data) {
// Managed > Synchronized > Imported > Local
if (PREFERENCES_ALL[`managed`]) {
(Object.keys(PREFERENCES_ALL[`managed`])).forEach((item) => {
let PREFERENCE = {'name': item, 'existing': false};
Object.keys(PREFERENCES_ALL[`managed`]).forEach((item) => {
let PREFERENCE = { name: item, existing: false };
if (PREFERENCES_ALL[`sync`]) {
PREFERENCE[`existing`] = (PREFERENCES_ALL[`sync`]).hasOwnProperty(PREFERENCE[`name`]);
PREFERENCE[`existing`] = PREFERENCES_ALL[`sync`].hasOwnProperty(
PREFERENCE[`name`],
);
}
if (!PREFERENCE[`existing`]) {
// Do not allow synchronized data to interfere with managed data.
forget(PREFERENCE[`name`]);
write(PREFERENCE[`name`], PREFERENCES_ALL[`managed`][PREFERENCE[`name`]]);
write(
PREFERENCE[`name`],
PREFERENCES_ALL[`managed`][PREFERENCE[`name`]],
);
}
});
}
// Import build data
if (PREFERENCES_ALL[`build`]) {
(Object.keys(PREFERENCES_ALL[`build`])).forEach((item) => {
let PREFERENCE = {'name': item, 'existing': false};
Object.keys(PREFERENCES_ALL[`build`]).forEach((item) => {
let PREFERENCE = { name: item, existing: false };
PREFERENCE[`existing`] = (
((PREFERENCES_ALL[`sync`]) ? (PREFERENCES_ALL[`sync`]).hasOwnProperty(PREFERENCE[`name`]) : false) ||
((PREFERENCES_ALL[`managed`]) ? (PREFERENCES_ALL[`managed`]).hasOwnProperty(PREFERENCE[`name`]) : false) ||
((PREFERENCES_ALL[`local`]) ? (PREFERENCES_ALL[`local`]).hasOwnProperty(PREFERENCE[`local`]) : false)
);
PREFERENCE[`existing`] =
(PREFERENCES_ALL[`sync`]
? PREFERENCES_ALL[`sync`].hasOwnProperty(PREFERENCE[`name`])
: false) ||
(PREFERENCES_ALL[`managed`]
? PREFERENCES_ALL[`managed`].hasOwnProperty(PREFERENCE[`name`])
: false) ||
(PREFERENCES_ALL[`local`]
? PREFERENCES_ALL[`local`].hasOwnProperty(PREFERENCE[`local`])
: false);
if (!PREFERENCE[`existing`]) {
write(PREFERENCE[`name`], PREFERENCES_ALL[`build`][PREFERENCE[`name`]], -1);
write(
PREFERENCE[`name`],
PREFERENCES_ALL[`build`][PREFERENCE[`name`]],
-1,
);
}
});
}
}