2013-12-23 18:27:33 +00:00
|
|
|
chrome.version = window.navigator.appVersion.match(/Chrome\/(\d+)/)[1] * 1 || 0;
|
|
|
|
|
2013-09-13 22:57:57 +00:00
|
|
|
require([
|
2013-12-04 17:24:04 +00:00
|
|
|
"command",
|
2014-01-21 06:14:46 +00:00
|
|
|
"storage/settingsProvider",
|
2013-12-04 17:24:04 +00:00
|
|
|
"ui/dialog",
|
2014-04-04 16:42:31 +00:00
|
|
|
"sessions",
|
|
|
|
"util/manos",
|
2013-12-04 17:24:04 +00:00
|
|
|
"ui/projectManager",
|
|
|
|
"ui/keys",
|
|
|
|
"fileManager",
|
|
|
|
"ui/menus",
|
|
|
|
"ui/palette",
|
2014-04-04 06:45:19 +00:00
|
|
|
"ui/cli",
|
2013-12-04 18:52:56 +00:00
|
|
|
"api",
|
|
|
|
"storage/syncfile"
|
2014-04-04 16:42:31 +00:00
|
|
|
], function(command, Settings, dialog, sessions, M) {
|
2013-08-20 00:53:03 +00:00
|
|
|
|
2013-08-23 23:03:46 +00:00
|
|
|
var frame = chrome.app.window.current();
|
|
|
|
|
2013-09-13 22:57:57 +00:00
|
|
|
var setTheme = function() {
|
2014-01-21 06:14:46 +00:00
|
|
|
Settings.pull("user").then(function(data) {
|
|
|
|
var themes = {
|
|
|
|
"dark": "css/caret-dark.css",
|
|
|
|
"light": "css/caret.css"
|
|
|
|
};
|
|
|
|
var theme = data.user.uiTheme || "light";
|
|
|
|
var url = themes[theme] || themes.dark;
|
|
|
|
document.find("#theme").setAttribute("href", url);
|
|
|
|
});
|
2013-09-13 22:57:57 +00:00
|
|
|
}
|
2014-02-27 06:34:02 +00:00
|
|
|
setTheme();
|
2014-01-12 23:35:30 +00:00
|
|
|
|
2014-02-27 06:34:02 +00:00
|
|
|
//these are modules that must be loaded before init:complete
|
2014-01-12 23:35:30 +00:00
|
|
|
var loadedModules = {
|
|
|
|
"editor": false,
|
|
|
|
"fileManager": false,
|
|
|
|
"sessions": false
|
|
|
|
};
|
2013-09-13 22:57:57 +00:00
|
|
|
|
2013-09-02 01:28:31 +00:00
|
|
|
//the settings manager may also fire init:restart to re-init components after startup
|
2014-01-12 23:35:30 +00:00
|
|
|
command.fire("init:startup", function(mod) {
|
|
|
|
//ignore callback in non-essential modules
|
|
|
|
if (typeof loadedModules[mod] == "undefined") return;
|
|
|
|
loadedModules[mod] = true;
|
|
|
|
for (var key in loadedModules) {
|
|
|
|
if (!loadedModules[key]) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//all specified modules are loaded, app is ready for init:complete
|
|
|
|
command.fire("init:complete");
|
|
|
|
});
|
2013-09-13 22:57:57 +00:00
|
|
|
command.on("init:restart", setTheme);
|
2013-09-02 01:26:22 +00:00
|
|
|
|
2014-02-27 06:34:02 +00:00
|
|
|
//code to enable update checking
|
2013-10-28 21:02:11 +00:00
|
|
|
var updateID = "caret:update";
|
|
|
|
|
2013-11-06 20:18:50 +00:00
|
|
|
var checkUpdates = function(isManual) {
|
|
|
|
chrome.runtime.requestUpdateCheck(function(status, details) {
|
|
|
|
if (status == "update_available") {
|
2013-12-16 18:44:11 +00:00
|
|
|
chrome.runtime.onUpdateAvailable.addListener(function() {
|
|
|
|
chrome.notifications.create(updateID, {
|
|
|
|
type: "basic",
|
|
|
|
iconUrl: "icon-128.png",
|
|
|
|
title: "Caret: Update Available",
|
|
|
|
message: "An update to Caret version " + details.version + " is available. Would you like to update and restart now?",
|
|
|
|
buttons: [ { title: "Yes, update and restart" }, { title: "No thanks" }]
|
|
|
|
}, function(id) { updateID = id });
|
|
|
|
});
|
2013-11-06 20:18:50 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2014-01-21 06:14:46 +00:00
|
|
|
Settings.pull("user").then(function(cfg) {
|
|
|
|
if (cfg.user.promptForUpdates !== false) checkUpdates();
|
|
|
|
});
|
2013-11-06 20:18:50 +00:00
|
|
|
command.on("app:check-for-updates", checkUpdates);
|
2013-10-28 21:02:11 +00:00
|
|
|
|
|
|
|
chrome.notifications.onButtonClicked.addListener(function(id, index) {
|
|
|
|
if (id != updateID) return;
|
|
|
|
if (index == 0) {
|
|
|
|
chrome.runtime.reload();
|
2013-09-16 17:22:49 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-02-27 06:34:02 +00:00
|
|
|
command.on("app:exit", function() {
|
2014-04-04 16:42:31 +00:00
|
|
|
var cancelled = false;
|
|
|
|
var tabs = sessions.getAllTabs();
|
|
|
|
M.serial(tabs, function(tab, c) {
|
|
|
|
if (!tab.file || (tab.file && tab.modified)) {
|
|
|
|
return dialog(
|
|
|
|
tab.fileName + " has unsaved work.",
|
|
|
|
[
|
|
|
|
{ label: "Save", value: "save", shortcut: "s" },
|
|
|
|
{ label: "Discard", value: "discard", shortcut: "n" },
|
|
|
|
{ label: "Cancel", value: "cancel", shortcut: "c" }
|
|
|
|
],
|
|
|
|
function(value) {
|
|
|
|
if (!value || value == "cancel") {
|
|
|
|
cancelled = true;
|
|
|
|
}
|
|
|
|
if (value == "save") {
|
|
|
|
return tab.save(c);
|
|
|
|
}
|
|
|
|
c();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
c();
|
|
|
|
}, function() {
|
|
|
|
if (!cancelled) frame.close();
|
|
|
|
})
|
2014-02-27 06:34:02 +00:00
|
|
|
});
|
|
|
|
|
2014-04-03 22:06:30 +00:00
|
|
|
command.on("app:minimize", function() {
|
|
|
|
frame.minimize();
|
|
|
|
});
|
|
|
|
|
|
|
|
command.on("app:maximize", function() {
|
2014-04-04 16:13:54 +00:00
|
|
|
frame.isMaximized() || frame.isFullscreen() ? frame.restore() : frame.fullscreen();
|
|
|
|
});
|
2014-04-03 22:06:30 +00:00
|
|
|
|
2014-03-25 02:22:52 +00:00
|
|
|
//It's nice to be able to launch the debugger from a command stroke
|
|
|
|
command.on("app:debug", function() {
|
|
|
|
debugger;
|
|
|
|
});
|
|
|
|
|
2014-03-25 02:29:56 +00:00
|
|
|
command.on("app:restart", function() {
|
|
|
|
chrome.runtime.reload();
|
2014-04-04 16:13:54 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
//handle immersive fullscreen
|
|
|
|
frame.onFullscreened.addListener(function() {
|
|
|
|
Settings.pull("user").then(function(user) {
|
|
|
|
if (user.immersiveFullscreen) {
|
|
|
|
document.find("body").addClass("immersive");
|
|
|
|
}
|
2014-04-04 16:16:35 +00:00
|
|
|
});
|
2014-04-04 16:13:54 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
frame.onRestored.addListener(function() {
|
|
|
|
document.find("body").removeClass("immersive");
|
|
|
|
});
|
2014-03-25 02:29:56 +00:00
|
|
|
|
2013-08-20 00:53:03 +00:00
|
|
|
});
|