focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
183 lines (149 loc) • 17.8 kB
JavaScript
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"]}
;