@cognitive-class/jupyterlab-cde-plugin
Version:
Drop-in Cognos Dashboard Embedded plugin for Jupyterlab
147 lines (130 loc) • 13.6 kB
JavaScript
import _defineProperty from 'babel-runtime/helpers/defineProperty';
import _Object$getPrototypeOf from 'babel-runtime/core-js/object/get-prototype-of';
import _classCallCheck from 'babel-runtime/helpers/classCallCheck';
import _createClass from 'babel-runtime/helpers/createClass';
import _possibleConstructorReturn from 'babel-runtime/helpers/possibleConstructorReturn';
import _inherits from 'babel-runtime/helpers/inherits';
import EventEmitter from 'events';
import React, { PureComponent, Fragment } from 'react';
import PropTypes from 'prop-types';
import PreferenceDialog from './preference-dialog';
import SourceMetaDialog from './source-meta-dialog';
var emitter = new EventEmitter();
export function openDialog() {
emitter.emit('openDialog');
}
var Container = function (_PureComponent) {
_inherits(Container, _PureComponent);
function Container() {
var _ref;
var _temp, _this, _ret;
_classCallCheck(this, Container);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Container.__proto__ || _Object$getPrototypeOf(Container)).call.apply(_ref, [this].concat(args))), _this), _this.state = {
isDialogOpen: false,
isSourceMetaDialogOpen: false,
selectedFiles: [],
csvUrl: null,
username: null
}, _this.openDialog = function () {
_this.setState({
selectedFiles: [],
csvUrl: null,
isDialogOpen: true
});
}, _this.closeDialog = function () {
_this.setState({
isDialogOpen: false
});
}, _this.handlePreferenceDialogRef = function (node) {
_this.preferenceDialog = node;
}, _this.handleSourceMetaDialogRef = function (node) {
_this.sourceMetaDialog = node;
}, _this.handleSave = function (selectedFiles) {
var _this$state = _this.state,
username = _this$state.username,
csvUrl = _this$state.csvUrl;
if (!csvUrl && !(username && selectedFiles.length > 0)) return;
_this.setState({
isDialogOpen: false,
isSourceMetaDialogOpen: true,
selectedFiles: selectedFiles
});
}, _this.handleSourceMetaSave = function () {
_this.setState({
isSourceMetaDialogOpen: false,
selectedFiles: []
});
}, _this.handleCancel = function () {
_this.setState({
isDialogOpen: false,
isSourceMetaDialogOpen: false
});
}, _this.handleCSVUrlChange = function (event) {
var target = event.target;
var value = target.type === 'checkbox' ? target.checked : target.value;
var name = target.name;
_this.setState(_defineProperty({}, name, value));
}, _temp), _possibleConstructorReturn(_this, _ret);
}
_createClass(Container, [{
key: 'componentDidMount',
value: function componentDidMount() {
emitter.on('openDialog', this.openDialog);
function readCookie(k) {
return (document.cookie.match('(^|; )' + k + '=([^;]*)') || 0)[2];
}
var username = readCookie('username');
this.setState({ username: username });
}
}, {
key: 'componentWillUnmount',
value: function componentWillUnmount() {
emitter.removeListener('openDialog', this.openDialog);
}
}, {
key: 'render',
value: function render() {
var _props = this.props,
preferencesDialogTitle = _props.preferencesDialogTitle,
preferencesDialogContent = _props.preferencesDialogContent;
var _state = this.state,
isDialogOpen = _state.isDialogOpen,
isSourceMetaDialogOpen = _state.isSourceMetaDialogOpen,
csvUrl = _state.csvUrl,
selectedFiles = _state.selectedFiles,
username = _state.username;
return React.createElement(
Fragment,
null,
isDialogOpen && React.createElement(PreferenceDialog, {
innerRef: this.handlePreferenceDialogRef,
onCancel: this.handleCancel,
onSave: this.handleSave,
title: preferencesDialogTitle,
content: preferencesDialogContent,
handleChange: this.handleCSVUrlChange,
username: username
}),
isSourceMetaDialogOpen && React.createElement(SourceMetaDialog, {
innerRef: this.handleSourceMetaDialogRef,
onCancel: this.handleCancel,
onSave: this.handleSourceMetaSave,
csvUrl: csvUrl,
selectedFiles: selectedFiles,
username: username
})
);
}
}]);
return Container;
}(PureComponent);
Container.displayName = 'Container';
Container.propTypes = {
preferencesDialogTitle: PropTypes.node.isRequired,
preferencesDialogContent: PropTypes.node.isRequired
};
export default Container;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/source-manager/container.js"],"names":["EventEmitter","React","PureComponent","Fragment","PropTypes","PreferenceDialog","SourceMetaDialog","emitter","openDialog","emit","Container","state","isDialogOpen","isSourceMetaDialogOpen","selectedFiles","csvUrl","username","setState","closeDialog","handlePreferenceDialogRef","node","preferenceDialog","handleSourceMetaDialogRef","sourceMetaDialog","handleSave","length","handleSourceMetaSave","handleCancel","handleCSVUrlChange","event","target","value","type","checked","name","on","readCookie","k","document","cookie","match","removeListener","props","preferencesDialogTitle","preferencesDialogContent","displayName","propTypes","isRequired"],"mappings":"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","file":"container.js","sourcesContent":["import EventEmitter from 'events'\nimport React, { PureComponent, Fragment } from 'react'\nimport PropTypes from 'prop-types'\nimport PreferenceDialog from './preference-dialog'\nimport SourceMetaDialog from './source-meta-dialog'\n\nconst emitter = new EventEmitter()\n\nexport function openDialog() {\n  emitter.emit('openDialog')\n}\n\nexport default class Container extends PureComponent {\n  static displayName = 'Container'\n\n  static propTypes = {\n    preferencesDialogTitle: PropTypes.node.isRequired,\n    preferencesDialogContent: PropTypes.node.isRequired,\n  }\n\n  state = {\n    isDialogOpen: false,\n    isSourceMetaDialogOpen: false,\n    selectedFiles: [],\n    csvUrl: null,\n    username: null,\n  }\n\n  componentDidMount() {\n    emitter.on('openDialog', this.openDialog)\n    function readCookie(k) { return (document.cookie.match(`(^|; )${k}=([^;]*)`) || 0)[2] }\n    const username = readCookie('username')\n    this.setState({ username })\n  }\n\n  componentWillUnmount() {\n    emitter.removeListener('openDialog', this.openDialog)\n  }\n\n  openDialog = () => {\n    this.setState({\n      selectedFiles: [],\n      csvUrl: null,\n      isDialogOpen: true,\n    })\n  }\n\n  closeDialog = () => {\n    this.setState({\n      isDialogOpen: false,\n    })\n  }\n\n  handlePreferenceDialogRef = (node) => {\n    this.preferenceDialog = node\n  }\n\n  handleSourceMetaDialogRef = (node) => {\n    this.sourceMetaDialog = node\n  }\n\n  handleSave = (selectedFiles) => {\n    const { username, csvUrl } = this.state\n    if (!csvUrl && !(username && selectedFiles.length > 0)) return\n    this.setState({\n      isDialogOpen: false,\n      isSourceMetaDialogOpen: true,\n      selectedFiles,\n    })\n  }\n\n  handleSourceMetaSave = () => {\n    this.setState({\n      isSourceMetaDialogOpen: false,\n      selectedFiles: [],\n    })\n  }\n\n  handleCancel = () => {\n    this.setState({\n      isDialogOpen: false,\n      isSourceMetaDialogOpen: false,\n    })\n  }\n\n  handleCSVUrlChange = (event) => {\n    const { target } = event\n    const value = target.type === 'checkbox' ? target.checked : target.value\n    const { name } = target\n\n    this.setState({\n      [name]: value,\n    })\n  }\n\n  render() {\n    const {\n      preferencesDialogTitle,\n      preferencesDialogContent,\n    } = this.props\n    const {\n      isDialogOpen, isSourceMetaDialogOpen, csvUrl, selectedFiles, username,\n    } = this.state\n\n    return (\n      <Fragment>\n        {isDialogOpen && (\n          <PreferenceDialog\n            innerRef={this.handlePreferenceDialogRef}\n            onCancel={this.handleCancel}\n            onSave={this.handleSave}\n            title={preferencesDialogTitle}\n            content={preferencesDialogContent}\n            handleChange={this.handleCSVUrlChange}\n            username={username}\n          />\n        )}\n        {isSourceMetaDialogOpen && (\n          <SourceMetaDialog\n            innerRef={this.handleSourceMetaDialogRef}\n            onCancel={this.handleCancel}\n            onSave={this.handleSourceMetaSave}\n            csvUrl={csvUrl}\n            selectedFiles={selectedFiles}\n            username={username}\n          />\n        )}\n      </Fragment>\n    )\n  }\n}\n"]}