mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-13 14:39:52 +03:00
1007e8e5ad
Fixes #1899
144 lines
6.2 KiB
JavaScript
144 lines
6.2 KiB
JavaScript
/*global window, document, Ghost, $, _, Backbone, JST */
|
|
(function () {
|
|
"use strict";
|
|
|
|
Ghost.Views.Debug = Ghost.View.extend({
|
|
events: {
|
|
"click .settings-menu a": "handleMenuClick",
|
|
"click .js-delete": "handleDeleteClick"
|
|
},
|
|
|
|
initialize: function () {
|
|
// Disable import button and initizalize BlueImp file upload
|
|
$('#startupload').prop('disabled', true);
|
|
$('#importfile').fileupload({
|
|
url: Ghost.paths.apiRoot + '/db/',
|
|
limitMultiFileUploads: 1,
|
|
replaceFileInput: false,
|
|
headers: {
|
|
'X-CSRF-Token': $("meta[name='csrf-param']").attr('content')
|
|
},
|
|
dataType: 'json',
|
|
add: function (e, data) {
|
|
/*jslint unparam:true*/
|
|
// unregister click event to preveng duplicate binding
|
|
$('#startupload').off("click");
|
|
data.context = $('#startupload').prop('disabled', false)
|
|
.click(function () {
|
|
$('#startupload').prop('disabled', true);
|
|
data.context = $('#startupload').text('Importing');
|
|
data.submit();
|
|
// unregister click event to allow different subsequent uploads
|
|
$('#startupload').off('click');
|
|
});
|
|
},
|
|
done: function (e, data) {
|
|
/*jslint unparam:true*/
|
|
$('#startupload').text('Import');
|
|
if (!data.result) {
|
|
throw new Error('No response received from server.');
|
|
}
|
|
if (!data.result.message) {
|
|
throw new Error('Unknown error');
|
|
}
|
|
|
|
Ghost.notifications.addItem({
|
|
type: 'success',
|
|
message: data.result.message,
|
|
status: 'passive'
|
|
});
|
|
},
|
|
error: function (response) {
|
|
$('#startupload').text('Import');
|
|
var responseJSON = response.responseJSON,
|
|
message = responseJSON && responseJSON.error ? responseJSON.error : 'unknown';
|
|
Ghost.notifications.addItem({
|
|
type: 'error',
|
|
message: ['A problem was encountered while importing new content to your blog. Error: ', message].join(''),
|
|
status: 'passive'
|
|
});
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
handleMenuClick: function (ev) {
|
|
ev.preventDefault();
|
|
|
|
var $target = $(ev.currentTarget);
|
|
|
|
// Hide the current content
|
|
this.$(".settings-content").hide();
|
|
|
|
// Show the clicked content
|
|
this.$("#debug-" + $target.attr("class")).show();
|
|
|
|
return false;
|
|
},
|
|
|
|
handleDeleteClick: function (ev) {
|
|
ev.preventDefault();
|
|
this.addSubview(new Ghost.Views.Modal({
|
|
model: {
|
|
options: {
|
|
close: true,
|
|
confirm: {
|
|
accept: {
|
|
func: function () {
|
|
$.ajax({
|
|
url: Ghost.paths.apiRoot + '/db/',
|
|
type: 'DELETE',
|
|
headers: {
|
|
'X-CSRF-Token': $("meta[name='csrf-param']").attr('content')
|
|
},
|
|
success: function onSuccess(response) {
|
|
if (!response) {
|
|
throw new Error('No response received from server.');
|
|
}
|
|
if (!response.message) {
|
|
throw new Error(response.detail || 'Unknown error');
|
|
}
|
|
|
|
Ghost.notifications.addItem({
|
|
type: 'success',
|
|
message: response.message,
|
|
status: 'passive'
|
|
});
|
|
|
|
},
|
|
error: function onError(response) {
|
|
var responseText = JSON.parse(response.responseText),
|
|
message = responseText && responseText.error ? responseText.error : 'unknown';
|
|
Ghost.notifications.addItem({
|
|
type: 'error',
|
|
message: ['A problem was encountered while deleting content from your blog. Error: ', message].join(''),
|
|
status: 'passive'
|
|
});
|
|
|
|
}
|
|
});
|
|
},
|
|
text: "Yes"
|
|
},
|
|
reject: {
|
|
func: function () {
|
|
return true;
|
|
},
|
|
text: "No"
|
|
}
|
|
},
|
|
type: "action",
|
|
style: ["wide", "centered"],
|
|
animation: 'fade'
|
|
},
|
|
content: {
|
|
template: 'blank',
|
|
title: 'Would you really like to delete all content from your blog?',
|
|
text: '<p>This is permanent! No backups, no restores, no magic undo button. <br /> We warned you, ok?</p>'
|
|
}
|
|
}
|
|
}));
|
|
}
|
|
});
|
|
}()); |