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