stylus/backup/fileSaveLoad.js

105 lines
2.9 KiB
JavaScript
Raw Normal View History

2017-02-05 06:25:44 +00:00
/* globals getStyles, saveStyle */
2017-02-03 09:24:47 +00:00
'use strict';
2017-01-30 19:02:50 +00:00
2017-02-05 06:25:44 +00:00
var STYLISH_DUMP_FILE_EXT = '.txt';
var STYLISH_DUMPFILE_EXTENSION = '.json';
2017-02-03 09:24:47 +00:00
var STYLISH_DEFAULT_SAVE_NAME = 'stylus-mm-dd-yyy' + STYLISH_DUMP_FILE_EXT;
2017-01-30 19:02:50 +00:00
2017-02-03 09:24:47 +00:00
function saveAsFile (text, fileName, dialog) {
fileName = fileName || STYLISH_DEFAULT_SAVE_NAME;
dialog = typeof dialog === 'boolean' ? dialog : true;
return new Promise(function (resolve) {
var fileContent = 'data:text/plain;charset=utf-8,' + encodeURIComponent(text);
chrome.downloads.download({
filename: fileName,
saveAs: true,
url: fileContent
}, resolve);
});
2017-01-30 19:02:50 +00:00
}
/**
* !!works only when page has representation - backgound page won't work
*
* opens open file dialog,
* gets selected file,
* gets it's path,
* gets content of it by ajax
*/
2017-02-03 09:24:47 +00:00
function loadFromFile (formatToFilter) {
return new Promise(function (resolve) {
var fileInput = document.createElement('input');
fileInput.style = 'display: none;';
fileInput.type = 'file';
fileInput.accept = formatToFilter || STYLISH_DUMP_FILE_EXT;
fileInput.acceptCharset = 'utf-8';
2017-01-30 19:02:50 +00:00
2017-02-03 09:24:47 +00:00
document.body.appendChild(fileInput);
fileInput.initialValue = fileInput.value;
function changeHandler() {
if (fileInput.value !== fileInput.initialValue) {
var fReader = new FileReader();
fReader.onloadend = function (event) {
fileInput.removeEventListener('change', changeHandler);
fileInput.remove();
resolve(event.target.result);
};
fReader.readAsText(fileInput.files[0], 'utf-8');
}
}
fileInput.addEventListener('change', changeHandler);
fileInput.click();
});
2017-02-03 09:17:26 +00:00
}
2017-02-05 06:25:44 +00:00
function generateFileName() {
var today = new Date();
var dd = '0' + today.getDate();
var mm = '0' + (today.getMonth() + 1);
var yyyy = today.getFullYear();
dd = dd.substr(-2);
mm = mm.substr(-2);
today = mm + '-' + dd + '-' + yyyy;
return 'stylus-' + today + STYLISH_DUMPFILE_EXTENSION;
}
document.getElementById('file-all-styles').addEventListener('click', function () {
chrome.permissions.request({permissions: ['downloads']}, function (granted) {
if (granted) {
getStyles({}, function (styles) {
var text = JSON.stringify(styles);
saveAsFile(text, generateFileName());
});
}
});
});
document.getElementById('unfile-all-styles').addEventListener('click', function () {
loadFromFile(STYLISH_DUMPFILE_EXTENSION).then(function (rawText) {
var json = JSON.parse(rawText);
var i = 0, nextStyle;
function done() {
window.alert(i + ' styles installed/updated');
location.reload();
}
function proceed() {
nextStyle = json[i++];
if (nextStyle) {
saveStyle(nextStyle, proceed);
}
else {
i--;
done();
}
}
proceed();
});
});