@cognitive-class/jupyterlab-cde-plugin
Version:
Drop-in Cognos Dashboard Embedded plugin for Jupyterlab
214 lines (189 loc) • 19.3 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _formik = require('formik');
var _form = require('antd/lib/form');
var _form2 = _interopRequireDefault(_form);
var _input = require('antd/lib/input');
var _input2 = _interopRequireDefault(_input);
var _switch = require('antd/lib/switch');
var _switch2 = _interopRequireDefault(_switch);
var _row = require('antd/lib/row');
var _row2 = _interopRequireDefault(_row);
var _col = require('antd/lib/col');
var _col2 = _interopRequireDefault(_col);
var _collapse = require('antd/lib/collapse');
var _collapse2 = _interopRequireDefault(_collapse);
var _sourcePreviewTable = require('./source-preview-table');
var _sourcePreviewTable2 = _interopRequireDefault(_sourcePreviewTable);
var _cognos = require('../utils/cognos');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
require('antd/lib/collapse/style/index.css');
require('antd/lib/form/style/index.css');
require('antd/lib/input/style/index.css');
require('antd/lib/button/style/index.css');
require('antd/lib/grid/style/index.css');
require('antd/lib/switch/style/index.css');
require('./source-meta-form.scss');
var FormItem = _form2.default.Item;
var Panel = _collapse2.default.Panel;
var SourceMetaForm = function SourceMetaForm(_ref) {
var data = _ref.data,
formRef = _ref.formRef,
isToggled = _ref.isToggled,
handleToggle = _ref.handleToggle,
previewData = _ref.previewData,
previewColumns = _ref.previewColumns;
return _react2.default.createElement(_formik.Formik, {
ref: formRef,
initialValues: data,
render: function render(_ref2) {
var values = _ref2.values,
handleChange = _ref2.handleChange;
return _react2.default.createElement(
_form2.default,
{ layout: 'horizontal', className: 'source-meta-form' },
values.source.srcUrl.sourceUrl ? _react2.default.createElement(
FormItem,
{ label: 'CSV file URL' },
_react2.default.createElement(_input2.default, { placeholder: 'https://gist.github.com/username/file.csv', disabled: true, name: 'source.srcUrl.sourceUrl', value: values.source.srcUrl.sourceUrl, onChange: handleChange })
) : null,
_react2.default.createElement(
_collapse2.default,
{ defaultActiveKey: ['1'] },
_react2.default.createElement(
Panel,
{ header: 'Preview data', key: '1' },
_react2.default.createElement(_sourcePreviewTable2.default, { data: previewData, columns: previewColumns })
)
),
_react2.default.createElement(
FormItem,
{ label: 'Table Name' },
_react2.default.createElement(_input2.default, { placeholder: 'Table Name', name: 'table.name', value: values.table.name, onChange: handleChange })
),
_react2.default.createElement(
FormItem,
{ label: 'Advanced Options' },
_react2.default.createElement(_switch2.default, { onChange: handleToggle })
),
data.table.column.map(function (item, index) {
return (
// eslint-disable-next-line react/no-array-index-key
_react2.default.createElement(
_row2.default,
{ key: index, gutter: 24, type: 'flex', justify: isToggled ? 'space-around' : 'start', align: 'middle' },
_react2.default.createElement(
_col2.default,
{ span: 2 },
_react2.default.createElement(
'h3',
null,
index + 1
)
),
_react2.default.createElement(
_col2.default,
{ span: 4, style: { display: 'block' } },
_react2.default.createElement(
FormItem,
{ label: index === 0 ? 'Column Name' : '' },
_react2.default.createElement(_input2.default, { placeholder: 'Column Name', name: 'table.column.' + index + '.name', value: values.table.column[index].name, onChange: handleChange })
)
),
isToggled ? _react2.default.createElement(
_react.Fragment,
null,
_react2.default.createElement(
_col2.default,
{ span: 4, style: { display: 'block' } },
_react2.default.createElement(
FormItem,
{ label: index === 0 ? 'Data Type' : '' },
_react2.default.createElement(
_formik.Field,
{ component: 'select', name: 'table.column.' + index + '.datatype', onChange: handleChange },
_cognos.datatype.map(function (each) {
return _react2.default.createElement(
'option',
{ key: each, value: each },
each
);
})
)
)
),
_react2.default.createElement(
_col2.default,
{ span: 4, style: { display: 'block' } },
_react2.default.createElement(
FormItem,
{ label: index === 0 ? 'Taxonomy' : '' },
_react2.default.createElement(
_formik.Field,
{ component: 'select', name: 'table.column.' + index + '.taxonomyFamily', onChange: handleChange },
_cognos.taxonomy.map(function (_ref3) {
var value = _ref3.value,
label = _ref3.label;
return _react2.default.createElement(
'option',
{ key: value, value: value },
label
);
})
)
)
),
_react2.default.createElement(
_col2.default,
{ span: 4, style: { display: 'block' } },
_react2.default.createElement(
FormItem,
{ label: index === 0 ? 'Usage' : '' },
_react2.default.createElement(
_formik.Field,
{ component: 'select', name: 'table.column.' + index + '.usage', onChange: handleChange },
_cognos.usage.map(function (_ref4) {
var value = _ref4.value,
label = _ref4.label;
return _react2.default.createElement(
'option',
{ key: value, value: value },
label
);
})
)
)
),
_react2.default.createElement(
_col2.default,
{ span: 4, style: { display: 'block' } },
_react2.default.createElement(
FormItem,
{ label: index === 0 ? 'Aggregate' : '' },
_react2.default.createElement(
_formik.Field,
{ component: 'select', name: 'table.column.' + index + '.regularAggregate', onChange: handleChange },
_cognos.aggregate.map(function (each) {
return _react2.default.createElement(
'option',
{ key: each, value: each },
each
);
})
)
)
)
) : null
)
);
})
);
}
});
};
exports.default = SourceMetaForm;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/source-manager/source-meta-form.js"],"names":["require","FormItem","Form","Item","Panel","Collapse","SourceMetaForm","data","formRef","isToggled","handleToggle","previewData","previewColumns","values","handleChange","source","srcUrl","sourceUrl","table","name","column","map","item","index","display","datatype","each","taxonomy","value","label","usage","aggregate"],"mappings":"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","file":"source-meta-form.js","sourcesContent":["import React, { Fragment } from 'react'\nimport { Formik, Field } from 'formik'\nimport Form from 'antd/lib/form'\nimport Input from 'antd/lib/input'\nimport Switch from 'antd/lib/switch'\nimport Row from 'antd/lib/row'\nimport Col from 'antd/lib/col'\nimport Collapse from 'antd/lib/collapse'\nimport SourcePreviewTable from './source-preview-table'\nimport {\n  datatype, usage, aggregate, taxonomy,\n} from '../utils/cognos'\n\nrequire('antd/lib/collapse/style/index.css')\nrequire('antd/lib/form/style/index.css')\nrequire('antd/lib/input/style/index.css')\nrequire('antd/lib/button/style/index.css')\nrequire('antd/lib/grid/style/index.css')\nrequire('antd/lib/switch/style/index.css')\nrequire('./source-meta-form.scss')\n\nconst FormItem = Form.Item\nconst { Panel } = Collapse\n\nconst SourceMetaForm = ({\n  data, formRef, isToggled, handleToggle, previewData, previewColumns,\n}) => (\n  <Formik\n    ref={formRef}\n    initialValues={data}\n    render={({ values, handleChange }) => (\n      <Form layout=\"horizontal\" className=\"source-meta-form\">\n        {values.source.srcUrl.sourceUrl\n          ? (\n            <FormItem label=\"CSV file URL\">\n              <Input placeholder=\"https://gist.github.com/username/file.csv\" disabled name=\"source.srcUrl.sourceUrl\" value={values.source.srcUrl.sourceUrl} onChange={handleChange} />\n            </FormItem>\n          ) : null}\n        <Collapse defaultActiveKey={['1']}>\n          <Panel header=\"Preview data\" key=\"1\">\n            <SourcePreviewTable data={previewData} columns={previewColumns} />\n          </Panel>\n        </Collapse>\n        <FormItem label=\"Table Name\">\n          <Input placeholder=\"Table Name\" name=\"table.name\" value={values.table.name} onChange={handleChange} />\n        </FormItem>\n        <FormItem label=\"Advanced Options\">\n          <Switch onChange={handleToggle} />\n        </FormItem>\n        {data.table.column.map((item, index) => (\n          // eslint-disable-next-line react/no-array-index-key\n          <Row key={index} gutter={24} type=\"flex\" justify={isToggled ? 'space-around' : 'start'} align=\"middle\">\n            <Col span={2}><h3>{index + 1}</h3></Col>\n            <Col span={4} style={{ display: 'block' }}>\n              <FormItem label={index === 0 ? 'Column Name' : ''}>\n                <Input placeholder=\"Column Name\" name={`table.column.${index}.name`} value={values.table.column[index].name} onChange={handleChange} />\n              </FormItem>\n            </Col>\n            {isToggled ? (\n              <Fragment>\n                <Col span={4} style={{ display: 'block' }}>\n                  <FormItem label={index === 0 ? 'Data Type' : ''}>\n                    <Field component=\"select\" name={`table.column.${index}.datatype`} onChange={handleChange}>\n                      {datatype.map(each => <option key={each} value={each}>{each}</option>)}\n                    </Field>\n                  </FormItem>\n                </Col>\n                <Col span={4} style={{ display: 'block' }}>\n                  <FormItem label={index === 0 ? 'Taxonomy' : ''}>\n                    <Field component=\"select\" name={`table.column.${index}.taxonomyFamily`} onChange={handleChange}>\n                      {taxonomy.map(({ value, label }) => <option key={value} value={value}>{label}</option>)}\n                    </Field>\n                  </FormItem>\n                </Col>\n                <Col span={4} style={{ display: 'block' }}>\n                  <FormItem label={index === 0 ? 'Usage' : ''}>\n                    <Field component=\"select\" name={`table.column.${index}.usage`} onChange={handleChange}>\n                      {usage.map(({ value, label }) => <option key={value} value={value}>{label}</option>)}\n                    </Field>\n                  </FormItem>\n                </Col>\n                <Col span={4} style={{ display: 'block' }}>\n                  <FormItem label={index === 0 ? 'Aggregate' : ''}>\n                    <Field component=\"select\" name={`table.column.${index}.regularAggregate`} onChange={handleChange}>\n                      {aggregate.map(each => <option key={each} value={each}>{each}</option>)}\n                    </Field>\n                  </FormItem>\n                </Col>\n              </Fragment>\n            ) : null}\n          </Row>\n        ))}\n      </Form>\n    )}\n  />\n)\n\nexport default SourceMetaForm\n"]}