/* * 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(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _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 { _x = parent; _x2 = property; _x3 = 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 _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i]; return arr2; } else { return Array.from(arr); } } 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 _components = require('./components'); var conf = pydio.getPluginConfigs('editor.diaporama'); var sizes = conf && conf.get("PREVIEWER_LOWRES_SIZES").split(",") || [300, 700, 1000, 1300]; var _PydioHOCs = PydioHOCs; var SizeProviders = _PydioHOCs.SizeProviders; var URLProvider = _PydioHOCs.URLProvider; var withResolution = _PydioHOCs.withResolution; var withSelection = _PydioHOCs.withSelection; var withResize = _PydioHOCs.withResize; var ImageSizeProvider = SizeProviders.ImageSizeProvider; var ContainerSizeProvider = SizeProviders.ContainerSizeProvider; var ExtendedImageContainer = withResize(_components.ImageContainer); var Editor = (function (_PureComponent) { _inherits(Editor, _PureComponent); function Editor() { _classCallCheck(this, Editor); _get(Object.getPrototypeOf(Editor.prototype), 'constructor', this).apply(this, arguments); } _createClass(Editor, [{ key: 'componentWillReceiveProps', /*static getCoveringBackgroundSource(ajxpNode) { return this.getThumbnailSource(ajxpNode); } static getThumbnailSource(ajxpNode) { var repoString = ""; if(pydio.repositoryId && ajxpNode.getMetadata().get("repository_id") && ajxpNode.getMetadata().get("repository_id") != pydio.repositoryId){ repoString = "&tmp_repository_id=" + ajxpNode.getMetadata().get("repository_id"); } var mtimeString = ajxpNode.buildRandomSeed(); return pydio.Parameters.get('ajxpServerAccess') + repoString + mtimeString + "&get_action=preview_data_proxy&get_thumb=true&file="+encodeURIComponent(ajxpNode.getPath()); } static getOriginalSource(ajxpNode) { return pydio.Parameters.get('ajxpServerAccess')+'&action=preview_data_proxy'+ajxpNode.buildRandomSeed()+'&file='+encodeURIComponent(ajxpNode.getPath()); } static getSharedPreviewTemplate(node, link) { // Return string return ''; } static getRESTPreviewLinks(node) { return { "Original image": "", "Thumbnail (200px)": "&get_thumb=true&dimension=200" }; }*/ value: function componentWillReceiveProps(nextProps) { if (this.props.selectionPlaying !== nextProps.selectionPlaying) { if (nextProps.selectionPlaying) { this.pe = new PeriodicalExecuter(nextProps.onRequestSelectionPlay, 3); } else { this.pe && this.pe.stop(); } } } }, { key: 'render', value: function render() { var _props = this.props; var node = _props.node; var src = _props.src; var orientation = _props.orientation; var editorData = _props.editorData; if (!node) return null; var imageClassName = ['diaporama-image-main-block']; if (orientation) { imageClassName = [].concat(_toConsumableArray(imageClassName), ['ort-rotate-' + orientation]); } return _react2['default'].createElement( ContainerSizeProvider, null, function (_ref) { var containerWidth = _ref.containerWidth; var containerHeight = _ref.containerHeight; return _react2['default'].createElement( ImageSizeProvider, { url: src, node: node }, function (_ref2) { var imgWidth = _ref2.imgWidth; var imgHeight = _ref2.imgHeight; return _react2['default'].createElement(ExtendedImageContainer, { editorData: editorData, node: node, src: src, width: imgWidth, height: imgHeight, containerWidth: containerWidth, containerHeight: containerHeight, imgClassName: imageClassName.join(" "), style: { backgroundColor: '#424242' }, imgStyle: { boxShadow: 'rgba(0, 0, 0, 0.117647) 0px 1px 6px, rgba(0, 0, 0, 0.117647) 0px 1px 4px' } }); } ); } ); } }], [{ key: 'propTypes', get: function get() { return { node: _react2['default'].PropTypes.instanceOf(AjxpNode).isRequired }; } }]); return Editor; })(_react.PureComponent); var getSelectionFilter = function getSelectionFilter(node) { return node.getMetadata().get('is_image') === '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) }); }); }; var mapStateToProps = function mapStateToProps(state, props) { var tabs = state.tabs; var tab = tabs.filter(function (_ref3) { var editorData = _ref3.editorData; var node = _ref3.node; return (!editorData || editorData.id === props.editorData.id) && node.getPath() === props.node.getPath(); })[0] || {}; if (!tab) return props; var node = tab.node; var resolution = tab.resolution; return _extends({ orientation: resolution === 'hi' ? node.getMetadata().get("image_exif_orientation") : null }, props); }; exports['default'] = (0, _redux.compose)(withSelection(getSelection, getSelectionFilter), withResolution(sizes, function (node) { return node ? pydio.Parameters.get('ajxpServerAccess') + '&action=preview_data_proxy&file=' + encodeURIComponent(node.getPath()) : ""; }, function (node, dimension) { return node ? pydio.Parameters.get('ajxpServerAccess') + '&action=preview_data_proxy&get_thumb=true&dimension=' + dimension + '&file=' + encodeURIComponent(node.getPath()) : ""; }), (0, _reactRedux.connect)(mapStateToProps))(Editor); module.exports = exports['default'];