Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/daniel/user profile #18

Open
wants to merge 199 commits into
base: master
Choose a base branch
from
Open
Changes from 11 commits
Commits
Show all changes
199 commits
Select commit Hold shift + click to select a range
5d48ee1
integrated tailwind and antdesign
justiceotuya Apr 20, 2019
f4d5f33
removed taiwindcss and rewrote the readme
justiceotuya Apr 21, 2019
7884570
Merge pull request #2 from team-helpme/feature/justiceotuya/integrate…
uimarshall Apr 21, 2019
24daa0b
finished the Landing Page
justiceotuya Apr 24, 2019
e6f1ab5
added next.config.js to .eslintignore
justiceotuya Apr 24, 2019
a1abd99
fixed linting errors for the front page
justiceotuya Apr 24, 2019
d8e3395
deletes hound.yml and make changes to travis.yml
uimarshall Apr 24, 2019
3cf3911
Merge pull request #4 from team-helpme/feature/marshall/delete-hound
justiceotuya Apr 25, 2019
501acef
fixed Landing page Bug reported by travis ci
justiceotuya Apr 25, 2019
8235020
Merge pull request #3 from team-helpme/feature/justiceotuya/finished-…
uimarshall Apr 25, 2019
d375028
fixed Landing page linting
justiceotuya Apr 26, 2019
c3851a1
Merge pull request #5 from team-helpme/fix/justiceotuya/fixed-linting…
uimarshall Apr 26, 2019
976ce3c
add basic expess server set up and database set up in mlab
uimarshall Apr 27, 2019
08ade0b
remove Uche Nnadi as author in package.json file
uimarshall Apr 27, 2019
2cfa498
Merge pull request #6 from team-helpme/feature/marshall/basic-express…
uimarshall Apr 29, 2019
0995fc0
Merge branch 'master' of https://github.com/team-helpme/helpme
uimarshall May 2, 2019
ad478aa
creates the user model and tests for basic crud operation
uimarshall May 2, 2019
f521f69
deleted test/package.json
uimarshall May 2, 2019
a55ecf8
add jest-mongodb-config file for jest testing
uimarshall May 4, 2019
45222d2
created the profile model and routes for creating and updating profile
cimthog May 4, 2019
86c7285
creates the user api-routes
uimarshall May 4, 2019
cc6171c
make module.exports = User = mongoose.model('users', UserSchema); int…
uimarshall May 9, 2019
cf2e827
modified User.js to create a new PR
uimarshall May 9, 2019
78a5a1d
created user profile routes
cimthog May 11, 2019
8c6102b
added ds_store to gitignore
justiceotuya May 13, 2019
27e3f21
refactored the landing page
justiceotuya May 13, 2019
3c1c139
refactored landing page and layout
justiceotuya May 14, 2019
2ee7d8a
made changes to file
justiceotuya May 15, 2019
7649664
made changes to file
justiceotuya May 15, 2019
474bbe7
made changes to file
justiceotuya May 15, 2019
0f4a222
made changes to file
justiceotuya May 15, 2019
78a2893
made changes to file
justiceotuya May 15, 2019
7cd2e3e
Merge pull request #14 from team-helpme/feature/justiceotuya/refactor…
uimarshall May 15, 2019
ad9aa00
finished login page
justiceotuya May 15, 2019
972f579
finished login page
justiceotuya May 15, 2019
7bbd73c
finished login page
justiceotuya May 15, 2019
325d9f0
finished login
justiceotuya May 15, 2019
adc1db5
finised the signup page
justiceotuya May 15, 2019
191d425
changed constants to capital letters
justiceotuya May 15, 2019
59c1b65
finished CRUD operation for profile model
cimthog May 16, 2019
a546e93
made few changes
cimthog May 16, 2019
06e4274
removed unnecessary console.log
cimthog May 16, 2019
4a8b49c
Merge branch 'master' of https://github.com/team-helpme/helpme
uimarshall May 17, 2019
0eb9aab
Merge branch 'master' into feature/marshall/create-user-model
uimarshall May 17, 2019
25351ec
fixed errors in the login and signup pages"
justiceotuya May 17, 2019
1dfd1ea
resolved eslint confilicts
cimthog May 17, 2019
7f30d46
removed empty test file
cimthog May 17, 2019
247a07a
modified User model and remove test folder
uimarshall May 17, 2019
8c841d8
Merge pull request #9 from team-helpme/feature/marshall/create-user-m…
justiceotuya May 17, 2019
40e9c73
Merge branch 'master' of https://github.com/team-helpme/helpme into f…
justiceotuya May 17, 2019
b1770c4
changed booleans to question format, added propTypes checking to Logi…
justiceotuya May 17, 2019
e7b11db
fix doc indent
justiceotuya May 18, 2019
38f6aa6
created user registration route in the user-api-routes
uimarshall May 21, 2019
a7136f6
Merge branch 'feature/marshall/create-user-api-routes' of https://git…
uimarshall May 21, 2019
eb6e663
fixed linting errors
uimarshall May 21, 2019
c8a4a94
refactored the forms
justiceotuya May 21, 2019
11bc109
remove duplicate lines of code in server/index.js and destructure req…
uimarshall May 21, 2019
ed0535d
refactored the forms
justiceotuya May 21, 2019
f1129a6
fixed minor indentation and naming issue
justiceotuya May 22, 2019
61ef2d3
put destructuring on line 13 in routes/api/users.js and modified erro…
uimarshall May 22, 2019
2abd7fa
Merge pull request #19 from team-helpme/feature/marshall/create-user-…
justiceotuya May 22, 2019
f840f32
merged package.json
justiceotuya May 22, 2019
a822058
Merge pull request #17 from team-helpme/feature/justiceotuya/signup
uimarshall May 22, 2019
6483de4
fixed path
cimthog May 22, 2019
e64dbd3
merged files
cimthog May 22, 2019
ba40879
added forget password page
justiceotuya May 22, 2019
d6f70cd
removed conflicting file
cimthog May 22, 2019
a4a46eb
added forget password page
justiceotuya May 22, 2019
51192ad
added forget password page
justiceotuya May 22, 2019
a8ff5f4
resolve conflicts
cimthog May 22, 2019
301091d
resolved conflicts
cimthog May 22, 2019
81359aa
resolved conflicts
cimthog May 22, 2019
1bfba61
resolved conflicts
cimthog May 22, 2019
353f44b
fixed duplicate comment
justiceotuya May 22, 2019
eb327a3
moved strings to constatnt file
justiceotuya May 22, 2019
82865cc
moved strings to constatnt file
justiceotuya May 22, 2019
224bda6
made minor changes as regards to inline styles
justiceotuya May 22, 2019
7f29244
created a function for validation
cimthog May 22, 2019
2a0d89a
Merge pull request #20 from team-helpme/feature/justiceotuya/forgot_p…
uimarshall May 23, 2019
86016a8
check for empty entries in a better way
cimthog May 24, 2019
70a416b
implements auth0 and user login, logout route
uimarshall May 24, 2019
7c1ba03
implements auth0 and user login, logout route
uimarshall May 24, 2019
6b343d8
fixed some linting issues
uimarshall May 24, 2019
ad9d2cb
resolve linting issues
uimarshall May 25, 2019
f407936
modified the code to give space to if statement blocks
uimarshall May 25, 2019
96a213a
checked if user exists when creating profile
cimthog May 26, 2019
80433a0
Merge pull request #21 from team-helpme/feature/Daniel/user-profile
uimarshall May 27, 2019
a4f8f76
destructure process.env in config/passport.js and routes/api/users.js
uimarshall May 27, 2019
7aee434
adds user input validations
uimarshall May 28, 2019
9450e28
create Post model
uimarshall May 28, 2019
b0f7fd0
Merge pull request #23 from team-helpme/feature/marshall/login-with-p…
justiceotuya May 28, 2019
b2a22d0
clean up code, pads if statement and change variables naming to camel…
uimarshall May 28, 2019
e3a2962
fixed glithes in landing page
justiceotuya May 28, 2019
127e3ba
Created the TimeLine Page
justiceotuya May 28, 2019
94118a1
Merge pull request #25 from team-helpme/feature/marshall/create-Post-…
justiceotuya May 29, 2019
862d057
minor fix
justiceotuya May 29, 2019
8683b2c
fix indent
justiceotuya May 29, 2019
6bfc564
move all strings to constant file and seperated module imports from c…
justiceotuya May 29, 2019
e31541b
removed trailing spaces
justiceotuya May 29, 2019
e66940b
Merge pull request #26 from team-helpme/fix/justice/landing_page
uimarshall May 30, 2019
774fa8b
pads if statement and change variables naming to camel case in valida…
uimarshall May 30, 2019
9e9ce36
merged master
justiceotuya May 30, 2019
30e2646
removed trailing spaces
justiceotuya May 30, 2019
01abf18
removed bindings so as to implement es6 class structure
justiceotuya May 30, 2019
a8ab903
Merge pull request #27 from team-helpme/feature/justiceotuya/Timeline…
justiceotuya May 30, 2019
576f671
Merge pull request #24 from team-helpme/feature/marshall/user-input-v…
uimarshall May 30, 2019
f68ec7d
adds userInview to conditioner render user using auth0
uimarshall May 30, 2019
74fb73e
finished the ui of the timeline
justiceotuya May 30, 2019
4717f38
Merge pull request #29 from team-helpme/feature/marshall/make-users-a…
uimarshall May 30, 2019
79d9c30
finished the ui of the timeline
justiceotuya May 31, 2019
ad155db
finished the ui of the timeline
justiceotuya May 31, 2019
e7721b5
merged wint master
justiceotuya Jun 1, 2019
66d27d6
fixed comments of the createPostButton function
justiceotuya Jun 1, 2019
e208e70
adds Post routes
uimarshall Jun 1, 2019
0e4ecc3
created forum topic and routes
cimthog Jun 1, 2019
2019299
fixed merge conflict
cimthog Jun 1, 2019
c81b042
Merge pull request #30 from team-helpme/feature/justiceotuya/Timeline…
uimarshall Jun 3, 2019
00188cf
integrated redux
justiceotuya Jun 3, 2019
a9c6383
integrated redux, deleted authenication folder since Auth0 is providi…
justiceotuya Jun 3, 2019
c0e65f3
tried fixing travis lint error
justiceotuya Jun 3, 2019
bd56212
fixed renamed folders
justiceotuya Jun 3, 2019
2ad3c11
fixed static folder not tracked by git
justiceotuya Jun 3, 2019
72c3239
Merge branch 'feature/justiceotuya/Adding_Redux' of https://github.co…
justiceotuya Jun 3, 2019
76bc88d
adding actions and reducers
justiceotuya Jun 5, 2019
1cf25fd
adding actions and reducers
justiceotuya Jun 5, 2019
c9e6adf
connected like, comment and fav button to redux
justiceotuya Jun 5, 2019
b536565
refactorin ang fixing errors
justiceotuya Jun 5, 2019
6658eaf
refactorin and fixing errors
justiceotuya Jun 5, 2019
87947ef
refactorin and fixing errors
justiceotuya Jun 5, 2019
72f93c8
Merge pull request #32 from team-helpme/feature/justiceotuya/Adding_R…
uimarshall Jun 6, 2019
287d775
handled like, favourite, comment toggling and status posting with redux
justiceotuya Jun 6, 2019
d0865ff
implements http-status-codes and JSend
uimarshall Jun 6, 2019
9041877
fixed convention for error messages
uimarshall Jun 7, 2019
bd71038
Merge pull request #31 from team-helpme/feature/marshall/create-Post-…
justiceotuya Jun 7, 2019
e84a9bc
fixed conflict
cimthog Jun 9, 2019
3e6383a
fixed error
justiceotuya Jun 9, 2019
bc22b65
fixed error
justiceotuya Jun 9, 2019
99a61ce
Fixed direct state Mutation and formatting
justiceotuya Jun 10, 2019
26b070a
added timeline comment posts
justiceotuya Jun 10, 2019
a4bd42a
formatting lists on each line
justiceotuya Jun 10, 2019
f453a57
made minor format change on handleCreateStatus function
justiceotuya Jun 10, 2019
9083e14
grouped timeline actions in mapDispatchToProps
justiceotuya Jun 10, 2019
3a24942
finished the timeline comments
justiceotuya Jun 10, 2019
d5604eb
fixed minor pr errors and bugs
justiceotuya Jun 10, 2019
5bcb0f2
Merge branch 'master' of https://github.com/team-helpme/helpme into f…
justiceotuya Jun 10, 2019
3af30ef
Merge pull request #33 from team-helpme/feature/justiceotuya/connecti…
uimarshall Jun 10, 2019
6d050cc
Added update post component
justiceotuya Jun 10, 2019
76f53de
merged from master
justiceotuya Jun 10, 2019
6b7d1c5
made post routes secured
cimthog Jun 10, 2019
7012034
fixed comment
justiceotuya Jun 10, 2019
5a10c68
fixed comment
justiceotuya Jun 10, 2019
b5d3322
fixed comment
justiceotuya Jun 10, 2019
336bcf0
Merge pull request #34 from team-helpme/feature/justiceotuya/timeline…
justiceotuya Jun 10, 2019
3da7f4b
connected redux saga
justiceotuya Jun 11, 2019
4915b3d
connected redux saga
justiceotuya Jun 11, 2019
25d75b8
connected redux saga
justiceotuya Jun 11, 2019
3b522ef
connected redux saga
justiceotuya Jun 11, 2019
a5ebdc8
Moved controlled comment from redux to internal state and made pr cha…
justiceotuya Jun 12, 2019
c21e8ac
Finished timeline UI
justiceotuya Jun 12, 2019
e04ad89
Merge pull request #36 from team-helpme/feature/Daniel/user-profile
justiceotuya Jun 12, 2019
a5ea3be
Merge pull request #35 from team-helpme/feature/justiceotuya/Implemen…
justiceotuya Jun 12, 2019
108a0db
merged from masterMerge branch 'master' of https://github.com/team-he…
justiceotuya Jun 12, 2019
400af5d
Finished timeline UI
justiceotuya Jun 12, 2019
5a3f8b0
made some fixes from PR
justiceotuya Jun 13, 2019
98ddb9c
finished forum UI
justiceotuya Jun 13, 2019
77b4569
fixed saga and error handling
justiceotuya Jun 13, 2019
ff60ad6
error handling for sagas
justiceotuya Jun 13, 2019
03d59e9
removed unused code
justiceotuya Jun 13, 2019
ab4c488
fixed setOnlineFriendsError error
justiceotuya Jun 13, 2019
3490fcf
fixed data error
justiceotuya Jun 13, 2019
9df03bf
fixed forum pr review
justiceotuya Jun 13, 2019
21cb9d0
Merge pull request #37 from team-helpme/feature/justiceotuya/Finishin…
justiceotuya Jun 13, 2019
532b43f
merged with master
justiceotuya Jun 13, 2019
c9f88d2
Merge pull request #38 from team-helpme/feature/justiceotuya/Forum_Fe…
justiceotuya Jun 13, 2019
68b46f8
added redux to forum
justiceotuya Jun 13, 2019
22a21d6
fixed bug that made both comment and status input display same value …
justiceotuya Jun 13, 2019
1249c1d
Merge pull request #39 from team-helpme/feature/justiceotuya/Forum_Redux
justiceotuya Jun 14, 2019
e11fd5f
readded signup
justiceotuya Jun 14, 2019
4952f22
connected registration to backend
justiceotuya Jun 14, 2019
b7c1e4c
connected registration to backend
justiceotuya Jun 14, 2019
18c1058
made fixes
justiceotuya Jun 14, 2019
6389a8a
fixed saga
justiceotuya Jun 15, 2019
72d9a9d
fixed authentication
justiceotuya Jun 17, 2019
b3f0fc3
fixed authentication
justiceotuya Jun 17, 2019
9e60dce
fixed authentication
justiceotuya Jun 17, 2019
1b845f1
Merge pull request #40 from team-helpme/feature/justiceotuya/API_conn…
uimarshall Jun 17, 2019
321a6ee
merged with master Merge branch 'master' of https://github.com/team-h…
justiceotuya Jun 17, 2019
774f85c
fixed authentication test
justiceotuya Jun 17, 2019
c85237b
made fixes
justiceotuya Jun 17, 2019
75fcba8
made changes
justiceotuya Jun 17, 2019
77b4743
made fixes
justiceotuya Jun 17, 2019
5de865e
updates readme
uimarshall Jun 17, 2019
9903e54
made fixes from pr
justiceotuya Jun 17, 2019
8076458
change method of adding image
uimarshall Jun 17, 2019
3e6069b
made fixes from pr
justiceotuya Jun 17, 2019
4b61f40
Merge pull request #44 from team-helpme/feature/marshall/Update-ReadMe
justiceotuya Jun 17, 2019
0f0e76f
Merge pull request #43 from team-helpme/feature/justiceotuya/Authenti…
justiceotuya Jun 17, 2019
ca03102
connected Authentication and backend
justiceotuya Jun 17, 2019
227ed44
added profile to user schema
cimthog Jun 18, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion components/timeLine/actionTypes.js
Original file line number Diff line number Diff line change
@@ -4,7 +4,9 @@ const actionTypes = {
FETCH_PROFILE_DATA_FAILURE: 'FETCH_PROFILE_DATA_FAILURE',
FETCH_PROFILE_DATA_SUCCESS: 'PROFILE_DATA_SUCCESS',
FETCH_PROFILE_REQUEST: 'FETCH_PROFILE_REQUEST',
TOGGLE_MODAL: 'TOGGLE MODAL',
TOGGLE_COMMENT_BUTTON: 'TOGGLE_COMMENT_BUTTON',
TOGGLE_POST_FAV: 'TOGGLE_POST_FAV',
TOGGLE_POST_LIKE: 'TOGGLE_POST_LIKE',
UPDATE_STATUS: 'UPDATE_STATUS',
};

