fixed crawler list

This commit is contained in:
snoop 2017-09-26 18:36:48 +09:00
parent 45b4aa3c5a
commit 52c52c8e48
2 changed files with 73 additions and 19 deletions

View File

@ -12,6 +12,8 @@ import MetaCrawlerInputItem from '@overflow/meta/api/model/MetaCrawlerInputItem'
import Target from '@overflow/target/api/model/Target'; import Target from '@overflow/target/api/model/Target';
import SensorRegistInfo from '@overflow/sensor/api/model/SensorRegistInfo'; import SensorRegistInfo from '@overflow/sensor/api/model/SensorRegistInfo';
import * as Utils from '@overflow/commons/util/Utils';
export interface CrawlerSelectorStateProps { export interface CrawlerSelectorStateProps {
metaCralwerList?: MetaCrawler[]; metaCralwerList?: MetaCrawler[];
targetId?: number; targetId?: number;
@ -110,29 +112,67 @@ export class CrawlerSelector extends React.Component<CrawlerSelectorProps, Crawl
// }, 1500); // }, 1500);
} }
public renderCrawler(): JSX.Element { public handleSelect(crawler: MetaCrawler): void {
this.setState({
selected: crawler,
});
this.props.onCrawlerReadAllByMetaCrawler(crawler);
this.props.onSelectCrawlerId(crawler.id);
let sd = this.props.getSensor();
sd.crawler = crawler;
this.props.setSensor(sd);
}
public handleRowActive(crawler: MetaCrawler): boolean {
if (this.state.selected === crawler) {
return true;
}
return false;
}
public renderCrawler(): JSX.Element[] {
if (this.props.metaCralwerList === undefined) { if (this.props.metaCralwerList === undefined) {
return null; return null;
} }
this.convertCrawler(); let elems: Array<JSX.Element> = new Array();
console.log(this.selectOptions);
return ( for(let index: number = 0 ; index < this.props.metaCralwerList.length; ++index) {
<Grid.Row> let crawler: MetaCrawler = this.props.metaCralwerList[index];
<Grid.Column width='4'>
<Dropdown openOnFocus elems.push(
placeholder='Select Crawler' selection options={this.selectOptions} onChange={this.handleCrawlerSelection.bind(this)} /> <Table.Row key={index} onClick={this.handleSelect.bind(this, crawler)} active={this.handleRowActive(crawler)}>
<br /> <Table.Cell textAlign={'center'}>{index + 1}</Table.Cell>
<br /> <Table.Cell textAlign={'center'}>{crawler.name}</Table.Cell>
</Grid.Column> <Table.Cell textAlign={'center'}>{crawler.description}</Table.Cell>
<Grid.Column> <Table.Cell>{Utils.date2date(crawler.createDate)}</Table.Cell>
<CrawlerAuthInputsContainer metaCrawlerInputItemList={this.props.metaCrawlerInputItemList} </Table.Row>,
getSensor={this.props.getSensor} setSensor={this.props.setSensor}/> );
</Grid.Column>
</Grid.Row> }
);
return elems;
// this.convertCrawler();
// console.log(this.selectOptions);
// return (
// <Grid.Row>
// <Grid.Column width='4'>
// <Dropdown openOnFocus
// placeholder='Select Crawler' selection options={this.selectOptions} onChange={this.handleCrawlerSelection.bind(this)} />
// <br />
// <br />
// </Grid.Column>
// <Grid.Column>
// <CrawlerAuthInputsContainer metaCrawlerInputItemList={this.props.metaCrawlerInputItemList}
// getSensor={this.props.getSensor} setSensor={this.props.setSensor}/>
// </Grid.Column>
// </Grid.Row>
// );
} }
public render(): JSX.Element { public render(): JSX.Element {
@ -144,7 +184,21 @@ export class CrawlerSelector extends React.Component<CrawlerSelectorProps, Crawl
<br /> <br />
<br /> <br />
<Grid> <Grid>
{this.props.metaCralwerList ? this.renderCrawler() : ''} {/* {this.props.metaCralwerList ? this.renderCrawler() : ''} */}
<Table celled selectable>
<Table.Header>
<Table.Row>
<Table.HeaderCell textAlign={'center'}>No.</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Name</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Description</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Created at</Table.HeaderCell>
</Table.Row>
</Table.Header>
<Table.Body>
{this.renderCrawler()}
</Table.Body>
</Table>
</Grid> </Grid>
</Segment> </Segment>
); );

View File

@ -2,7 +2,7 @@ import { connect, Dispatch } from 'react-redux';
import { import {
SensorConfigTargetSelect, SensorConfigTargetSelect,
Props as SensorConfigTargetSelectStateProps, Props as SensorConfigTargetSelectStateProps,
State as SensorConfigTargetSelectDispatchProps, DispatchProps as SensorConfigTargetSelectDispatchProps,
} from './components/SensorConfigTargetSelect'; } from './components/SensorConfigTargetSelect';
// import State from '../redux/state/ReadAllByTarget'; // import State from '../redux/state/ReadAllByTarget';
import { push as routerPush } from 'react-router-redux'; import { push as routerPush } from 'react-router-redux';