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);
            postData.append("origin_date", document.getElementById('entry-date').value);
            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 }