discovery send object
This commit is contained in:
parent
dcb5e78c3d
commit
ff2b542aff
20
src/ts/@overflow/discovery/react/DiscoveryTable.tsx
Normal file
20
src/ts/@overflow/discovery/react/DiscoveryTable.tsx
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
import { connect, Dispatch } from 'react-redux';
|
||||||
|
import {
|
||||||
|
DiscoveryTable,
|
||||||
|
StateProps as DiscoveryTableStateProps,
|
||||||
|
DispatchProps as DiscoveryTableDispatchProps,
|
||||||
|
} from './components/DiscoveryTable';
|
||||||
|
|
||||||
|
|
||||||
|
export function mapStateToProps(state: any, props: any): DiscoveryTableStateProps {
|
||||||
|
return {
|
||||||
|
onProbeChange: props.onProbeChange,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function mapDispatchToProps(dispatch: Dispatch<any>): DiscoveryTableDispatchProps {
|
||||||
|
return {
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export default connect(mapStateToProps, mapDispatchToProps)(DiscoveryTable);
|
|
@ -7,7 +7,7 @@ import {
|
||||||
Container,
|
Container,
|
||||||
} from 'semantic-ui-react';
|
} from 'semantic-ui-react';
|
||||||
import { DiscoveryProbe } from './DiscoveryProbe';
|
import { DiscoveryProbe } from './DiscoveryProbe';
|
||||||
import { DiscoveryTable } from './DiscoveryTable';
|
import DiscoveryTableContainer from '../DiscoveryTable';
|
||||||
import DiscoveryTreeContainer from '../DiscoveryTree';
|
import DiscoveryTreeContainer from '../DiscoveryTree';
|
||||||
|
|
||||||
export interface StateProps {
|
export interface StateProps {
|
||||||
|
@ -81,7 +81,7 @@ export class Discovery extends React.Component<Props, State> {
|
||||||
<Header as='h3' dividing> Discovery Details</Header>
|
<Header as='h3' dividing> Discovery Details</Header>
|
||||||
{/*<DiscoveryProbe probe={this.state.probeTemp}/>*/}
|
{/*<DiscoveryProbe probe={this.state.probeTemp}/>*/}
|
||||||
<br />
|
<br />
|
||||||
<DiscoveryTable onProbeChange={this.handleProbeChange.bind(this)} />
|
<DiscoveryTableContainer onProbeChange={this.handleProbeChange.bind(this)} />
|
||||||
|
|
||||||
<Modal size='small' open={this.state.startPopup} onClose={this.handlePopupClose}>
|
<Modal size='small' open={this.state.startPopup} onClose={this.handlePopupClose}>
|
||||||
<Modal.Header>Discovery</Modal.Header>
|
<Modal.Header>Discovery</Modal.Header>
|
||||||
|
|
|
@ -8,13 +8,20 @@ import {
|
||||||
Dropdown,
|
Dropdown,
|
||||||
Container,
|
Container,
|
||||||
Header,
|
Header,
|
||||||
|
DropdownProps,
|
||||||
} from 'semantic-ui-react';
|
} from 'semantic-ui-react';
|
||||||
|
|
||||||
|
import * as _ from 'lodash';
|
||||||
|
|
||||||
export interface Props {
|
export interface StateProps {
|
||||||
onProbeChange?(state:object):void;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface DispatchProps {
|
||||||
|
onProbeChange?(state: object): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
export type Props = StateProps & DispatchProps;
|
||||||
|
|
||||||
export interface State {
|
export interface State {
|
||||||
startIp: string;
|
startIp: string;
|
||||||
endIP: string;
|
endIP: string;
|
||||||
|
@ -26,6 +33,7 @@ export interface State {
|
||||||
export class DiscoveryTable extends React.Component<Props, State> {
|
export class DiscoveryTable extends React.Component<Props, State> {
|
||||||
|
|
||||||
private serviceTemp: any;
|
private serviceTemp: any;
|
||||||
|
private selectedServices: number | string | Array<number | string>;
|
||||||
|
|
||||||
constructor(props: Props, context: State) {
|
constructor(props: Props, context: State) {
|
||||||
super(props, context);
|
super(props, context);
|
||||||
|
@ -38,7 +46,7 @@ export class DiscoveryTable extends React.Component<Props, State> {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
public componentWillMount():void {
|
public componentWillMount(): void {
|
||||||
// super.componentWillMount();
|
// super.componentWillMount();
|
||||||
this.serviceTemp = [
|
this.serviceTemp = [
|
||||||
{ key: 'http', text: 'HTTP', value: 'http' },
|
{ key: 'http', text: 'HTTP', value: 'http' },
|
||||||
|
@ -58,44 +66,44 @@ export class DiscoveryTable extends React.Component<Props, State> {
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
public handleInput(event: React.SyntheticEvent<HTMLInputElement>, data: InputProps):void {
|
public handleInput(event: React.SyntheticEvent<HTMLInputElement>, data: InputProps): void {
|
||||||
// console.log( data.value);
|
// console.log( data.value);
|
||||||
// console.log( event.target);
|
// console.log( event.target);
|
||||||
// console.log(data.tabIndex);
|
// console.log(data.tabIndex);
|
||||||
|
|
||||||
let value: string = data.value;
|
let value: string = data.value;
|
||||||
switch (data.tabIndex) {
|
switch (data.tabIndex) {
|
||||||
case '1':{
|
case '1': {
|
||||||
this.setState({
|
this.setState({
|
||||||
startIp: value,
|
startIp: value,
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case '2':{
|
case '2': {
|
||||||
this.setState({
|
this.setState({
|
||||||
endIP: value,
|
endIP: value,
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case '3':{
|
case '3': {
|
||||||
this.setState({
|
this.setState({
|
||||||
excludeIp: value,
|
excludeIp: value,
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case '4':{
|
case '4': {
|
||||||
this.setState({
|
this.setState({
|
||||||
startPort: value,
|
startPort: value,
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case '5':{
|
case '5': {
|
||||||
this.setState({
|
this.setState({
|
||||||
endPort: value,
|
endPort: value,
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:{
|
default: {
|
||||||
console.log('Error');
|
console.log('Error');
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -105,7 +113,14 @@ export class DiscoveryTable extends React.Component<Props, State> {
|
||||||
}
|
}
|
||||||
|
|
||||||
public discoveryStartHandler(event: React.SyntheticEvent<HTMLButtonElement>, data: ButtonProps): void {
|
public discoveryStartHandler(event: React.SyntheticEvent<HTMLButtonElement>, data: ButtonProps): void {
|
||||||
this.props.onProbeChange(this.state);
|
|
||||||
|
let discoveryStartInfo: any = {
|
||||||
|
...this.state,
|
||||||
|
services: this.selectedServices,
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
this.props.onProbeChange(discoveryStartInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
public render(): JSX.Element {
|
public render(): JSX.Element {
|
||||||
|
@ -129,26 +144,25 @@ export class DiscoveryTable extends React.Component<Props, State> {
|
||||||
<Table.Row>
|
<Table.Row>
|
||||||
<Table.Cell><Header size='small'>Port Range</Header></Table.Cell>
|
<Table.Cell><Header size='small'>Port Range</Header></Table.Cell>
|
||||||
<Table.Cell>
|
<Table.Cell>
|
||||||
<Input tabIndex='4' placeholder='Start Port' onChange={this.handleInput.bind(this)} />
|
<Input tabIndex='4' placeholder='Start Port' onChange={this.handleInput.bind(this)} />
|
||||||
<Input tabIndex='5' placeholder='End Port' onChange={this.handleInput.bind(this)} />
|
<Input tabIndex='5' placeholder='End Port' onChange={this.handleInput.bind(this)} />
|
||||||
</Table.Cell>
|
</Table.Cell>
|
||||||
</Table.Row>
|
</Table.Row>
|
||||||
<Table.Row>
|
<Table.Row>
|
||||||
<Table.Cell><Header size='small'>Service</Header></Table.Cell>
|
<Table.Cell><Header size='small'>Service</Header></Table.Cell>
|
||||||
<Table.Cell>
|
<Table.Cell>
|
||||||
<Dropdown placeholder='Service' fluid multiple selection options={this.serviceTemp} />
|
<Dropdown placeholder='Service' fluid multiple selection options={this.serviceTemp}
|
||||||
|
onChange={(event: React.SyntheticEvent<HTMLElement>, data: DropdownProps) => {
|
||||||
|
this.selectedServices = data.value;
|
||||||
|
}} />
|
||||||
</Table.Cell>
|
</Table.Cell>
|
||||||
</Table.Row>
|
</Table.Row>
|
||||||
<Table.Row>
|
|
||||||
<Table.Cell><Header size='small'>End Port</Header></Table.Cell>
|
|
||||||
<Table.Cell><Input tabIndex='6' placeholder='End Port' onChange={this.handleInput.bind(this)} /></Table.Cell>
|
|
||||||
</Table.Row>
|
|
||||||
</Table.Body>
|
</Table.Body>
|
||||||
<Table.Footer>
|
<Table.Footer>
|
||||||
<Table.Row>
|
<Table.Row>
|
||||||
<Table.HeaderCell colSpan='2'>
|
<Table.HeaderCell colSpan='2'>
|
||||||
<Button icon='checkmark' floated='right' labelPosition='left'
|
<Button icon='checkmark' floated='right' labelPosition='left'
|
||||||
content='Start' positive onClick={this.discoveryStartHandler.bind(this)} />
|
content='Start' positive onClick={this.discoveryStartHandler.bind(this)} />
|
||||||
</Table.HeaderCell>
|
</Table.HeaderCell>
|
||||||
</Table.Row>
|
</Table.Row>
|
||||||
</Table.Footer>
|
</Table.Footer>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user