UNPKG

@cognitive-class/jupyterlab-cde-plugin

Version:

Drop-in Cognos Dashboard Embedded plugin for Jupyterlab

232 lines (200 loc) 19.5 kB
import _extends from 'babel-runtime/helpers/extends'; import _regeneratorRuntime from 'babel-runtime/regenerator'; import _toConsumableArray from 'babel-runtime/helpers/toConsumableArray'; import _asyncToGenerator from 'babel-runtime/helpers/asyncToGenerator'; 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 React, { PureComponent } from 'react'; import PropTypes from 'prop-types'; import Tree from 'antd/lib/tree'; import Spin from 'antd/lib/spin'; import Form from 'antd/lib/form'; import Input from 'antd/lib/input'; import Dialog from './dialog'; require('antd/lib/tree/style/index.css'); require('antd/lib/spin/style/index.css'); require('./preference-dialog.scss'); var TreeNode = Tree.TreeNode, DirectoryTree = Tree.DirectoryTree; var FormItem = Form.Item; var transformFileListToTreeData = function transformFileListToTreeData(fileList) { var treeData = []; fileList.forEach(function (_ref) { var type = _ref.type, name = _ref.name, path = _ref.path, mimetype = _ref.mimetype; if (type === 'file') { treeData.push({ title: name, key: path, mimetype: mimetype, isLeaf: true }); } else if (type === 'directory') { treeData.unshift({ title: name, key: path, mimetype: mimetype, isLeaf: false }); } }); return treeData; }; var PreferenceDialog = function (_PureComponent) { _inherits(PreferenceDialog, _PureComponent); function PreferenceDialog() { var _ref2, _this2 = this; var _temp, _this, _ret; _classCallCheck(this, PreferenceDialog); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref2 = PreferenceDialog.__proto__ || _Object$getPrototypeOf(PreferenceDialog)).call.apply(_ref2, [this].concat(args))), _this), _this.state = { treeData: [], selectedFiles: [] }, _this.onLoadData = function () { var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(_ref4) { var _ref4$props = _ref4.props, dataRef = _ref4$props.dataRef, eventKey = _ref4$props.eventKey, children = _ref4$props.children; var resp, _ref5, content, treeData; return _regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: if (!children) { _context.next = 2; break; } return _context.abrupt('return'); case 2: _context.next = 4; return fetch('/user-redirect/api/contents/' + eventKey, { cache: 'no-cache', mode: 'cors', credentials: 'include' }); case 4: resp = _context.sent; _context.next = 7; return resp.json(); case 7: _ref5 = _context.sent; content = _ref5.content; // eslint-disable-next-line no-param-reassign dataRef.children = transformFileListToTreeData(content); treeData = _this.state.treeData; _this.setState({ treeData: [].concat(_toConsumableArray(treeData)) }); case 12: case 'end': return _context.stop(); } } }, _callee, _this2); })); return function (_x) { return _ref3.apply(this, arguments); }; }(), _this.handleSelect = function (selectedKeys, e) { var selectedNodes = e.selectedNodes; var selectedFiles = selectedNodes.filter(function (_ref6) { var _ref6$props$isLeaf = _ref6.props.isLeaf, isLeaf = _ref6$props$isLeaf === undefined ? false : _ref6$props$isLeaf; return isLeaf; }).map(function (_ref7) { var key = _ref7.key; return key; }); _this.setState({ selectedFiles: selectedFiles }); }, _this.handleSubmit = function (e) { e.preventDefault(); var selectedFiles = _this.state.selectedFiles; var onSave = _this.props.onSave; onSave(selectedFiles); }, _this.renderTreeNodes = function (data) { return data.map(function (item) { if (item.children) { return React.createElement( TreeNode, { title: item.title, key: item.key, dataRef: item, mimetype: item.mimetype, disabled: true }, _this.renderTreeNodes(item.children) ); } return React.createElement(TreeNode, _extends({}, item, { dataRef: item, mimetype: item.mimetype, selectable: item.mimetype === 'text/csv' })); }); }, _temp), _possibleConstructorReturn(_this, _ret); } _createClass(PreferenceDialog, [{ key: 'componentDidMount', value: function componentDidMount() { var _this3 = this; fetch('/user-redirect/api/contents', { cache: 'no-cache', mode: 'cors', credentials: 'include' }).then(function (resp) { return resp.json(); }).then(function (_ref8) { var content = _ref8.content; var treeData = transformFileListToTreeData(content); _this3.setState({ treeData: treeData }); }); } }, { key: 'render', value: function render() { var _props = this.props, innerRef = _props.innerRef, onCancel = _props.onCancel, title = _props.title, content = _props.content, handleChange = _props.handleChange, username = _props.username; var treeData = this.state.treeData; return React.createElement( Dialog, { innerRef: innerRef, title: title, onCancel: onCancel, onSubmit: this.handleSubmit, okText: 'Next' }, content, React.createElement( Form, { layout: 'horizontal' }, React.createElement( FormItem, { label: 'CSV File URL' }, React.createElement(Input, { placeholder: 'https://gist.github.com/username/file.csv', name: 'csvUrl', onChange: handleChange }) ), React.createElement( FormItem, { label: 'Or select a file from public folder below' }, React.createElement(Input, { placeholder: 'Your CC Labs Username', name: 'username', value: username, disabled: true }) ) ), treeData.length ? React.createElement( DirectoryTree, { onSelect: this.handleSelect, loadData: this.onLoadData }, this.renderTreeNodes(treeData) ) : React.createElement( 'div', { className: 'spin' }, React.createElement(Spin, null) ) ); } }]); return PreferenceDialog; }(PureComponent); PreferenceDialog.displayName = 'PreferenceDialog'; PreferenceDialog.propTypes = { innerRef: PropTypes.func.isRequired, onCancel: PropTypes.func.isRequired, onSave: PropTypes.func.isRequired, title: PropTypes.node.isRequired, content: PropTypes.node.isRequired, handleChange: PropTypes.func.isRequired }; export default PreferenceDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/source-manager/preference-dialog.js"],"names":["React","PureComponent","PropTypes","Tree","Spin","Form","Input","Dialog","require","TreeNode","DirectoryTree","FormItem","Item","transformFileListToTreeData","fileList","treeData","forEach","type","name","path","mimetype","push","title","key","isLeaf","unshift","PreferenceDialog","state","selectedFiles","onLoadData","props","dataRef","eventKey","children","fetch","cache","mode","credentials","resp","json","content","setState","handleSelect","selectedKeys","e","selectedNodes","filter","map","handleSubmit","preventDefault","onSave","renderTreeNodes","data","item","then","innerRef","onCancel","handleChange","username","length","displayName","propTypes","func","isRequired","node"],"mappings":"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","file":"preference-dialog.js","sourcesContent":["import React, { PureComponent } from 'react'\nimport PropTypes from 'prop-types'\nimport Tree from 'antd/lib/tree'\nimport Spin from 'antd/lib/spin'\nimport Form from 'antd/lib/form'\nimport Input from 'antd/lib/input'\nimport Dialog from './dialog'\n\nrequire('antd/lib/tree/style/index.css')\nrequire('antd/lib/spin/style/index.css')\nrequire('./preference-dialog.scss')\n\nconst { TreeNode, DirectoryTree } = Tree\n\nconst FormItem = Form.Item\n\nconst transformFileListToTreeData = (fileList) => {\n  const treeData = []\n  fileList.forEach(({\n    type, name, path, mimetype,\n  }) => {\n    if (type === 'file') {\n      treeData.push({\n        title: name, key: path, mimetype, isLeaf: true,\n      })\n    } else if (type === 'directory') {\n      treeData.unshift({\n        title: name, key: path, mimetype, isLeaf: false,\n      })\n    }\n  })\n  return treeData\n}\n\nexport default class PreferenceDialog extends PureComponent {\n  static displayName = 'PreferenceDialog'\n\n  static propTypes = {\n    innerRef: PropTypes.func.isRequired,\n    onCancel: PropTypes.func.isRequired,\n    onSave: PropTypes.func.isRequired,\n    title: PropTypes.node.isRequired,\n    content: PropTypes.node.isRequired,\n    handleChange: PropTypes.func.isRequired,\n  }\n\n  state = {\n    treeData: [],\n    selectedFiles: [],\n  }\n\n  componentDidMount() {\n    fetch('/user-redirect/api/contents', { cache: 'no-cache', mode: 'cors', credentials: 'include' })\n      .then(resp => resp.json())\n      .then(({ content }) => {\n        const treeData = transformFileListToTreeData(content)\n        this.setState({ treeData })\n      })\n  }\n\n  onLoadData = async ({\n    props: {\n      dataRef, eventKey, children,\n    },\n  }) => {\n    if (children) {\n      return\n    }\n    const resp = await fetch(`/user-redirect/api/contents/${eventKey}`, { cache: 'no-cache', mode: 'cors', credentials: 'include' })\n    const { content } = await resp.json()\n    // eslint-disable-next-line no-param-reassign\n    dataRef.children = transformFileListToTreeData(content)\n    const { treeData } = this.state\n    this.setState({\n      treeData: [...treeData],\n    })\n  }\n\n  handleSelect = (selectedKeys, e) => {\n    const { selectedNodes } = e\n    const selectedFiles = selectedNodes.filter(({ props: { isLeaf = false } }) => isLeaf).map(({ key }) => key)\n    this.setState({ selectedFiles })\n  }\n\n  handleSubmit = (e) => {\n    e.preventDefault()\n\n    const { selectedFiles } = this.state\n    const { onSave } = this.props\n    onSave(selectedFiles)\n  }\n\n  renderTreeNodes = data => data.map((item) => {\n    if (item.children) {\n      return (\n        <TreeNode title={item.title} key={item.key} dataRef={item} mimetype={item.mimetype} disabled>\n          {this.renderTreeNodes(item.children)}\n        </TreeNode>\n      )\n    }\n    return <TreeNode {...item} dataRef={item} mimetype={item.mimetype} selectable={item.mimetype === 'text/csv'} />\n  })\n\n  render() {\n    const {\n      innerRef,\n      onCancel,\n      title,\n      content,\n      handleChange,\n      username,\n    } = this.props\n\n    const { treeData } = this.state\n\n    return (\n      <Dialog\n        innerRef={innerRef}\n        title={title}\n        onCancel={onCancel}\n        onSubmit={this.handleSubmit}\n        okText=\"Next\"\n      >\n        {content}\n        <Form layout=\"horizontal\">\n          <FormItem label=\"CSV File URL\">\n            <Input placeholder=\"https://gist.github.com/username/file.csv\" name=\"csvUrl\" onChange={handleChange} />\n          </FormItem>\n          <FormItem label=\"Or select a file from public folder below\">\n            <Input placeholder=\"Your CC Labs Username\" name=\"username\" value={username} disabled />\n          </FormItem>\n        </Form>\n        {treeData.length\n          ? (\n            <DirectoryTree\n              onSelect={this.handleSelect}\n              loadData={this.onLoadData}\n            >\n              {this.renderTreeNodes(treeData)}\n            </DirectoryTree>)\n          : <div className=\"spin\"><Spin /></div>}\n      </Dialog>\n    )\n  }\n}\n"]}