import Ember from 'ember'; import {request as ajax} from 'ic-ajax'; export default Ember.Controller.extend({ uploadButtonText: 'Import', importErrors: '', submitting: false, ghostPaths: Ember.inject.service('ghost-paths'), notifications: Ember.inject.service(), labsJSON: Ember.computed('model.labs', function () { return JSON.parse(this.get('model.labs') || {}); }), saveLabs: function (optionName, optionValue) { var self = this, labsJSON = this.get('labsJSON'); // Set new value in the JSON object labsJSON[optionName] = optionValue; this.set('model.labs', JSON.stringify(labsJSON)); this.get('model').save().catch(function (errors) { self.showErrors(errors); self.get('model').rollbackAttributes(); }); }, actions: { onUpload: function (file) { var self = this, formData = new FormData(), notifications = this.get('notifications'), currentUserId = this.get('session.user.id'); this.set('uploadButtonText', 'Importing'); this.set('importErrors', ''); formData.append('importfile', file); ajax(this.get('ghostPaths.url').api('db'), { type: 'POST', data: formData, dataType: 'json', cache: false, contentType: false, processData: false }).then(function () { // Clear the store, so that all the new data gets fetched correctly. self.store.unloadAll(); // Reload currentUser and set session self.set('session.user', self.store.findRecord('user', currentUserId)); // TODO: keep as notification, add link to view content notifications.showNotification('Import successful.'); }).catch(function (response) { if (response && response.jqXHR && response.jqXHR.responseJSON && response.jqXHR.responseJSON.errors) { self.set('importErrors', response.jqXHR.responseJSON.errors); } notifications.showAlert('Import Failed', {type: 'error'}); }).finally(function () { self.set('uploadButtonText', 'Import'); }); }, exportData: function () { var iframe = $('#iframeDownload'), downloadURL = this.get('ghostPaths.url').api('db') + '?access_token=' + this.get('session.secure.access_token'); if (iframe.length === 0) { iframe = $('