From f5df582be3d4ff91b303832317abf708371f9c86 Mon Sep 17 00:00:00 2001 From: Charles Wahome Date: Tue, 25 May 2021 12:37:52 +0300 Subject: [PATCH 1/2] add check for whether the sample url is present --- .../query-runner/query-input/QueryInput.tsx | 210 ++++++++---------- 1 file changed, 88 insertions(+), 122 deletions(-) diff --git a/src/app/views/query-runner/query-input/QueryInput.tsx b/src/app/views/query-runner/query-input/QueryInput.tsx index 437f663e1..2df70ec47 100644 --- a/src/app/views/query-runner/query-input/QueryInput.tsx +++ b/src/app/views/query-runner/query-input/QueryInput.tsx @@ -1,12 +1,11 @@ import { Dropdown } from 'office-ui-fabric-react'; -import React, { Component } from 'react'; +import React from 'react'; import { injectIntl } from 'react-intl'; -import { connect } from 'react-redux'; -import { bindActionCreators, Dispatch } from 'redux'; +import { useDispatch, useSelector } from 'react-redux'; import { IQueryInputProps } from '../../../../types/query-runner'; -import { IRootState } from '../../../../types/root'; -import * as queryInputActionCreators from '../../../services/actions/query-input-action-creators'; +import { IRootState } from '../../../../types/root'; +import { setSampleQuery } from '../../../services/actions/query-input-action-creators'; import { getStyleFor } from '../../../utils/badge-color'; import { parseSampleUrl } from '../../../utils/sample-url-generation'; import { translateMessage } from '../../../utils/translate-messages'; @@ -14,144 +13,111 @@ import SubmitButton from '../../../views/common/submit-button/SubmitButton'; import { queryRunnerStyles } from '../QueryRunner.styles'; import { AutoComplete } from './auto-complete'; -export class QueryInput extends Component { - constructor(props: any) { - super(props); - this.state = { - httpMethods: [ - { key: 'GET', text: 'GET' }, - { key: 'POST', text: 'POST' }, - { key: 'PUT', text: 'PUT' }, - { key: 'PATCH', text: 'PATCH' }, - { key: 'DELETE', text: 'DELETE' }, - ], - urlVersions: [ - { key: 'v1.0', text: 'v1.0' }, - { key: 'beta', text: 'beta' }, - ], - classes: { - textField: 'col-sm-12 col-lg-9', - gridElements: 'col-sm-12 col-lg-1', - }, - }; - } +const QueryInput = (props: IQueryInputProps) => { + const { + handleOnRunQuery, + handleOnMethodChange, + handleOnVersionChange + } = props; + + const dispatch = useDispatch(); + const httpMethods = [ + { key: 'GET', text: 'GET' }, + { key: 'POST', text: 'POST' }, + { key: 'PUT', text: 'PUT' }, + { key: 'PATCH', text: 'PATCH' }, + { key: 'DELETE', text: 'DELETE' }, + ]; + + const urlVersions = [ + { key: 'v1.0', text: 'v1.0' }, + { key: 'beta', text: 'beta' }, + ]; + + const { sampleQuery, authToken, + isLoadingData: submitting } = useSelector((state: IRootState) => state); + const authenticated = !!authToken; - public contentChanged = (value: string) => { - const { sampleQuery } = this.props; + const showError = !authenticated && sampleQuery.selectedVerb !== 'GET'; + const verbSelector: any = queryRunnerStyles().verbSelector; + verbSelector.title = { + ...verbSelector.title, + background: getStyleFor(sampleQuery.selectedVerb), + }; + + const contentChanged = (value: string) => { const query = { ...sampleQuery, ...{ sampleUrl: value } }; - this.changeUrlVersion(value); - this.props.actions!.setSampleQuery(query); + changeUrlVersion(value); + dispatch(setSampleQuery(query)); }; - private changeUrlVersion(newUrl: string) { - const query = { ...this.props.sampleQuery }; + const changeUrlVersion = (newUrl: string) => { + const query = { ...sampleQuery }; const { queryVersion: newQueryVersion } = parseSampleUrl(newUrl); const { queryVersion: oldQueryVersion } = parseSampleUrl(query.sampleUrl); if (newQueryVersion !== oldQueryVersion) { if (newQueryVersion === 'v1.0' || newQueryVersion === 'beta') { - const sampleQuery = { ...query }; - sampleQuery.selectedVersion = newQueryVersion; - sampleQuery.sampleUrl = newUrl; - this.props.actions!.setSampleQuery(sampleQuery); + const sampleQueryToSet = { ...query }; + sampleQueryToSet.selectedVersion = newQueryVersion; + sampleQueryToSet.sampleUrl = newUrl; + dispatch(setSampleQuery(sampleQueryToSet)); } } } - public handleOnRunQuery = () => { + const runQuery = () => { + if (!sampleQuery.sampleUrl) { + return; + } // allows the state to be populated with the new url before running it setTimeout(() => { - this.props.handleOnRunQuery(); + handleOnRunQuery(); }, 500); }; - public render() { - const { httpMethods, urlVersions } = this.state; - - const { - handleOnRunQuery, - handleOnMethodChange, - handleOnVersionChange, - sampleQuery, - submitting, - authenticated, - } = this.props; - - const { - intl: { messages }, - }: any = this.props; - const showError = !authenticated && sampleQuery.selectedVerb !== 'GET'; - const verbSelector: any = queryRunnerStyles().verbSelector; - verbSelector.title = { - ...verbSelector.title, - background: getStyleFor(sampleQuery.selectedVerb), - }; - - return ( -
-
- handleOnMethodChange(method)} - /> -
-
- handleOnVersionChange(method)} - /> -
-
- -
-
- handleOnRunQuery()} - submitting={submitting} - /> -
+ return ( +
+
+ handleOnMethodChange(method)} + />
- ); - } -} - -function mapStateToProps({ sampleQuery, isLoadingData, theme, graphExplorerMode, authToken }: IRootState) { - return { - sampleQuery, - submitting: isLoadingData, - theme, - mode: graphExplorerMode, - authenticated: !!authToken, - }; -} - -function mapDispatchToProps(dispatch: Dispatch): object { - return { - actions: bindActionCreators( - { - ...queryInputActionCreators, - }, - dispatch - ), - }; +
+ handleOnVersionChange(method)} + /> +
+
+ +
+
+ runQuery()} + submitting={submitting} + /> +
+
) } // @ts-ignore const IntlQueryInput = injectIntl(QueryInput); // @ts-ignore -export default connect(mapStateToProps, mapDispatchToProps)(IntlQueryInput); +export default IntlQueryInput; From e1f16ee77b19538b3bf92fcc869f872386587aab Mon Sep 17 00:00:00 2001 From: Charles Wahome Date: Tue, 25 May 2021 12:38:13 +0300 Subject: [PATCH 2/2] display error message when sample url is empty --- .../query-runner/query-input/auto-complete/AutoComplete.tsx | 1 + src/messages/GE.json | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/src/app/views/query-runner/query-input/auto-complete/AutoComplete.tsx b/src/app/views/query-runner/query-input/auto-complete/AutoComplete.tsx index 6311ba957..6ee38a740 100644 --- a/src/app/views/query-runner/query-input/auto-complete/AutoComplete.tsx +++ b/src/app/views/query-runner/query-input/auto-complete/AutoComplete.tsx @@ -404,6 +404,7 @@ class AutoComplete extends Component { onRenderSuffix={(this.renderSuffix()) ? this.renderSuffix : undefined} ariaLabel={translateMessage('Query Sample Input')} role='textbox' + errorMessage={!queryUrl ? translateMessage('Missing url') : ''} /> {showSuggestions && userInput && filteredSuggestions.length > 0 &&