41 changes: 26 additions & 15 deletions components/timeLine/actions.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,16 @@
import actionTypes from './actionTypes';

const {
TOGGLE_MODAL, FETCH_PROFILE_REQUEST,
FETCH_PROFILE_REQUEST,
FETCH_PROFILE_DATA_FAILURE,
FETCH_PROFILE_DATA_SUCCESS, UPDATE_STATUS, ADD_POST_TO_TIMELINE,
FETCH_PROFILE_DATA_SUCCESS,
UPDATE_STATUS,
ADD_POST_TO_TIMELINE,
TOGGLE_POST_LIKE,
TOGGLE_POST_FAV,
TOGGLE_COMMENT_BUTTON,
} = actionTypes;

export const controlModal = () => ({ type: TOGGLE_MODAL });

export const setPostUpdateField = text => ({ payload: text, type: UPDATE_STATUS });

// Instead of plain objects, we are returning function.
@@ -38,14 +41,22 @@ export const fetchProfileData = () => dispatch => {
});
};

export const handlePostUpdate = data => {
const {
id, firstName, lastName, email, post, avatar,
} = data;
return ({
payload: {
avatar, email, firstName, id, lastName, post,
},
type: ADD_POST_TO_TIMELINE,
});
};
export const handlePostUpdate = payload => ({
payload,
type: ADD_POST_TO_TIMELINE,
});

