Support for template

This commit is contained in:
benweet 2013-04-14 22:15:40 +01:00
parent d00b734017
commit b7b63b843c
8 changed files with 80 additions and 108 deletions

View File

@ -1 +1 @@
CACHE MANIFEST # v35 CACHE: index.html css/bootstrap.css css/jgrowl.css css/main.css js/main-min.js js/require.js NETWORK: *
CACHE MANIFEST # v36 CACHE: index.html css/bootstrap.css css/jgrowl.css css/main.css js/main-min.js js/require.js NETWORK: *

View File

@ -329,6 +329,9 @@ hr {
}
#modal-settings textarea {
max-width: 206px;
height: 150px;
height: 180px;
}
.tooltip-inner {
text-align: left;
}

View File

@ -488,10 +488,10 @@
<a target="_blank" href="http://requirejs.org/">RequireJS</a>
</dd>
<dd>
<a target="_blank" href="http://underscorejs.org/">Underscore.js</a>
<a target="_blank" href="http://layout.jquery-dev.net/">UI Layout</a>
</dd>
<dd>
<a target="_blank" href="http://layout.jquery-dev.net/">UI Layout</a>
<a target="_blank" href="http://underscorejs.org/">Underscore.js</a>
</dd>
</dl>
<p>Copyright 2013 <a target="_blank"

View File

