Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Automatic Import] Fix the enter bug #199894

Merged
merged 25 commits into from
Dec 11, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
3840ad5
Fix the enter bug
ilyannn Nov 8, 2024
c48c76a
Move up the logic of completeStep
ilyannn Nov 13, 2024
09d943a
Fix the close button bug
ilyannn Nov 13, 2024
c99de53
Merge branch 'main' into auto-import/form-submit-fixes
elasticmachine Nov 13, 2024
60af1de
Merge branch 'main' of github.com:elastic/kibana into auto-import/for…
ilyannn Nov 25, 2024
a215cc7
Merge branch 'auto-import/form-submit-fixes' of github.com:ilyannn/ki…
ilyannn Nov 25, 2024
feb0b72
Make stuff easier to test
ilyannn Nov 25, 2024
69ec953
Move step 1 tests to create_integration_assistant.test.tsx
ilyannn Nov 25, 2024
65497d3
Rename ...StepReady to ...StepCompleted
ilyannn Nov 25, 2024
0aa6007
Fill out the rest of the tests
ilyannn Nov 26, 2024
f90b49f
Fix the test when there are two Next buttons
ilyannn Nov 26, 2024
76811a9
Merge branch 'main' into auto-import/form-submit-fixes
ilyannn Nov 26, 2024
37aa33b
Revert an accidental rename
ilyannn Nov 26, 2024
27e1ff3
Remove commented out things
ilyannn Nov 26, 2024
7456753
Allow for the possibiliy of an unknown step
ilyannn Nov 26, 2024
b395639
Update the Cypress test
ilyannn Dec 6, 2024
ea78042
Merge branch 'main' into auto-import/form-submit-fixes
ilyannn Dec 6, 2024
18e6b94
Merge branch 'main' into auto-import/form-submit-fixes
ilyannn Dec 8, 2024
413db06
Merge branch 'main' into auto-import/form-submit-fixes
ilyannn Dec 9, 2024
11729a8
Merge branch 'main' into auto-import/form-submit-fixes
ilyannn Dec 10, 2024
ff4de18
Implement review feedback
ilyannn Dec 10, 2024
78192c7
Fix the button identifier
ilyannn Dec 10, 2024
a99a987
Merge branch 'main' into auto-import/form-submit-fixes
ilyannn Dec 11, 2024
a014966
Revert the Cypress test for now
ilyannn Dec 11, 2024
21df245
Revert the Cypress part further
ilyannn Dec 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,11 @@
* 2.0.
*/

import React, { useReducer, useMemo, useEffect } from 'react';
import React, { useReducer, useMemo, useEffect, useCallback } from 'react';
import { KibanaPageTemplate } from '@kbn/shared-ux-page-kibana-template';
import { Header } from './header';
import { Footer } from './footer';
import { useNavigate, Page } from '../../../common/hooks/use_navigate';
import { ConnectorStep, isConnectorStepReady } from './steps/connector_step';
import { IntegrationStep, isIntegrationStepReady } from './steps/integration_step';
import { DataStreamStep, isDataStreamStepReady } from './steps/data_stream_step';
Expand All @@ -22,14 +23,56 @@ import { ExperimentalFeaturesService } from '../../../services';

