Skip to content

Commit

Permalink
Merge pull request #5 from stephmilovic/lens_cases
Browse files Browse the repository at this point in the history
Lens Cases UI
  • Loading branch information
patrykkopycinski authored Jun 15, 2021
2 parents 6ff1f5c + ab71519 commit 3aef8c6
Show file tree
Hide file tree
Showing 6 changed files with 100 additions and 20 deletions.
41 changes: 23 additions & 18 deletions x-pack/plugins/cases/public/components/case_view/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ import { useTimelineContext } from '../timeline_context/use_timeline_context';
import { CasesNavigation } from '../links';
import { OwnerProvider } from '../owner_context';
import { DoesNotExist } from './does_not_exist';
import { CasesLensIntegration, CasesLensIntegrationProvider } from '../lens_context';

const gutterTimeline = '70px'; // seems to be a timeline reference from the original file
export interface CaseViewComponentProps {
Expand All @@ -60,6 +61,7 @@ export interface CaseViewComponentProps {
}

export interface CaseViewProps extends CaseViewComponentProps {
lensIntegration?: CasesLensIntegration;
onCaseDataSuccess?: (data: Case) => void;
timelineIntegration?: CasesTimelineIntegration;
}
Expand Down Expand Up @@ -485,6 +487,7 @@ export const CaseView = React.memo(
caseId,
configureCasesNavigation,
getCaseDetailHrefWithCommentId,
lensIntegration,
onCaseDataSuccess,
onComponentInitialized,
ruleDetailsNavigation,
Expand Down Expand Up @@ -514,24 +517,26 @@ export const CaseView = React.memo(
return (
data && (
<CasesTimelineIntegrationProvider timelineIntegration={timelineIntegration}>
<OwnerProvider owner={[data.owner]}>
<CaseComponent
allCasesNavigation={allCasesNavigation}
caseData={data}
caseDetailsNavigation={caseDetailsNavigation}
caseId={caseId}
configureCasesNavigation={configureCasesNavigation}
getCaseDetailHrefWithCommentId={getCaseDetailHrefWithCommentId}
fetchCase={fetchCase}
onComponentInitialized={onComponentInitialized}
ruleDetailsNavigation={ruleDetailsNavigation}
showAlertDetails={showAlertDetails}
subCaseId={subCaseId}
updateCase={updateCase}
useFetchAlertData={useFetchAlertData}
userCanCrud={userCanCrud}
/>
</OwnerProvider>
<CasesLensIntegrationProvider lensIntegration={lensIntegration}>
<OwnerProvider owner={[data.owner]}>
<CaseComponent
allCasesNavigation={allCasesNavigation}
caseData={data}
caseDetailsNavigation={caseDetailsNavigation}
caseId={caseId}
configureCasesNavigation={configureCasesNavigation}
getCaseDetailHrefWithCommentId={getCaseDetailHrefWithCommentId}
fetchCase={fetchCase}
onComponentInitialized={onComponentInitialized}
ruleDetailsNavigation={ruleDetailsNavigation}
showAlertDetails={showAlertDetails}
subCaseId={subCaseId}
updateCase={updateCase}
useFetchAlertData={useFetchAlertData}
userCanCrud={userCanCrud}
/>
</OwnerProvider>
</CasesLensIntegrationProvider>
</CasesTimelineIntegrationProvider>
)
);
Expand Down
43 changes: 43 additions & 0 deletions x-pack/plugins/cases/public/components/lens_context/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
/*
* 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; you may not use this file except in compliance with the Elastic License
* 2.0.
*/

import React, { useState } from 'react';
import { EuiMarkdownEditorUiPlugin, EuiMarkdownAstNodePosition } from '@elastic/eui';
import { Plugin } from 'unified';

interface LensProcessingPluginRendererProps {
id: string | null;
title: string;
graphEventId?: string;
type: 'lens';
[key: string]: string | null | undefined;
}

export interface CasesLensIntegration {
editor_plugins: {
parsingPlugin: Plugin;
processingPluginRenderer: React.FC<
LensProcessingPluginRendererProps & { position: EuiMarkdownAstNodePosition }
>;
uiPlugin: EuiMarkdownEditorUiPlugin;
};
}

// This context is available to all children of the stateful_event component where the provider is currently set
export const CasesLensIntegrationContext = React.createContext<CasesLensIntegration | null>(null);

export const CasesLensIntegrationProvider: React.FC<{
lensIntegration?: CasesLensIntegration;
}> = ({ children, lensIntegration }) => {
const [activeLensIntegration] = useState(lensIntegration ?? null);

return (
<CasesLensIntegrationContext.Provider value={activeLensIntegration}>
{children}
</CasesLensIntegrationContext.Provider>
);
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
/*
* 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; you may not use this file except in compliance with the Elastic License
* 2.0.
*/

import { useContext } from 'react';
import { CasesLensIntegrationContext } from '.';

export const useLensContext = () => {
return useContext(CasesLensIntegrationContext);
};
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export type TemporaryProcessingPluginsType = [
[
typeof rehype2react,
Parameters<typeof rehype2react>[0] & {
components: { a: FunctionComponent<EuiLinkAnchorProps>; timeline: unknown };
components: { a: FunctionComponent<EuiLinkAnchorProps>; lens: unknown; timeline: unknown };
}
],
...PluggableList
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,11 @@ import {
import { useMemo } from 'react';
import { useTimelineContext } from '../timeline_context/use_timeline_context';
import { TemporaryProcessingPluginsType } from './types';
import { useLensContext } from '../lens_context/use_lens_context';

export const usePlugins = () => {
const timelinePlugins = useTimelineContext()?.editor_plugins;
const lensPlugins = useLensContext()?.editor_plugins;

return useMemo(() => {
const uiPlugins = getDefaultEuiMarkdownUiPlugins();
Expand All @@ -31,10 +33,19 @@ export const usePlugins = () => {
processingPlugins[1][1].components.timeline = timelinePlugins.processingPluginRenderer;
}

if (lensPlugins) {
uiPlugins.push(lensPlugins.uiPlugin);

parsingPlugins.push(lensPlugins.parsingPlugin);

// This line of code is TS-compatible and it will break if [1][1] change in the future.
processingPlugins[1][1].components.lens = lensPlugins.processingPluginRenderer;
}

return {
uiPlugins,
parsingPlugins,
processingPlugins,
};
}, [timelinePlugins]);
}, [lensPlugins, timelinePlugins]);
};
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ import { SEND_ALERT_TO_TIMELINE } from './translations';
import { useInsertTimeline } from '../use_insert_timeline';
import { SpyRoute } from '../../../common/utils/route/spy_routes';
import * as timelineMarkdownPlugin from '../../../common/components/markdown_editor/plugins/timeline';
import * as lensMarkdownPlugin from '../../../common/components/markdown_editor/plugins/lens';

interface Props {
caseId: string;
Expand Down Expand Up @@ -223,6 +224,13 @@ export const CaseView = React.memo(({ caseId, subCaseId, userCanCrud }: Props) =
onClick: onConfigureCasesNavClick,
},
getCaseDetailHrefWithCommentId,
lensIntegration: {
editor_plugins: {
parsingPlugin: lensMarkdownPlugin.parser,
processingPluginRenderer: lensMarkdownPlugin.renderer,
uiPlugin: lensMarkdownPlugin.plugin,
},
},
onCaseDataSuccess,
onComponentInitialized,
ruleDetailsNavigation: {
Expand Down

0 comments on commit 3aef8c6

Please sign in to comment.