define([ 'jquery', '/bower_components/chainpad-crypto/crypto.js', '/bower_components/nthen/index.js', '/common/sframe-common.js', '/common/common-interface.js', '/common/common-ui-elements.js', '/common/common-util.js', '/common/common-hash.js', '/common/hyperscript.js', 'json.sortify', '/customize/messages.js', 'css!/bower_components/bootstrap/dist/css/bootstrap.min.css', 'css!/bower_components/components-font-awesome/css/font-awesome.min.css', 'less!/secureiframe/app-secure.less', ], function ( $, Crypto, nThen, SFCommon, UI, UIElements, Util, Hash, h, Sortify, Messages) { var APP = window.APP = {}; var andThen = function (common) { var metadataMgr = common.getMetadataMgr(); var sframeChan = common.getSframeChannel(); var $body = $('body'); var hideIframe = function () { sframeChan.event('EV_SECURE_IFRAME_CLOSE'); }; var displayed; var create = {}; // Share modal create['share'] = function (data) { var priv = metadataMgr.getPrivateData(); var f = (data && data.file) ? UIElements.createFileShareModal : UIElements.createShareModal; var friends = common.getFriends(); var _modal; var modal = f({ origin: priv.origin, pathname: priv.pathname, password: priv.password, isTemplate: priv.isTemplate, hashes: priv.hashes, common: common, title: data.title, friends: friends, onClose: function () { if (_modal && _modal.close) { _modal.close(); } hideIframe(); }, fileData: { hash: priv.hashes.fileHash, password: priv.password } }); $('button.cancel').click(); // Close any existing alertify _modal = UI.openCustomModal(modal); displayed = modal; }; // Properties modal create['properties'] = function (data) { require(['/common/inner/properties.js'], function (Properties) { Properties.getPropertiesModal(common, { onClose: function () { hideIframe(); } }, function (e) { if (e) { console.error(e); } displayed = modal; }); }); }; // Access modal create['access'] = function (data) { require(['/common/inner/access.js'], function (Access) { Access.getAccessModal(common, { onClose: function () { hideIframe(); } }, function (e, modal) { if (e) { console.error(e); } displayed = modal; }); }); }; // File uploader var onFilePicked = function (data) { var privateData = metadataMgr.getPrivateData(); var parsed = Hash.parsePadUrl(data.url); if (displayed && displayed.hide) { displayed.hide(); } hideIframe(); if (parsed.type === 'file') { var secret = Hash.getSecrets('file', parsed.hash, data.password); var fileHost = privateData.fileHost || privateData.origin; var src = fileHost + Hash.getBlobPathFromHex(secret.channel); var key = Hash.encodeBase64(secret.keys.cryptKey); sframeChan.event("EV_SECURE_ACTION", { type: parsed.type, src: src, name: data.name, key: key }); return; } sframeChan.event("EV_SECURE_ACTION", { type: parsed.type, href: data.url, name: data.name }); }; var fmConfig = { body: $('body'), noHandlers: true, onUploaded: function (ev, data) { onFilePicked(data); } }; APP.FM = common.createFileManager(fmConfig); create['filepicker'] = function (_filters) { var updateContainer = function () {}; var filters = _filters; var types = filters.types || []; var data = { FM: APP.FM }; // Create modal var modal = UI.createModal({ $body: $body, onClose: function () { hideIframe(); } }); displayed = modal; modal.show(); // Set the fixed content modal.$modal.attr('id', 'cp-filepicker-dialog'); var $block = modal.$modal.find('.cp-modal'); // Description var text = Messages.filePicker_description; if (types && types.length === 1 && types[0] !== 'file') { text = Messages.selectTemplate; } $block.append(h('p', text)); // Add filter input var $filter = $(h('p.cp-modal-form')).appendTo($block); var to; var $input = $('', { type: 'text', 'class': 'cp-filepicker-filter', 'placeholder': Messages.filePicker_filter }).appendTo($filter).on('keypress', function () { if (to) { window.clearTimeout(to); } to = window.setTimeout(updateContainer, 300); }); // If file, display the upload button if (types.indexOf('file') !== -1 && common.isLoggedIn()) { var f = (filters && filters.filter) || {}; delete data.accept; if (Array.isArray(f.fileType)) { data.accept = f.fileType.map(function (val) { if (/^[a-z]+\/$/.test(val)) { val += '*'; } return val; }); } $filter.append(common.createButton('upload', false, data)); } var $container = $(h('span.cp-filepicker-content', [ h('div.cp-loading-spinner-container', h('span.cp-spinner')) ])).appendTo($block); // Update the files list when needed updateContainer = function () { var filter = $input.val().trim(); var todo = function (err, list) { if (err) { return void console.error(err); } $container.html(''); Object.keys(list).forEach(function (id) { var data = list[id]; var name = data.filename || data.title || '?'; if (filter && name.toLowerCase().indexOf(filter.toLowerCase()) === -1) { return; } var $span = $('', { 'class': 'cp-filepicker-content-element', 'title': name, }).appendTo($container); $span.append(UI.getFileIcon(data)); $('', {'class': 'cp-filepicker-content-element-name'}).text(name) .appendTo($span); $span.click(function () { if (typeof onFilePicked === "function") { onFilePicked({url: data.href, name: name, password: data.password}); } }); // Add thumbnail if it exists common.displayThumbnail(data.href, data.channel, data.password, $span); }); $input.focus(); }; common.getFilesList(filters, todo); }; updateContainer(); }; sframeChan.on('EV_REFRESH', function (data) { if (!data) { return; } var type = data.modal; if (!create[type]) { return; } if (displayed && displayed.close) { displayed.close(); } else if (displayed && displayed.hide) { displayed.hide(); } displayed = undefined; create[type](data); }); UI.removeLoadingScreen(); }; var main = function () { var common; var _andThen = Util.once(andThen); nThen(function (waitFor) { $(waitFor(function () { UI.addLoadingScreen({hideTips: true, hideLogo: true}); })); SFCommon.create(waitFor(function (c) { APP.common = common = c; })); }).nThen(function (/*waitFor*/) { var metadataMgr = common.getMetadataMgr(); if (metadataMgr.getMetadataLazy() !== 'uninitialized') { _andThen(common); return; } metadataMgr.onChange(function () { _andThen(common); }); }); }; main(); });