UNPKG

@cognitive-class/jupyterlab-cde-plugin

Version:

Drop-in Cognos Dashboard Embedded plugin for Jupyterlab

188 lines (147 loc) 14.5 kB
'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"]}