Migrate actions,reducers and action types to TS #15
This commit is contained in:
26
app/reducers/circles/CircleState.ts
Normal file
26
app/reducers/circles/CircleState.ts
Normal 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;
|
||||
}
|
||||
14
app/reducers/circles/ICircleAction.ts
Normal file
14
app/reducers/circles/ICircleAction.ts
Normal file
@@ -0,0 +1,14 @@
|
||||
|
||||
import {CircleActionType} from 'constants/circleActionType'
|
||||
|
||||
/**
|
||||
* Circle action interface
|
||||
*
|
||||
* @export
|
||||
* @interface ICircleAction
|
||||
*/
|
||||
export interface ICircleAction {
|
||||
payload: any,
|
||||
type: CircleActionType
|
||||
|
||||
}
|
||||
162
app/reducers/circles/circleReducer.ts
Normal file
162
app/reducers/circles/circleReducer.ts
Normal 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;
|
||||
|
||||
}
|
||||
}
|
||||
3
app/reducers/circles/index.ts
Normal file
3
app/reducers/circles/index.ts
Normal file
@@ -0,0 +1,3 @@
|
||||
import { circleReducer } from "./circleReducer";
|
||||
|
||||
export {circleReducer};
|
||||
Reference in New Issue
Block a user