UNPKG

focus-components-v3

Version:

Focus web components to build applications (based on Material Design)

183 lines (149 loc) 17.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _i18next = require('i18next'); var _i18next2 = _interopRequireDefault(_i18next); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } 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) : _defaults(subClass, superClass); } var DraggableIframe = function (_Component) { _inherits(DraggableIframe, _Component); function DraggableIframe(props) { _classCallCheck(this, DraggableIframe); var _this = _possibleConstructorReturn(this, _Component.call(this, props)); _this.dragInit = function (e) { e.preventDefault(); document.onmousemove = _this.moveElem; document.onmouseup = _this.destroy; _this.setState({ xPos: e.pageX, yPos: e.pageY, selected: _this.refs.helpFrame, xElem: e.pageX - _this.refs.helpFrame.offsetLeft, yElem: e.pageY - _this.refs.helpFrame.offsetTop }); }; _this.moveElem = function (e) { var _this$state = _this.state, xPos = _this$state.xPos, yPos = _this$state.yPos, xElem = _this$state.xElem, yElem = _this$state.yElem, selected = _this$state.selected; _this.setState({ xPos: e.pageX, yPos: e.pageY }); if (selected !== null) { selected.style.left = xPos - xElem + 'px'; selected.style.top = yPos - yElem + 'px'; } }; _this.destroy = function (e) { e.preventDefault(); document.onmousemove = null; document.onmouseup = null; _this.setState({ selected: null }); }; _this.toggle = function () { for (var _len = arguments.length, params = Array(_len), _key = 0; _key < _len; _key++) { params[_key] = arguments[_key]; } var _this$state2 = _this.state, oldPos = _this$state2.yPos, isShown = _this$state2.isShown, yElem = _this$state2.yElem; var _window = window, pageYOffset = _window.pageYOffset, outerHeight = _window.outerHeight; var yPos = isShown ? oldPos : pageYOffset > oldPos ? pageYOffset + 50 : pageYOffset + outerHeight < oldPos ? pageYOffset + outerHeight - _this.props.height - 100 : oldPos; _this.setState({ isShown: !_this.state.isShown, params: params, yPos: yPos }); _this.refs.helpFrame.style.top = yPos - yElem + 'px'; }; if (props.toggleFunctionName) { window[props.toggleFunctionName] = _this.toggle; } _this.state = { isShown: false, params: [], xPos: 0, yPos: 0, xElem: 0, yElem: 0, selected: null }; return _this; } DraggableIframe.prototype.render = function render() { var _props = this.props, title = _props.title, iframeUrl = _props.iframeUrl, width = _props.width, height = _props.height, queryUrl = _props.queryUrl; var _state = this.state, selected = _state.selected, isShown = _state.isShown, params = _state.params; var url = iframeUrl + params.map(function (param, i) { return typeof queryUrl[i] === 'string' ? queryUrl[i] + param : ''; }).join(''); return _react2.default.createElement( 'div', { className: 'help-frame ' + (selected ? 'is-dragging' : ''), onMouseDown: this.dragInit, ref: 'helpFrame', style: { width: width, display: isShown ? 'block' : 'none' } }, _react2.default.createElement( 'span', { className: 'help-center-title' }, _i18next2.default.t(title) ), _react2.default.createElement( 'div', { className: 'mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect close-icon', onClick: this.toggle }, _react2.default.createElement( 'i', { className: 'material-icons' }, 'close' ) ), _react2.default.createElement('br', null), _react2.default.createElement(IFrame, { height: height, src: url, width: width }) ); }; return DraggableIframe; }(_react.Component); DraggableIframe.displayName = 'DraggableIframe'; DraggableIframe.propTypes = { iframeUrl: _react.PropTypes.string.isRequired, width: _react.PropTypes.number.isRequired, height: _react.PropTypes.number.isRequired, title: _react.PropTypes.string.isRequired, toggleFunctionName: _react.PropTypes.string.isRequired, queryUrl: _react.PropTypes.array }; exports.default = DraggableIframe; var IFrame = function (_Component2) { _inherits(IFrame, _Component2); function IFrame() { _classCallCheck(this, IFrame); return _possibleConstructorReturn(this, _Component2.apply(this, arguments)); } IFrame.prototype.shouldComponentUpdate = function shouldComponentUpdate(_ref) { var src = _ref.src; return src !== this.props.src; }; IFrame.prototype.render = function render() { var _props2 = this.props, height = _props2.height, src = _props2.src, width = _props2.width; return _react2.default.createElement('iframe', { frameBorder: 0, height: height, src: src, width: width }); }; return IFrame; }(_react.Component); module.exports = exports['default']; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["fr-FR.js"],"names":["DraggableIframe","props","dragInit","e","preventDefault","document","onmousemove","moveElem","onmouseup","destroy","setState","xPos","pageX","yPos","pageY","selected","refs","helpFrame","xElem","offsetLeft","yElem","offsetTop","state","style","left","top","toggle","params","oldPos","isShown","window","pageYOffset","outerHeight","height","toggleFunctionName","render","title","iframeUrl","width","queryUrl","url","map","param","i","join","display","t","displayName","propTypes","string","isRequired","number","array","IFrame","shouldComponentUpdate","src"],"mappings":"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","file":"fr-FR.js","sourcesContent":["import React, {Component, PropTypes} from 'react';\r\nimport i18next from 'i18next';\r\n\r\nclass DraggableIframe extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        if (props.toggleFunctionName) {\r\n            window[props.toggleFunctionName] = this.toggle;\r\n        }\r\n        this.state = {\r\n            isShown: false,\r\n            params: [],\r\n            xPos: 0,\r\n            yPos: 0,\r\n            xElem: 0,\r\n            yElem: 0,\r\n            selected: null\r\n        };\r\n    };\r\n\r\n\r\n    dragInit = (e) => {\r\n        e.preventDefault();\r\n        document.onmousemove = this.moveElem;\r\n        document.onmouseup = this.destroy;\r\n        this.setState({\r\n            xPos: e.pageX,\r\n            yPos: e.pageY,\r\n            selected: this.refs.helpFrame,\r\n            xElem: e.pageX - this.refs.helpFrame.offsetLeft,\r\n            yElem: e.pageY - this.refs.helpFrame.offsetTop\r\n        });\r\n    };\r\n\r\n    moveElem = (e) => {\r\n        const {xPos, yPos, xElem, yElem, selected} = this.state;\r\n        this.setState({\r\n            xPos: e.pageX,\r\n            yPos: e.pageY\r\n        });\r\n        if (selected !== null) {\r\n            selected.style.left = (xPos - xElem) + 'px';\r\n            selected.style.top = (yPos - yElem) + 'px';\r\n        }\r\n    };\r\n\r\n    destroy = (e) => {\r\n        e.preventDefault();\r\n        document.onmousemove = null;\r\n        document.onmouseup = null;\r\n        this.setState({selected: null});\r\n    };\r\n\r\n    toggle = (...params) => {\r\n        const {yPos: oldPos, isShown, yElem} = this.state;\r\n        const {pageYOffset, outerHeight} = window;\r\n        const yPos = isShown ? oldPos : pageYOffset > oldPos ? pageYOffset + 50 : pageYOffset + outerHeight < oldPos ? pageYOffset + outerHeight - this.props.height - 100 : oldPos;\r\n        this.setState({isShown: !this.state.isShown, params, yPos});\r\n        this.refs.helpFrame.style.top = (yPos - yElem) + 'px';\r\n    }\r\n\r\n    render() {\r\n        const {title, iframeUrl, width, height, queryUrl} = this.props;\r\n        const {selected, isShown, params} = this.state;\r\n        const url = iframeUrl + params.map((param, i) => typeof queryUrl[i] === 'string' ? queryUrl[i] + param : '').join('');\r\n        return (\r\n            <div className={`help-frame ${selected ? 'is-dragging' : ''}`} onMouseDown={this.dragInit} ref='helpFrame' style={{width, display: isShown ? 'block' : 'none'}}>\r\n                <span className='help-center-title'>{i18next.t(title)}</span>\r\n                <div className='mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect close-icon' onClick={this.toggle}>\r\n                    <i className='material-icons'>close</i>\r\n                </div>\r\n                <br />\r\n                <IFrame height={height} src={url} width={width} />\r\n            </div>\r\n        );\r\n    }\r\n}\r\nDraggableIframe.displayName = 'DraggableIframe';\r\nDraggableIframe.propTypes = {\r\n    iframeUrl: PropTypes.string.isRequired,\r\n    width: PropTypes.number.isRequired,\r\n    height: PropTypes.number.isRequired,\r\n    title: PropTypes.string.isRequired,\r\n    toggleFunctionName: PropTypes.string.isRequired,\r\n    queryUrl: PropTypes.array\r\n};\r\nexport default DraggableIframe;\r\n\r\nclass IFrame extends Component {\r\n    shouldComponentUpdate({src}) {\r\n        return src !== this.props.src;\r\n    }\r\n\r\n    render() {\r\n        const {height, src, width} = this.props;\r\n        return <iframe frameBorder={0} height={height} src={src} width={width} />;\r\n    }\r\n}\r\n"]}