UNPKG

@cognitive-class/jupyterlab-cde-plugin

Version:

Drop-in Cognos Dashboard Embedded plugin for Jupyterlab

147 lines (130 loc) 13.6 kB
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":";;;;;;AAAA,OAAOA,YAAP,MAAyB,QAAzB;AACA,OAAOC,KAAP,IAAgBC,aAAhB,EAA+BC,QAA/B,QAA+C,OAA/C;AACA,OAAOC,SAAP,MAAsB,YAAtB;AACA,OAAOC,gBAAP,MAA6B,qBAA7B;AACA,OAAOC,gBAAP,MAA6B,sBAA7B;;AAEA,IAAMC,UAAU,IAAIP,YAAJ,EAAhB;;AAEA,OAAO,SAASQ,UAAT,GAAsB;AAC3BD,UAAQE,IAAR,CAAa,YAAb;AACD;;IAEoBC,S;;;;;;;;;;;;;;6LAQnBC,K,GAAQ;AACNC,oBAAc,KADR;AAENC,8BAAwB,KAFlB;AAGNC,qBAAe,EAHT;AAINC,cAAQ,IAJF;AAKNC,gBAAU;AALJ,K,QAmBRR,U,GAAa,YAAM;AACjB,YAAKS,QAAL,CAAc;AACZH,uBAAe,EADH;AAEZC,gBAAQ,IAFI;AAGZH,sBAAc;AAHF,OAAd;AAKD,K,QAEDM,W,GAAc,YAAM;AAClB,YAAKD,QAAL,CAAc;AACZL,sBAAc;AADF,OAAd;AAGD,K,QAEDO,yB,GAA4B,UAACC,IAAD,EAAU;AACpC,YAAKC,gBAAL,GAAwBD,IAAxB;AACD,K,QAEDE,yB,GAA4B,UAACF,IAAD,EAAU;AACpC,YAAKG,gBAAL,GAAwBH,IAAxB;AACD,K,QAEDI,U,GAAa,UAACV,aAAD,EAAmB;AAAA,wBACD,MAAKH,KADJ;AAAA,UACtBK,QADsB,eACtBA,QADsB;AAAA,UACZD,MADY,eACZA,MADY;;AAE9B,UAAI,CAACA,MAAD,IAAW,EAAEC,YAAYF,cAAcW,MAAd,GAAuB,CAArC,CAAf,EAAwD;AACxD,YAAKR,QAAL,CAAc;AACZL,sBAAc,KADF;AAEZC,gCAAwB,IAFZ;AAGZC;AAHY,OAAd;AAKD,K,QAEDY,oB,GAAuB,YAAM;AAC3B,YAAKT,QAAL,CAAc;AACZJ,gCAAwB,KADZ;AAEZC,uBAAe;AAFH,OAAd;AAID,K,QAEDa,Y,GAAe,YAAM;AACnB,YAAKV,QAAL,CAAc;AACZL,sBAAc,KADF;AAEZC,gCAAwB;AAFZ,OAAd;AAID,K,QAEDe,kB,GAAqB,UAACC,KAAD,EAAW;AAAA,UACtBC,MADsB,GACXD,KADW,CACtBC,MADsB;;AAE9B,UAAMC,QAAQD,OAAOE,IAAP,KAAgB,UAAhB,GAA6BF,OAAOG,OAApC,GAA8CH,OAAOC,KAAnE;AAF8B,UAGtBG,IAHsB,GAGbJ,MAHa,CAGtBI,IAHsB;;;AAK9B,YAAKjB,QAAL,qBACGiB,IADH,EACUH,KADV;AAGD,K;;;;;wCAjEmB;AAClBxB,cAAQ4B,EAAR,CAAW,YAAX,EAAyB,KAAK3B,UAA9B;AACA,eAAS4B,UAAT,CAAoBC,CAApB,EAAuB;AAAE,eAAO,CAACC,SAASC,MAAT,CAAgBC,KAAhB,YAA+BH,CAA/B,kBAA+C,CAAhD,EAAmD,CAAnD,CAAP;AAA8D;AACvF,UAAMrB,WAAWoB,WAAW,UAAX,CAAjB;AACA,WAAKnB,QAAL,CAAc,EAAED,kBAAF,EAAd;AACD;;;2CAEsB;AACrBT,cAAQkC,cAAR,CAAuB,YAAvB,EAAqC,KAAKjC,UAA1C;AACD;;;6BA0DQ;AAAA,mBAIH,KAAKkC,KAJF;AAAA,UAELC,sBAFK,UAELA,sBAFK;AAAA,UAGLC,wBAHK,UAGLA,wBAHK;AAAA,mBAOH,KAAKjC,KAPF;AAAA,UAMLC,YANK,UAMLA,YANK;AAAA,UAMSC,sBANT,UAMSA,sBANT;AAAA,UAMiCE,MANjC,UAMiCA,MANjC;AAAA,UAMyCD,aANzC,UAMyCA,aANzC;AAAA,UAMwDE,QANxD,UAMwDA,QANxD;;;AASP,aACE;AAAC,gBAAD;AAAA;AACGJ,wBACC,oBAAC,gBAAD;AACE,oBAAU,KAAKO,yBADjB;AAEE,oBAAU,KAAKQ,YAFjB;AAGE,kBAAQ,KAAKH,UAHf;AAIE,iBAAOmB,sBAJT;AAKE,mBAASC,wBALX;AAME,wBAAc,KAAKhB,kBANrB;AAOE,oBAAUZ;AAPZ,UAFJ;AAYGH,kCACC,oBAAC,gBAAD;AACE,oBAAU,KAAKS,yBADjB;AAEE,oBAAU,KAAKK,YAFjB;AAGE,kBAAQ,KAAKD,oBAHf;AAIE,kBAAQX,MAJV;AAKE,yBAAeD,aALjB;AAME,oBAAUE;AANZ;AAbJ,OADF;AAyBD;;;;EArHoCd,a;;AAAlBQ,S,CACZmC,W,GAAc,W;AADFnC,S,CAGZoC,S,GAAY;AACjBH,0BAAwBvC,UAAUgB,IAAV,CAAe2B,UADtB;AAEjBH,4BAA0BxC,UAAUgB,IAAV,CAAe2B;AAFxB,C;eAHArC,S","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"]}