From 6b114c498b1759fda574b109bb38eb42bc1da84b Mon Sep 17 00:00:00 2001 From: insanity Date: Thu, 24 Aug 2017 20:19:58 +0900 Subject: [PATCH] history filter --- src/ts/@overflow/app/config/index.ts | 2 + .../@overflow/history/react/HistoryList.tsx | 5 + .../react/components/HistoryFilter.tsx | 33 ------ .../history/react/components/HistoryList.tsx | 102 ++++++++++++++++-- .../redux/action/history_type_read_all.ts | 10 ++ .../redux/reducer/history_type_read_all.ts | 26 +++++ .../meta/redux/state/HistoryTypeReadAll.ts | 14 +++ 7 files changed, 152 insertions(+), 40 deletions(-) delete mode 100644 src/ts/@overflow/history/react/components/HistoryFilter.tsx create mode 100644 src/ts/@overflow/meta/redux/action/history_type_read_all.ts create mode 100644 src/ts/@overflow/meta/redux/reducer/history_type_read_all.ts create mode 100644 src/ts/@overflow/meta/redux/state/HistoryTypeReadAll.ts diff --git a/src/ts/@overflow/app/config/index.ts b/src/ts/@overflow/app/config/index.ts index 05de6d4..8993559 100644 --- a/src/ts/@overflow/app/config/index.ts +++ b/src/ts/@overflow/app/config/index.ts @@ -42,6 +42,7 @@ import DiscoveryInfraTargetRegistAllReducer from '@overflow/discovery/redux/redu import HistoryReadAllByProbeReducer from '@overflow/history/redux/reducer/read_all_by_probe'; import HistoryReadAllByProbeAndTypeReducer from '@overflow/history/redux/reducer/read_all_by_probe_and_type'; +import HistoryTypeReadAllReducer from '@overflow/meta/redux/reducer/history_type_read_all'; import AsyncRequest from '@overflow/app/redux/saga/AsyncRequest'; @@ -108,6 +109,7 @@ const reduxConfig: ReduxConfig = { HistoryReadAllByProbeAndTypeReducer, readAllTargetByInfraReducer, InfraReadServiceReducer, + HistoryTypeReadAllReducer, ], sagaWatchers: [ AsyncRequest, diff --git a/src/ts/@overflow/history/react/HistoryList.tsx b/src/ts/@overflow/history/react/HistoryList.tsx index 0c44b07..5f3519b 100644 --- a/src/ts/@overflow/history/react/HistoryList.tsx +++ b/src/ts/@overflow/history/react/HistoryList.tsx @@ -13,12 +13,14 @@ import MetaHistoryType from '@overflow/meta/api/model/MetaHistoryType'; import * as readAllByProbeActions from '../redux/action/read_all_by_probe'; import * as readAllByProbeAndTypeActions from '../redux/action/read_all_by_probe_and_type'; import * as probeListActions from '@overflow/probe/redux/action/read_all_by_domain'; +import * as historyTypeListActions from '@overflow/meta/redux/action/history_type_read_all'; export function mapStateToProps(state: any, ownProps?: any): HistoryStateProps { return { path: ownProps.params, probes: state.probeList, histories: state.historyPage, + historyTypes: state.historyTypes, }; } @@ -39,6 +41,9 @@ export function mapDispatchToProps(dispatch: Dispatch, own onReadAllProbeByDomain: (domain: Domain) => { dispatch(asyncRequestActions.request('ProbeService', 'readAllByDomain', probeListActions.REQUEST, JSON.stringify(domain))); }, + onReadAllMetaHistoryType: () => { + dispatch(asyncRequestActions.request('MetaHistoryTypeService', 'readAll', historyTypeListActions.REQUEST)); + }, }; } diff --git a/src/ts/@overflow/history/react/components/HistoryFilter.tsx b/src/ts/@overflow/history/react/components/HistoryFilter.tsx deleted file mode 100644 index 57cd153..0000000 --- a/src/ts/@overflow/history/react/components/HistoryFilter.tsx +++ /dev/null @@ -1,33 +0,0 @@ -import * as React from 'react'; -import { Table, Button, Header, Container, Menu, Icon } from 'semantic-ui-react'; - - -export interface StateProps { -} - -export interface DispatchProps { -} - -export type Props = StateProps & DispatchProps; - -export interface State { -} - -export class HistoryFilter extends React.Component { - - constructor(props: any, context: any) { - super(props, context); - this.state = { - }; - - } - - public render(): JSX.Element { - return ( - - - ); - } - - -} diff --git a/src/ts/@overflow/history/react/components/HistoryList.tsx b/src/ts/@overflow/history/react/components/HistoryList.tsx index f21ead6..64e2f50 100644 --- a/src/ts/@overflow/history/react/components/HistoryList.tsx +++ b/src/ts/@overflow/history/react/components/HistoryList.tsx @@ -13,10 +13,12 @@ export interface StateProps { probes: Probe[]; histories: Page; path: any; + historyTypes: MetaHistoryType[]; } export interface DispatchProps { onReadAllProbeByDomain?(domain: Domain): void; + onReadAllMetaHistoryType?(): void; onReadAllByDomain?(domain: Domain, pageNo: string, countPerPage: string): void; onReadAllByProbe?(probe: Probe, pageNo: string, countPerPage: string): void; @@ -27,18 +29,17 @@ export type Props = StateProps & DispatchProps; export interface State { isTypedHistory: boolean; - selectedProbeId: number; } export class HistoryList extends React.Component { private countPerPage: number = 10; + private selectedProbeId: number = 0; constructor(props: Props, context: State) { super(props, context); this.state = { isTypedHistory: false, - selectedProbeId: 0, }; } @@ -47,6 +48,8 @@ export class HistoryList extends React.Component { id: 1, }; this.props.onReadAllProbeByDomain(domain); + this.props.onReadAllMetaHistoryType(); + if (this.props.path === '/histories') { this.setState({ isTypedHistory: false, @@ -61,14 +64,14 @@ export class HistoryList extends React.Component { } public getAllHistory(pageNo: number): void { - if (this.state.selectedProbeId === 0) { + if (this.selectedProbeId === 0) { let domain: Domain = { id: Number(1), }; this.props.onReadAllByDomain(domain, String(pageNo), String(this.countPerPage)); } else { let probe: Probe = { - id: Number(this.state.selectedProbeId), + id: Number(this.selectedProbeId), }; this.props.onReadAllByProbe(probe, String(pageNo), String(this.countPerPage)); } @@ -113,9 +116,6 @@ export class HistoryList extends React.Component { } public render(): JSX.Element { - if (this.props.probes !== undefined) { - console.log(this.props.probes); - } let historyList: JSX.Element = ( @@ -160,13 +160,101 @@ export class HistoryList extends React.Component { ); + let filter = ; return ( ); } + + private handleProbeChange = (probeId: number) => { + this.selectedProbeId = probeId; + this.getAllHistory(0); + } } + + +export interface FilterProps { + probes: Probe[]; + historyTypes: MetaHistoryType[]; + onProbeChange(probeId: number): void; +} + +export interface FilterState { + selectedProbeId: number; +} + +import { Dropdown, Form, Radio } from 'semantic-ui-react'; + +export class HistoryFilter extends React.Component { + + constructor(props: any, context: any) { + super(props, context); + this.state = { + selectedProbeId: 0, + }; + } + + public render(): JSX.Element { + if (this.props.probes === null || this.props.probes === undefined) { + return null; + } + console.log(this.props.historyTypes); + return ( +
+ Probe + + , data: any) => { + this.setState({ + selectedProbeId: data.value, + }); + this.props.onProbeChange(data.value); + }} /> + + Type + + + + + + + + ); + } + + private getOptions(): Array { + let res = new Array; + let all = { + key: 0, + text: 'All', + value: 0, + }; + res.push(all); + this.props.probes.map((probe: Probe, index: number) => { + let option = { + key: index + 1, + text: probe.displayName, + value: probe.id, + }; + res.push(option); + }); + return res; + } +} diff --git a/src/ts/@overflow/meta/redux/action/history_type_read_all.ts b/src/ts/@overflow/meta/redux/action/history_type_read_all.ts new file mode 100644 index 0000000..72f572b --- /dev/null +++ b/src/ts/@overflow/meta/redux/action/history_type_read_all.ts @@ -0,0 +1,10 @@ + +export type REQUEST = '@overflow/history_type/read_all/REQUEST'; +export type REQUEST_SUCCESS = '@overflow/history_type/read_all/REQUEST/SUCCESS'; +export type REQUEST_FAILURE = '@overflow/history_type/read_all/REQUEST/FAILURE'; + +export const REQUEST: REQUEST = '@overflow/history_type/read_all/REQUEST'; +export const REQUEST_SUCCESS: REQUEST_SUCCESS = '@overflow/history_type/read_all/REQUEST/SUCCESS'; +export const REQUEST_FAILURE: REQUEST_FAILURE = '@overflow/history_type/read_all/REQUEST/FAILURE'; + + diff --git a/src/ts/@overflow/meta/redux/reducer/history_type_read_all.ts b/src/ts/@overflow/meta/redux/reducer/history_type_read_all.ts new file mode 100644 index 0000000..8dcd61a --- /dev/null +++ b/src/ts/@overflow/meta/redux/reducer/history_type_read_all.ts @@ -0,0 +1,26 @@ + +import Action from '@overflow/commons/redux/Action'; +import { ReducersMapObject } from 'redux'; + +import * as HistoryTypeReadAllActions from '../action/history_type_read_all'; +import HistoryTypeReadAllState, { defaultState as HistoryTypeReadAllDefaultState } from '../state/HistoryTypeReadAll'; + +import MetaHistoryType from '../../api/model/MetaHistoryType'; + +const reducer: ReducersMapObject = { + [HistoryTypeReadAllActions.REQUEST_SUCCESS]: + (state: HistoryTypeReadAllState = HistoryTypeReadAllDefaultState, action: Action): + HistoryTypeReadAllState => { + return { + ...state, + historyTypes: action.payload, + }; + }, + [HistoryTypeReadAllActions.REQUEST_FAILURE]: + (state: HistoryTypeReadAllState = HistoryTypeReadAllDefaultState, action: Action): + HistoryTypeReadAllState => { + return state; + }, +}; + +export default reducer; diff --git a/src/ts/@overflow/meta/redux/state/HistoryTypeReadAll.ts b/src/ts/@overflow/meta/redux/state/HistoryTypeReadAll.ts new file mode 100644 index 0000000..8dd0259 --- /dev/null +++ b/src/ts/@overflow/meta/redux/state/HistoryTypeReadAll.ts @@ -0,0 +1,14 @@ + +import MetaHistoryType from '../../api/model/MetaHistoryType'; + +export interface State { + readonly historyTypes: MetaHistoryType[]; + readonly error?: Error; +} + +export const defaultState: State = { + historyTypes: undefined, + error: undefined, +}; + +export default State;