Skip to content

Latest commit

 

History

History
154 lines (101 loc) · 8.02 KB

readme.md

File metadata and controls

154 lines (101 loc) · 8.02 KB

DevBook

DevBook live

DevBook is a social networking site similar to Facebook. Users can find and add friends, post status updates and images, and comment on these items. Users see a feed that shows status updates and other activities of their friends and selves.

DevBook is a personal project of Todd Nestor.

DevBook home page

Features

Customize profiles with personal details and images

Users can customize their profile information and view other users' profiles.

Edit profile

View profile

Search for friends and send friend requests

Users can search for other users and send friend requests to them.

Friendships were implemented using a friendship join table that joins the user table with itself. There is a status column to determine what state the friendship is in.

User search

lodash's debounce method was utilized for the search so that ajax requests are not sent off while a user is actively typing. It waits until the user has stopped typing for 250ms before sending off the request.

this.conductSearch = _.debounce(() => {
  this.props.searchUsers(this.state.searchTerm);
}, 250);

When a user requests to be friends with another user it creates two friendship entries. One for each user as the user_id and the opposite user as the friend_id. The user who created the request's entry shows "pending" as the status, the other user's status shows "requested". When a request is accepted both entries' statuses are changed to "accepted".

The Active Record State Machine was utilized to keep these entries in sync.

state_machine :status, initial: :pending do
  after_transition on: :accept, do: [:accept_mutual_friendship!]
  after_transition on: :block, do: [:block_mutual_friendship!]

  event :accept do
    transition any => :accepted
  end

  event :block do
    transition any => :blocked
  end
end

This means that when accept! is called on a friendship, then the status is changed to "accepted" and then after that transition it changes the status on the other entry to "accepted" as well.

Blocking works in a similar way changing the status of the friendship for the friend doing the blocking to "blocked" and then changing the status of the friendship for the blocked friend to "been_blocked". This is so that we can track who did the blocking and only the user who did the blocking can unblock the other user.

Post status updates that can optionally include one or many images

Users can post status updates that include images.

Create status

Create photo albums

Users can create photo albums.

Create album

View a personalized feed of friends' status updates and other activities

Users can view a feed of friends' status updates and other activities. The feed will load more items when a user scrolls to the bottom of the feed.

View feed

There are multiple types of activities showing up in the feed. There are status updates, user updates (user updated profile image, user updated relationship status, etc.), so the ActivityItem component renders different components based on this type.

const renderItem = () => {
  switch( activity.feedable_type ) {
    case 'Status':
      return <Status activity={activity} />
    case 'User':
      return <UserUpdate activity={activity} />
    case 'Friendship':
      return <Friendship activity={activity} />
    default:
      return <span style={{display: 'none'}}></span>
  }
}

The switch is on the feedable_type of the activity because activities have a polymorphic relationship with statuses, users, friendships, and other models. feedable is the alias for this relationship. The activities table has both feedable_type and feedable_id columns to track it's parent.

Comment on any activity or status update and include an optional picture on comments

Users can comment on status updates and other activities and optionally include an image in their comment.

Create and view comments

Other features

  • Automatic linking of any URLs entered in status updates and comments.
  • User's can have multiple sessions so they can be logged in from multiple devices and logging out of one doesn't log them out of the others.
  • User's can block other users. If a user is blocked by another user they never see the user blocking them in search results or user lists.

Product Design

DevBook was built in two weeks including the creating the development plan. The development plan includes the estimated timeline, planned database schema, along with the original wireframes and other planning documents.

Technology

DevBook utilizes Ruby on Rails for the back end API and React.js for the front end.

Front end

DevBook is a single page app.

The following is a list of some of the technologies used to create the DevBook front end.

  • React.js is the framework used for the entirety of the front end.
  • React Router is used to update the view based on the URL path.
  • Redux is utilized to store the bulk of the data needed on the client-side, and to trigger API calls as needed.
  • React Sweet Alert is used for alerting the user and asking for confirmation of dangerous actions such as deleting a status update.
  • Sass is used to better organize the CSS.
  • jQuery is used for ajax calls.
  • webpack is used to bundle and minify javascript files.
  • Babel is used to trnaslate jsx into javascript.
  • React Dropzone is used to allow users to drag and drop files to be uploaded.

Back end

DevBook makes asynchronous http requests to the back end to create, fetch, update, and delete data.

The following is a list of some of the technologies used to create the DevBook back end.

  • Ruby on Rails is the framework used for the back end, creating models that interact with the database, controllers that contain methods to respond to http requests, a router that maps routes to those controller methods, and jbuilder views to respond to requests with JSON data.
  • Heroku hosts DevBook.
  • BCrypt is used to securely hash and salt passwords before storing them in the database so that raw passwords are never stored.
  • Paperclip is used to upload files (such as images) to DreamObjects where they are stored. In addition Paperclip creates multiple sizes of the files to be utilized throughout the app.
  • DreamObjects is where everything is stored. It is similar to AWS's S3, and the same API that S3 uses can be used with DreamObjects. DreamObjects also provides a CDN so that files are served with the fastest possible response times.
  • State Machine Active Record is used to watch for changes in friendship statuses and change other entries based on those changes, as well as create activities for those changes so that a user's friends will see when their friend becomes friends with someone new.

Future Implementation

There are many features planned for DevBook, including the following:

  • Reactions Users will be able to react to status updates and other activities by liking, disliking, laughing, or other reactions TBD.
  • Notifications Users will see when one of their friends comments on or reacts to one of their activities.
  • URL previews When a URL is input on a comment or status update a preview will be generated to show an image and brief excerpt about the website linked.
  • Messaging Users will be able to send messages to each other and see responses in real time.