2018-10-31 12:00:31 -04:00
|
|
|
import DataUtils, { REQUEST_TYPE_GET, REQUEST_TYPE_PUT, REQUEST_TYPE_POST, REQUEST_TYPE_DELETE, CONTENT_TYPE_JSON, CONTENT_TYPE_FORM } from '../tools/utilities/DataUtils';
|
|
|
|
import * as DataEvent from '../tools/events/DataEvent';
|
|
|
|
import StringUtils from '../tools/utilities/StringUtils';
|
|
|
|
class EntryTasks {
|
|
|
|
//--------------------------
|
|
|
|
// constructor
|
|
|
|
//--------------------------
|
|
|
|
constructor() {
|
|
|
|
var folio = [];
|
|
|
|
this.dataUtils = new DataUtils();
|
|
|
|
}
|
|
|
|
//--------------------------
|
|
|
|
// methods
|
|
|
|
//--------------------------
|
|
|
|
start() {}
|
|
|
|
|
|
|
|
submitPost(edit, uploadFiles) {
|
|
|
|
let self = this;
|
|
|
|
return new Promise(function(resolve, reject) {
|
|
|
|
//collect form data
|
|
|
|
//if(!this.validateForm())
|
|
|
|
var postData = new FormData();
|
|
|
|
//let projectImages = document.getElementById('projectImages');
|
|
|
|
//var fileSelect = projectImages;
|
|
|
|
var files = uploadFiles;
|
|
|
|
for (var i = 0; i < files.length; i++) {
|
|
|
|
var file = files[i];
|
|
|
|
// Check the file type.
|
|
|
|
if (!file.type.match('image.*')) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
// Add the file to the request.
|
|
|
|
postData.append('feature_image', file, file.name);
|
|
|
|
}
|
|
|
|
//var category = document.getElementById("content_category");
|
|
|
|
//let project_form = document.forms.namedItem("folio-project");
|
|
|
|
var txt = document.createElement("textarea");
|
|
|
|
txt.innerHTML = document.getElementById('edit-text-code').innerHTML;
|
|
|
|
postData.append("title", document.getElementById('entry_title').value);
|
|
|
|
postData.append('slug', new StringUtils().cleanString(document.getElementById('entry_title').value));
|
|
|
|
postData.append("entry_plaintext", txt.value);
|
2018-11-05 17:32:33 -05:00
|
|
|
postData.append("origin_date", document.getElementById('entry-date').value);
|
2018-10-31 12:00:31 -04:00
|
|
|
postData.append("tags", document.getElementById('entry_tags').value);
|
|
|
|
let postURL;
|
|
|
|
let postEventType;
|
|
|
|
if (edit) {
|
|
|
|
let postID = document.getElementById('post-sumbit-btn').getAttribute('data-id');
|
|
|
|
postURL = "/api/blog/update/" + postID;
|
|
|
|
postEventType = DataEvent.POST_UPDATED;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
postURL = "/api/blog/add";
|
|
|
|
postEventType = DataEvent.POST_ADDED;
|
|
|
|
}
|
|
|
|
self.dataUtils.request(postURL, postEventType, REQUEST_TYPE_POST, CONTENT_TYPE_FORM, postData)
|
|
|
|
.then((response) => {
|
|
|
|
resolve({
|
|
|
|
response
|
|
|
|
})
|
|
|
|
}).catch((err) => {
|
|
|
|
reject({
|
|
|
|
err
|
|
|
|
});
|
|
|
|
})
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
validateForm() {
|
|
|
|
let valid = false;
|
|
|
|
if (this.entry_form.title.value == "" || this.entry_form.price.value == "" || this.entry_form.description == "") {
|
|
|
|
return valid;
|
|
|
|
} else {
|
|
|
|
valid = true;
|
|
|
|
return valid;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//--------------------------
|
|
|
|
// event handlers
|
|
|
|
//--------------------------
|
|
|
|
}
|
|
|
|
export { EntryTasks as default }
|