Ports cleanup
- Remove duplicate platform specific (from src/) and other unnecessary files - Fix and update vapi-*.js files for Safari - Add tools/make-safari.sh - Move js/vapi-appinfo.js to meta/ (so, every vendor specific file will be at the same location)pull/2/head
parent
e6e3868080
commit
e54c09da8a
@ -1,131 +0,0 @@
|
||||
// » header
|
||||
// could be used for background and other extension pages
|
||||
|
||||
(function() {
|
||||
'use strict';
|
||||
|
||||
self.vAPI = self.vAPI || {};
|
||||
|
||||
// http://www.w3.org/International/questions/qa-scripts#directions
|
||||
var setScriptDirection = function(langugae) {
|
||||
document.body.setAttribute(
|
||||
'dir',
|
||||
~['ar', 'he', 'fa', 'ps', 'ur'].indexOf(langugae) ? 'rtl' : 'ltr'
|
||||
);
|
||||
};
|
||||
|
||||
vAPI.download = function(details) {
|
||||
if (!details.url) {
|
||||
return;
|
||||
}
|
||||
|
||||
var a = document.createElement('a');
|
||||
|
||||
if ('download' in a) {
|
||||
a.href = details.url;
|
||||
a.setAttribute('download', details.filename || '');
|
||||
a.dispatchEvent(new MouseEvent('click'));
|
||||
}
|
||||
else {
|
||||
var messager = vAPI.messaging.channel('_download');
|
||||
messager.send({
|
||||
what: 'gotoURL',
|
||||
details: {
|
||||
url: details.url,
|
||||
index: -1
|
||||
}
|
||||
});
|
||||
messager.close();
|
||||
}
|
||||
};
|
||||
// «
|
||||
|
||||
if (self.chrome) {
|
||||
// » crx
|
||||
var chrome = self.chrome;
|
||||
|
||||
vAPI.getURL = function(path) {
|
||||
return chrome.runtime.getURL(path);
|
||||
};
|
||||
|
||||
vAPI.i18n = function(s) {
|
||||
return chrome.i18n.getMessage(s) || s;
|
||||
};
|
||||
|
||||
setScriptDirection(vAPI.i18n('@@ui_locale'));
|
||||
// «
|
||||
} else if (self.safari) {
|
||||
// » safariextz
|
||||
vAPI.getURL = function(path) {
|
||||
return safari.extension.baseURI + path;
|
||||
};
|
||||
|
||||
var xhr = new XMLHttpRequest;
|
||||
xhr.overrideMimeType('application/json;charset=utf-8');
|
||||
xhr.open('GET', './locales.json', false);
|
||||
xhr.send();
|
||||
vAPI.i18nData = JSON.parse(xhr.responseText);
|
||||
|
||||
if (vAPI.i18nData[vAPI.i18n = navigator.language.replace('-', '_')]
|
||||
|| vAPI.i18nData[vAPI.i18n = vAPI.i18n.slice(0, 2)]) {
|
||||
vAPI.i18nLocale = vAPI.i18n;
|
||||
} else {
|
||||
vAPI.i18nLocale = vAPI.i18nData._;
|
||||
}
|
||||
|
||||
xhr = new XMLHttpRequest;
|
||||
xhr.overrideMimeType('application/json;charset=utf-8');
|
||||
xhr.open('GET', './_locales/' + vAPI.i18nLocale + '/messages.json', false);
|
||||
xhr.send();
|
||||
vAPI.i18nData = JSON.parse(xhr.responseText);
|
||||
|
||||
for (var i18nKey in vAPI.i18nData) {
|
||||
vAPI.i18nData[i18nKey] = vAPI.i18nData[i18nKey].message;
|
||||
}
|
||||
|
||||
vAPI.i18n = function(s) {
|
||||
return this.i18nData[s] || s;
|
||||
};
|
||||
|
||||
setScriptDirection(vAPI.i18nLocale);
|
||||
|
||||
// update popover size to its content
|
||||
if (safari.self.identifier === 'popover' && safari.self) {
|
||||
window.addEventListener('load', function() {
|
||||
// Initial dimensions are set in Info.plist
|
||||
var pWidth = safari.self.width;
|
||||
var pHeight = safari.self.height;
|
||||
var upadteTimer = null;
|
||||
var resizePopover = function() {
|
||||
if (upadteTimer) {
|
||||
return;
|
||||
}
|
||||
|
||||
upadteTimer = setTimeout(function() {
|
||||
safari.self.width = Math.max(pWidth, document.body.clientWidth);
|
||||
safari.self.height = Math.max(pHeight, document.body.clientHeight);
|
||||
upadteTimer = null;
|
||||
}, 20);
|
||||
};
|
||||
|
||||
var mutObs = window.MutationObserver || window.WebkitMutationObserver;
|
||||
|
||||
if (mutObs) {
|
||||
(new mutObs(resizePopover)).observe(document, {
|
||||
childList: true,
|
||||
attributes: true,
|
||||
characterData: true,
|
||||
subtree: true
|
||||
});
|
||||
}
|
||||
else {
|
||||
// Safari doesn't support DOMAttrModified
|
||||
document.addEventListener('DOMSubtreeModified', resizePopover);
|
||||
}
|
||||
});
|
||||
}
|
||||
// «
|
||||
}
|
||||
// » footer
|
||||
})();
|
||||
// «
|
Loading…
Reference in New Issue