Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
130594e42d
40
src/ts/@overflow/sensor/react/SensorConfigTargetSelect.tsx
Normal file
40
src/ts/@overflow/sensor/react/SensorConfigTargetSelect.tsx
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
import { connect, Dispatch } from 'react-redux';
|
||||||
|
import {
|
||||||
|
SensorConfigTargetSelect,
|
||||||
|
Props as SensorConfigTargetSelectStateProps,
|
||||||
|
State as SensorConfigTargetSelectDispatchProps,
|
||||||
|
} from './components/SensorConfigTargetSelect';
|
||||||
|
// import State from '../redux/state/ReadAllByTarget';
|
||||||
|
import { push as routerPush } from 'react-router-redux';
|
||||||
|
|
||||||
|
// import Target from '@overflow/target/api/model/Target';
|
||||||
|
// import Sensor from '@overflow/sensor/api/model/Sensor';
|
||||||
|
// import SensorItem from '@overflow/sensor/api/model/SensorItem';
|
||||||
|
import Domain from '@overflow/domain/api/model/Domain';
|
||||||
|
import PageParams from '@overflow/commons/api/model/PageParams';
|
||||||
|
|
||||||
|
import * as asyncRequestActions from '@overflow/commons/redux/action/asyncRequest';
|
||||||
|
import * as targetListActions from '@overflow/target/redux/action/read_all_by_probe';
|
||||||
|
import * as readActionType from '@overflow/infra/redux/action/read';
|
||||||
|
|
||||||
|
export function mapStateToProps(state: any, props: any): SensorConfigTargetSelectStateProps {
|
||||||
|
return {
|
||||||
|
infraList: state.infraList,
|
||||||
|
infra: state.infra,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function mapDispatchToProps(dispatch: Dispatch<any>): SensorConfigTargetSelectDispatchProps {
|
||||||
|
return {
|
||||||
|
onReadAllTargetByDomain: (domain: Domain, pageParams: PageParams) => {
|
||||||
|
dispatch(asyncRequestActions.request('InfraService', 'readAllByDomain', targetListActions.REQUEST,
|
||||||
|
JSON.stringify(domain), JSON.stringify(pageParams)));
|
||||||
|
},
|
||||||
|
onReadInfra: (infraId: number) => {
|
||||||
|
dispatch(asyncRequestActions.request('InfraService', 'read', readActionType.REQUEST, infraId));
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export default connect(mapStateToProps, mapDispatchToProps)(SensorConfigTargetSelect);
|
|
@ -16,30 +16,19 @@ import * as SensorItemReadAllActions from '@overflow/meta/redux/action/sensor_it
|
||||||
import * as RegistActions from '../redux/action/regist';
|
import * as RegistActions from '../redux/action/regist';
|
||||||
|
|
||||||
import * as asyncRequestActions from '@overflow/commons/redux/action/asyncRequest';
|
import * as asyncRequestActions from '@overflow/commons/redux/action/asyncRequest';
|
||||||
import * as targetListActions from '@overflow/target/redux/action/read_all_by_probe';
|
|
||||||
import * as readActionType from '@overflow/infra/redux/action/read';
|
|
||||||
import PageParams from '@overflow/commons/api/model/PageParams';
|
|
||||||
// FIXME::....
|
// FIXME::....
|
||||||
|
|
||||||
export function mapStateToProps(state: any, props: any): SensorConfigurationStateProps {
|
export function mapStateToProps(state: any, props: any): SensorConfigurationStateProps {
|
||||||
return {
|
return {
|
||||||
infraList: state.infraList,
|
|
||||||
infraId: props.params.id,
|
infraId: props.params.id,
|
||||||
infra: state.infra,
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export function mapDispatchToProps(dispatch: Dispatch<any>): SensorConfigurationDispatchProps {
|
export function mapDispatchToProps(dispatch: Dispatch<any>): SensorConfigurationDispatchProps {
|
||||||
return {
|
return {
|
||||||
onReadAllTargetByDomain: (domain: Domain, pageParams: PageParams) => {
|
|
||||||
// dispatch(asyncRequestActions.request('InfraService', 'readAllByDomain',
|
|
||||||
// targetListActions.REQUEST, JSON.stringify(domain), '0', '10'));
|
|
||||||
dispatch(asyncRequestActions.request('InfraService', 'readAllByDomain', targetListActions.REQUEST,
|
|
||||||
JSON.stringify(domain), JSON.stringify(pageParams)));
|
|
||||||
},
|
|
||||||
onReadInfra: (infraId: number) => {
|
|
||||||
dispatch(asyncRequestActions.request('InfraService', 'read', readActionType.REQUEST, infraId));
|
|
||||||
},
|
|
||||||
// onCheckCrawlerAuth: (authInfo: string) => {
|
// onCheckCrawlerAuth: (authInfo: string) => {
|
||||||
// // dispatch(ReadActions.request(id));
|
// // dispatch(ReadActions.request(id));
|
||||||
// },
|
// },
|
||||||
|
|
|
@ -39,8 +39,6 @@ import { MetaSensorStatus_ID } from '@overflow/meta/api/model/MetaSensorStatus';
|
||||||
|
|
||||||
export interface SensorConfigStepperStateProps {
|
export interface SensorConfigStepperStateProps {
|
||||||
steps?: Array<JSX.Element>;
|
steps?: Array<JSX.Element>;
|
||||||
infraList?: Page;
|
|
||||||
infra?: Infra;
|
|
||||||
infraId?: number;
|
infraId?: number;
|
||||||
setSensor?(data: SensorRegistInfo): void;
|
setSensor?(data: SensorRegistInfo): void;
|
||||||
getSensor?(): SensorRegistInfo;
|
getSensor?(): SensorRegistInfo;
|
||||||
|
@ -60,8 +58,6 @@ export interface SensorConfigStepperState {
|
||||||
|
|
||||||
export class SensorConfigStepper extends React.Component<SensorConfigStepperProps, SensorConfigStepperState> {
|
export class SensorConfigStepper extends React.Component<SensorConfigStepperProps, SensorConfigStepperState> {
|
||||||
|
|
||||||
private selectOptions: Array<DropdownItemProps>;
|
|
||||||
|
|
||||||
constructor(props: SensorConfigStepperProps, context: SensorConfigStepperState) {
|
constructor(props: SensorConfigStepperProps, context: SensorConfigStepperState) {
|
||||||
super(props, context);
|
super(props, context);
|
||||||
this.state = {
|
this.state = {
|
||||||
|
@ -136,19 +132,23 @@ export class SensorConfigStepper extends React.Component<SensorConfigStepperProp
|
||||||
if (sd.infra === undefined || sd.infra === null) {
|
if (sd.infra === undefined || sd.infra === null) {
|
||||||
return 'Target';
|
return 'Target';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
{
|
||||||
if (sd.crawler === undefined || sd.crawler === null) {
|
if (sd.crawler === undefined || sd.crawler === null) {
|
||||||
return 'Crawler';
|
return 'Crawler';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 3:
|
||||||
{
|
{
|
||||||
if (sd.sensorItemMap === undefined || sd.sensorItemMap === null || this.checkItemMapSize() === false) {
|
if (sd.sensorItemMap === undefined || sd.sensorItemMap === null || this.checkItemMapSize() === false) {
|
||||||
return 'Sensor Item';
|
return 'Sensor Item';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 4:
|
||||||
{
|
{
|
||||||
if (sd.interval === undefined) {
|
if (sd.interval === undefined) {
|
||||||
return 'Interval';
|
return 'Interval';
|
||||||
|
@ -228,77 +228,6 @@ export class SensorConfigStepper extends React.Component<SensorConfigStepperProp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public convertInfraList(): void {
|
|
||||||
|
|
||||||
if (this.props.infraList === undefined) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
let selectionOptions: Array<DropdownItemProps> = new Array;
|
|
||||||
|
|
||||||
for (let infra of this.props.infraList.content) {
|
|
||||||
|
|
||||||
selectionOptions.push(this.createOption(infra));
|
|
||||||
|
|
||||||
}
|
|
||||||
this.selectOptions = selectionOptions;
|
|
||||||
}
|
|
||||||
|
|
||||||
public convertInfra(): void {
|
|
||||||
if (this.props.infra === undefined) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let selectionOptions: Array<DropdownItemProps> = new Array;
|
|
||||||
|
|
||||||
selectionOptions.push(this.createOption(this.props.infra));
|
|
||||||
this.selectOptions = selectionOptions;
|
|
||||||
|
|
||||||
let sd = this.props.getSensor();
|
|
||||||
// sd.targetId = this.props.infra.target.id;
|
|
||||||
// sd.type = this.props.infra.infraType.name;
|
|
||||||
sd.infra = this.props.infra;
|
|
||||||
this.props.setSensor(sd);
|
|
||||||
}
|
|
||||||
|
|
||||||
public createOption(infra: Infra): DropdownItemProps {
|
|
||||||
let option = {
|
|
||||||
key: infra.id,
|
|
||||||
text: infra.infraType.name + '-' + infra.target.displayName,
|
|
||||||
// value: infra.target.id,
|
|
||||||
value: JSON.stringify(infra),
|
|
||||||
// icon: 'check', // or close?
|
|
||||||
};
|
|
||||||
return option;
|
|
||||||
}
|
|
||||||
|
|
||||||
public defaultValue(): any {
|
|
||||||
if (this.selectOptions !== undefined && this.selectOptions.length > 0) {
|
|
||||||
return this.selectOptions[0].value;
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public onChangeTarget(event: React.SyntheticEvent<HTMLElement>, data: DropdownProps): void {
|
|
||||||
let sd = this.props.getSensor();
|
|
||||||
// let infra: Infra = JSON.parse(String(data.value));
|
|
||||||
// sd.targetId = infra.target.id;
|
|
||||||
// sd.type = infra.infraType.name;
|
|
||||||
sd.infra = JSON.parse(String(data.value));
|
|
||||||
this.props.setSensor(sd);
|
|
||||||
}
|
|
||||||
|
|
||||||
public renderInfra(): JSX.Element {
|
|
||||||
|
|
||||||
if (this.props.infraId === undefined) {
|
|
||||||
this.convertInfraList();
|
|
||||||
} else {
|
|
||||||
this.convertInfra();
|
|
||||||
}
|
|
||||||
|
|
||||||
return (<Dropdown
|
|
||||||
placeholder='Select Target' selection options={this.selectOptions} defaultValue={this.defaultValue()}
|
|
||||||
onChange={this.onChangeTarget.bind(this)} />);
|
|
||||||
}
|
|
||||||
|
|
||||||
public render(): JSX.Element {
|
public render(): JSX.Element {
|
||||||
|
|
||||||
|
@ -307,20 +236,24 @@ export class SensorConfigStepper extends React.Component<SensorConfigStepperProp
|
||||||
<Step.Group fluid>
|
<Step.Group fluid>
|
||||||
<Step active={this.handleActive(1)} completed={this.handleCompleted(1)}>
|
<Step active={this.handleActive(1)} completed={this.handleCompleted(1)}>
|
||||||
<Icon name='settings' color='grey' />
|
<Icon name='settings' color='grey' />
|
||||||
<Step.Content title='Step 1' description='골라골라 크롤러를 골라' />
|
<Step.Content title='Step 1' description='Choose Target' />
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step active={this.handleActive(2)} completed={this.handleCompleted(2)}>
|
<Step active={this.handleActive(2)} completed={this.handleCompleted(2)}>
|
||||||
<Icon name='list ul' color='grey' />
|
<Icon name='list ul' color='grey' />
|
||||||
<Step.Content title='Step 2' description='골라골라 아이템도 골라' />
|
<Step.Content title='Step 2' description='Choose Crawler' />
|
||||||
</Step>
|
</Step>
|
||||||
|
|
||||||
<Step active={this.handleActive(3)} completed={this.handleCompleted(3)}>
|
<Step active={this.handleActive(3)} completed={this.handleCompleted(3)}>
|
||||||
<Icon name='options' color='grey' />
|
<Icon name='options' color='grey' />
|
||||||
<Step.Content title='Step 3' description='나머지도 골라 아 빨리' />
|
<Step.Content title='Step 3' description='Choose Items' />
|
||||||
|
</Step>
|
||||||
|
|
||||||
|
<Step active={this.handleActive(4)} completed={this.handleCompleted(4)}>
|
||||||
|
<Icon name='options' color='grey' />
|
||||||
|
<Step.Content title='Step 4' description='Input ETC' />
|
||||||
</Step>
|
</Step>
|
||||||
</Step.Group>
|
</Step.Group>
|
||||||
{this.renderInfra()}
|
|
||||||
{this.showContent()}
|
{this.showContent()}
|
||||||
<br />
|
<br />
|
||||||
<Button.Group floated='right'> {/* floated 사용시 레이아웃 깨지는 현상 */}
|
<Button.Group floated='right'> {/* floated 사용시 레이아웃 깨지는 현상 */}
|
||||||
|
|
|
@ -0,0 +1,162 @@
|
||||||
|
import * as React from 'react';
|
||||||
|
|
||||||
|
import {
|
||||||
|
Icon,
|
||||||
|
Step,
|
||||||
|
Button,
|
||||||
|
Table,
|
||||||
|
Radio,
|
||||||
|
Form,
|
||||||
|
Container,
|
||||||
|
Checkbox,
|
||||||
|
} from 'semantic-ui-react';
|
||||||
|
import {
|
||||||
|
Grid,
|
||||||
|
Image,
|
||||||
|
Label,
|
||||||
|
Segment,
|
||||||
|
Dropdown,
|
||||||
|
Input,
|
||||||
|
List,
|
||||||
|
Accordion,
|
||||||
|
Loader,
|
||||||
|
DropdownItemProps, DropdownProps,
|
||||||
|
} from 'semantic-ui-react';
|
||||||
|
|
||||||
|
|
||||||
|
import MetaCrawler from '@overflow/meta/api/model/MetaCrawler';
|
||||||
|
import Infra from '@overflow/infra/api/model/Infra';
|
||||||
|
import Domain from '@overflow/domain/api/model/Domain';
|
||||||
|
|
||||||
|
import Page from '@overflow/commons/api/model/Page';
|
||||||
|
import SensorRegistInfo from '../../api/model/SensorRegistInfo';
|
||||||
|
|
||||||
|
import PageParams from '@overflow/commons/api/model/PageParams';
|
||||||
|
|
||||||
|
|
||||||
|
export interface StateProps {
|
||||||
|
infraList?: Page;
|
||||||
|
infra?: Infra;
|
||||||
|
infraId?: number;
|
||||||
|
setSensor?(data: SensorRegistInfo): void;
|
||||||
|
getSensor?(): SensorRegistInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface DispatchProps {
|
||||||
|
|
||||||
|
onReadAllTargetByDomain?(domain: Domain, pageParams: PageParams): void;
|
||||||
|
onReadInfra?(infraId: number): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
export type Props = StateProps & DispatchProps;
|
||||||
|
|
||||||
|
export interface State {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
export class SensorConfigTargetSelect extends React.Component<Props, State> {
|
||||||
|
|
||||||
|
private selectOptions: Array<DropdownItemProps>;
|
||||||
|
|
||||||
|
constructor(props: Props, context: State) {
|
||||||
|
super(props, context);
|
||||||
|
this.state = {
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public componentWillMount(): void {
|
||||||
|
if (this.props.infraId === undefined) {
|
||||||
|
const pageParams: PageParams = {
|
||||||
|
pageNo: '0',
|
||||||
|
countPerPage: '999',
|
||||||
|
sortCol: 'id',
|
||||||
|
sortDirection: 'descending',
|
||||||
|
};
|
||||||
|
this.props.onReadAllTargetByDomain({ id: 1 }, pageParams);
|
||||||
|
} else {
|
||||||
|
this.props.onReadInfra(this.props.infraId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public convertInfraList(): void {
|
||||||
|
|
||||||
|
if (this.props.infraList === undefined) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
let selectionOptions: Array<DropdownItemProps> = new Array;
|
||||||
|
|
||||||
|
for (let infra of this.props.infraList.content) {
|
||||||
|
|
||||||
|
selectionOptions.push(this.createOption(infra));
|
||||||
|
|
||||||
|
}
|
||||||
|
this.selectOptions = selectionOptions;
|
||||||
|
}
|
||||||
|
|
||||||
|
public convertInfra(): void {
|
||||||
|
if (this.props.infra === undefined) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let selectionOptions: Array<DropdownItemProps> = new Array;
|
||||||
|
|
||||||
|
selectionOptions.push(this.createOption(this.props.infra));
|
||||||
|
this.selectOptions = selectionOptions;
|
||||||
|
|
||||||
|
let sd = this.props.getSensor();
|
||||||
|
// sd.targetId = this.props.infra.target.id;
|
||||||
|
// sd.type = this.props.infra.infraType.name;
|
||||||
|
sd.infra = this.props.infra;
|
||||||
|
this.props.setSensor(sd);
|
||||||
|
}
|
||||||
|
|
||||||
|
public createOption(infra: Infra): DropdownItemProps {
|
||||||
|
let option = {
|
||||||
|
key: infra.id,
|
||||||
|
text: infra.infraType.name + '-' + infra.target.displayName,
|
||||||
|
// value: infra.target.id,
|
||||||
|
value: JSON.stringify(infra),
|
||||||
|
// icon: 'check', // or close?
|
||||||
|
};
|
||||||
|
return option;
|
||||||
|
}
|
||||||
|
|
||||||
|
public defaultValue(): any {
|
||||||
|
if (this.selectOptions !== undefined && this.selectOptions.length > 0) {
|
||||||
|
return this.selectOptions[0].value;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public onChangeTarget(event: React.SyntheticEvent<HTMLElement>, data: DropdownProps): void {
|
||||||
|
let sd = this.props.getSensor();
|
||||||
|
// let infra: Infra = JSON.parse(String(data.value));
|
||||||
|
// sd.targetId = infra.target.id;
|
||||||
|
// sd.type = infra.infraType.name;
|
||||||
|
sd.infra = JSON.parse(String(data.value));
|
||||||
|
this.props.setSensor(sd);
|
||||||
|
}
|
||||||
|
|
||||||
|
public renderInfra(): JSX.Element {
|
||||||
|
|
||||||
|
if (this.props.infraId === undefined) {
|
||||||
|
this.convertInfraList();
|
||||||
|
} else {
|
||||||
|
this.convertInfra();
|
||||||
|
}
|
||||||
|
|
||||||
|
return (<Dropdown
|
||||||
|
placeholder='Select Target' selection options={this.selectOptions} defaultValue={this.defaultValue()}
|
||||||
|
onChange={this.onChangeTarget.bind(this)} />);
|
||||||
|
}
|
||||||
|
|
||||||
|
public render(): JSX.Element {
|
||||||
|
return (
|
||||||
|
<Container fluid>
|
||||||
|
{this.renderInfra()}
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
|
@ -33,17 +33,15 @@ import SensorItemTree from '@overflow/meta/react/SensorItemTree';
|
||||||
import CrawlerSelectorContainer from '@overflow/meta/react/CrawlerSelector';
|
import CrawlerSelectorContainer from '@overflow/meta/react/CrawlerSelector';
|
||||||
|
|
||||||
import SensorConfigStepperContainer from '../SensorConfigStepper';
|
import SensorConfigStepperContainer from '../SensorConfigStepper';
|
||||||
import PageParams from '@overflow/commons/api/model/PageParams';
|
import SensorConfigTargetSelectContainer from '../SensorConfigTargetSelect';
|
||||||
|
|
||||||
|
|
||||||
export interface SensorConfigurationStateProps {
|
export interface SensorConfigurationStateProps {
|
||||||
infraId?: number;
|
infraId?: number;
|
||||||
infraList?: Page;
|
|
||||||
infra?: Infra;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface SensorConfigurationDispatchProps {
|
export interface SensorConfigurationDispatchProps {
|
||||||
onReadAllTargetByDomain?(domain: Domain, pageParams: PageParams): void;
|
|
||||||
onReadInfra?(infraId: number): void;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface SensorConfigurationState {
|
export interface SensorConfigurationState {
|
||||||
|
@ -64,19 +62,7 @@ export class SensorConfiguration extends React.Component<SensorConfigurationProp
|
||||||
this.sensorData = {};
|
this.sensorData = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
public componentWillMount(): void {
|
|
||||||
if (this.props.infraId === undefined) {
|
|
||||||
const pageParams: PageParams = {
|
|
||||||
pageNo: '0',
|
|
||||||
countPerPage: '999',
|
|
||||||
sortCol: 'id',
|
|
||||||
sortDirection: 'descending',
|
|
||||||
};
|
|
||||||
this.props.onReadAllTargetByDomain({ id: 1 }, pageParams);
|
|
||||||
} else {
|
|
||||||
this.props.onReadInfra(this.props.infraId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public onSelectCrawlerId = (id: number) => {
|
public onSelectCrawlerId = (id: number) => {
|
||||||
this.setState({
|
this.setState({
|
||||||
|
@ -95,6 +81,8 @@ export class SensorConfiguration extends React.Component<SensorConfigurationProp
|
||||||
|
|
||||||
public render(): JSX.Element {
|
public render(): JSX.Element {
|
||||||
let steps = [
|
let steps = [
|
||||||
|
<SensorConfigTargetSelectContainer setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)}
|
||||||
|
infraId={this.props.infraId} />,
|
||||||
<CrawlerSelectorContainer onSelectCrawlerId={this.onSelectCrawlerId.bind(this)}
|
<CrawlerSelectorContainer onSelectCrawlerId={this.onSelectCrawlerId.bind(this)}
|
||||||
setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)} />,
|
setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)} />,
|
||||||
<Segment vertical>
|
<Segment vertical>
|
||||||
|
@ -104,7 +92,7 @@ export class SensorConfiguration extends React.Component<SensorConfigurationProp
|
||||||
<ETCSelector setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)} />];
|
<ETCSelector setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)} />];
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<SensorConfigStepperContainer steps={steps} infraId={this.props.infraId} infra={this.props.infra} infraList={this.props.infraList}
|
<SensorConfigStepperContainer steps={steps} infraId={this.props.infraId}
|
||||||
setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)} />
|
setSensor={this.setSensor.bind(this)} getSensor={this.getSensor.bind(this)} />
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user