2014-03-03 21:41:34 +00:00
|
|
|
/* jshint node:true, browser:true */
|
2014-10-09 12:10:36 +01:00
|
|
|
/* global Ember */
|
2014-03-20 13:52:16 +00:00
|
|
|
|
|
|
|
// Ghost Image Preview
|
|
|
|
//
|
|
|
|
// Manages the conversion of image markdown `![]()` from markdown into the HTML image preview
|
|
|
|
// This provides a dropzone and other interface elements for adding images
|
|
|
|
// Is only used in the admin client.
|
|
|
|
|
2014-03-17 22:01:29 +00:00
|
|
|
var Ghost = Ghost || {};
|
2013-05-11 17:44:25 +01:00
|
|
|
(function () {
|
2014-03-20 13:52:16 +00:00
|
|
|
var ghostimagepreview = function () {
|
2013-05-11 17:44:25 +01:00
|
|
|
return [
|
2013-08-20 21:16:40 +01:00
|
|
|
// ![] image syntax
|
2013-05-11 17:44:25 +01:00
|
|
|
{
|
|
|
|
type: 'lang',
|
2013-08-20 21:16:40 +01:00
|
|
|
filter: function (text) {
|
2013-09-01 22:03:01 +01:00
|
|
|
var imageMarkdownRegex = /^(?:\{<(.*?)>\})?!(?:\[([^\n\]]*)\])(?:\(([^\n\]]*)\))?$/gim,
|
|
|
|
/* regex from isURL in node-validator. Yum! */
|
|
|
|
uriRegex = /^(?!mailto:)(?:(?:https?|ftp):\/\/)?(?:\S+(?::\S*)?@)?(?:(?:(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[0-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]+-?)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})))|localhost)(?::\d{2,5})?(?:\/[^\s]*)?$/i,
|
|
|
|
pathRegex = /^(\/)?([^\/\0]+(\/)?)+$/i;
|
2013-08-19 22:52:50 +01:00
|
|
|
|
2013-09-01 22:03:01 +01:00
|
|
|
return text.replace(imageMarkdownRegex, function (match, key, alt, src) {
|
2014-03-17 22:01:29 +00:00
|
|
|
var result = '',
|
|
|
|
output;
|
2013-08-18 21:09:23 +01:00
|
|
|
|
2013-09-01 22:03:01 +01:00
|
|
|
if (src && (src.match(uriRegex) || src.match(pathRegex))) {
|
2013-08-18 21:09:23 +01:00
|
|
|
result = '<img class="js-upload-target" src="' + src + '"/>';
|
|
|
|
}
|
2014-03-17 22:01:29 +00:00
|
|
|
|
2014-06-23 21:17:57 -04:00
|
|
|
if ((Ghost && Ghost.touchEditor) || (typeof window !== 'undefined' && Ember.touchEditor)) {
|
2014-03-17 22:01:29 +00:00
|
|
|
output = '<section class="image-uploader">' +
|
|
|
|
result + '<div class="description">Mobile uploads coming soon</div></section>';
|
|
|
|
} else {
|
|
|
|
output = '<section id="image_upload_' + key + '" class="js-drop-zone image-uploader">' +
|
|
|
|
result + '<div class="description">Add image of <strong>' + alt + '</strong></div>' +
|
|
|
|
'<input data-url="upload" class="js-fileupload main fileupload" type="file" name="uploadimage">' +
|
|
|
|
'</section>';
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
2013-05-11 17:44:25 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
|
|
|
// Client-side export
|
|
|
|
if (typeof window !== 'undefined' && window.Showdown && window.Showdown.extensions) {
|
2014-03-20 13:52:16 +00:00
|
|
|
window.Showdown.extensions.ghostimagepreview = ghostimagepreview;
|
2013-05-11 17:44:25 +01:00
|
|
|
}
|
|
|
|
// Server-side export
|
2014-03-03 21:41:34 +00:00
|
|
|
if (typeof module !== 'undefined') {
|
2014-03-20 13:52:16 +00:00
|
|
|
module.exports = ghostimagepreview;
|
2014-03-03 21:41:34 +00:00
|
|
|
}
|
2013-10-16 12:44:30 -06:00
|
|
|
}());
|