export const CreateIntegrationAssistant = React.memo(() => {
const [state, dispatch] = useReducer(reducer, initialState);

const navigate = useNavigate();
const { generateCel: isGenerateCelEnabled } = ExperimentalFeaturesService.get();

const celInputStepIndex = isGenerateCelEnabled && state.hasCelInput ? 5 : null;
const celReviewStepIndex = isGenerateCelEnabled && state.celInputResult ? 6 : null;
const deployStepIndex = isGenerateCelEnabled && state.hasCelInput ? 7 : 5;

const telemetry = useTelemetry();
useEffect(() => {
telemetry.reportAssistantOpen();
}, [telemetry]);

const isNextStepEnabled = useMemo(() => {
if (state.step === 1) {
return isConnectorStepReady(state);
} else if (state.step === 2) {
return isIntegrationStepReady(state);
} else if (state.step === 3) {
return isDataStreamStepReady(state);
} else if (state.step === 4) {
return isReviewStepReady(state);
} else if (isGenerateCelEnabled && state.step === 5) {
return isCelInputStepReady(state);
} else if (isGenerateCelEnabled && state.step === 6) {
return isCelReviewStepReady(state);
}
return false;
}, [state, isGenerateCelEnabled]);

const goBackStep = useCallback(() => {
if (state.step === 1) {
navigate(Page.landing);
} else {
dispatch({ type: 'SET_STEP', payload: state.step - 1 });
}
}, [navigate, dispatch, state.step]);

const completeStep = useCallback(() => {
if (!isNextStepEnabled) {
// If the user tries to navigate to the next step without completing the current step.
return;
}
telemetry.reportAssistantStepComplete({ step: state.step });
if (state.step === 3 || state.step === 5) {
dispatch({ type: 'SET_IS_GENERATING', payload: true });
} else {
dispatch({ type: 'SET_STEP', payload: state.step + 1 });
}
}, [telemetry, state.step, isNextStepEnabled]);

const actions = useMemo<Actions>(
() => ({
setStep: (payload) => {
Expand All @@ -53,27 +96,11 @@ export const CreateIntegrationAssistant = React.memo(() => {
setCelInputResult: (payload) => {
dispatch({ type: 'SET_CEL_INPUT_RESULT', payload });
},
completeStep,
}),
[]
[completeStep]
);

const isNextStepEnabled = useMemo(() => {
if (state.step === 1) {
return isConnectorStepReady(state);
} else if (state.step === 2) {
return isIntegrationStepReady(state);
} else if (state.step === 3) {
return isDataStreamStepReady(state);
} else if (state.step === 4) {
return isReviewStepReady(state);
} else if (isGenerateCelEnabled && state.step === 5) {
return isCelInputStepReady(state);
} else if (isGenerateCelEnabled && state.step === 6) {
return isCelReviewStepReady(state);
}
return false;
}, [state, isGenerateCelEnabled]);

return (
<ActionsProvider value={actions}>
<KibanaPageTemplate>
Expand All @@ -95,28 +122,21 @@ export const CreateIntegrationAssistant = React.memo(() => {
result={state.result}
/>
)}
{state.step === 5 &&
(isGenerateCelEnabled && state.hasCelInput ? (
<CelInputStep
integrationSettings={state.integrationSettings}
connector={state.connector}
isGenerating={state.isGenerating}
/>
) : (
<DeployStep
integrationSettings={state.integrationSettings}
result={state.result}
connector={state.connector}
/>
))}

{isGenerateCelEnabled && state.celInputResult && state.step === 6 && (
{state.step === celInputStepIndex && (
<CelInputStep
integrationSettings={state.integrationSettings}
connector={state.connector}
isGenerating={state.isGenerating}
/>
)}
{state.step === celReviewStepIndex && (
<ReviewCelStep
isGenerating={state.isGenerating}
celInputResult={state.celInputResult}
/>
)}
{isGenerateCelEnabled && state.step === 7 && (

{state.step === deployStepIndex && (
<DeployStep
integrationSettings={state.integrationSettings}
result={state.result}
Expand All @@ -126,10 +146,14 @@ export const CreateIntegrationAssistant = React.memo(() => {
)}
</KibanaPageTemplate.Section>
<Footer
currentStep={state.step}
isGenerating={state.isGenerating}
hasCelInput={state.hasCelInput}
isAnalyzeStep={state.step === 3}
isAnalyzeCelStep={state.step === celInputStepIndex}
isLastStep={state.step === deployStepIndex}
isNextStepEnabled={isNextStepEnabled}
isNextAddingToElastic={state.step === deployStepIndex - 1}
onBack={goBackStep}
onNext={completeStep}
/>
</KibanaPageTemplate>
</ActionsProvider>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,10 @@
*/

import { EuiLoadingSpinner } from '@elastic/eui';
import React, { useCallback, useMemo } from 'react';
import React, { useMemo } from 'react';
import { ButtonsFooter } from '../../../../common/components/buttons_footer';
import { useNavigate, Page } from '../../../../common/hooks/use_navigate';
import { useTelemetry } from '../../telemetry';
import { useActions, type State } from '../state';
import { type State } from '../state';
import * as i18n from './translations';
import { ExperimentalFeaturesService } from '../../../../services';

// Generation button for Step 3
const AnalyzeButtonText = React.memo<{ isGenerating: boolean }>(({ isGenerating }) => {
Expand Down Expand Up @@ -43,61 +40,47 @@ const AnalyzeCelButtonText = React.memo<{ isGenerating: boolean }>(({ isGenerati
AnalyzeCelButtonText.displayName = 'AnalyzeCelButtonText';

interface FooterProps {
currentStep: State['step'];
isGenerating: State['isGenerating'];
hasCelInput: State['hasCelInput'];
isNextStepEnabled?: boolean;
isAnalyzeStep: boolean;
isAnalyzeCelStep: boolean;
isLastStep: boolean;
isNextStepEnabled: boolean;
isNextAddingToElastic: boolean;
onBack: () => void;
onNext: () => void;
}

export const Footer = React.memo<FooterProps>(
({ currentStep, isGenerating, hasCelInput, isNextStepEnabled = false }) => {
const telemetry = useTelemetry();
const { setStep, setIsGenerating } = useActions();
const navigate = useNavigate();

const { generateCel: isGenerateCelEnabled } = ExperimentalFeaturesService.get();

const onBack = useCallback(() => {
if (currentStep === 1) {
navigate(Page.landing);
} else {
setStep(currentStep - 1);
}
}, [currentStep, navigate, setStep]);

const onNext = useCallback(() => {
telemetry.reportAssistantStepComplete({ step: currentStep });
if (currentStep === 3 || currentStep === 5) {
setIsGenerating(true);
} else {
setStep(currentStep + 1);
}
}, [currentStep, setIsGenerating, setStep, telemetry]);

const nextButtonText = useMemo(() => {
if (currentStep === 3) {
return <AnalyzeButtonText isGenerating={isGenerating} />;
}
if (currentStep === 4 && (!isGenerateCelEnabled || !hasCelInput)) {
return i18n.ADD_TO_ELASTIC;
}
if (currentStep === 5 && isGenerateCelEnabled && hasCelInput) {
return <AnalyzeCelButtonText isGenerating={isGenerating} />;
}
if (currentStep === 6 && isGenerateCelEnabled) {
return i18n.ADD_TO_ELASTIC;
}
}, [currentStep, isGenerating, hasCelInput, isGenerateCelEnabled]);
({
isGenerating,
isAnalyzeStep,
isAnalyzeCelStep,
isLastStep,
isNextStepEnabled,
isNextAddingToElastic,
onBack,
onNext,
}) => {
const nextButtonText = useMemo(
() =>
isNextAddingToElastic ? (
i18n.ADD_TO_ELASTIC
) : isAnalyzeStep ? (
<AnalyzeButtonText isGenerating={isGenerating} />
) : isAnalyzeCelStep ? (
<AnalyzeCelButtonText isGenerating={isGenerating} />
) : null,
[isNextAddingToElastic, isAnalyzeStep, isGenerating, isAnalyzeCelStep]
);

if (currentStep === 7 || (currentStep === 5 && (!isGenerateCelEnabled || !hasCelInput))) {
return <ButtonsFooter cancelButtonText={i18n.CLOSE} />;
}
return (
return isLastStep ? (
<ButtonsFooter cancelButtonText={i18n.CLOSE} />
) : (
<ButtonsFooter
isNextDisabled={!isNextStepEnabled || isGenerating}
nextButtonText={nextButtonText}
isNextDisabled={!isNextStepEnabled}
onBack={onBack}
onNext={onNext}
nextButtonText={nextButtonText}
/>
);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ export interface Actions {
setHasCelInput: (payload: State['hasCelInput']) => void;
setResult: (payload: State['result']) => void;
setCelInputResult: (payload: State['celInputResult']) => void;
completeStep: () => void;
}

const ActionsContext = createContext<Actions | undefined>(undefined);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ interface CelInputStepProps {

export const CelInputStep = React.memo<CelInputStepProps>(
({ integrationSettings, connector, isGenerating }) => {
const { setIsGenerating, setStep, setCelInputResult } = useActions();
const { setIsGenerating, setStep, setCelInputResult, completeStep } = useActions();

const onGenerationCompleted = useCallback<OnComplete>(
(result: State['celInputResult']) => {
Expand All @@ -43,7 +43,14 @@ export const CelInputStep = React.memo<CelInputStepProps>(
<EuiFlexItem>
<StepContentWrapper title={i18n.CEL_INPUT_TITLE} subtitle={i18n.CEL_INPUT_DESCRIPTION}>
<EuiPanel hasShadow={false} hasBorder>
<EuiForm component="form" fullWidth>
<EuiForm
component="form"
fullWidth
onSubmit={(e) => {
e.preventDefault();
completeStep();
}}
>
<ApiDefinitionInput integrationSettings={integrationSettings} />
</EuiForm>
</EuiPanel>
Expand Down
Loading