(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.PydioEml = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _PydioHOCs = PydioHOCs; var SelectionControls = _PydioHOCs.SelectionControls; exports.SelectionControls = SelectionControls; },{}],2:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); var _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } }; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _reactRedux = require('react-redux'); var _redux = require('redux'); var _PydioHOCs = PydioHOCs; var withSelection = _PydioHOCs.withSelection; var styles = { chip: { margin: 4 }, container: { height: '100%', width: '100%', flexDirection: 'column' }, headers: { maxHeight: 44, overflowY: 'scroll', paddingLeft: 20, display: 'flex', flexWrap: 'wrap', flexDirection: 'row', color: '#757575' }, headerName: { width: 50, display: 'flex', justifyContent: 'flex-end', alignItems: 'center' }, headerTitleAttribute: { fontSize: '14px', fontWeight: 'bold' }, title: { display: 'flex', justifyContent: 'flex-end', marginTop: 20, marginBottom: 20, marginLeft: 20, marginRight: 20, subject: { flex: 1, fontWeight: 'bold', fontSize: 18, color: '#A9A9A9' }, date: { fontWeight: 'light', color: '#A9A9A9' } }, body: { height: '100%', flex: 1, marginLeft: 20, marginRight: 20, overflowY: 'scroll' }, popover: { zIndex: 100000 }, attachments: { display: 'flex', overflowX: 'scroll', width: '100%', maxHeight: 150, position: 'absolute', alignItems: 'center', bottom: 0, paddingTop: 4, paddingBottom: 4 }, attachment: { marginLeft: 8 } }; var EmailBody = function EmailBody(_ref) { var isHtml = _ref.isHtml; var body = _ref.body; if (isHtml) { return _react2['default'].createElement('div', { style: styles.body, dangerouslySetInnerHTML: { __html: body } }); } else { return _react2['default'].createElement( 'p', null, body ); } }; var ContactChip = function ContactChip(_ref2) { var contact = _ref2.contact; return _react2['default'].createElement( MaterialUI.Chip, { style: styles.chip }, _react2['default'].createElement( MaterialUI.Avatar, { size: 32 }, contact[0] ), contact ); }; var HeaderField = (function (_React$Component) { _inherits(HeaderField, _React$Component); function HeaderField(props) { _classCallCheck(this, HeaderField); _get(Object.getPrototypeOf(HeaderField.prototype), 'constructor', this).call(this, props); } _createClass(HeaderField, [{ key: 'render', value: function render() { var _props = this.props; var headerName = _props.headerName; var headerValue = _props.headerValue; var emails = null; if (headerValue) { emails = headerValue.split(',').map(function (email) { return _react2['default'].createElement(ContactChip, { contact: email }); }); } else { return _react2['default'].createElement('div', null); } var hName = undefined; switch (headerName) { case 'From': hName = pydio.MessageHash['editor.eml.1'];break; case 'To': hName = pydio.MessageHash['editor.eml.2'];break; case 'Cc': hName = pydio.MessageHash['editor.eml.12'];break; default: hName = 'unexpected header';break; } return _react2['default'].createElement( 'div', null, _react2['default'].createElement( 'div', { style: styles.headers }, _react2['default'].createElement( 'div', { style: styles.headerName }, _react2['default'].createElement( 'p', { style: { fontSize: '14px', fontWeight: 'bold', color: '#9f9f9f' } }, hName, ': ' ) ), emails ), _react2['default'].createElement(MaterialUI.Divider, null) ); } }]); return HeaderField; })(_react2['default'].Component); var Attachment = (function (_React$Component2) { _inherits(Attachment, _React$Component2); function Attachment(props) { _classCallCheck(this, Attachment); _get(Object.getPrototypeOf(Attachment.prototype), 'constructor', this).call(this, props); this.state = { open: false }; } _createClass(Attachment, [{ key: 'downloadAttachment', value: function downloadAttachment() { var _props2 = this.props; var pydio = _props2.pydio; var node = _props2.node; this.props.pydio.ApiClient.downloadSelection(null, 'eml_dl_attachment', { file: node.getPath(), attachment_id: this.props.attachment.id }); } }, { key: 'copyAttachment', value: function copyAttachment() { var _props3 = this.props; var pydio = _props3.pydio; var node = _props3.node; var attachment = _props3.attachment; var submit = function submit(path) { var wsId = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; pydio.ApiClient.request({ get_action: 'eml_cp_attachment', file: node.getPath(), attachment_id: attachment.id, destination: path }, function (transport) { console.log(transport.responseXML); }); }; pydio.UI.openComponentInModal('FSActions', 'TreeDialog', { isMove: false, dialogTitle: MessageHash[159], submitValue: submit }); } }, { key: 'handleTouchTap', value: function handleTouchTap(event) { // This prevents ghost click. event.preventDefault(); this.setState({ open: true, anchorEl: event.currentTarget }); } }, { key: 'handleRequestClose', value: function handleRequestClose() { this.setState({ open: false }); } }, { key: 'render', value: function render() { var _props4 = this.props; var pydio = _props4.pydio; var attachment = _props4.attachment; return _react2['default'].createElement( MaterialUI.Paper, { style: styles.attachment }, _react2['default'].createElement(MaterialUI.IconButton, { iconClassName: 'mdi mdi-file', disabled: true }), attachment.fileName, _react2['default'].createElement( MaterialUI.IconButton, { iconClassName: 'mdi mdi-dots-vertical', onTouchTap: this.handleTouchTap.bind(this) }, _react2['default'].createElement( MaterialUI.Popover, { useLayerForClickAway: false, style: { zIndex: 100000 }, open: this.state.open, anchorEl: this.state.anchorEl, anchorOrigin: { horizontal: 'right', vertical: 'top' }, targetOrigin: { horizontal: 'right', vertical: 'bottom' }, onRequestClose: this.handleRequestClose.bind(this) }, _react2['default'].createElement( MaterialUI.Menu, { style: { zIndex: 100000 } }, _react2['default'].createElement(MaterialUI.MenuItem, { primaryText: pydio.MessageHash['editor.eml.10'], onTouchTap: this.downloadAttachment.bind(this) }), _react2['default'].createElement(MaterialUI.MenuItem, { primaryText: pydio.MessageHash['editor.eml.11'], onTouchTap: this.copyAttachment.bind(this) }) ) ) ) ); } }]); return Attachment; })(_react2['default'].Component); var Editor = (function (_React$Component3) { _inherits(Editor, _React$Component3); function Editor(props) { _classCallCheck(this, Editor); _get(Object.getPrototypeOf(Editor.prototype), 'constructor', this).call(this, props); this.state = { headers: [], isHtml: false, body: '', attachments: [] }; } _createClass(Editor, [{ key: 'componentWillMount', value: function componentWillMount() { this.loadFileContent(this.props); } }, { key: 'componentWillReceiveProps', value: function componentWillReceiveProps(nextProps) { if (nextProps.node !== this.props.node) { this.loadFileContent(nextProps); } } }, { key: 'loadFileContent', value: function loadFileContent(props) { var pydio = props.pydio; var node = props.node; var onLoad = props.onLoad; pydio.ApiClient.request({ get_action: 'eml_get_xml_structure', file: node.getPath() }, (function (transport) { this.parseHeaders(transport.responseXML); this.parseAttachments(transport.responseXML); }).bind(this)); pydio.ApiClient.request({ get_action: 'eml_get_bodies', file: node.getPath() }, (function (transport) { this.parseBody(transport.responseXML); }).bind(this)); } }, { key: 'parseBody', value: function parseBody(xmlDoc) { var body = XMLUtils.XPathSelectSingleNode(xmlDoc, 'email_body/mimepart[@type="html"]').firstChild.nodeValue; var isHtml = true; if (!body) { body = XMLUtils.XPathSelectSingleNode(xmlDoc, 'email_body/mimepart[@type="plain"]').firstChild.nodeValue; ishtml = false; } this.setState({ body: body }); this.setState({ isHtml: isHtml }); } }, { key: 'parseHeaders', value: function parseHeaders(xmlDoc) { var headers = XMLUtils.XPathSelectNodes(xmlDoc, 'email/header'); var searchedHeaders = {}; headers.forEach(function (value) { var hName = XMLUtils.XPathGetSingleNodeText(value, 'headername'); var hValue = XMLUtils.XPathGetSingleNodeText(value, 'headervalue'); searchedHeaders[hName] = hValue; }); this.setState({ headers: searchedHeaders }); } }, { key: 'parseAttachments', value: function parseAttachments(xmlDoc) { var allHeaders = XMLUtils.XPathSelectNodes(xmlDoc, '//header'); // let attachments = {}; var attachments = []; var id = 0; allHeaders.forEach(function (el) { var hName = XMLUtils.XPathGetSingleNodeText(el, 'headername'); var hValue = XMLUtils.XPathGetSingleNodeText(el, 'headervalue'); if (hName != 'Content-Disposition' || hValue != 'attachment') return; var mimepart = el.parentNode; var filename = ''; var params = XMLUtils.XPathSelectNodes(el, 'parameter'); params.forEach(function (c) { if (XMLUtils.XPathGetSingleNodeText(c, "paramname") == "filename") { filename = XMLUtils.XPathGetSingleNodeText(c, "paramvalue"); } }); var foundId = false; allHeaders.forEach(function (h) { if (h.parentNode != mimepart) return; var siblingName = XMLUtils.XPathGetSingleNodeText(h, "headername"); if (siblingName == "X-Attachment-Id") { id = XMLUtils.XPathGetSingleNodeText(h, "headervalue"); foundId = true; } }); // attachments[id] = filename; attachments.push({ id: id, fileName: filename }); if (!foundId) { id = id + 1; } }); this.setState({ attachments: attachments }); } }, { key: 'render', value: function render() { var _this = this; return _react2['default'].createElement( MaterialUI.Paper, { zDepth: 1, style: styles.container }, ["From", "To", "Cc"].map(function (id) { return _react2['default'].createElement(HeaderField, _extends({}, _this.props, { key: id, headerName: id, headerValue: _this.state.headers[id] })); }), _react2['default'].createElement( 'div', { style: styles.title }, _react2['default'].createElement( 'div', { style: styles.title.subject }, _react2['default'].createElement( 'p', { style: { fontSize: 18, color: '#9f9f9f' } }, this.state.headers['Subject'] ) ), _react2['default'].createElement( 'div', { style: styles.title.date }, _react2['default'].createElement( 'p', { style: { fontSize: 14, color: '#9f9f9f', opacity: 0.8 } }, this.state.headers['Date'] ) ) ), _react2['default'].createElement(EmailBody, { isHtml: this.state.isHtml, body: this.state.body }), _react2['default'].createElement( 'div', { style: styles.attachments }, Object.values(this.state.attachments).map(function (a) { return _react2['default'].createElement(Attachment, _extends({}, _this.props, { attachment: a })); }) ) ); } }]); return Editor; })(_react2['default'].Component); var editors = pydio.Registry.getActiveExtensionByType("editor"); var conf = editors.filter(function (_ref3) { var id = _ref3.id; return id === 'editor.eml'; })[0]; var getSelectionFilter = function getSelectionFilter(node) { return conf.mimes.indexOf(node.getAjxpMime()) > -1; }; var getSelection = function getSelection(node) { return new Promise(function (resolve, reject) { var selection = []; node.getParent().getChildren().forEach(function (child) { return selection.push(child); }); selection = selection.filter(getSelectionFilter); resolve({ selection: selection, currentIndex: selection.reduce(function (currentIndex, current, index) { return current === node && index || currentIndex; }, 0) }); }); }; exports['default'] = (0, _redux.compose)(withSelection(getSelection), (0, _reactRedux.connect)())(Editor); module.exports = exports['default']; },{"react":"react","react-redux":"react-redux","redux":"redux"}],3:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _editor = require('./editor'); var _editor2 = _interopRequireDefault(_editor); var _controls = require('./controls'); var Controls = _interopRequireWildcard(_controls); exports.Editor = _editor2['default']; exports.Controls = Controls; },{"./controls":1,"./editor":2}]},{},[3])(3) }); //# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","res/build/PydioEml/controls.js","res/build/PydioEml/editor.js","res/build/PydioEml/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nvar _PydioHOCs = PydioHOCs;\nvar SelectionControls = _PydioHOCs.SelectionControls;\nexports.SelectionControls = SelectionControls;\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n    value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();\n\nvar _get = function get(_x2, _x3, _x4) { var _again = true; _function: while (_again) { var object = _x2, property = _x3, receiver = _x4; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x2 = parent; _x3 = property; _x4 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactRedux = require('react-redux');\n\nvar _redux = require('redux');\n\nvar _PydioHOCs = PydioHOCs;\nvar withSelection = _PydioHOCs.withSelection;\n\nvar styles = {\n    chip: {\n        margin: 4\n    },\n    container: {\n        height: '100%',\n        width: '100%',\n        flexDirection: 'column'\n    },\n    headers: {\n        maxHeight: 44,\n        overflowY: 'scroll',\n        paddingLeft: 20,\n        display: 'flex',\n        flexWrap: 'wrap',\n        flexDirection: 'row',\n        color: '#757575'\n    },\n    headerName: {\n        width: 50,\n        display: 'flex',\n        justifyContent: 'flex-end',\n        alignItems: 'center'\n    },\n    headerTitleAttribute: {\n        fontSize: '14px',\n        fontWeight: 'bold'\n    },\n    title: {\n        display: 'flex',\n        justifyContent: 'flex-end',\n        marginTop: 20,\n        marginBottom: 20,\n        marginLeft: 20,\n        marginRight: 20,\n        subject: {\n            flex: 1,\n            fontWeight: 'bold',\n            fontSize: 18,\n            color: '#A9A9A9'\n        },\n        date: {\n            fontWeight: 'light',\n            color: '#A9A9A9'\n        }\n    },\n    body: {\n        height: '100%',\n        flex: 1,\n        marginLeft: 20,\n        marginRight: 20,\n        overflowY: 'scroll'\n    },\n    popover: {\n        zIndex: 100000\n    },\n    attachments: {\n        display: 'flex',\n        overflowX: 'scroll',\n        width: '100%',\n        maxHeight: 150,\n        position: 'absolute',\n        alignItems: 'center',\n        bottom: 0,\n        paddingTop: 4,\n        paddingBottom: 4\n    },\n    attachment: {\n        marginLeft: 8\n    }\n};\n\nvar EmailBody = function EmailBody(_ref) {\n    var isHtml = _ref.isHtml;\n    var body = _ref.body;\n\n    if (isHtml) {\n        return _react2['default'].createElement('div', { style: styles.body, dangerouslySetInnerHTML: { __html: body } });\n    } else {\n        return _react2['default'].createElement(\n            'p',\n            null,\n            body\n        );\n    }\n};\n\nvar ContactChip = function ContactChip(_ref2) {\n    var contact = _ref2.contact;\n\n    return _react2['default'].createElement(\n        MaterialUI.Chip,\n        { style: styles.chip },\n        _react2['default'].createElement(\n            MaterialUI.Avatar,\n            { size: 32 },\n            contact[0]\n        ),\n        contact\n    );\n};\n\nvar HeaderField = (function (_React$Component) {\n    _inherits(HeaderField, _React$Component);\n\n    function HeaderField(props) {\n        _classCallCheck(this, HeaderField);\n\n        _get(Object.getPrototypeOf(HeaderField.prototype), 'constructor', this).call(this, props);\n    }\n\n    _createClass(HeaderField, [{\n        key: 'render',\n        value: function render() {\n            var _props = this.props;\n            var headerName = _props.headerName;\n            var headerValue = _props.headerValue;\n\n            var emails = null;\n            if (headerValue) {\n                emails = headerValue.split(',').map(function (email) {\n                    return _react2['default'].createElement(ContactChip, { contact: email });\n                });\n            } else {\n                return _react2['default'].createElement('div', null);\n            }\n            var hName = undefined;\n            switch (headerName) {\n                case 'From':\n                    hName = pydio.MessageHash['editor.eml.1'];break;\n                case 'To':\n                    hName = pydio.MessageHash['editor.eml.2'];break;\n                case 'Cc':\n                    hName = pydio.MessageHash['editor.eml.12'];break;\n                default:\n                    hName = 'unexpected header';break;\n            }\n            return _react2['default'].createElement(\n                'div',\n                null,\n                _react2['default'].createElement(\n                    'div',\n                    { style: styles.headers },\n                    _react2['default'].createElement(\n                        'div',\n                        { style: styles.headerName },\n                        _react2['default'].createElement(\n                            'p',\n                            { style: { fontSize: '14px', fontWeight: 'bold', color: '#9f9f9f' } },\n                            hName,\n                            ': '\n                        )\n                    ),\n                    emails\n                ),\n                _react2['default'].createElement(MaterialUI.Divider, null)\n            );\n        }\n    }]);\n\n    return HeaderField;\n})(_react2['default'].Component);\n\nvar Attachment = (function (_React$Component2) {\n    _inherits(Attachment, _React$Component2);\n\n    function Attachment(props) {\n        _classCallCheck(this, Attachment);\n\n        _get(Object.getPrototypeOf(Attachment.prototype), 'constructor', this).call(this, props);\n\n        this.state = {\n            open: false\n        };\n    }\n\n    _createClass(Attachment, [{\n        key: 'downloadAttachment',\n        value: function downloadAttachment() {\n            var _props2 = this.props;\n            var pydio = _props2.pydio;\n            var node = _props2.node;\n\n            this.props.pydio.ApiClient.downloadSelection(null, 'eml_dl_attachment', { file: node.getPath(), attachment_id: this.props.attachment.id });\n        }\n    }, {\n        key: 'copyAttachment',\n        value: function copyAttachment() {\n            var _props3 = this.props;\n            var pydio = _props3.pydio;\n            var node = _props3.node;\n            var attachment = _props3.attachment;\n\n            var submit = function submit(path) {\n                var wsId = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];\n\n                pydio.ApiClient.request({\n                    get_action: 'eml_cp_attachment',\n                    file: node.getPath(),\n                    attachment_id: attachment.id,\n                    destination: path\n                }, function (transport) {\n                    console.log(transport.responseXML);\n                });\n            };\n\n            pydio.UI.openComponentInModal('FSActions', 'TreeDialog', {\n                isMove: false,\n                dialogTitle: MessageHash[159],\n                submitValue: submit\n            });\n        }\n    }, {\n        key: 'handleTouchTap',\n        value: function handleTouchTap(event) {\n            // This prevents ghost click.\n            event.preventDefault();\n\n            this.setState({\n                open: true,\n                anchorEl: event.currentTarget\n            });\n        }\n    }, {\n        key: 'handleRequestClose',\n        value: function handleRequestClose() {\n            this.setState({\n                open: false\n            });\n        }\n    }, {\n        key: 'render',\n        value: function render() {\n            var _props4 = this.props;\n            var pydio = _props4.pydio;\n            var attachment = _props4.attachment;\n\n            return _react2['default'].createElement(\n                MaterialUI.Paper,\n                {\n                    style: styles.attachment\n                },\n                _react2['default'].createElement(MaterialUI.IconButton, { iconClassName: 'mdi mdi-file', disabled: true }),\n                attachment.fileName,\n                _react2['default'].createElement(\n                    MaterialUI.IconButton,\n                    {\n                        iconClassName: 'mdi mdi-dots-vertical',\n                        onTouchTap: this.handleTouchTap.bind(this)\n                    },\n                    _react2['default'].createElement(\n                        MaterialUI.Popover,\n                        {\n                            useLayerForClickAway: false,\n                            style: { zIndex: 100000 },\n                            open: this.state.open,\n                            anchorEl: this.state.anchorEl,\n                            anchorOrigin: { horizontal: 'right', vertical: 'top' },\n                            targetOrigin: { horizontal: 'right', vertical: 'bottom' },\n                            onRequestClose: this.handleRequestClose.bind(this)\n                        },\n                        _react2['default'].createElement(\n                            MaterialUI.Menu,\n                            {\n                                style: { zIndex: 100000 }\n                            },\n                            _react2['default'].createElement(MaterialUI.MenuItem, {\n                                primaryText: pydio.MessageHash['editor.eml.10'],\n                                onTouchTap: this.downloadAttachment.bind(this)\n                            }),\n                            _react2['default'].createElement(MaterialUI.MenuItem, {\n                                primaryText: pydio.MessageHash['editor.eml.11'],\n                                onTouchTap: this.copyAttachment.bind(this)\n                            })\n                        )\n                    )\n                )\n            );\n        }\n    }]);\n\n    return Attachment;\n})(_react2['default'].Component);\n\nvar Editor = (function (_React$Component3) {\n    _inherits(Editor, _React$Component3);\n\n    function Editor(props) {\n        _classCallCheck(this, Editor);\n\n        _get(Object.getPrototypeOf(Editor.prototype), 'constructor', this).call(this, props);\n\n        this.state = { headers: [], isHtml: false, body: '', attachments: [] };\n    }\n\n    _createClass(Editor, [{\n        key: 'componentWillMount',\n        value: function componentWillMount() {\n            this.loadFileContent(this.props);\n        }\n    }, {\n        key: 'componentWillReceiveProps',\n        value: function componentWillReceiveProps(nextProps) {\n            if (nextProps.node !== this.props.node) {\n                this.loadFileContent(nextProps);\n            }\n        }\n    }, {\n        key: 'loadFileContent',\n        value: function loadFileContent(props) {\n            var pydio = props.pydio;\n            var node = props.node;\n            var onLoad = props.onLoad;\n\n            pydio.ApiClient.request({\n                get_action: 'eml_get_xml_structure',\n                file: node.getPath()\n            }, (function (transport) {\n                this.parseHeaders(transport.responseXML);\n                this.parseAttachments(transport.responseXML);\n            }).bind(this));\n\n            pydio.ApiClient.request({\n                get_action: 'eml_get_bodies',\n                file: node.getPath()\n            }, (function (transport) {\n                this.parseBody(transport.responseXML);\n            }).bind(this));\n        }\n    }, {\n        key: 'parseBody',\n        value: function parseBody(xmlDoc) {\n            var body = XMLUtils.XPathSelectSingleNode(xmlDoc, 'email_body/mimepart[@type=\"html\"]').firstChild.nodeValue;\n            var isHtml = true;\n            if (!body) {\n                body = XMLUtils.XPathSelectSingleNode(xmlDoc, 'email_body/mimepart[@type=\"plain\"]').firstChild.nodeValue;\n                ishtml = false;\n            }\n            this.setState({ body: body });\n            this.setState({ isHtml: isHtml });\n        }\n    }, {\n        key: 'parseHeaders',\n        value: function parseHeaders(xmlDoc) {\n            var headers = XMLUtils.XPathSelectNodes(xmlDoc, 'email/header');\n            var searchedHeaders = {};\n\n            headers.forEach(function (value) {\n                var hName = XMLUtils.XPathGetSingleNodeText(value, 'headername');\n                var hValue = XMLUtils.XPathGetSingleNodeText(value, 'headervalue');\n                searchedHeaders[hName] = hValue;\n            });\n            this.setState({ headers: searchedHeaders });\n        }\n    }, {\n        key: 'parseAttachments',\n        value: function parseAttachments(xmlDoc) {\n            var allHeaders = XMLUtils.XPathSelectNodes(xmlDoc, '//header');\n            // let attachments = {};\n            var attachments = [];\n            var id = 0;\n            allHeaders.forEach(function (el) {\n                var hName = XMLUtils.XPathGetSingleNodeText(el, 'headername');\n                var hValue = XMLUtils.XPathGetSingleNodeText(el, 'headervalue');\n                if (hName != 'Content-Disposition' || hValue != 'attachment') return;\n                var mimepart = el.parentNode;\n                var filename = '';\n\n                var params = XMLUtils.XPathSelectNodes(el, 'parameter');\n                params.forEach(function (c) {\n                    if (XMLUtils.XPathGetSingleNodeText(c, \"paramname\") == \"filename\") {\n                        filename = XMLUtils.XPathGetSingleNodeText(c, \"paramvalue\");\n                    }\n                });\n\n                var foundId = false;\n                allHeaders.forEach(function (h) {\n                    if (h.parentNode != mimepart) return;\n                    var siblingName = XMLUtils.XPathGetSingleNodeText(h, \"headername\");\n                    if (siblingName == \"X-Attachment-Id\") {\n                        id = XMLUtils.XPathGetSingleNodeText(h, \"headervalue\");\n                        foundId = true;\n                    }\n                });\n                // attachments[id] = filename;\n                attachments.push({ id: id, fileName: filename });\n                if (!foundId) {\n                    id = id + 1;\n                }\n            });\n            this.setState({ attachments: attachments });\n        }\n    }, {\n        key: 'render',\n        value: function render() {\n            var _this = this;\n\n            return _react2['default'].createElement(\n                MaterialUI.Paper,\n                { zDepth: 1, style: styles.container },\n                [\"From\", \"To\", \"Cc\"].map(function (id) {\n                    return _react2['default'].createElement(HeaderField, _extends({}, _this.props, { key: id, headerName: id, headerValue: _this.state.headers[id] }));\n                }),\n                _react2['default'].createElement(\n                    'div',\n                    { style: styles.title },\n                    _react2['default'].createElement(\n                        'div',\n                        { style: styles.title.subject },\n                        _react2['default'].createElement(\n                            'p',\n                            { style: { fontSize: 18, color: '#9f9f9f' } },\n                            this.state.headers['Subject']\n                        )\n                    ),\n                    _react2['default'].createElement(\n                        'div',\n                        { style: styles.title.date },\n                        _react2['default'].createElement(\n                            'p',\n                            { style: { fontSize: 14, color: '#9f9f9f', opacity: 0.8 } },\n                            this.state.headers['Date']\n                        )\n                    )\n                ),\n                _react2['default'].createElement(EmailBody, { isHtml: this.state.isHtml, body: this.state.body }),\n                _react2['default'].createElement(\n                    'div',\n                    { style: styles.attachments },\n                    Object.values(this.state.attachments).map(function (a) {\n                        return _react2['default'].createElement(Attachment, _extends({}, _this.props, { attachment: a }));\n                    })\n                )\n            );\n        }\n    }]);\n\n    return Editor;\n})(_react2['default'].Component);\n\nvar editors = pydio.Registry.getActiveExtensionByType(\"editor\");\nvar conf = editors.filter(function (_ref3) {\n    var id = _ref3.id;\n    return id === 'editor.eml';\n})[0];\n\nvar getSelectionFilter = function getSelectionFilter(node) {\n    return conf.mimes.indexOf(node.getAjxpMime()) > -1;\n};\n\nvar getSelection = function getSelection(node) {\n    return new Promise(function (resolve, reject) {\n        var selection = [];\n\n        node.getParent().getChildren().forEach(function (child) {\n            return selection.push(child);\n        });\n        selection = selection.filter(getSelectionFilter);\n\n        resolve({\n            selection: selection,\n            currentIndex: selection.reduce(function (currentIndex, current, index) {\n                return current === node && index || currentIndex;\n            }, 0)\n        });\n    });\n};\n\nexports['default'] = (0, _redux.compose)(withSelection(getSelection), (0, _reactRedux.connect)())(Editor);\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n  value: true\n});\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _editor = require('./editor');\n\nvar _editor2 = _interopRequireDefault(_editor);\n\nvar _controls = require('./controls');\n\nvar Controls = _interopRequireWildcard(_controls);\n\nexports.Editor = _editor2['default'];\nexports.Controls = Controls;\n"]}