cloudcmd/client/modules/upload.js
2019-02-08 15:47:05 +02:00

70 lines
1.5 KiB
JavaScript

/* global CloudCmd, DOM */
'use strict';
CloudCmd.Upload = exports;
const Files = require('../dom/files');
const Images = require('../dom/images');
const uploadFiles = require('../dom/upload-files');
const createElement = require('@cloudcmd/create-element');
module.exports.init = async () => {
Images.show.load('top');
await CloudCmd.View();
};
module.exports.show = show;
module.exports.hide = hide;
function show() {
Images.show.load('top');
Files.get('upload', (error, innerHTML) => {
const autoSize = true;
const el = createElement('div', {
innerHTML,
});
CloudCmd.View.show(el, {
autoSize,
afterShow,
});
});
const fontFamily = [
'"Droid Sans Mono"',
'"Ubuntu Mono"',
'"Consolas"',
'monospace',
].join(', ');
createElement('style', {
dataName: 'upload-css',
innerText: '[data-name=js-upload-file-button] {' +
`font-family: ${fontFamily};` +
'font-size: 20px;' +
'width: 97%' +
'}',
});
}
function hide() {
CloudCmd.View.hide();
}
function afterShow() {
const button = DOM.getByDataName('js-upload-file-button');
Images.hide();
DOM.Events.add('change', button, ({target}) => {
const {files} = target;
hide();
uploadFiles(files);
});
}