Stackedit/js/main.js

292 lines
8.9 KiB
JavaScript
Raw Normal View History

2013-03-24 19:42:15 +00:00
function showError(msg) {
alert(msg);
}
2013-03-24 14:54:26 +00:00
2013-03-24 19:42:15 +00:00
var fileManager = (function($) {
2013-03-24 14:54:26 +00:00
var fileManager = {};
fileManager.init = function() {
2013-03-24 23:21:55 +00:00
fileManager.selectFile();
2013-03-24 14:54:26 +00:00
window.setInterval(function() {
fileManager.saveFile();
}, 5000);
$(".action-create-file").click(function() {
2013-03-24 23:21:55 +00:00
fileManager.saveFile();
fileManager.createFile();
fileManager.selectFile();
});
$(".action-remove-file").click(function() {
fileManager.deleteFile();
fileManager.selectFile();
});
2013-03-24 23:21:55 +00:00
$("#file-title").click(function() {
$(this).hide();
$("#file-title-input").show().focus();
});
$("#file-title-input").blur(function() {
var title = $.trim($(this).val());
2013-03-26 23:32:36 +00:00
if (title) {
2013-03-25 12:03:22 +00:00
var fileIndex = localStorage["file.current"];
2013-03-24 23:21:55 +00:00
localStorage[fileIndex + ".title"] = title;
}
$(this).hide();
$("#file-title").show();
fileManager.updateFileDescList();
2013-03-25 12:03:22 +00:00
fileManager.updateFileTitleUI();
2013-03-24 23:21:55 +00:00
});
2013-03-24 14:54:26 +00:00
};
2013-03-26 23:32:36 +00:00
2013-03-24 23:21:55 +00:00
fileManager.selectFile = function() {
// If file system does not exist
2013-03-26 23:32:36 +00:00
if (!localStorage["file.count"]) {
2013-03-24 23:21:55 +00:00
localStorage.clear();
localStorage["file.count"] = 0;
}
this.updateFileDescList();
2013-03-24 23:21:55 +00:00
// If no file create one
2013-03-26 23:32:36 +00:00
if (this.fileDescList.length === 0) {
2013-03-24 23:21:55 +00:00
this.createFile();
this.updateFileDescList();
2013-03-24 23:21:55 +00:00
}
// If no default file take first one
2013-03-26 23:32:36 +00:00
if (!localStorage["file.current"]) {
localStorage["file.current"] = this.fileDescList[0].index;
2013-03-24 23:21:55 +00:00
}
// Update the editor and the file title
var fileIndex = localStorage["file.current"];
$("#wmd-input").val(localStorage[fileIndex + ".content"]);
2013-03-25 23:17:34 +00:00
createEditor();
2013-03-26 23:32:36 +00:00
this.updateFileTitleUI();
2013-03-24 14:54:26 +00:00
};
2013-03-24 23:21:55 +00:00
fileManager.createFile = function(title) {
2013-03-26 23:32:36 +00:00
if (!title) {
2013-03-25 23:17:34 +00:00
title = "Filename";
2013-03-24 23:21:55 +00:00
}
// Find a fileIndex
var fileCount = parseInt(localStorage["file.count"]);
var i;
2013-03-26 23:32:36 +00:00
for (i = 0; i < fileCount; i++) {
if (!localStorage["file." + i + ".title"]) {
break;
}
}
var fileIndex = "file." + i;
// Create the file in the localStorag
2013-03-24 23:21:55 +00:00
localStorage[fileIndex + ".content"] = "";
localStorage[fileIndex + ".title"] = title;
2013-03-24 23:21:55 +00:00
localStorage["file.current"] = fileIndex;
2013-03-26 23:32:36 +00:00
if (i == fileCount) {
localStorage["file.count"] = fileCount + 1;
}
};
2013-03-26 23:32:36 +00:00
fileManager.deleteFile = function() {
var fileIndex = localStorage["file.current"];
localStorage.removeItem("file.current");
localStorage.removeItem(fileIndex + ".title");
localStorage.removeItem(fileIndex + ".content");
2013-03-24 23:21:55 +00:00
};
2013-03-26 23:32:36 +00:00
fileManager.updateFileDescList = function() {
2013-03-24 23:21:55 +00:00
var fileCount = parseInt(localStorage["file.count"]);
var lastIndex = -1;
this.fileDescList = [];
2013-03-24 23:21:55 +00:00
$("#file-selector").empty();
2013-03-26 23:32:36 +00:00
for ( var i = 0; i < fileCount; i++) {
2013-03-24 23:21:55 +00:00
var fileIndex = "file." + i;
var title = localStorage[fileIndex + ".title"];
2013-03-26 23:32:36 +00:00
if (title) {
lastIndex = i;
2013-03-26 23:32:36 +00:00
this.fileDescList
.push({ "index" : fileIndex, "title" : title });
2013-03-25 12:03:22 +00:00
}
}
localStorage["file.count"] = lastIndex + 1;
this.fileDescList.sort(function(a, b) {
if (a.title.toLowerCase() < b.title.toLowerCase())
return -1;
if (a.title.toLowerCase() > b.title.toLowerCase())
return 1;
return 0;
});
2013-03-25 12:03:22 +00:00
};
2013-03-26 23:32:36 +00:00
fileManager.updateFileTitleUI = function() {
// Update the editor and the file title
2013-03-25 12:03:22 +00:00
var fileIndex = localStorage["file.current"];
var title = localStorage[fileIndex + ".title"];
document.title = "StackEdit - " + title;
$(".file-title").text(title);
2013-03-25 12:03:22 +00:00
$("#file-title-input").val(title);
$("#file-selector").empty();
2013-03-26 23:32:36 +00:00
for ( var i = 0; i < this.fileDescList.length; i++) {
var fileDesc = this.fileDescList[i];
var a = $("<a>").text(fileDesc.title);
var li = $("<li>").append(a);
2013-03-26 23:32:36 +00:00
if (fileDesc.index == fileIndex) {
li.addClass("disabled");
2013-03-26 23:32:36 +00:00
} else {
a.attr("href", "javascript:void(0);").click(
(function(fileIndex) {
return function() {
localStorage["file.current"] = fileIndex;
fileManager.selectFile();
};
})(fileDesc.index));
}
$("#file-selector").append(li);
2013-03-24 23:21:55 +00:00
}
2013-03-26 23:32:36 +00:00
};
2013-03-24 14:54:26 +00:00
fileManager.saveFile = function() {
2013-03-24 23:21:55 +00:00
var content = $("#wmd-input").val();
var fileIndex = localStorage["file.current"];
localStorage[fileIndex + ".content"] = content;
2013-03-26 23:32:36 +00:00
// insertFile(this.currentFile, this.content);
2013-03-24 19:42:15 +00:00
};
return fileManager;
})(jQuery);
var gdrive = (function($) {
var CLIENT_ID = '241271498917-jpto9lls9fqnem1e4h6ppds9uob8rpvu.apps.googleusercontent.com';
var SCOPES = [ 'https://www.googleapis.com/auth/drive.install',
'https://www.googleapis.com/auth/drive.file' ];
var driveEnabled = false;
var gdrive = {};
gdrive.init = function() {
function start() {
driveEnabled = true;
try {
var state = JSON.parse(decodeURI((/state=(.+?)(&|$)/
.exec(location.search) || [ , null ])[1]));
if (state.action == 'create') {
2013-03-26 23:32:36 +00:00
gdrive.createFile(state.folderId, fileManager.currentFile,
fileManager.content);
2013-03-24 19:42:15 +00:00
}
} catch (e) {
}
}
function handleAuthResult(authResult) {
if (authResult && !authResult.error) {
$("#drive-link").hide();
gapi.client.load('drive', 'v2', function() {
start();
});
}
}
$("#drive-link").click(
function() {
gapi.auth.authorize({ 'client_id' : CLIENT_ID,
'scope' : SCOPES, 'immediate' : false }, handleAuthResult);
});
gapi.auth.authorize({ 'client_id' : CLIENT_ID, 'scope' : SCOPES,
'immediate' : true }, handleAuthResult);
2013-03-24 14:54:26 +00:00
};
2013-03-24 19:42:15 +00:00
gdrive.createFile = function(folderId, title, content) {
2013-03-26 22:48:35 +00:00
var boundary = '-------314159265358979323846';
var delimiter = "\r\n--" + boundary + "\r\n";
var close_delim = "\r\n--" + boundary + "--";
2013-03-24 19:42:15 +00:00
var contentType = 'text/x-markdown';
2013-03-26 23:32:36 +00:00
var metadata = { 'title' : title, 'mimeType' : contentType,
'parents' : [ { 'kind' : 'drive#fileLink', 'id' : folderId } ] };
2013-03-24 19:42:15 +00:00
var base64Data = btoa(content);
var multipartRequestBody = delimiter
+ 'Content-Type: application/json\r\n\r\n'
+ JSON.stringify(metadata) + delimiter + 'Content-Type: '
+ contentType + '\r\n' + 'Content-Transfer-Encoding: base64\r\n'
+ '\r\n' + base64Data + close_delim;
var request = gapi.client.request({
'path' : '/upload/drive/v2/files',
'method' : 'POST',
'params' : { 'uploadType' : 'multipart', },
'headers' : { 'Content-Type' : 'multipart/mixed; boundary="'
+ boundary + '"', }, 'body' : multipartRequestBody, });
2013-03-24 20:30:06 +00:00
request.execute(function(file) {
console.log(file);
});
2013-03-24 19:42:15 +00:00
};
return gdrive;
})(jQuery);
2013-03-25 23:17:34 +00:00
function createEditor() {
$("#wmd-button-bar").empty();
2013-03-26 23:32:36 +00:00
var converter = Markdown.getSanitizingConverter();
var editor = new Markdown.Editor(converter);
editor.run();
$(".wmd-button-row").addClass("btn-group").find("li:not(.wmd-spacer)")
.addClass("btn").css("left", 0).find("span").hide();
$("#wmd-bold-button").append($("<i>").addClass("icon-bold"));
$("#wmd-italic-button").append($("<i>").addClass("icon-italic"));
$("#wmd-link-button").append($("<i>").addClass("icon-globe"));
$("#wmd-quote-button").append($("<i>").addClass("icon-indent-left"));
$("#wmd-code-button").append($("<i>").addClass("icon-code"));
$("#wmd-image-button").append($("<i>").addClass("icon-picture"));
$("#wmd-olist-button").append($("<i>").addClass("icon-numbered-list"));
$("#wmd-ulist-button").append($("<i>").addClass("icon-list"));
$("#wmd-heading-button").append($("<i>").addClass("icon-text-height"));
$("#wmd-hr-button").append($("<i>").addClass("icon-hr"));
$("#wmd-undo-button").append($("<i>").addClass("icon-undo"));
$("#wmd-redo-button").append($("<i>").addClass("icon-share-alt"));
}
var layoutOrientation = 0;
var layout;
function createLayout() {
var layoutGlobalConfig = { closable : true, resizable : false,
slidable : false, livePaneResizing : true, spacing_open : 20,
spacing_closed : 20, togglerLength_open : 90,
2013-03-26 23:32:36 +00:00
togglerLength_closed : 90, center__minWidth : 100, center__minHeight : 100,
stateManagement__enabled : false, };
if (layoutOrientation === 0) {
2013-03-26 23:32:36 +00:00
$(".ui-layout-east").addClass("well").attr("id", "wmd-preview");
layout = $('body').layout(
$.extend(layoutGlobalConfig,
{ east__resizable : true, east__size : .5, east__minSize : 200,
south__closable : false, }));
2013-03-26 23:32:36 +00:00
} else if (layoutOrientation === 1) {
$(".ui-layout-east").remove();
$(".ui-layout-south").addClass("well").attr("id", "wmd-preview");
layout = $('body').layout(
$.extend(layoutGlobalConfig, { south__resizable : true,
south__size : .5, south__minSize : 200, }));
}
2013-03-26 23:32:36 +00:00
$(".ui-layout-toggler-north").addClass("btn").append(
$("<b>").addClass("caret"));
$(".ui-layout-toggler-south").addClass("btn").append(
$("<b>").addClass("caret"));
$(".ui-layout-toggler-east").addClass("btn").append(
$("<b>").addClass("caret"));
2013-03-25 23:17:34 +00:00
}
2013-03-25 12:03:22 +00:00
2013-03-24 19:42:15 +00:00
(function($) {
$(function() {
2013-03-25 12:03:22 +00:00
createLayout();
2013-03-24 19:42:15 +00:00
if (typeof (Storage) !== "undefined") {
fileManager.init();
} else {
showError("Web storage is not available");
}
$("#navbar").click(function() {
layout.allowOverflow('north');
});
2013-03-24 19:42:15 +00:00
});
2013-03-24 14:54:26 +00:00
})(jQuery);