member props modify

This commit is contained in:
geek 2017-07-20 17:33:14 +09:00
parent 07fbd85925
commit 6a94fbc73e
8 changed files with 123 additions and 53 deletions

View File

@ -0,0 +1,26 @@
import { connect, Dispatch } from 'react-redux';
import {
PWChange,
StateProps as PWCangeStateProps,
DispatchProps as PWCangeDispatchProps,
} from './components/PWChange';
import * as pwChangeActions from '../redux/action/pw_change';
export function mapStateToProps(state: any): PWCangeStateProps {
return {
};
}
export function mapDispatchToProps(dispatch: Dispatch<any>): PWCangeDispatchProps {
return {
onResetPassword: (pass: string) => {
dispatch(pwChangeActions.request(pass));
},
};
}
export default connect(mapStateToProps, mapDispatchToProps)(PWChange);

View File

@ -1,31 +1,25 @@
import { connect, Dispatch } from 'react-redux'; import { connect, Dispatch } from 'react-redux';
import { import {
SignIn, SignIn,
Props as SignInProps, StateProps as SignInStateProps,
State as SignInState, DispatchProps as SigninDispatchProps,
} from './components/SignIn'; } from './components/SignIn';
import State from '../redux/state/SignIn'; import State from '../redux/state/SignIn';
import * as signinActions from '../redux/action/signIn'; import * as signinActions from '../redux/action/signIn';
export function mapStateToProps(state: SignInState): SignInProps { export function mapStateToProps(state: any): SignInStateProps {
return { return {
}; };
} }
export function mapDispatchToProps(dispatch: Dispatch<SignInState>): SignInProps { export function mapDispatchToProps(dispatch: Dispatch<any>): SigninDispatchProps {
return { return {
onSignin: (signinId: string, signinPw: string) => { onSignIn: (signinId: string, signinPw: string) => {
dispatch(signinActions.request(signinId, signinPw)); dispatch(signinActions.request(signinId, signinPw));
}, },
onSignup: () => {
return;
},
onResetPassword: () => {
return;
},
}; };
} }

View File

@ -11,23 +11,17 @@ import State from '../redux/state/SignUp';
import * as signupActions from '../redux/action/signUp'; import * as signupActions from '../redux/action/signUp';
export function mapStateToProps(state: SignUpState): SignUpProps { export function mapStateToProps(state: any): SignUpProps {
return { return {
}; };
} }
export function mapDispatchToProps(dispatch: Dispatch<SignUpState>): SignUpProps { export function mapDispatchToProps(dispatch: Dispatch<any>): SignUpProps {
return { return {
onSignin: () => { onSignUp: (member: Member) => {
return;
},
onSignup: (member: Member) => {
dispatch(signupActions.request(member)); dispatch(signupActions.request(member));
}, },
onResetPassword: () => {
return;
},
}; };
} }

View File

@ -6,16 +6,22 @@ import {
Button, Button,
Grid, Grid,
Form, Form,
Container, Container, ButtonProps,
} from 'semantic-ui-react'; } from 'semantic-ui-react';
export interface StateProps {
}
export interface DispatchProps {
onResetPassword?(pass:string):void;
}
export type Props = StateProps & DispatchProps;
export interface State { export interface State {
pass: string; pass: string;
passCon: string; passCon: string;
} }
export interface Props {
}
export class PWChange extends React.Component<Props, State> { export class PWChange extends React.Component<Props, State> {
constructor(props: Props, context: State) { constructor(props: Props, context: State) {
@ -28,11 +34,6 @@ export class PWChange extends React.Component<Props, State> {
} }
public onSubmit():void {
console.log(this.state);
}
public render(): JSX.Element { public render(): JSX.Element {
return ( return (
<Container fluid> <Container fluid>
@ -51,7 +52,7 @@ export class PWChange extends React.Component<Props, State> {
this.setState({ passCon: data.value }); this.setState({ passCon: data.value });
}} /> }} />
<Form.Group> <Form.Group>
<Button primary fluid style={{margin:'7'}} onClick={this.onSubmit}> Submit </Button> <Button primary fluid style={{margin:'7'}} onClick={this.passChangeClick}> Submit </Button>
<Button fluid style={{margin:'7'}}> Cancel </Button> <Button fluid style={{margin:'7'}}> Cancel </Button>
</Form.Group> </Form.Group>
</Form> </Form>
@ -64,7 +65,8 @@ export class PWChange extends React.Component<Props, State> {
); );
} }
private passChangeClick(event: React.SyntheticEvent<HTMLButtonElement>, data: ButtonProps):void {
this.props.onResetPassword(this.state.pass);
}
} }

View File

