Merge branch 'master' into flux-staging

pull/10616/head
Nathaniel Cook 2019-01-07 16:41:44 -07:00
commit f5cbe8b522
4 changed files with 89 additions and 6 deletions

View File

@ -221,3 +221,8 @@
display: block;
margin: 0 auto;
}
.wizard-step--filter {
float:right;
padding-bottom: 15px;
}

View File

@ -61,6 +61,12 @@ export class SelectDataSourceStep extends PureComponent<Props, State> {
this.state = {showStreamingSources: false}
}
public componentDidMount() {
if (this.isStreaming && this.props.type !== DataLoaderType.Streaming) {
this.props.onSetDataLoadersType(DataLoaderType.Streaming)
}
}
public render() {
return (
<Form onSubmit={this.handleClickNext}>

View File

@ -0,0 +1,44 @@
// Libraries
import React from 'react'
import {shallow} from 'enzyme'
// Components
import StreamingSelector from 'src/onboarding/components/selectionStep/StreamingSelector'
import CardSelectCard from 'src/clockface/components/card_select/CardSelectCard'
import {Input} from 'src/clockface'
// Constants
import {PLUGIN_BUNDLE_OPTIONS} from 'src/onboarding/constants/pluginConfigs'
const setup = (override = {}) => {
const props = {
telegrafPlugins: [],
pluginBundles: [],
onTogglePluginBundle: jest.fn(),
...override,
}
return shallow(<StreamingSelector {...props} />)
}
describe('Onboarding.Components.SelectionStep.StreamingSelector', () => {
it('renders a filter input and plugin bundles', () => {
const wrapper = setup()
const cards = wrapper.find(CardSelectCard)
const filter = wrapper.find(Input)
expect(cards.length).toBe(PLUGIN_BUNDLE_OPTIONS.length)
expect(filter.exists()).toBe(true)
})
describe('if searchTerm is not empty', () => {
it('filters the plugin bundles', async () => {
const wrapper = setup()
const searchTerm = 'syste'
wrapper.setState({searchTerm})
const cards = wrapper.find(CardSelectCard)
expect(cards.length).toBe(1)
})
})
})

View File

@ -1,11 +1,11 @@
// Libraries
import React, {PureComponent} from 'react'
import React, {PureComponent, ChangeEvent} from 'react'
import uuid from 'uuid'
// Components
import {ErrorHandling} from 'src/shared/decorators/errors'
import CardSelectCard from 'src/clockface/components/card_select/CardSelectCard'
import {GridSizer} from 'src/clockface'
import {GridSizer, Input, IconFont} from 'src/clockface'
import FancyScrollbar from 'src/shared/components/fancy_scrollbar/FancyScrollbar'
// Constants
@ -25,6 +25,7 @@ export interface Props {
interface State {
gridSizerUpdateFlag: string
searchTerm: string
}
const ANIMATION_LENGTH = 400
@ -36,6 +37,7 @@ class StreamingSelector extends PureComponent<Props, State> {
super(props)
this.state = {
gridSizerUpdateFlag: uuid.v4(),
searchTerm: '',
}
}
@ -55,7 +57,7 @@ class StreamingSelector extends PureComponent<Props, State> {
}
public render() {
const {gridSizerUpdateFlag} = this.state
const {gridSizerUpdateFlag, searchTerm} = this.state
return (
<FancyScrollbar
@ -64,11 +66,21 @@ class StreamingSelector extends PureComponent<Props, State> {
maxHeight={this.scrollMaxHeight}
>
<div className="wizard-step--grid-container">
<div className="wizard-step--filter">
<Input
icon={IconFont.Search}
widthPixels={290}
value={searchTerm}
onBlur={this.handleFilterBlur}
onChange={this.handleFilterChange}
placeholder="Filter Plugins..."
/>
</div>
<GridSizer
wait={ANIMATION_LENGTH}
recalculateFlag={gridSizerUpdateFlag}
>
{PLUGIN_BUNDLE_OPTIONS.map(b => {
{this.filteredBundles.map(b => {
return (
<CardSelectCard
key={b}
@ -87,7 +99,15 @@ class StreamingSelector extends PureComponent<Props, State> {
)
}
private isCardChecked(bundle: BundleName) {
private get filteredBundles(): BundleName[] {
const {searchTerm} = this.state
return PLUGIN_BUNDLE_OPTIONS.filter(b =>
b.toLowerCase().includes(searchTerm.toLowerCase())
)
}
private isCardChecked(bundle: BundleName): boolean {
const {pluginBundles} = this.props
if (pluginBundles.find(b => b === bundle)) {
@ -96,9 +116,17 @@ class StreamingSelector extends PureComponent<Props, State> {
return false
}
private handleToggle = (bundle: BundleName) => () => {
private handleToggle = (bundle: BundleName) => (): void => {
this.props.onTogglePluginBundle(bundle, this.isCardChecked(bundle))
}
private handleFilterChange = (e: ChangeEvent<HTMLInputElement>): void => {
this.setState({searchTerm: e.target.value})
}
private handleFilterBlur = (e: ChangeEvent<HTMLInputElement>): void => {
this.setState({searchTerm: e.target.value})
}
}
export default StreamingSelector