UNPKG

@cognitive-class/jupyterlab-cde-plugin

Version:

Drop-in Cognos Dashboard Embedded plugin for Jupyterlab

273 lines (217 loc) 21.7 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _regenerator = require('babel-runtime/regenerator'); var _regenerator2 = _interopRequireDefault(_regenerator); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _asyncToGenerator2 = require('babel-runtime/helpers/asyncToGenerator'); var _asyncToGenerator3 = _interopRequireDefault(_asyncToGenerator2); 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); var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _papaparse = require('papaparse'); var _papaparse2 = _interopRequireDefault(_papaparse); var _spin = require('antd/lib/spin'); var _spin2 = _interopRequireDefault(_spin); var _notification = require('antd/lib/notification'); var _notification2 = _interopRequireDefault(_notification); var _dialog = require('./dialog'); var _dialog2 = _interopRequireDefault(_dialog); var _sourceMetaForm = require('./source-meta-form'); var _sourceMetaForm2 = _interopRequireDefault(_sourceMetaForm); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } require('antd/lib/spin/style/index.css'); require('antd/lib/notification/style/index.css'); var SourceMetaDialog = function (_PureComponent) { (0, _inherits3.default)(SourceMetaDialog, _PureComponent); function SourceMetaDialog() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, SourceMetaDialog); 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 = SourceMetaDialog.__proto__ || (0, _getPrototypeOf2.default)(SourceMetaDialog)).call.apply(_ref, [this].concat(args))), _this), _this.formRef = _react2.default.createRef(), _this.state = { data: null, previewData: null, toggleAdvanceOption: false, previewColumns: null }, _this.handleToggle = function () { var toggleAdvanceOption = _this.state.toggleAdvanceOption; _this.setState({ toggleAdvanceOption: !toggleAdvanceOption }); }, _this.handleSubmit = function (e) { e.preventDefault(); var onSave = _this.props.onSave; var values = _this.formRef.current.state.values; values.table.column.forEach(function (each, index) { values.table.column[index].label = each.name; }); window.currentDashboard.addSources([{ module: values, name: values.table.name, id: values.source.id }]); onSave(); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(SourceMetaDialog, [{ key: 'componentDidMount', value: function () { var _ref2 = (0, _asyncToGenerator3.default)( /*#__PURE__*/_regenerator2.default.mark(function _callee() { var _props, selectedFiles, username, csvUrl, onCancel, requestUrl, fileContent, sourcePlaceholder, sourceId, previewData, previewColumns; return _regenerator2.default.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _props = this.props, selectedFiles = _props.selectedFiles, username = _props.username, csvUrl = _props.csvUrl, onCancel = _props.onCancel; requestUrl = csvUrl || 'https://labs-api.cognitiveclass.ai/users/' + username + '/files/' + selectedFiles[0]; _context.next = 4; return fetch('/user-redirect/cognos/filePreview?url=' + requestUrl, { credentials: 'include' }).then(function (resp) { return resp.text(); }).then(function (data) { return _papaparse2.default.parse(data); }); case 4: fileContent = _context.sent; if (!(fileContent.errors.length > 0)) { _context.next = 9; break; } _notification2.default.error({ message: 'File Does Not Exists' }); onCancel(); return _context.abrupt('return'); case 9: sourcePlaceholder = []; sourceId = (Date.now().toString(36) + Math.random().toString(36).substr(2, 5)).toUpperCase(); // eslint-disable-next-line no-return-assign fileContent.data[0].forEach(function (item, index) { return sourcePlaceholder[index] = { name: item, datatype: 'Text', description: '', label: item, usage: 'attribute', regularAggregate: 'none', taxonomyFamily: 'cNone' }; }); // fileContent.data[1].forEach((item, index) => { // // eslint-disable-next-line no-restricted-globals // if (!isNaN(item)) { // sourcePlaceholder[index].datatype = 'NUMERIC' // } // }) previewData = []; fileContent.data.forEach(function (row, index) { var obj = {}; obj.key = index; obj.width = 150; row.forEach(function (item, innerIndex) { obj['column_' + innerIndex] = item; }); previewData.push(obj); }); previewColumns = fileContent.data[0].map(function (item, index) { return { title: 'Column ' + (index + 1), dataIndex: 'column_' + index, key: 'column_' + index }; }); this.setState({ previewData: previewData, previewColumns: previewColumns, data: (0, _extends3.default)({}, this.state.data, { xsd: 'https://ibm.com/daas/module/1.0/module.xsd', source: { id: sourceId, srcUrl: { sourceUrl: requestUrl, mimeType: 'text/csv' } }, table: { name: 'table_' + sourceId, column: sourcePlaceholder }, label: 'Module Name', identifier: 'moduleId' }) }); case 16: case 'end': return _context.stop(); } } }, _callee, this); })); function componentDidMount() { return _ref2.apply(this, arguments); } return componentDidMount; }() }, { key: 'render', value: function render() { var _props2 = this.props, content = _props2.content, onCancel = _props2.onCancel, innerRef = _props2.innerRef; var _state = this.state, data = _state.data, previewData = _state.previewData, previewColumns = _state.previewColumns, toggleAdvanceOption = _state.toggleAdvanceOption; return _react2.default.createElement( _dialog2.default, { innerRef: innerRef, title: 'Edit source metadata', onCancel: onCancel, onSubmit: this.handleSubmit, okText: 'Ok', width: '60vw' }, content, data ? _react2.default.createElement(_sourceMetaForm2.default, { isToggled: toggleAdvanceOption, handleToggle: this.handleToggle, data: data, formRef: this.formRef, previewColumns: previewColumns, previewData: previewData }) : _react2.default.createElement( 'div', { style: { textAlign: 'center' } }, _react2.default.createElement(_spin2.default, { size: 'large' }) ) ); } }]); return SourceMetaDialog; }(_react.PureComponent); SourceMetaDialog.displayName = 'SourceMetaDialog'; SourceMetaDialog.propTypes = { innerRef: _propTypes2.default.func.isRequired, onCancel: _propTypes2.default.func.isRequired, onSave: _propTypes2.default.func.isRequired, content: _propTypes2.default.node.isRequired // selectedFiles: PropTypes.arrayOf(PropTypes.string).isRequired, }; exports.default = SourceMetaDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/source-manager/source-meta-dialog.js"],"names":["require","SourceMetaDialog","formRef","React","createRef","state","data","previewData","toggleAdvanceOption","previewColumns","handleToggle","setState","handleSubmit","e","preventDefault","onSave","props","values","current","table","column","forEach","each","index","label","name","window","currentDashboard","addSources","module","id","source","selectedFiles","username","csvUrl","onCancel","requestUrl","fetch","credentials","then","resp","text","Papa","parse","fileContent","errors","length","notification","error","message","sourcePlaceholder","sourceId","Date","now","toString","Math","random","substr","toUpperCase","item","datatype","description","usage","regularAggregate","taxonomyFamily","row","obj","key","width","innerIndex","push","map","title","dataIndex","xsd","srcUrl","sourceUrl","mimeType","identifier","content","innerRef","textAlign","PureComponent","displayName","propTypes","PropTypes","func","isRequired","node"],"mappings":"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","file":"source-meta-dialog.js","sourcesContent":["import React, { PureComponent } from 'react'\nimport PropTypes from 'prop-types'\nimport Papa from 'papaparse'\nimport Spin from 'antd/lib/spin'\nimport notification from 'antd/lib/notification'\nimport Dialog from './dialog'\nimport SourceMetaForm from './source-meta-form'\n\nrequire('antd/lib/spin/style/index.css')\nrequire('antd/lib/notification/style/index.css')\n\nexport default class SourceMetaDialog extends PureComponent {\n  formRef = React.createRef()\n\n  static displayName = 'SourceMetaDialog'\n\n  static propTypes = {\n    innerRef: PropTypes.func.isRequired,\n    onCancel: PropTypes.func.isRequired,\n    onSave: PropTypes.func.isRequired,\n    content: PropTypes.node.isRequired,\n    // selectedFiles: PropTypes.arrayOf(PropTypes.string).isRequired,\n  }\n\n  state = {\n    data: null,\n    previewData: null,\n    toggleAdvanceOption: false,\n    previewColumns: null,\n  }\n\n  async componentDidMount() {\n    const {\n      selectedFiles, username, csvUrl, onCancel,\n    } = this.props\n\n    const requestUrl = csvUrl || `https://labs-api.cognitiveclass.ai/users/${username}/files/${selectedFiles[0]}`\n\n    const fileContent = await fetch(`/user-redirect/cognos/filePreview?url=${requestUrl}`, { credentials: 'include' }).then(resp => resp.text()).then(data => Papa.parse(data))\n\n\n    if (fileContent.errors.length > 0) {\n      notification.error({\n        message: 'File Does Not Exists',\n      })\n      onCancel()\n      return\n    }\n\n    const sourcePlaceholder = []\n    const sourceId = (Date.now().toString(36) + Math.random().toString(36).substr(2, 5)).toUpperCase()\n    // eslint-disable-next-line no-return-assign\n    fileContent.data[0].forEach((item, index) => sourcePlaceholder[index] = {\n      name: item,\n      datatype: 'Text',\n      description: '',\n      label: item,\n      usage: 'attribute',\n      regularAggregate: 'none',\n      taxonomyFamily: 'cNone',\n    })\n    // fileContent.data[1].forEach((item, index) => {\n    //   // eslint-disable-next-line no-restricted-globals\n    //   if (!isNaN(item)) {\n    //     sourcePlaceholder[index].datatype = 'NUMERIC'\n    //   }\n    // })\n    const previewData = []\n    fileContent.data.forEach((row, index) => {\n      const obj = {}\n      obj.key = index\n      obj.width = 150\n      row.forEach((item, innerIndex) => {\n        obj[`column_${innerIndex}`] = item\n      })\n      previewData.push(obj)\n    })\n    const previewColumns = fileContent.data[0].map((item, index) => ({\n      title: `Column ${index + 1}`,\n      dataIndex: `column_${index}`,\n      key: `column_${index}`,\n    }))\n    this.setState({\n      previewData,\n      previewColumns,\n      data: {\n        ...this.state.data,\n        xsd: 'https://ibm.com/daas/module/1.0/module.xsd',\n        source: {\n          id: sourceId,\n          srcUrl: {\n            sourceUrl: requestUrl,\n            mimeType: 'text/csv',\n          },\n        },\n        table: {\n          name: `table_${sourceId}`,\n          column: sourcePlaceholder,\n        },\n        label: 'Module Name',\n        identifier: 'moduleId',\n      },\n    })\n  }\n\n  handleToggle = () => {\n    const { toggleAdvanceOption } = this.state\n    this.setState({ toggleAdvanceOption: !toggleAdvanceOption })\n  }\n\n  handleSubmit = (e) => {\n    e.preventDefault()\n    const { onSave } = this.props\n    const { values } = this.formRef.current.state\n    values.table.column.forEach((each, index) => {\n      values.table.column[index].label = each.name\n    })\n    window.currentDashboard.addSources([{\n      module: values,\n      name: values.table.name,\n      id: values.source.id,\n    }])\n    onSave()\n  }\n\n  render() {\n    const {\n      content,\n      onCancel,\n      innerRef,\n    } = this.props\n\n    const {\n      data, previewData, previewColumns, toggleAdvanceOption,\n    } = this.state\n\n    return (\n      <Dialog\n        innerRef={innerRef}\n        title=\"Edit source metadata\"\n        onCancel={onCancel}\n        onSubmit={this.handleSubmit}\n        okText=\"Ok\"\n        width=\"60vw\"\n      >\n        {content}\n        {data\n          ? (\n            <SourceMetaForm\n              isToggled={toggleAdvanceOption}\n              handleToggle={this.handleToggle}\n              data={data}\n              formRef={this.formRef}\n              previewColumns={previewColumns}\n              previewData={previewData}\n            />\n          )\n          : <div style={{ textAlign: 'center' }}><Spin size=\"large\" /></div>\n        }\n      </Dialog>\n    )\n  }\n}\n"]}