UNPKG

@cognitive-class/jupyterlab-cde-plugin

Version:

Drop-in Cognos Dashboard Embedded plugin for Jupyterlab

181 lines (176 loc) 18.7 kB
import React, { Fragment } from 'react'; import { Formik, Field } from 'formik'; import Form from 'antd/lib/form'; import Input from 'antd/lib/input'; import Switch from 'antd/lib/switch'; import Row from 'antd/lib/row'; import Col from 'antd/lib/col'; import Collapse from 'antd/lib/collapse'; import SourcePreviewTable from './source-preview-table'; import { datatype, usage, aggregate, taxonomy } from '../utils/cognos'; 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 = Form.Item; var Panel = Collapse.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 React.createElement(Formik, { ref: formRef, initialValues: data, render: function render(_ref2) { var values = _ref2.values, handleChange = _ref2.handleChange; return React.createElement( Form, { layout: 'horizontal', className: 'source-meta-form' }, values.source.srcUrl.sourceUrl ? React.createElement( FormItem, { label: 'CSV file URL' }, React.createElement(Input, { placeholder: 'https://gist.github.com/username/file.csv', disabled: true, name: 'source.srcUrl.sourceUrl', value: values.source.srcUrl.sourceUrl, onChange: handleChange }) ) : null, React.createElement( Collapse, { defaultActiveKey: ['1'] }, React.createElement( Panel, { header: 'Preview data', key: '1' }, React.createElement(SourcePreviewTable, { data: previewData, columns: previewColumns }) ) ), React.createElement( FormItem, { label: 'Table Name' }, React.createElement(Input, { placeholder: 'Table Name', name: 'table.name', value: values.table.name, onChange: handleChange }) ), React.createElement( FormItem, { label: 'Advanced Options' }, React.createElement(Switch, { onChange: handleToggle }) ), data.table.column.map(function (item, index) { return ( // eslint-disable-next-line react/no-array-index-key React.createElement( Row, { key: index, gutter: 24, type: 'flex', justify: isToggled ? 'space-around' : 'start', align: 'middle' }, React.createElement( Col, { span: 2 }, React.createElement( 'h3', null, index + 1 ) ), React.createElement( Col, { span: 4, style: { display: 'block' } }, React.createElement( FormItem, { label: index === 0 ? 'Column Name' : '' }, React.createElement(Input, { placeholder: 'Column Name', name: 'table.column.' + index + '.name', value: values.table.column[index].name, onChange: handleChange }) ) ), isToggled ? React.createElement( Fragment, null, React.createElement( Col, { span: 4, style: { display: 'block' } }, React.createElement( FormItem, { label: index === 0 ? 'Data Type' : '' }, React.createElement( Field, { component: 'select', name: 'table.column.' + index + '.datatype', onChange: handleChange }, datatype.map(function (each) { return React.createElement( 'option', { key: each, value: each }, each ); }) ) ) ), React.createElement( Col, { span: 4, style: { display: 'block' } }, React.createElement( FormItem, { label: index === 0 ? 'Taxonomy' : '' }, React.createElement( Field, { component: 'select', name: 'table.column.' + index + '.taxonomyFamily', onChange: handleChange }, taxonomy.map(function (_ref3) { var value = _ref3.value, label = _ref3.label; return React.createElement( 'option', { key: value, value: value }, label ); }) ) ) ), React.createElement( Col, { span: 4, style: { display: 'block' } }, React.createElement( FormItem, { label: index === 0 ? 'Usage' : '' }, React.createElement( Field, { component: 'select', name: 'table.column.' + index + '.usage', onChange: handleChange }, usage.map(function (_ref4) { var value = _ref4.value, label = _ref4.label; return React.createElement( 'option', { key: value, value: value }, label ); }) ) ) ), React.createElement( Col, { span: 4, style: { display: 'block' } }, React.createElement( FormItem, { label: index === 0 ? 'Aggregate' : '' }, React.createElement( Field, { component: 'select', name: 'table.column.' + index + '.regularAggregate', onChange: handleChange }, aggregate.map(function (each) { return React.createElement( 'option', { key: each, value: each }, each ); }) ) ) ) ) : null ) ); }) ); } }); }; export default SourceMetaForm; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/source-manager/source-meta-form.js"],"names":["React","Fragment","Formik","Field","Form","Input","Switch","Row","Col","Collapse","SourcePreviewTable","datatype","usage","aggregate","taxonomy","require","FormItem","Item","Panel","SourceMetaForm","data","formRef","isToggled","handleToggle","previewData","previewColumns","values","handleChange","source","srcUrl","sourceUrl","table","name","column","map","item","index","display","each","value","label"],"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"]}