export const likeButtonClicked = payload => ({
payload,
type: TOGGLE_POST_LIKE,
});

export const favButtonClicked = payload => ({
payload,
type: TOGGLE_POST_FAV,
});

export const commentButtonClicked = payload => ({
payload,
type: TOGGLE_COMMENT_BUTTON,
});
13 changes: 4 additions & 9 deletions components/timeLine/components/CreatePostComponent.jsx
Original file line number Diff line number Diff line change
@@ -19,7 +19,7 @@ const { TextArea } = Input;
*/
const CreatePostInput = props => {
const {
InputPlaceholder, rowHeight, handleOnChange, textValue,
InputPlaceholder, rowHeight, handleOnChange,
} = props;
return (
<TextArea
@@ -29,7 +29,6 @@ const CreatePostInput = props => {
autosize={{ minRows: rowHeight }}
autoFocus
onChange={handleOnChange}
value={textValue}
/>
);
};
@@ -80,21 +79,19 @@ const CreatePostComponent = props => {
rowHeight,
handleOkFunction,
handleOnChange,
textValue,
} = props;

return (
<>
<form onSubmit={handleOkFunction}>
<CreatePostInput
InputPlaceholder={InputPlaceholder}
rowHeight={rowHeight}
handleOnChange={handleOnChange}
textValue={textValue}
/>
<div className="comment-post-button">
<CreatePostButtons handleOkFunction={handleOkFunction} />
</div>
</>
</form>
);
};

