UNPKG

@tomino/dynamic-form-semantic-ui

Version:

Semantic UI form renderer based on dynamic form generation

164 lines 19.5 kB
"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