discourse-data-explorer/assets/javascripts/discourse/components/json-file-uploader.js.es6

106 lines
2.4 KiB
Plaintext
Raw Normal View History

2019-07-16 07:15:27 -04:00
import {
default as computed,
on,
observes
} from "ember-addons/ember-computed-decorators";
2017-05-11 12:45:15 -04:00
export default Ember.Component.extend({
fileInput: null,
loading: false,
expectedRootObjectName: null,
hover: 0,
2018-10-10 07:56:23 -04:00
classNames: ["json-uploader"],
2017-05-11 12:45:15 -04:00
@on("didInsertElement")
_initialize() {
const $this = $(this.element);
const fileInput = this.element.querySelector("#js-file-input");
this.set("fileInput", fileInput);
2017-05-11 12:45:15 -04:00
$(fileInput).on("change", () => this.fileSelected(this.files));
2017-05-11 12:45:15 -04:00
$this.on("dragover", e => {
2017-05-11 12:45:15 -04:00
if (e.preventDefault) e.preventDefault();
return false;
});
$this.on("dragenter", e => {
2017-05-11 12:45:15 -04:00
if (e.preventDefault) e.preventDefault();
this.set("hover", this.hover + 1);
2017-05-11 12:45:15 -04:00
return false;
});
$this.on("dragleave", e => {
2017-05-11 12:45:15 -04:00
if (e.preventDefault) e.preventDefault();
this.set("hover", this.hover - 1);
2017-05-11 12:45:15 -04:00
return false;
});
$this.on("drop", e => {
2017-05-11 12:45:15 -04:00
if (e.preventDefault) e.preventDefault();
this.set("hover", 0);
this.fileSelected(e.dataTransfer.files);
2017-05-11 12:45:15 -04:00
return false;
});
},
2017-05-11 12:45:15 -04:00
@computed("extension")
accept(extension) {
2018-10-10 07:56:23 -04:00
return (
".json,application/json,application/x-javascript,text/json" +
(extension ? `,${extension}` : "")
2018-10-10 07:56:23 -04:00
);
},
2017-05-11 12:45:15 -04:00
@observes("destination", "expectedRootObjectName")
setReady() {
2017-05-11 12:45:15 -04:00
let parsed;
try {
parsed = JSON.parse(this.value);
2017-05-11 12:45:15 -04:00
} catch (e) {
2018-10-10 07:56:23 -04:00
this.set("ready", false);
2017-05-11 12:45:15 -04:00
return;
}
const rootObject = parsed[this.expectedRootObjectName];
2017-05-11 12:45:15 -04:00
if (rootObject !== null && rootObject !== undefined) {
2018-10-10 07:56:23 -04:00
this.set("ready", true);
2017-05-11 12:45:15 -04:00
} else {
2018-10-10 07:56:23 -04:00
this.set("ready", false);
2017-05-11 12:45:15 -04:00
}
},
2017-05-11 12:45:15 -04:00
actions: {
selectFile() {
$(this.fileInput).click();
2017-05-11 12:45:15 -04:00
}
},
fileSelected(fileList) {
let files = [];
for (let i = 0; i < fileList.length; i++) {
files[i] = fileList[i];
}
const fileNameRegex = /\.(json|txt)$/;
files = files.filter(file => {
2017-05-11 12:45:15 -04:00
if (fileNameRegex.test(file.name)) {
return true;
}
if (file.type === "text/plain") {
return true;
}
return false;
});
const firstFile = fileList[0];
2018-10-10 07:56:23 -04:00
this.set("loading", true);
2017-05-11 12:45:15 -04:00
const reader = new FileReader();
reader.onload = evt => {
this.setProperties({ value: evt.target.result, loading: false });
2017-05-11 12:45:15 -04:00
};
reader.readAsText(firstFile);
}
});