autoformatted syntax
This commit is contained in:
		
							parent
							
								
									23625b4ba8
								
							
						
					
					
						commit
						3e475d162a
					
				
					 1 changed files with 280 additions and 238 deletions
				
			
		|  | @ -12,145 +12,166 @@ 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 = {}; | ||||
| 
 | ||||
| 	// Initialize the selected pref data.
 | ||||
| 	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) { | ||||
|       // Syntax of splitting is by commas.
 | ||||
|       DATA_NAME = String(DATA_NAME).trim().split(","); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 	// 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) { | ||||
| 			// Syntax of splitting is by commas.
 | ||||
| 			DATA_NAME = (String(DATA_NAME).trim()).split(","); | ||||
| 		} | ||||
| 	}; | ||||
| 
 | ||||
| 	/* | ||||
|   /* | ||||
| 		Find the data now. | ||||
| 
 | ||||
| 		@param {number} SOURCE the data source | ||||
| 	*/ | ||||
| 	function read_database(SOURCE = -1) { | ||||
| 		let data = {}; | ||||
| 		let data_returned; | ||||
|   function read_database(SOURCE = -1) { | ||||
|     let data = {}; | ||||
|     let data_returned; | ||||
| 
 | ||||
| 		async function read_database_local() { | ||||
| 			return new Promise((resolve, reject) => { | ||||
| 				chrome.storage.local.get(null, function(result) { | ||||
| 					if (chrome.runtime.lastError) { | ||||
| 						// Something went wrong
 | ||||
| 						reject(new Error(chrome.runtime.lastError)); | ||||
| 					} else { | ||||
| 						// If the key exists, return the value
 | ||||
| 						resolve(result); | ||||
| 					} | ||||
| 				}); | ||||
| 			}); | ||||
| 		}; | ||||
|     async function read_database_local() { | ||||
|       return new Promise((resolve, reject) => { | ||||
|         chrome.storage.local.get(null, function (result) { | ||||
|           if (chrome.runtime.lastError) { | ||||
|             // Something went wrong
 | ||||
|             reject(new Error(chrome.runtime.lastError)); | ||||
|           } else { | ||||
|             // If the key exists, return the value
 | ||||
|             resolve(result); | ||||
|           } | ||||
|         }); | ||||
|       }); | ||||
|     } | ||||
| 
 | ||||
| 		async function read_database_sync() { | ||||
| 			return new Promise((resolve, reject) => { | ||||
| 				chrome.storage.sync.get(null, function(result) { | ||||
| 					if (chrome.runtime.lastError) { | ||||
| 						// Something went wrong
 | ||||
| 						reject(new Error(chrome.runtime.lastError)); | ||||
| 					} else { | ||||
| 						// If the key exists, return the value
 | ||||
| 						resolve(result); | ||||
| 					} | ||||
| 				}); | ||||
| 			}); | ||||
| 		} | ||||
|     async function read_database_sync() { | ||||
|       return new Promise((resolve, reject) => { | ||||
|         chrome.storage.sync.get(null, function (result) { | ||||
|           if (chrome.runtime.lastError) { | ||||
|             // Something went wrong
 | ||||
|             reject(new Error(chrome.runtime.lastError)); | ||||
|           } else { | ||||
|             // If the key exists, return the value
 | ||||
|             resolve(result); | ||||
|           } | ||||
|         }); | ||||
|       }); | ||||
|     } | ||||
| 
 | ||||
| 		// Return the data.
 | ||||
| 		if (SOURCE > 0) { | ||||
| 			data_returned = read_database_sync(); | ||||
| 		} else { | ||||
| 			data_returned = read_database_local(); | ||||
| 		} | ||||
|     // Return the data.
 | ||||
|     if (SOURCE > 0) { | ||||
|       data_returned = read_database_sync(); | ||||
|     } else { | ||||
|       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. | ||||
|   /* Recursively find through each data, returning either that value or null when the object is not found. | ||||
| 
 | ||||
| 	@param {dictionary} DATA_ALL the data | ||||
| 	@param {object} DATA_PATH the path of the data | ||||
| 	@return {object} the data | ||||
| 	*/ | ||||
| 	function find_data(DATA_ALL, DATA_PATH, PARAMETER_TEST) { | ||||
| 		// Pull the data out.
 | ||||
| 		let DATA_PATH_SELECTED = String(DATA_PATH.shift()).trim(); | ||||
| 		let DATA_SELECTED = DATA_ALL; | ||||
|   function find_data(DATA_ALL, DATA_PATH, PARAMETER_TEST) { | ||||
|     // Pull the data out.
 | ||||
|     let DATA_PATH_SELECTED = String(DATA_PATH.shift()).trim(); | ||||
|     let DATA_SELECTED = DATA_ALL; | ||||
| 
 | ||||
| 		// Only run when the data is valid.
 | ||||
| 		if (DATA_ALL) { | ||||
| 			if (DATA_SELECTED) { | ||||
| 				// Get the selected data.
 | ||||
| 				DATA_SELECTED = DATA_ALL[DATA_PATH_SELECTED]; | ||||
|     // Only run when the data is valid.
 | ||||
|     if (DATA_ALL) { | ||||
|       if (DATA_SELECTED) { | ||||
|         // Get the selected data.
 | ||||
|         DATA_SELECTED = DATA_ALL[DATA_PATH_SELECTED]; | ||||
| 
 | ||||
| 				if (DATA_PATH.length > 0) { | ||||
| 					// Recursively run to make use of the existing data.
 | ||||
| 					DATA_SELECTED = find_data(DATA_SELECTED, DATA_PATH, PARAMETER_TEST); | ||||
| 				} | ||||
| 			} else if (PARAMETER_TEST && DATA_SELECTED) { | ||||
| 				let QUALIFIED = false; | ||||
|         if (DATA_PATH.length > 0) { | ||||
|           // Recursively run to make use of the existing data.
 | ||||
|           DATA_SELECTED = find_data(DATA_SELECTED, DATA_PATH, PARAMETER_TEST); | ||||
|         } | ||||
|       } else if (PARAMETER_TEST && DATA_SELECTED) { | ||||
|         let QUALIFIED = false; | ||||
| 
 | ||||
| 				// The expected keys are "field" and "test value"
 | ||||
| 				DATA_SELECTED_KEYS = Object.keys(DATA_SELECTED); | ||||
| 				if (PARAMETER_TEST[`field`] && PARAMETER_TEST[`test value`]) { | ||||
|         // 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`] | ||||
|               ]; | ||||
|             if (PARAMETER_TEST[`value`]) { | ||||
|               QUALIFIED = | ||||
|                 new RegExp(String(PARAMETER_TEST[`value`])).test( | ||||
|                   PARAMETER_TEST[`test value`], | ||||
|                 ) || | ||||
|                 PARAMETER_TEST[`test value`].includes(PARAMETER_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`]] | ||||
| 							if (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]]; | ||||
|               break; | ||||
|             } | ||||
|           } | ||||
| 
 | ||||
| 							if (QUALIFIED) { | ||||
| 								DATA_SELECTED = DATA_SELECTED[DATA_SELECTED_KEYS[DATA_SELECTED_KEY_INDEX]]; | ||||
| 								break; | ||||
| 							} | ||||
| 					} | ||||
|           if (!QUALIFIED) { | ||||
|             DATA_SELECTED = null; | ||||
|           } | ||||
|         } else { | ||||
|           // It is not valid, so do not return anything.
 | ||||
|           DATA_SELECTED = null; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
| 					if (!QUALIFIED) { | ||||
| 						DATA_SELECTED = null; | ||||
| 					} | ||||
| 				} else { | ||||
| 					// It is not valid, so do not return anything.
 | ||||
| 					DATA_SELECTED = null; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|     // Now return the data.
 | ||||
|     return DATA_SELECTED; | ||||
|   } | ||||
| 
 | ||||
| 		// Now return the data.
 | ||||
| 		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); | ||||
|   } | ||||
| 
 | ||||
| 	// 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) => { | ||||
|     if (DATA_ALL[DATA_SOURCE]) { | ||||
|       DATA[DATA_SOURCE] = DATA_NAME | ||||
|         ? find_data(DATA_ALL[DATA_SOURCE], DATA_NAME, PARAMETER_TEST) | ||||
|         : DATA_ALL[DATA_SOURCE]; | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
| 	// Let's get through everything and then determine which one has…
 | ||||
| 	(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]; | ||||
| 		} | ||||
| 	}); | ||||
|   // 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[`value`] = DATA[DATA_RETURNED[`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[`value`] = DATA[DATA_RETURNED[`source`]]; | ||||
| 
 | ||||
| 	return(DATA_RETURNED[`value`]); | ||||
|   return DATA_RETURNED[`value`]; | ||||
| } | ||||
| 
 | ||||
| /* Write the data on the selected prefname. | ||||
|  | @ -160,70 +181,76 @@ export async function read(DATA_NAME, CLOUD = 0, PARAMETER_TEST = null) { | |||
| @param {int} CLOUD store in the cloud; otherwise set to automatic | ||||
| */ | ||||
| export function write(PATH, DATA, CLOUD = -1) { | ||||
| 	let DATA_INJECTED = {}; | ||||
|   let DATA_INJECTED = {}; | ||||
| 
 | ||||
| 	/* Forcibly write the data to chrome database | ||||
|   /* Forcibly write the data to chrome database | ||||
| 
 | ||||
| 	@param {object} DATA the data | ||||
| 	@param {number} CLOUD the storage | ||||
| 	*/ | ||||
| 	function write_database(DATA, CLOUD = 0) { | ||||
| 		// If CLOUD is set to 0, it should automatically determine where the previous source of data was taken from.
 | ||||
|   function write_database(DATA, CLOUD = 0) { | ||||
|     // If CLOUD is set to 0, it should automatically determine where the previous source of data was taken from.
 | ||||
| 
 | ||||
| 		if (CLOUD > 0) { | ||||
| 			chrome.storage.sync.set(DATA); | ||||
| 		} else if (CLOUD < 0) { | ||||
| 			chrome.storage.local.set(DATA); | ||||
| 		}; | ||||
| 	}; | ||||
|     if (CLOUD > 0) { | ||||
|       chrome.storage.sync.set(DATA); | ||||
|     } else if (CLOUD < 0) { | ||||
|       chrome.storage.local.set(DATA); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| 	/* Appropriately nest and merge the data. | ||||
|   /* Appropriately nest and merge the data. | ||||
| 
 | ||||
| 	@param {object} EXISTING the original data | ||||
| 	@param {object} PATH the subpath | ||||
| 	@param {object} VALUE the value | ||||
| 	@return {object} the updated data | ||||
| 	*/ | ||||
| 	function nest(EXISTING, SUBPATH, VALUE) { | ||||
| 		let DATABASE = EXISTING; | ||||
|   function nest(EXISTING, SUBPATH, VALUE) { | ||||
|     let DATABASE = EXISTING; | ||||
| 
 | ||||
| 		// Get the current path.
 | ||||
| 		let PATH = {}; | ||||
| 		PATH[`current`] = String(SUBPATH.shift()).trim(); | ||||
| 		PATH[`target`] = SUBPATH; | ||||
|     // Get the current path.
 | ||||
|     let PATH = {}; | ||||
|     PATH[`current`] = String(SUBPATH.shift()).trim(); | ||||
|     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); | ||||
| 		} else { | ||||
| 			DATABASE[PATH[`current`]] = VALUE; | ||||
| 		}; | ||||
| 		// Return the value.
 | ||||
| 		return (DATABASE); | ||||
| 	}; | ||||
|     if (PATH[`target`].length > 0) { | ||||
|       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) => { | ||||
|   read(null, CLOUD).then((DATA_ALL) => { | ||||
|     // handle empty collected data.
 | ||||
|     if (!DATA_ALL) { | ||||
|       DATA_ALL = {}; | ||||
|     } | ||||
| 
 | ||||
| 		// handle empty collected data.
 | ||||
| 		if (!DATA_ALL) {DATA_ALL = {};} | ||||
|     let DATA_NAME = PATH; | ||||
| 
 | ||||
| 		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(","); | ||||
|     } | ||||
| 
 | ||||
| 		// 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(","); | ||||
| 		} | ||||
|     // Merge!
 | ||||
|     DATA_INJECTED = nest(DATA_ALL, DATA_NAME, DATA); | ||||
| 
 | ||||
| 		// Merge!
 | ||||
| 		DATA_INJECTED = nest(DATA_ALL, DATA_NAME, DATA); | ||||
| 
 | ||||
| 		// Write!
 | ||||
| 		write_database(DATA_INJECTED, CLOUD); | ||||
| 	}); | ||||
|     // Write!
 | ||||
|     write_database(DATA_INJECTED, CLOUD); | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /* Dangerous: Resets all data or a domain's data. | ||||
| 
 | ||||
| @param {string} preference the preference name to delete | ||||
|  | @ -232,53 +259,56 @@ export function write(PATH, DATA, CLOUD = -1) { | |||
| @return {boolean} the user's confirmation | ||||
| */ | ||||
| export function forget(preference, subpreference, CLOUD = 0) { | ||||
|   let forget_action = false; | ||||
| 
 | ||||
| 	let forget_action = false; | ||||
|   (async () => { | ||||
|     // Import alerts module.
 | ||||
|     let alerts = await import(chrome.runtime.getURL(`gui/scripts/alerts.js`)); | ||||
| 
 | ||||
| 	(async () => { | ||||
| 		// Import alerts module.
 | ||||
| 		let alerts = await import(chrome.runtime.getURL(`gui/scripts/alerts.js`)); | ||||
|     // Confirm the action.
 | ||||
|     let forget_action = alerts.confirm_action(); | ||||
| 
 | ||||
| 		// Confirm the action.
 | ||||
| 		let forget_action = alerts.confirm_action(); | ||||
|     if (forget_action) { | ||||
|       if (preference) { | ||||
|         if (subpreference) { | ||||
|           // Get the data.
 | ||||
|           data = read(preference, CLOUD); | ||||
| 
 | ||||
| 		if (forget_action) { | ||||
| 			if (preference) { | ||||
| 				if (subpreference) { | ||||
| 					// Get the data.
 | ||||
| 					data = read(preference, CLOUD); | ||||
|           // Should only run when existent
 | ||||
|           if (data[subpreference]) { | ||||
|             delete data[subpreference]; | ||||
|             write([preference, subpreference], data, CLOUD); | ||||
|           } | ||||
|         } else { | ||||
|           // Remove that particular data.
 | ||||
|           if (CLOUD <= 0) { | ||||
|             chrome.storage.local.get(null, (data) => { | ||||
|               delete data[preference]; | ||||
| 
 | ||||
| 					// Should only run when existent
 | ||||
| 					if (data[subpreference]) { | ||||
| 						delete data[subpreference]; | ||||
| 						write([preference, subpreference], data, CLOUD); | ||||
| 					} | ||||
| 				} else { | ||||
| 					// Remove that particular data.
 | ||||
| 					if (CLOUD <= 0) { | ||||
| 						chrome.storage.local.get(null, (data) => { | ||||
| 							delete data[preference]; | ||||
|               chrome.storage.local.set(data, (result) => {}); | ||||
|             }); | ||||
|           } | ||||
|           if (CLOUD >= 0) { | ||||
|             chrome.storage.sync.get(null, (data) => { | ||||
|               delete data[preference]; | ||||
| 
 | ||||
| 							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(); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   })(); | ||||
| 
 | ||||
| 							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();}; | ||||
| 			}; | ||||
| 		}; | ||||
| 	})(); | ||||
| 
 | ||||
| 	return (forget_action); | ||||
|   return forget_action; | ||||
| } | ||||
| 
 | ||||
| /* Initialize the storage. | ||||
|  | @ -286,57 +316,69 @@ export function forget(preference, subpreference, CLOUD = 0) { | |||
| @param {dictionary} data this build's managed data | ||||
| */ | ||||
| export function init(data) { | ||||
| 	let PREFERENCES_ALL = {}; | ||||
| 	PREFERENCES_ALL[`build`] = data; | ||||
|   let PREFERENCES_ALL = {}; | ||||
|   PREFERENCES_ALL[`build`] = data; | ||||
| 
 | ||||
| 	// Read all data.
 | ||||
| 	chrome.storage.managed.get(null, function(DATA_MANAGED){ | ||||
| 		PREFERENCES_ALL[`managed`] = DATA_MANAGED; | ||||
| 	}); | ||||
|   // Read all data.
 | ||||
|   chrome.storage.managed.get(null, function (DATA_MANAGED) { | ||||
|     PREFERENCES_ALL[`managed`] = DATA_MANAGED; | ||||
|   }); | ||||
| 
 | ||||
| 	chrome.storage.local.get(null, function(DATA_LOCAL){ | ||||
| 		PREFERENCES_ALL[`local`] = DATA_LOCAL; | ||||
| 	}); | ||||
|   chrome.storage.local.get(null, function (DATA_LOCAL) { | ||||
|     PREFERENCES_ALL[`local`] = DATA_LOCAL; | ||||
|   }); | ||||
| 
 | ||||
| 	chrome.storage.sync.get(null, function(DATA_SYNC){ | ||||
| 		PREFERENCES_ALL[`sync`] = DATA_SYNC; | ||||
| 	}); | ||||
|   chrome.storage.sync.get(null, function (DATA_SYNC) { | ||||
|     PREFERENCES_ALL[`sync`] = DATA_SYNC; | ||||
|   }); | ||||
| 
 | ||||
| 	// Merge data.
 | ||||
| 	// Managed > Synchronized > Imported > Local
 | ||||
|   // Merge data.
 | ||||
|   // Managed > Synchronized > Imported > Local
 | ||||
| 
 | ||||
| 	if (PREFERENCES_ALL[`managed`]) { | ||||
| 		(Object.keys(PREFERENCES_ALL[`managed`])).forEach((item) => { | ||||
| 			let PREFERENCE = {'name': item, 'existing': false}; | ||||
|   if (PREFERENCES_ALL[`managed`]) { | ||||
|     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`]); | ||||
| 			} | ||||
|       if (PREFERENCES_ALL[`sync`]) { | ||||
|         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`]]); | ||||
| 			} | ||||
|       if (!PREFERENCE[`existing`]) { | ||||
|         // Do not allow synchronized data to interfere with managed data.
 | ||||
|         forget(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 }; | ||||
| 
 | ||||
| 	// Import build data
 | ||||
| 	if (PREFERENCES_ALL[`build`]) { | ||||
| 		(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); | ||||
| 			} | ||||
| 
 | ||||
| 		}); | ||||
| 	} | ||||
|       if (!PREFERENCE[`existing`]) { | ||||
|         write( | ||||
|           PREFERENCE[`name`], | ||||
|           PREFERENCES_ALL[`build`][PREFERENCE[`name`]], | ||||
|           -1, | ||||
|         ); | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue