@cognitive-class/jupyterlab-cde-plugin
Version:
Drop-in Cognos Dashboard Embedded plugin for Jupyterlab
232 lines (200 loc) • 19.5 kB
JavaScript
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"]}