@tomino/dynamic-form-semantic-ui
Version:
Semantic UI form renderer based on dynamic form generation
164 lines • 19.5 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const react_1 = tslib_1.__importDefault(require("react"));
const graphql_tag_1 = tslib_1.__importDefault(require("graphql-tag"));
const test_utils_1 = require("react-apollo/test-utils");
const apollo_query_view_1 = require("./apollo_query_view");
const editor_common_1 = require("../editor/editor_common");
const mobx_react_1 = require("mobx-react");
const helpers_1 = require("../helpers");
const context_1 = require("../context");
exports.thumbnails = {
light: '',
dark: ''
};
exports.variables = {
variables: editor_common_1.prop({
control: 'Table',
props: { text: 'Variables - Constant', display: 'group' },
elements: [
{
control: 'Input',
props: { placeholder: 'Name', value: { source: 'name' }, label: 'Name' }
},
{
control: 'Input',
props: { placeholder: 'Value', label: 'Value', value: { source: 'value' } }
},
{
control: 'Select',
props: {
label: 'Type',
value: { source: 'type' },
options: [
{ text: 'String', value: 'string' },
{ text: 'Number', value: 'number' },
{ text: 'Boolean', value: 'boolean' }
]
}
}
],
type: 'array',
items: {
type: 'object',
properties: {
name: { type: 'string' },
value: { type: 'string' },
type: { type: 'string' }
}
}
}),
boundVariables: editor_common_1.prop({
control: 'Table',
props: { text: 'Variables - Bound', display: 'group' },
elements: [
{
control: 'Input',
props: { placeholder: 'Name', label: 'Name', value: { source: 'name' } }
},
{
control: 'Select',
props: {
options: { handler: 'datasetSource' },
label: 'Source',
value: { source: 'source' }
}
}
],
type: 'array',
items: {
type: 'object',
properties: {
name: { type: 'string' },
source: { type: 'string' },
value: { type: 'string' }
}
}
})
};
const ApolloQueryEditorComponent = (props) => {
const controlProps = props.formElement.props;
const context = react_1.default.useContext(context_1.Context);
controlProps.query;
let fakeData = helpers_1.getValue(props, context, 'fakeData');
if (fakeData) {
let data;
try {
data = eval(`(${fakeData.trim()})`);
}
catch (ex) {
return react_1.default.createElement("div", null,
"Error parsing json: ",
ex.message);
}
const mocks = [
{
request: {
query: graphql_tag_1.default([controlProps.query]),
variables: apollo_query_view_1.parseVariables(props, context)
},
result: {
data
}
}
];
return (react_1.default.createElement(test_utils_1.MockedProvider, { mocks: mocks, addTypename: false },
react_1.default.createElement(apollo_query_view_1.ApolloQueryView.Component, Object.assign({}, props))));
}
return react_1.default.createElement(apollo_query_view_1.ApolloQueryView.Component, Object.assign({}, props));
};
exports.ApolloQueryEditor = {
Component: mobx_react_1.observer(ApolloQueryEditorComponent),
title: 'Apollo Query',
control: 'ApolloQuery',
thumbnail: exports.thumbnails,
provider: true,
group: 'Data',
props: {
...editor_common_1.propGroup('Query', {
query: editor_common_1.prop({
label: 'Query',
control: 'Code',
props: {
display: 'topLabel',
language: 'graphql'
},
type: 'string'
}),
target: editor_common_1.dataProp({
label: 'Target'
}),
propTarget: editor_common_1.prop({
label: 'Prop Target',
documentation: 'The query result will be passed to child components under this prop name'
}),
loadingText: editor_common_1.prop({
props: { value: { source: 'loadingText' } },
type: 'string'
})
}),
...exports.variables,
...editor_common_1.propGroup('Handlers', {
onResult: editor_common_1.handlerProp({
label: 'onResult'
}),
onError: editor_common_1.handlerProp({
label: 'onError'
}),
onQuery: editor_common_1.handlerProp({
label: 'onQuery'
})
}),
...editor_common_1.propGroup('Editor', {
fakeData: editor_common_1.boundProp({
control: 'Code',
props: { language: 'javascript', display: 'topLabel' }
})
})
},
defaultProps: {
loadingText: 'Loading ...'
}
};
//# sourceMappingURL=apollo_query.editor.js.map