Migrate actions,reducers and action types to TS #15

This commit is contained in:
Qolzam
2017-10-10 08:01:25 +07:00
parent 3b3899e7af
commit f9d213f741
113 changed files with 2692 additions and 1275 deletions

View File

@@ -0,0 +1,26 @@
import { Circle } from "domain/circles";
/**
* Circle state
*
* @export
* @class CircleState
*/
export class CircleState {
/**
* The list of Circles belong to users
*
* @type {({[userId: string]: {[circleId: string]: Circle}} | null)}
* @memberof CircleState
*/
userCircles: {[userId: string]: {[circleId: string]: Circle}} = {};
/**
* If user circles are loaded {true} or not {false}
*
* @type {Boolean}
* @memberof CircleState
*/
loaded: Boolean = false;
}

View File

@@ -0,0 +1,14 @@
import {CircleActionType} from 'constants/circleActionType'
/**
* Circle action interface
*
* @export
* @interface ICircleAction
*/
export interface ICircleAction {
payload: any,
type: CircleActionType
}

View File

@@ -0,0 +1,162 @@
// - Import react components
import moment from 'moment'
import _ from 'lodash'
// - Import domain
import { User } from "domain/users";
import { Circle } from "domain/circles";
// - Import action types
import {CircleActionType} from 'constants/circleActionType'
import { CircleState } from "./CircleState";
import { ICircleAction } from "./ICircleAction";
/**
* Circle reducer
* @param state
* @param action
*/
export var circleReducer = (state: CircleState = new CircleState(), action: ICircleAction) => {
const { payload } = action
switch (action.type) {
case CircleActionType.CLEAR_ALL_CIRCLES:
return new CircleState();
case CircleActionType.ADD_CIRCLE:
return {
...state,
userCircles: {
...state.userCircles,
[payload.circle.ownerId]: {
...state.userCircles![payload.circle.ownerId],
[payload.circle.id]: { ...payload.circle }
}
}
}
case CircleActionType.UPDATE_CIRCLE:
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...state.userCircles![payload.uid],
[payload.circle.id]: {
...state.userCircles![payload.uid][payload.circle.id],
...payload.circle,
openCircleSettings:false }
}
}
}
case CircleActionType.DELETE_CIRCLE:
let filteredCircles = {}
Object.keys(state.userCircles![payload.uid]).map((key) => {
if (key !== payload.id) {
return _.merge(filteredCircles, { [key]: { ...state.userCircles![payload.uid][key] } })
}
})
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...filteredCircles
}
}
}
case CircleActionType.ADD_LIST_CIRCLE:
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...state.userCircles![payload.uid],
...payload.circles
}
},
loaded:true
}
case CircleActionType.ADD_FOLLOWING_USER:
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...state.userCircles![payload.uid],
[payload.cid]: {
...state.userCircles![payload.uid][payload.cid],
users:{
...state.userCircles![payload.uid][payload.cid].users,
[payload.followingId]: {
...payload.userCircle
}
}
}
}
}
}
case CircleActionType.DELETE_FOLLOWING_USER:
let filteredUserCircle = {}
Object.keys(state.userCircles![payload.uid][payload.cid].users).map((key) => {
if (key !== payload.followingId) {
return _.merge(filteredUserCircle, { [key]: { ...state.userCircles![payload.uid][payload.cid].users[key] } })
}
})
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...state.userCircles![payload.uid],
[payload.cid]: {
...state.userCircles![payload.uid][payload.cid],
users:{
...filteredUserCircle
}
}
}
}
}
case CircleActionType.CLOSE_CIRCLE_SETTINGS:
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...state.userCircles![payload.uid],
[payload.id]: {
...state.userCircles![payload.uid][payload.id],
openCircleSettings: false
}
}
}
}
case CircleActionType.OPEN_CIRCLE_SETTINGS:
return {
...state,
userCircles: {
...state.userCircles,
[payload.uid]: {
...state.userCircles![payload.uid],
[payload.id]: {
...state.userCircles![payload.uid][payload.id],
openCircleSettings: true
}
}
}
}
default:
return state;
}
}

View File

@@ -0,0 +1,3 @@
import { circleReducer } from "./circleReducer";
export {circleReducer};