-
Notifications
You must be signed in to change notification settings - Fork 8.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Security Solution][Detections] Value Lists Modal supports multiple e…
…xports (#73532) (#73621) * Remove need for ValueListsTable Modifying columns has revealed that they should be exposed as props, at which point we have no real need for the table component. * Unroll the ActionButton component I thought this was useful when I wrote it! * Handle multiple simultaneous exports on value lists modal Instead of passing our export function to GenericDownloader, we now manage the multiple exports ourselves, and when successful we pass the blob to GenericDownloader. * tracks a list of exporting IDs instead of single ID * chains onto the export promise to set local state * Port useful table tests over to modal tests These verify that we've wired up our table actions to our API calls. A little brittle/tied to implementation, but I'd rather have them than not. * WIP: Simpler version of GenericDownloader * Replace use of GenericDownloader with simpler AutoDownload This component takes a blob and downloads it in a cross-browser-compatible manner. * Handle error when uploading value lists Converts to the try/catch/finally form as well. * Fix failing cypress test We lost this test subj during our refactor, oops * More explicit setting of global DOM function Our component fails due to this method being undefined, so we mock it out for these tests. We do not need to reset the mock as it is assigned fresh on every test. * Fixes jest failures on CI Defines a global static method in a more portable way, as the regular assignment was failing on CI as the property was readonly. * Simplify our export/delete clicks in jest tests The less we assume about the UI, the more robust these'll be. Co-authored-by: Elastic Machine <[email protected]> Co-authored-by: Elastic Machine <[email protected]>
- Loading branch information
1 parent
bb2e167
commit 6250e80
Showing
8 changed files
with
220 additions
and
246 deletions.
There are no files selected for viewing
35 changes: 35 additions & 0 deletions
35
...solution/public/detections/components/value_lists_management_modal/auto_download.test.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License; | ||
* you may not use this file except in compliance with the Elastic License. | ||
*/ | ||
|
||
import React from 'react'; | ||
import { mount } from 'enzyme'; | ||
|
||
import { globalNode } from '../../../common/mock'; | ||
import { AutoDownload } from './auto_download'; | ||
|
||
describe('AutoDownload', () => { | ||
beforeEach(() => { | ||
// our DOM environment lacks this function that our component needs | ||
Object.defineProperty(globalNode.window.URL, 'revokeObjectURL', { | ||
writable: true, | ||
value: jest.fn(), | ||
}); | ||
}); | ||
|
||
it('calls onDownload once if a blob is provided', () => { | ||
const onDownload = jest.fn(); | ||
mount(<AutoDownload blob={new Blob([''])} onDownload={onDownload} />); | ||
|
||
expect(onDownload).toHaveBeenCalledTimes(1); | ||
}); | ||
|
||
it('does not call onDownload if no blob is provided', () => { | ||
const onDownload = jest.fn(); | ||
mount(<AutoDownload blob={undefined} onDownload={onDownload} />); | ||
|
||
expect(onDownload).not.toHaveBeenCalled(); | ||
}); | ||
}); |
42 changes: 42 additions & 0 deletions
42
...rity_solution/public/detections/components/value_lists_management_modal/auto_download.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License; | ||
* you may not use this file except in compliance with the Elastic License. | ||
*/ | ||
|
||
import React, { useEffect, useRef } from 'react'; | ||
import styled from 'styled-components'; | ||
|
||
const InvisibleAnchor = styled.a` | ||
display: none; | ||
`; | ||
|
||
interface AutoDownloadProps { | ||
blob: Blob | undefined; | ||
name?: string; | ||
onDownload?: () => void; | ||
} | ||
|
||
export const AutoDownload: React.FC<AutoDownloadProps> = ({ blob, name, onDownload }) => { | ||
const anchorRef = useRef<HTMLAnchorElement>(null); | ||
|
||
useEffect(() => { | ||
if (blob && anchorRef?.current) { | ||
if (typeof window.navigator.msSaveOrOpenBlob === 'function') { | ||
window.navigator.msSaveBlob(blob); | ||
} else { | ||
const objectURL = window.URL.createObjectURL(blob); | ||
anchorRef.current.href = objectURL; | ||
anchorRef.current.download = name ?? 'download.txt'; | ||
anchorRef.current.click(); | ||
window.URL.revokeObjectURL(objectURL); | ||
} | ||
|
||
if (onDownload) { | ||
onDownload(); | ||
} | ||
} | ||
}, [blob, name, onDownload]); | ||
|
||
return <InvisibleAnchor ref={anchorRef} />; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.