kibana/examples/guided_onboarding_example/public/components/step_four.tsx
Luke Elmers b6287708f6
Adds AGPL 3.0 license (#192025)
Updates files outside of x-pack to be triple-licensed under Elastic
License 2.0, AGPL 3.0, or SSPL 1.0.
2024-09-06 19:02:41 -06:00

75 lines
2.4 KiB
TypeScript

/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the "Elastic License
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side
* Public License v 1"; you may not use this file except in compliance with, at
* your election, the "Elastic License 2.0", the "GNU Affero General Public
* License v3.0 only", or the "Server Side Public License, v 1".
*/
import React, { useEffect, useState } from 'react';
import { EuiButton, EuiSpacer, EuiText, EuiTitle } from '@elastic/eui';
import { GuidedOnboardingPluginStart } from '@kbn/guided-onboarding-plugin/public/types';
import { FormattedMessage } from '@kbn/i18n-react';
import { EuiPageHeader, EuiPageSection, EuiCode } from '@elastic/eui';
import { useParams } from 'react-router-dom';
interface StepFourProps {
guidedOnboarding?: GuidedOnboardingPluginStart;
}
export const StepFour: React.FC<StepFourProps> = ({ guidedOnboarding }) => {
const { indexName } = useParams<{ indexName: string }>();
const [, setIsTourStepOpen] = useState<boolean>(false);
useEffect(() => {
const subscription = guidedOnboarding?.guidedOnboardingApi
?.isGuideStepActive$('testGuide', 'step4')
.subscribe((isStepActive) => {
setIsTourStepOpen(isStepActive);
});
return () => subscription?.unsubscribe();
}, [guidedOnboarding]);
return (
<>
<EuiPageHeader>
<EuiTitle>
<h2>
<FormattedMessage
id="guidedOnboardingExample.stepFour.title"
defaultMessage="Example step 4"
/>
</h2>
</EuiTitle>
</EuiPageHeader>
<EuiPageSection>
<EuiText>
<p>
<FormattedMessage
id="guidedOnboardingExample.guidesSelection.stepFour.explanation"
defaultMessage="This step has a dynamic URL with a param {indexName} passed in step 1"
values={{
indexName: (
<EuiCode language="javascript">&#123;indexName: {indexName}&#125;</EuiCode>
),
}}
/>
</p>
</EuiText>
<EuiSpacer />
<EuiButton
onClick={async () => {
await guidedOnboarding?.guidedOnboardingApi?.completeGuideStep('testGuide', 'step4');
}}
>
Complete step 4
</EuiButton>
</EuiPageSection>
</>
);
};