@cognitive-class/jupyterlab-cde-plugin
Version:
Drop-in Cognos Dashboard Embedded plugin for Jupyterlab
188 lines (147 loc) • 14.5 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
exports.openDialog = openDialog;
var _events = require('events');
var _events2 = _interopRequireDefault(_events);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _preferenceDialog = require('./preference-dialog');
var _preferenceDialog2 = _interopRequireDefault(_preferenceDialog);
var _sourceMetaDialog = require('./source-meta-dialog');
var _sourceMetaDialog2 = _interopRequireDefault(_sourceMetaDialog);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var emitter = new _events2.default();
function openDialog() {
emitter.emit('openDialog');
}
var Container = function (_PureComponent) {
(0, _inherits3.default)(Container, _PureComponent);
function Container() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, Container);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = Container.__proto__ || (0, _getPrototypeOf2.default)(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((0, _defineProperty3.default)({}, name, value));
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(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 _react2.default.createElement(
_react.Fragment,
null,
isDialogOpen && _react2.default.createElement(_preferenceDialog2.default, {
innerRef: this.handlePreferenceDialogRef,
onCancel: this.handleCancel,
onSave: this.handleSave,
title: preferencesDialogTitle,
content: preferencesDialogContent,
handleChange: this.handleCSVUrlChange,
username: username
}),
isSourceMetaDialogOpen && _react2.default.createElement(_sourceMetaDialog2.default, {
innerRef: this.handleSourceMetaDialogRef,
onCancel: this.handleCancel,
onSave: this.handleSourceMetaSave,
csvUrl: csvUrl,
selectedFiles: selectedFiles,
username: username
})
);
}
}]);
return Container;
}(_react.PureComponent);
Container.displayName = 'Container';
Container.propTypes = {
preferencesDialogTitle: _propTypes2.default.node.isRequired,
preferencesDialogContent: _propTypes2.default.node.isRequired
};
exports.default = Container;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/source-manager/container.js"],"names":["openDialog","emitter","EventEmitter","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","PureComponent","displayName","propTypes","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"]}