cloudcmd/client/modules/upload.js
2019-05-24 12:51:50 +03:00

69 lines
1.4 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;
async function show() {
Images.show.load('top');
const innerHTML = await Files.get('upload');
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: 16px;
margin: 10px 0 10px 0;
}`,
});
}
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);
});
}