@ -389,15 +389,15 @@ define(["jquery", "google-helper", "dropbox-helper", "github-helper", "synchroni
// Create a new publication on GitHub
function newPublishGithub(event) {
var publishObject = {};
publishObject.repository = core.getInputValue($("#input-publish-github-reponame"), event);
publishObject.branch = core.getInputValue($("#input-publish-github-branch"), event);
publishObject.path = core.getInputValue($("#input-publish-github-path"), event);
publishObject.provider = newPublishProvider;
var publishAttributes = {};
publishAttributes.repository = core.getInputValue($("#input-publish-github-reponame"), event);
publishAttributes.branch = core.getInputValue($("#input-publish-github-branch"), event);
publishAttributes.path = core.getInputValue($("#input-publish-github-path"), event);
publishAttributes.provider = newPublishProvider;
if(event.isPropagationStopped()) {
return;
}
publisher.newLocation(publishObject);
publisher.newLocation(publishAttributes);
}
// Create a new publication on Blogger

View File

@ -9,10 +9,10 @@ define(["jquery", "github-helper"], function($, githubHelper) {
providerName: "GitHub"
};
publishGithub.publish = function(publishObject, title, content, callback) {
publishGithub.publish = function(publishAttributes, title, content, callback) {
var commitMsg = core.settings.commitMsg;
githubHelper.upload(publishObject.repository, publishObject.branch,
publishObject.path, content, commitMsg, callback);
githubHelper.upload(publishAttributes.repository, publishAttributes.branch,
publishAttributes.path, content, commitMsg, callback);
};
publishGithub.init = function(coreModule) {

10
js/main-min.js vendored

File diff suppressed because one or more lines are too long

View File

@ -41,28 +41,34 @@ define(["jquery", "github-provider", "underscore"], function($) {
};
// Apply template to the current document
publisher.applyTemplate = function() {
publisher.applyTemplate = function(publishAttributes) {
var fileIndex = fileManager.getCurrentFileIndex();
return _.template(core.settings.template, {
documentTitle: localStorage[fileIndex + ".title"],
documentMarkdown: $("#wmd-input").val(),
documentHTML: $("#wmd-preview").html()
});
try {
return _.template(core.settings.template, {
documentTitle: localStorage[fileIndex + ".title"],
documentMarkdown: $("#wmd-input").val(),
documentHTML: $("#wmd-preview").html(),
publishAttributes: publishAttributes
});
} catch(e) {
core.showError(e);
throw e;
}
};
// Used to get content to publish
function getPublishContent(publishObject) {
if(publishObject.format === undefined) {
publishObject.format = $("input:radio[name=radio-publish-format]:checked").prop("value");
function getPublishContent(publishAttributes) {
if(publishAttributes.format === undefined) {
publishAttributes.format = $("input:radio[name=radio-publish-format]:checked").prop("value");
}
if(publishObject.format == "markdown") {
if(publishAttributes.format == "markdown") {
return $("#wmd-input").val();
}
else if(publishObject.format == "html") {
else if(publishAttributes.format == "html") {
return $("#wmd-preview").html();
}
else {
return publisher.applyTemplate();
return publisher.applyTemplate(publishAttributes);
}
}
@ -79,12 +85,12 @@ define(["jquery", "github-provider", "underscore"], function($) {
// Dequeue a synchronized location
var publishIndex = publishIndexList.pop();
var publishObject = JSON.parse(localStorage[publishIndex]);
var content = getPublishContent(publishObject);
var publishAttributes = JSON.parse(localStorage[publishIndex]);
var content = getPublishContent(publishAttributes);
// Call the provider
var provider = providerMap[publishObject.provider];
provider.publish(publishObject, publishTitle, content, function(error) {
var provider = providerMap[publishAttributes.provider];
provider.publish(publishAttributes, publishTitle, content, function(error) {
publishLocation(callback, errorFlag);
});
}
@ -105,30 +111,30 @@ define(["jquery", "github-provider", "underscore"], function($) {
publishRunning = false;
publisher.updatePublishButton();
if(errorFlag === undefined) {
core.showMessage('"' + title + '" successfully published.');
core.showMessage('"' + publishTitle + '" successfully published.');
}
});
};
// Generate a publishIndex associated to a fileIndex and store a publishObject
function createPublishIndex(fileIndex, publishObject) {
// Generate a publishIndex associated to a fileIndex and store publishAttributes
function createPublishIndex(fileIndex, publishAttributes) {
var publishIndex = undefined;
do {
publishIndex = "publish." + core.randomString();
} while(_.has(localStorage, publishIndex));
localStorage[publishIndex] = JSON.stringify(publishObject);
localStorage[publishIndex] = JSON.stringify(publishAttributes);
localStorage[fileIndex + ".publish"] += publishIndex + ";";
}
// Add a new publish location to a local document
publisher.newLocation = function(publishObject) {
publisher.newLocation = function(publishAttributes) {
var fileIndex = fileManager.getCurrentFileIndex();
var title = localStorage[fileIndex + ".title"];
var content = getPublishContent(publishObject);
var provider = providerMap[publishObject.provider];
provider.publish(publishObject, title, content, function(error) {
var content = getPublishContent(publishAttributes);
var provider = providerMap[publishAttributes.provider];
provider.publish(publishAttributes, title, content, function(error) {
if(error === undefined) {
createPublishIndex(fileIndex, publishObject);
createPublishIndex(fileIndex, publishAttributes);
publisher.notifyPublish();
core.showMessage('"' + title
+ '" will now be published on GitHub.');
@ -155,10 +161,10 @@ define(["jquery", "github-provider", "underscore"], function($) {
}
_.each(publishIndexList, function(publishIndex) {
var serializedObject = localStorage[publishIndex];
var publishObject = JSON.parse(serializedObject);
var publishDesc = JSON.stringify(_.omit(publishObject, 'provider')).replace(/{|}|"/g, "");
var publishAttributes = JSON.parse(serializedObject);
var publishDesc = JSON.stringify(_.omit(publishAttributes, 'provider')).replace(/{|}|"/g, "");
lineElement = $(_.template(lineTemplate, {
provider: providerMap[publishObject.provider],
provider: providerMap[publishAttributes.provider],
publishDesc: publishDesc
}));
lineElement.append($(removeButtonTemplate).click(function() {
@ -184,9 +190,30 @@ define(["jquery", "github-provider", "underscore"], function($) {
});
$(".tooltip-template").tooltip({
title: ['Variables:\n',
'documentTitle: the document title'
].join("")
html: true,
container: '#modal-settings',
placement: 'right',
trigger: 'manual',
title: ['Available variables:<br>',
'<ul><li><b>documentTitle</b>: document title</li>',
'<li><b>documentMarkdown</b>: document in Markdown format</li>',
'<li><b>documentHTML</b>: document in HTML format</li>',
'<li><b>publishAttributes</b>: attributes of the publish location (undefined when using "Save")</li></ul>',
'Examples:<br>',
_.escape('<title><%= documentTitle %></title>'),
'<br>',
_.escape('<div><%- documentHTML %></div>'),
'<br>',
_.escape('<% if(publishAttributes.provider == "github") print(documentMarkdown); %>'),
'<br><br><a target="_blank" href="http://underscorejs.org/#template">More info</a>',
].join("")
}).click(function(e) {
$(this).tooltip('show');
e.stopPropagation();
});
$(document).click(function(e) {
$(".tooltip-template").tooltip('hide');
});
};

View File

@ -1,58 +0,0 @@
<!DOCTYPE html>
<html>
<head>
<title>README.md</title>
</head>
<body><h1>StackEdit</h1>
<p>StackEdit is a free, open-source Markdown editor based on PageDown, the Markdown library used by Stack Overflow and the other Stack Exchange sites.</p>
<h3>StackEdit can:</h3>
<ul>
<li>Manage multiple Markdown documents locally</li>
<li>Export your documents in Markdown or HTML format</li>
<li>Synchronize your Markdown documents in the Cloud</li>
<li>Edit existing Markdown documents from Google Drive and Dropbox</li>
<li>Publish your document on GitHub in one click</li>
</ul>
<h3>Features:</h3>
<ul>
<li>Real-time HTML preview</li>
<li>WYSIWYG control buttons</li>
<li>Configurable layout</li>
<li>Offline editing</li>
<li>Online synchronization using Google Drive and Dropbox</li>
<li>Publish on GitHub</li>
</ul>
<blockquote>
<p><strong>NOTE:</strong> This page has been written with <a href="http://benweet.github.io/stackedit/" title="StackEdit">StackEdit</a>.</p>
</blockquote>StackEdit
=========
StackEdit is a free, open-source Markdown editor based on PageDown, the Markdown library used by Stack Overflow and the other Stack Exchange sites.
### StackEdit can:
- Manage multiple Markdown documents locally
- Export your documents in Markdown or HTML format
- Synchronize your Markdown documents in the Cloud
- Edit existing Markdown documents from Google Drive and Dropbox
- Publish your document on GitHub in one click
### Features:
- Real-time HTML preview
- WYSIWYG control buttons
- Configurable layout
- Offline editing
- Online synchronization using Google Drive and Dropbox
- Publish on GitHub
> **NOTE:** This page has been written with [StackEdit][1].
[1]: http://benweet.github.io/stackedit/ "StackEdit"</body>
</html>