@@ -104,8 +101,8 @@ CreatePostInput.propTypes = {
InputPlaceholder: PropTypes.string.isRequired,
handleOnChange: PropTypes.func.isRequired,
rowHeight: PropTypes.number.isRequired,
textValue: PropTypes.string.isRequired,
};

CreatePostButtons.propTypes = {
handleOkFunction: PropTypes.func.isRequired,
};
@@ -114,6 +111,4 @@ CreatePostComponent.propTypes = {
handleOkFunction: PropTypes.func.isRequired,
handleOnChange: PropTypes.func.isRequired,
rowHeight: PropTypes.number.isRequired,
textValue: PropTypes.string.isRequired,

};
27 changes: 25 additions & 2 deletions components/timeLine/components/TimeLine.css
Original file line number Diff line number Diff line change
@@ -124,8 +124,22 @@
margin-right: 8px
}

.liked,
.favourited {
margin-right: 8px;
transform: scale(1.05);
}

.liked {
color: #1890ff
color: #1890ff;
}

.favourited {
color: #FFD700
}

.mr-8 {
margin-right: 8px
}

.post-reaction>*:active {
@@ -183,7 +197,8 @@
display: block
}

.skeleton-section, .TimeLine_posts {
.skeleton-section,
.TimeLine_posts {
padding: 1em;
background-color: #ffffff;
}
@@ -192,6 +207,14 @@
text-align: justify;
}

