publiclab/plots2

Invert negation in if/else- relationships_controller

first-timers opened this issue ยท 4 comments

Hi, this is a first-timers-only issue. This means we've worked to make it more legible to folks who either haven't contributed to our codebase before, or even folks who haven't contributed to open source before.

If that's you, we're interested in helping you take the first step and can answer questions and help you out as you do. Note that we're especially interested in contributions from people from underrepresented groups in free and open-source software!

We know that the process of creating a pull request is one of the biggest barrier for new contributors. This issue is for you ๐Ÿ’

If you have contributed before, consider leaving this one for someone new, and looking through our general help wanted issues. Thanks!

๐Ÿค” What you will need to know.

Nothing. This issue is meant to welcome you to Open Source :) We are happy to walk you through the process.

๐Ÿ“‹ Step by Step

  • ๐Ÿ™‹ Claim this issue: Claim the issue by commenting. If someone else has claimed it, ask if they've opened a pull request already and if they're stuck -- maybe you can help them solve a problem or move it along!
๐Ÿ’ก Learn how to claim ๐Ÿ™‹

Claiming an issue

Unless the issue is marked as reserved for someone, you can just say "I'd like to try this!" and then you've claimed it - no need to wait for someone to assign it to you. Just be sure you link your pull request (PR) to this issue so we can see where your solution is.

And open one early if possible - even before you've completed it with additional commits - and others can help you figure out any issues you may face.

See this page for some help in taking your first steps!

Below is a "diff" showing in red (and a -) which lines to remove, and in green (and a +) which lines to add:

@@ -4,16 +4,16 @@ class RelationshipsController < ApplicationController
   def create
     user = User.find(params[:followed_id])
     respond_to do |format|
-      if !current_user.following?(user)
-        current_user.follow(user)
-        format.html { redirect_to URI.parse(request.referer || "/").path, notice: "You have started following " + user.username }
-        format.js { render "create", locals: { following: true, profile_user: user } }
-      else
+      if current_user.following?(user)
         format.html {
           flash[:error] = "Error in following user"
           redirect_to URI.parse(request.referer || "/").path
         }
         format.js { render "create", locals: { following: false, profile_user: user } }
+      else
+        current_user.follow(user)
+        format.html { redirect_to URI.parse(request.referer || "/").path, notice: "You have started following #{user.username}" }
+        format.js { render "create", locals: { following: true, profile_user: user } }
       end
     end
   end
@@ -22,16 +22,16 @@ def destroy
     user = User.find_by_id(params[:id])
     relation = Relationship.where(follower_id: current_user.id, followed_id: params[:id])
     respond_to do |format|
-      if !relation.nil?
-        current_user.unfollow(user)
-        format.html { redirect_to URI.parse(request.referer || "/").path, notice: "You have unfollowed " + user.username }
-        format.js { render "destroy", locals: { unfollowing: true, profile_user: user } }
-      else
+      if relation.nil?
         format.html {
           flash[:error] = "Error in unfollowing user"
           redirect_to URI.parse(request.referer || "/").path
         }
         format.js { render "destroy", locals: { unfollowing: false, profile_user: user } }
+      else
+        current_user.unfollow(user)
+        format.html { redirect_to URI.parse(request.referer || "/").path, notice: "You have unfollowed " + user.username }
+        format.js { render "destroy", locals: { unfollowing: true, profile_user: user } }
       end
     end
   end
  • ๐Ÿ’พ Commit your changes

  • ๐Ÿ”€ Start a Pull Request. There are two ways how you can start a pull request:

  1. If you are not familiar with GitHub or the pull request model, here is a guide you can follow on how GitHub works.

  2. If you are familiar with the terminal or would like to learn to use it, here is a great tutorial on how to send a pull request using the terminal.

  3. You can also edit files directly in your browser and open a pull request from there.

  • ๐Ÿ Done Ask in the comments for a review :)

Please keep us updated

๐Ÿ’ฌโฐ - We encourage contributors to be respectful to the community and provide an update within a week of claiming a first-timers-only issue. We're happy to keep it assigned to you as long as you need if you update us with a request for more time or help, but if we don't see any activity a week after you claim it we may reassign it to give someone else a chance. Thank you in advance!

If this happens to you, don't sweat it! Grab another open issue.

Is someone else already working on this?

๐Ÿ”—- We encourage contributors to link to the original issue in their pull request so all users can easily see if someone's already started on it.

๐Ÿ‘ฅ- If someone seems stuck, offer them some help! Otherwise, take a look at some other issues you can help with. Thanks!

๐Ÿค”โ“ Questions?

Leave a comment below, and reach out in our chatroom!

hi @Dhei-vid, reserving this for you

Thank you. @cesswairimu

Can I try to solve this issue? Thank you!

@xiaodaiweiwei It's already be assigned.