sensor paging sorting

This commit is contained in:
insanity 2017-08-28 14:46:58 +09:00
parent a03599f16e
commit 1e387df380
7 changed files with 73 additions and 33 deletions

View File

@ -116,7 +116,7 @@ export class HistoryList extends React.Component<Props, State> {
return metaType;
}
public handlePaging = (pageNo: number) => {
private handlePaging = (pageNo: number) => {
let probe: Probe = {
id: Number(1),
};

View File

@ -7,8 +7,6 @@ import {
DispatchProps as SensorListDispatchProps,
} from './components/SensorList';
import State from '../redux/state/ReadAllByTarget';
import * as ReadAllByTargetActions from '../redux/action/read_all_by_target';
import * as ReadAllByProbeActions from '../redux/action/read_all_by_probe';
import * as ReadAllByDomainActions from '../redux/action/read_all_by_domain';
@ -18,30 +16,30 @@ import Sensor from '@overflow/sensor/api/model/Sensor';
import Probe from '@overflow/probe/api/model/Probe';
import Domain from '@overflow/domain/api/model/Domain';
import Infra from '@overflow/infra/api/model/Infra';
import PageParams from '@overflow/commons/api/model/PageParams';
import * as asyncRequestActions from '@overflow/commons/redux/action/asyncRequest';
export function mapStateToProps(state: any, props: any): SensorListStateProps {
return {
sensorList:state.SensorList,
sensorList: state.SensorList,
infraId: props.params.id,
};
}
export function mapDispatchToProps(dispatch: Dispatch<any>): SensorListDispatchProps {
return {
onReadAllByTarget: (target: Target) => {
dispatch(asyncRequestActions.request('SensorService', 'readAllByTarget', ReadAllByTargetActions.REQUEST, JSON.stringify(target)));
onReadAllByInfra: (infraId: number, pageParams: PageParams) => {
dispatch(asyncRequestActions.request('SensorService', 'readAllByInfra',
ReadAllByInfraActions.REQUEST, infraId, JSON.stringify(pageParams)));
},
onReadAllByInfra: (infraId: number) => {
dispatch(asyncRequestActions.request('SensorService', 'readAllByInfra', ReadAllByInfraActions.REQUEST, infraId));
onReadAllByDomain: (domain: Domain, pageParams: PageParams) => {
dispatch(asyncRequestActions.request('SensorService', 'readAllByDomain',
ReadAllByDomainActions.REQUEST, JSON.stringify(domain), JSON.stringify(pageParams)));
},
onReadAllByProbe: (probe: Probe) => {
dispatch(ReadAllByProbeActions.request(probe));
},
onReadAllByDomain: (domain: Domain) => {
dispatch(asyncRequestActions.request('SensorService', 'readAllByDomain', ReadAllByDomainActions.REQUEST, JSON.stringify(domain)));
},
onSelectSensor: (id: number) => {
dispatch(routerPush('/sensor/' + String(id)));
},

View File

@ -7,21 +7,25 @@ import Sensor from '@overflow/sensor/api/model/Sensor';
import Target from '@overflow/target/api/model/Target';
import Domain from '@overflow/domain/api/model/Domain';
import Infra from '@overflow/infra/api/model/Infra';
import PageParams from '@overflow/commons/api/model/PageParams';
import Page from '@overflow/commons/api/model/Page';
import { Pager } from '@overflow/commons/react/component/Pager';
import { SortTableHeaderRow } from '@overflow/commons/react/component/SortTableHeaderRow';
export interface StateProps {
probe?: Probe;
target?: Target;
sensorList?: Sensor[];
sensorList?: Page;
infraId?: number;
}
export interface DispatchProps {
onReadAllByTarget?(target: Target): void;
onReadAllByDomain?(domain: Domain, pageParams: PageParams): void;
onReadAllByInfra?(infraId: number, pageParams: PageParams): void;
onReadAllByProbe?(probe: Probe): void;
onReadAllByDomain?(domain: Domain): void;
onSelectSensor?(id: number): void;
onAddSensor?(infraId: string): void;
onReadAllByInfra?(infraId: number): void;
}
export type SensorListProps = StateProps & DispatchProps;
@ -33,7 +37,10 @@ export interface SensorListState {
export class SensorList extends React.Component<SensorListProps, SensorListState> {
// private data: any;
private countPerPage: number = 10;
private sortCol: string = 'id';
private sortDirection: string = 'descending';
private pageNo: number = 0;
constructor(props: SensorListProps, context: SensorListState) {
super(props, context);
@ -43,16 +50,24 @@ export class SensorList extends React.Component<SensorListProps, SensorListState
}
public componentWillMount(): void {
// super.componentWillMount();
this.getData();
}
public getData(): void {
const pageParams: PageParams = {
pageNo: String(this.pageNo),
countPerPage: String(this.countPerPage),
sortCol: this.sortCol,
sortDirection: this.sortDirection,
};
if (this.props.infraId === undefined) {
let domain: Domain = {
id: 1,
};
this.props.onReadAllByDomain(domain);
this.props.onReadAllByDomain(domain, pageParams);
} else {
this.props.onReadAllByInfra(this.props.infraId);
this.props.onReadAllByInfra(this.props.infraId, pageParams);
}
}
public handleSelect(selectedSensor: Sensor): void {
@ -87,21 +102,29 @@ export class SensorList extends React.Component<SensorListProps, SensorListState
public render(): JSX.Element {
let colsmap: Map<string, string> = new Map();
colsmap.set('No.', 'id');
colsmap.set('Status', 'status.name');
colsmap.set('Crawler', 'crawler.name');
colsmap.set('Description', 'description');
colsmap.set('Item count', 'itemCount');
let sensorList: JSX.Element = (
<Container fluid>
<Table celled selectable striped>
<Table celled selectable striped sortable>
<Table.Header>
<Table.Row>
<SortTableHeaderRow columnMap={colsmap} onHeaderColumnClick={this.handleSort} />
{/* <Table.Row>
<Table.HeaderCell textAlign={'center'}>No.</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Status</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Crawler</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Description</Table.HeaderCell>
<Table.HeaderCell textAlign={'center'}>Item count</Table.HeaderCell>
</Table.Row>
</Table.Row> */}
</Table.Header>
<Table.Body>
{this.props.sensorList ? this.props.sensorList.map((sensor: Sensor, index: number) => (
{this.props.sensorList ? this.props.sensorList.content.map((sensor: Sensor, index: number) => (
<Table.Row key={index} onClick={this.handleSelect.bind(this, sensor)}>
<Table.Cell textAlign={'center'}>{index + 1}</Table.Cell>
<Table.Cell negative={this.checkCellStatus(sensor.status)} textAlign={'center'}>
@ -114,6 +137,13 @@ export class SensorList extends React.Component<SensorListProps, SensorListState
</Table.Row>
)) : ''}
</Table.Body>
<Table.Footer>
<Table.Row>
<Table.HeaderCell colSpan='6' textAlign='center'>
<Pager page={this.props.sensorList} onPageChange={this.handlePaging} />
</Table.HeaderCell>
</Table.Row>
</Table.Footer>
</Table>
<Button content='Add' icon='add' labelPosition='left' floated='right' positive onClick={this.handleAddSensor.bind(this)} />
@ -126,7 +156,18 @@ export class SensorList extends React.Component<SensorListProps, SensorListState
data={this.props.sensorList}
/>
);
}
private handlePaging = (pageNo: number) => {
this.pageNo = pageNo;
this.getData();
}
private handleSort = (col: string, direction: string): void => {
console.log(col + ' || direction:' + direction);
this.sortCol = col;
this.sortDirection = direction;
this.getData();
}
}

View File

@ -4,14 +4,15 @@ import Sensor from '@overflow/sensor/api/model/Sensor';
import * as ReadAllByDomainActionTypes from '../action/read_all_by_domain';
import ReadAllByDomain, { defaultState as readAllByDomainDefaultState } from '../state/ReadAllByDomain';
import Page from '@overflow/commons/api/model/Page';
const reducer: ReducersMapObject = {
[ReadAllByDomainActionTypes.REQUEST_SUCCESS]:
(state: ReadAllByDomain = readAllByDomainDefaultState, action: Action<Sensor[]>):
(state: ReadAllByDomain = readAllByDomainDefaultState, action: Action<Page>):
ReadAllByDomain => {
return {
...state,
SensorList:<Sensor[]>action.payload,
SensorList:<Page>action.payload,
};
},
[ReadAllByDomainActionTypes.REQUEST_FAILURE]:

View File

@ -6,14 +6,14 @@ import Sensor from '@overflow/sensor/api/model/Sensor';
import * as ReadAllByInfraActionTypes from '../action/read_all_by_infra';
import ReadAllByInfraState, { defaultState as readAllByInfraDefaultState } from '../state/ReadAllByInfra';
import Page from '@overflow/commons/api/model/Page';
const reducer: ReducersMapObject = {
[ReadAllByInfraActionTypes.REQUEST_SUCCESS]:
(state: ReadAllByInfraState = readAllByInfraDefaultState, action: Action<Sensor[]>): ReadAllByInfraState => {
console.log(action);
(state: ReadAllByInfraState = readAllByInfraDefaultState, action: Action<Page>): ReadAllByInfraState => {
return {
...state,
SensorList:<Sensor[]>action.payload,
SensorList:<Page>action.payload,
};
},
[ReadAllByInfraActionTypes.REQUEST_FAILURE]:

View File

@ -1,7 +1,7 @@
import Sensor from '../../api/model/Sensor';
import Page from '@overflow/commons/api/model/Page';
export interface State {
readonly SensorList: Sensor[];
readonly SensorList: Page;
readonly error?: Error;
}

View File

@ -1,7 +1,7 @@
import Sensor from '../../api/model/Sensor';
import Page from '@overflow/commons/api/model/Page';
export interface State {
readonly SensorList: Sensor[];
readonly SensorList: Page;
readonly error?: Error;
}