.ant-list-item.ant-list-item-no-flex {
display: grid;
}

.ant-list-item-action {
grid-row: 4;
}

@media screen and (max-width:767px) {
.TimeLine_content {
max-width: 458px;
211 changes: 122 additions & 89 deletions components/timeLine/components/TimeLine.jsx
Original file line number Diff line number Diff line change
@@ -1,142 +1,153 @@
/* eslint-disable no-shadow */
import { bindActionCreators } from 'redux';
import { connect } from 'react-redux';
import { Divider, Icon } from 'antd';
import PropTypes from 'prop-types';
import React from 'react';

import {
commentButtonClicked,
favButtonClicked,
fetchProfileData,
handlePostUpdate,
likeButtonClicked,
setPostUpdateField
} from '../actions';
import { components } from '../../layout';
import CreatePostModal from './CreatePostModal';
import { CreatePostComponent } from './CreatePostComponent';
// dummy data to be replaced with api data, commented so that test
// can pass, will be removed when api is ready
import data from '../../../static/data/timelineData.json';
import { STRINGS } from '../constants';
import TimeLineOnlineFriends from './TimeLineOnlineFriends';
import TimeLinePopularTopic from './TimeLinePopularTopic';
import CreatePostModal from './CreatePostModal';
import { getStatusValue, getTimelineData } from '../selectors';
import TimeLinePosts from './TimeLinePosts';
import TimeLineProfileInfo from './TimeLineProfileInfo';
import { STRINGS } from '../constants';

const { CREATE_POST_PLACEHOLDER, TIMELINE_TITLE } = STRINGS;
const { PageLayout } = components;
export const data = (id, post) => ({
comment: 0,
email: 'jotuya2@gmail.com',
favouriteCount: 0,
favourited: false,
firstName: 'Justice',
id,
lastName: 'Otuya',
liked: false,
likes: 0,
post,
});

/** Helper function that is used to render the TimeLine Component
* @class TimeLine
* @extends {React.Component}
* @return {Object} returns the TimeLine component
*/
class TimeLine extends React.Component {
state = {
activeComment: '',
activeLikeButton: '',
comment: false,
commentValue: '',
like: false,
likeCount: 0,
searchValue: '',
statusValue: '',
timelineData: '',
visible: false,
};
state ={
isModalOpen: false,
}

componentDidMount() {
this.setState({ timelineData: data });
}
componentDidMount() {
const { fetchProfileData } = this.props;
fetchProfileData();
}

/**
* Helper function that handels the visibility of a modal
* Helper function that handles the visibility of a modal
* @function
* @return {Object} returns 'true' to show the modal
*/
modalHandler = () => {
const { visible } = this.state;
const { isModalOpen } = this.state;
this.setState({
visible,
isModalOpen: !isModalOpen,
});
};

/**
* Helper function that is used to handle the data from post component,
* it also closes the post modal
* it also closes the post modal
* @function
* @return {Object} returns 'false' to close the modal post component
*/
handleOk = () => {
const { visible } = this.state;
// close the modal;
if (visible) {
this.setState({
visible: false,
});
handleCreateStatus = () => {
const {
handlePostUpdate, setPostUpdateField, statusValue, timelineData,
} = this.props;

const { isModalOpen } = this.state;

// get post
handlePostUpdate(data(timelineData.length + 1, statusValue));

// close modal
if (isModalOpen) {
this.modalHandler();
}

// make an api call
// clear post component
setPostUpdateField('');
// close the modal and make make an api call
};

/**
* Helper function that is used to hable clicking on the like button
* Helper function that is used to handle clicking on the like button
* @function
* @param {Number} id the id of the liked post
* @return {Object} changes the state of the like component
*/
handleLikeButton = () => {
const { like } = this.state;
this.setState({
like: !like,
});
handleLikeButton = id => {
const { likeButtonClicked } = this.props;
likeButtonClicked(id);
};

/**
* Helper function that is used to handle clicking on the comment button
* Helper function that is used to handle favourite button
* @function
* @param {Number} id the id of the commented post
* @return {Object} changes the state of the like component
*/
handleComment = id => {
const { comment } = this.state;
this.setState({
activeComment: id,
comment: !comment,
});
};
handleFavButton = id => {
const { favButtonClicked } = this.props;
favButtonClicked(id);
};

/**
* Helper function that is used to handle comment value
* Helper function that is used to handle clicking on the comment button
* @function
* @return {Object} changes the state of the comment value
* @param {Number} id the id of the commented post
* @return {Object} changes the state of the like component
*/
handleCommentValue = e => {
this.setState({
commentValue: e.target.value,
});
}
handleComment = id => {
const { commentButtonClicked } = this.props;
commentButtonClicked(id);
};

/**
* Helper function that is used to handle status value
* @function
* @return {Object} changes the state of the status value
*/
handleStatusValue = e => {
this.setState({
statusValue: e.target.value,
});
const { setPostUpdateField } = this.props;
setPostUpdateField(e.target.value);
}

handleSearch=e => {
this.setState({
searchValue: e.target.value,
});
clearStatusValue = e => {
const { setPostUpdateField } = this.props;
setPostUpdateField(e.target.value = '');
}

render() {
const {
timelineData, visible, statusValue, likes,
likeCount, activeComment, activeLikeButton, commentValue, searchValue,
} = this.state;
timelineData,
} = this.props;
const { isModalOpen } = this.state;

return (
<PageLayout
isSiderPresent={timelineData.length > 0}
isFooterPresent={false}
isAuthenticated
title={TIMELINE_TITLE}
handleSearch={this.handleSearch}
searchValue={searchValue}
>
<main className="TimeLine_content">

@@ -147,30 +158,22 @@ class TimeLine extends React.Component {
</div>

<CreatePostModal
visible={visible}
handleOkFunction={this.handleOk}
visible={isModalOpen}
handleOkFunction={this.handleCreateStatus}
closeModal={this.modalHandler}
handleOnChange={this.handleStatusValue}
textValue={statusValue}
/>
</section>

{/* profile info desktop */}
<TimeLineProfileInfo />
{/* popular topics aside */}
<TimeLinePopularTopic />
{/* online friends aside tab */}
<TimeLineOnlineFriends />

{/* main timeline */}
<section className="TimeLine_post">
{/* create post component */}
<section className="TimeLine-post-component">
<CreatePostComponent
InputPlaceholder={CREATE_POST_PLACEHOLDER}
rowHeight={5}
handleOkFunction={this.handleCreateStatus}
handleOnChange={this.handleStatusValue}
textValue={statusValue}
/>
</section>

@@ -179,16 +182,10 @@ class TimeLine extends React.Component {
<section className="TimeLine_posts">
{/* timeline posts */}
<TimeLinePosts
timelineData={timelineData}
likes={likes}
likeCount={likeCount}
activeComment={activeComment}
activeLikeButton={activeLikeButton}
handleComment={this.handleComment}
profileData={timelineData}
handleLikeButton={this.handleLikeButton}
handleOk={this.handleOk}
handleOnChange={this.handleCommentValue}
textValue={commentValue}
handleFavButton={this.handleFavButton}
handleComment={this.handleComment}
/>
</section>
</section>
@@ -197,4 +194,40 @@ class TimeLine extends React.Component {
);
}
}
export default TimeLine;

const mapStateToProps = state => ({
statusValue: getStatusValue(state),
timelineData: getTimelineData(state),
});

const timeLineActions = {
commentButtonClicked,
favButtonClicked,
fetchProfileData,
handlePostUpdate,
likeButtonClicked,
setPostUpdateField,
};

const mapDispatchToProps = dispatch => bindActionCreators(timeLineActions, dispatch);

export default connect(mapStateToProps, mapDispatchToProps)(TimeLine);
TimeLine.propTypes = {
commentButtonClicked: PropTypes.func.isRequired,
favButtonClicked: PropTypes.func.isRequired,
fetchProfileData: PropTypes.func.isRequired,
handlePostUpdate: PropTypes.func.isRequired,
likeButtonClicked: PropTypes.func.isRequired,
setPostUpdateField: PropTypes.func.isRequired,
statusValue: PropTypes.string.isRequired,
timelineData: PropTypes.arrayOf(PropTypes.shape({
avatar: PropTypes.string.isRequired,
comment: PropTypes.string.isRequired,
favs: PropTypes.number.isRequired,
firstName: PropTypes.string.isRequired,
image: PropTypes.string.isRequired,
lastName: PropTypes.string.isRequired,
likes: PropTypes.number.isRequired,
post: PropTypes.string.isRequired,
})).isRequired,
};
195 changes: 114 additions & 81 deletions components/timeLine/components/TimeLinePosts.jsx
Original file line number Diff line number Diff line change
@@ -11,117 +11,150 @@ import './TimeLine.css';

const { COMMENT_PLACEHOLDER } = STRINGS;

const IconText = ({ type, text, action }) => (
const IconText = ({
type, text, action, className,
}) => (
<span>
<Icon type={type} className="icon_text" onClick={action} />
<Icon
type={type}
className={className}
onClick={action}
theme="filled"
/>
{text}
</span>
);

const TimeLinePosts = props => {
const {
timelineData, activeComment, handleComment, handleOk, handleLikeButton,
profileData,
handleComment,
handleOk,
handleLikeButton,
handleFavButton,
} = props;
return (

timelineData.length !== 0 ? (
<List
itemLayout="vertical"
dataSource={timelineData}
className="list_style"
size="large"
renderItem={user => {
const {
id, firstName, lastName, post, avatar, image, textValue, handleOnChange,
comment, likes, favs,
} = user;
return profileData.length !== 0 ? (
<List
itemLayout="vertical"
dataSource={profileData}
style={{ margin: '0 1em' }}
size="large"
renderItem={user => {
const {
id,
firstName,
lastName,
post,
avatar,
image,
liked,
favourited,
textValue,
handleOnChange,
likes,
comment,
favouriteCount,
} = user;
return (
<List.Item
key={id}
actions={[
<IconText
type="star"
className={favourited ? 'favourited' : 'mr-8'}
text={favouriteCount}
action={() => handleFavButton(id)}
key={1}
/>,
<IconText
type="like"
className={liked ? 'liked' : 'mr-8'}
text={likes}
action={() => handleLikeButton(id)}
key={2}
/>,
<IconText
type="message"
className="mr-8"
text={comment}
action={() => handleComment(id)}
key={3}
/>,
]}
>
<List.Item.Meta
avatar={(<Avatar src={avatar} className="user-avatar" />)}
title={`${firstName} ${lastName}`}
description="3h ago"
/>

return (
<List.Item
key={id}
actions={[
<IconText
type="star-o"
text={favs}
key="star-o"
/>,
<IconText
type="like-o"
text={likes}
key="like-o"
action={() => handleLikeButton(id)}
/>,
<IconText
type="message"
text={comment}
key="message"
action={() => handleComment(id)}
/>,
]}
>
<List.Item.Meta
avatar={<Avatar src={avatar} className="user-avatar" />}
title={`${firstName} ${lastName}`}
description="3h ago"
/>
{image ? (
{
image ? (
<img
className="post-image"
alt={image ? `${firstName} image` : null}
src={image}
/>
) : null
}
{post.substring(0, 300)}
{/* post comment component */}
<div className={activeComment === id ? 'show' : 'hide'}>
<CreatePostComponent
handleOkFunction={handleOk}
InputPlaceholder={COMMENT_PLACEHOLDER}
rowHeight={2}
textValue={textValue}
handleOnChange={handleOnChange}
/>
</div>
</List.Item>
);
}}
/>
)
: LOADING_SKELETON.map(items => {
// data loading simulation
const {
paragraph, title, loading, active, avatar, id,
} = items;
return (
<Skeleton
key={id}
paragraph={paragraph}
title={title}
loading={loading}
active={active}
avatar={avatar}
className="skeleton-section"
/>
) : <div />
}
{post.substring(0, 150)}
{/* post comment component */}

<div className={profileData[id - 1].isCommentOpen ? 'show' : 'hide'}>
<CreatePostComponent
handleOkFunction={handleOk}
InputPlaceholder={COMMENT_PLACEHOLDER}
rowHeight={2}
textValue={textValue}
handleOnChange={handleOnChange}
/>
</div>
</List.Item>
);
})
}
}
/>
) : (
// data loading simulation
LOADING_SKELETON.map(items => {
const {
paragraph,
title,
loading,
active,
avatar,
id,
} = items;
return (
<Skeleton
key={id}
paragraph={paragraph}
title={title}
loading={loading}
active={active}
avatar={avatar}
className="skeleton-section"
/>
);
})
);
};

export default TimeLinePosts;

IconText.propTypes = {
action: PropTypes.func.isRequired,
className: PropTypes.string.isRequired,
text: PropTypes.string.isRequired,
type: PropTypes.string.isRequired,
};

TimeLinePosts.propTypes = {
activeComment: PropTypes.string.isRequired,
handleComment: PropTypes.func.isRequired,
handleFavButton: PropTypes.func.isRequired,
handleLikeButton: PropTypes.func.isRequired,
handleOk: PropTypes.func.isRequired,
timelineData: PropTypes.arrayOf(PropTypes.shape({
profileData: PropTypes.arrayOf(PropTypes.shape({
avatar: PropTypes.string.isRequired,
comment: PropTypes.string.isRequired,
favs: PropTypes.number.isRequired,
7 changes: 4 additions & 3 deletions components/timeLine/components/TimeLineProfileInfo.jsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
import { Divider } from 'antd';
import React from 'react';

import { STRINGS, USER_PROFILE } from '../constants';
import './TimeLine.css';
import {
USER_PROFILE, STRINGS
} from '../constants';

const { FOLLOWERS, FOLLOWING, USERS_BIO } = STRINGS;
const { FOLLOWING, FOLLOWERS, USERS_BIO } = STRINGS;

const TimeLineProfileInfo = () => {
const {
2 changes: 1 addition & 1 deletion components/timeLine/index.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { reducers } from './reducers';
import reducers from './reducers';
import * as components from './components';
import * as actions from './actions';

53 changes: 46 additions & 7 deletions components/timeLine/reducers.js
Original file line number Diff line number Diff line change
@@ -7,40 +7,79 @@ const initialState = {
statusValue: '',
timelineData: [],
};

export const reducers = (state = initialState, action) => {
export default (state = initialState, action) => {
const {
CLEAR_STATUS_FIELD,
FETCH_PROFILE_REQUEST,
FETCH_PROFILE_DATA_FAILURE,
FETCH_PROFILE_DATA_SUCCESS,
TOGGLE_MODAL,
UPDATE_STATUS,
ADD_POST_TO_TIMELINE,
TOGGLE_POST_LIKE,
TOGGLE_POST_FAV,
TOGGLE_COMMENT_BUTTON,
} = actionTypes;

const {
type, timelineData, error, payload,
type, error, payload, timelineData,
} = action;

const { isOpen } = state;
let newArray = [];

switch (type) {
case FETCH_PROFILE_REQUEST:
return { ...state, isFetching: true };

case FETCH_PROFILE_DATA_SUCCESS:
return { ...state, isFetching: false, timelineData };

case FETCH_PROFILE_DATA_FAILURE:
return { ...state, error, isFetching: false };
case TOGGLE_MODAL:
return { ...state, isOpen: !isOpen };

case ADD_POST_TO_TIMELINE:
return payload.post !== ''
? { ...state, timelineData: [payload, ...state.timelineData] } : state;

case UPDATE_STATUS:
return { ...state, statusValue: payload };

case CLEAR_STATUS_FIELD:
return { ...state, statusValue: '' };

case TOGGLE_POST_LIKE:
newArray = state.timelineData.map(item => {
const { id, liked, likes } = item;
if (id === payload) {
item.liked = !liked;
item.likes = liked ? likes - 1 : likes + 1;
}
return item;
});
return {
...state,
timelineData: [...newArray],
};

case TOGGLE_POST_FAV:
newArray = state.timelineData.map(item => {
const { id, favourited, favouriteCount } = item;
if (id === payload) {
item.favourited = !favourited;
item.favouriteCount = favourited ? favouriteCount - 1 : favouriteCount + 1;
}
return item;
});
return { ...state, timelineData: [...newArray] };

case TOGGLE_COMMENT_BUTTON:
newArray = state.timelineData.map(item => {
const { id, isCommentOpen } = item;
if (id === payload) {
item.isCommentOpen = !isCommentOpen;
}
return item;
});
return { ...state, timelineData: [...newArray] };
default:
return state;
}
1 change: 0 additions & 1 deletion components/timeLine/selectors.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { STRINGS } from './constants';

const { NAME } = STRINGS;
export const getIsOpen = state => state[NAME].isOpen;
export const getStatusValue = state => state[NAME].statusValue;
export const getTimelineData = state => state[NAME].timelineData;
611 changes: 510 additions & 101 deletions static/data/timelineData.json

Large diffs are not rendered by default.

3 changes: 2 additions & 1 deletion store/rootReducer.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import { combineReducers } from 'redux';
import * as timeLine from '../components/timeLine';

const rootReducer = combineReducers({

timeLine: timeLine.reducers,
});

export default rootReducer;