@ -9,16 +9,24 @@ import {
Grid, Grid,
Form, Form,
Container, Container,
ButtonProps,
} from 'semantic-ui-react'; } from 'semantic-ui-react';
const options = [{ key: 'southkorea', value: '82', text: 'South Korea(82)' }, const options = [
{ key: 'unitedstates', value: '1', text: 'United States(1)' }]; { key: 'southkorea', value: '82', text: 'South Korea(82)' },
{ key: 'unitedstates', value: '1', text: 'United States(1)' },
];
export interface Props { export interface StateProps {
} }
export interface DispatchProps {
onSignIn?(signinId: string, signinPw: string ): void;
onSignUp?(): void;
onResetPassword?():void;
}
export type Props = StateProps & DispatchProps;
export interface State { export interface State {
forgotPopup: boolean; forgotPopup: boolean;
sendComPopup: boolean; sendComPopup: boolean;
@ -61,7 +69,7 @@ export class SignIn extends React.Component<Props, State> {
<a style={{fontSize:10}} onClick={this.forgotPopupOpen}>Forgot Password</a> <a style={{fontSize:10}} onClick={this.forgotPopupOpen}>Forgot Password</a>
</div> </div>
<Form.Group> <Form.Group>
<Button fluid primary style={{margin:'7'}} onClick={this.onSignIn}> Sign In </Button> <Button fluid primary style={{margin:'7'}} onClick={ this.signInClick }> Sign In </Button>
<Button fluid style={{margin:'7'}} href='/#/test2'> Sign Up </Button> <Button fluid style={{margin:'7'}} href='/#/test2'> Sign Up </Button>
</Form.Group> </Form.Group>
</Form> </Form>
@ -115,9 +123,9 @@ export class SignIn extends React.Component<Props, State> {
sendComPopup: true, sendComPopup: true,
}); });
} };
private onSignIn = () => { private signInClick(event: React.SyntheticEvent<HTMLButtonElement>, data: ButtonProps):void {
console.log(this.state); this.props.onSignIn(this.state.email, this.state.pass);
} }
} }

View File

@ -1,17 +1,14 @@
import *as React from 'react'; import *as React from 'react';
import { import {
Input,
InputOnChangeData, InputOnChangeData,
Select,
Button, Button,
Dropdown,
Grid, Grid,
Form, Form,
Container, Container,
} from 'semantic-ui-react'; } from 'semantic-ui-react';
export interface Props { export interface Props {
// onSignUp?():void;
} }
export interface State { export interface State {
@ -24,8 +21,10 @@ export interface State {
country: string; country: string;
} }
const options = [{ key: 'southkorea', value: '82', text: 'South Korea(82)' }, const options = [
{ key: 'unitedstates', value: '1', text: 'United States(1)' }] { key: 'southkorea', value: '82', text: 'South Korea(82)' },
{ key: 'unitedstates', value: '1', text: 'United States(1)' },
];
export class SignUp extends React.Component<Props, State> { export class SignUp extends React.Component<Props, State> {
@ -44,10 +43,6 @@ export class SignUp extends React.Component<Props, State> {
} }
public onSubmit():void {
console.log(this.state);
}
public onChange (event: React.SyntheticEvent<HTMLInputElement>, data: InputOnChangeData):void { public onChange (event: React.SyntheticEvent<HTMLInputElement>, data: InputOnChangeData):void {
console.log(event); console.log(event);
console.log(data); console.log(data);
@ -97,7 +92,7 @@ export class SignUp extends React.Component<Props, State> {
} }
} /> } />
<Form.Group> <Form.Group>
<Button primary fluid style={{margin:'7'}} onClick={this.onSubmit}> Sign Up </Button> <Button primary fluid style={{margin:'7'}} onClick={this.onSignUp}> Sign Up </Button>
<Button fluid style={{margin:'7'}}> Cancel </Button> <Button fluid style={{margin:'7'}}> Cancel </Button>
</Form.Group> </Form.Group>
</Form> </Form>
@ -110,6 +105,10 @@ export class SignUp extends React.Component<Props, State> {
); );
} }
//
// private onSignUp():void {
// console.log('');
// }
} }

View File

@ -0,0 +1,41 @@
import Action from '@overflow/commons/redux/Action';
import Member from '@overflow/member/api/model/Member';
import PWChangePayload from '../payload/PWChangePayload';
// Action Type
export type REQUEST = '@overflow/member/pw_change/REQUEST';
export type REQUEST_SUCCESS = '@overflow/member/pw_change/REQUEST_SUCCESS';
export type REQUEST_FAILURE = '@overflow/member/pw_change/REQUEST_FAILURE';
export const REQUEST: REQUEST = '@overflow/member/pw_change/REQUEST';
export const REQUEST_SUCCESS: REQUEST_SUCCESS = '@overflow/member/pw_change/REQUEST_SUCCESS';
export const REQUEST_FAILURE: REQUEST_FAILURE = '@overflow/member/pw_change/REQUEST_FAILURE';
// Action Creater
export type request = (pass: string) => Action<PWChangePayload>;
export type requestSuccess = (member: Member) => Action<Member>;
export type requestFailure = (error: Error) => Action;
export const request: request = (pass: string): Action<PWChangePayload> => {
return {
type: REQUEST,
payload: {
pass: pass,
},
};
};
export const requestSuccess: requestSuccess = (member: Member): Action<Member> => {
return {
type: REQUEST_SUCCESS,
payload: member,
};
};
export const requestFailure: requestFailure = (error: Error): Action => {
return {
type: REQUEST_FAILURE,
error: error,
};
};

View File

@ -0,0 +1,6 @@
import Member from '../../api/model/Member';
interface PWChangePayload {
pass: string;
}
export default PWChangePayload;