loading...
Cover image for dev.to Repo Recap from the Past Three Weeks
The DEV Team

dev.to Repo Recap from the Past Three Weeks

andy profile image Andy Zhao (he/him) ・14 min read

Welcome back to another Repo Recap, where we (usually) cover last week's contributions to dev.to's repository and the iOS repo. This edition will be covering three weeks, March 16 to April 5.

Features

  • Night mode is officially out in public beta, as well as changing the font of posts! You can change it in your settings: https://dev.to/settings/misc Thanks to @ben for getting it out the door!

Add proper css vars to user style config #2105

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This renders the proper night theme using CSS variables. This currently takes hardcoded theme info right in application.html.erb but could be modified to take variables in the future.

Also added another font option: comic sans.

  • Thanks to @picocreator making our Docker build run in a one line step! More details in the PR:

Feature : docker-run.sh script + docker container build #1844

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

A single bash script that helps quickly setup either a DEV or DEMO environment

bash-3.2$ ./docker-run.sh 
#---
#
# This script will perform the following steps ... 
#
# 1) Stop and remove any docker container with the name 'dev-to-postgres' and 'dev-to'
# 2) Reset any storage directories if RUN_MODE starts with 'RESET-'
# 3) Build the dev.to docker image, with the name of 'dev-to:dev' or 'dev-to:demo'
# 4) Deploy the postgres container, mounting '_docker-storage/postgres' with the name 'dev-to-postgres'
# 5) Deploy the dev-to container, with the name of 'dev-to-app', and sets up its port to 3000
#
# To run this script properly, execute with the following (inside the dev.to repository folder)...
# './docker-run.sh [RUN_MODE] [Additional docker envrionment arguments]'
#
# Alternatively to run this script in 'interactive mode' simply run
# './docker-run.sh INTERACTIVE-DEMO'
#
#---
#---
#
# RUN_MODE can either be the following
#
# - 'DEV'  : Start up the container into bash, with a quick start guide
# - 'DEMO' : Start up the container, and run dev.to (requries ALGOLIA environment variables)
# - 'RESET-DEV'   : Resets postgresql and upload data directory for a clean deployment, before running as DEV mode
# - 'RESET-DEMO'  : Resets postgresql and upload data directory for a clean deployment, before running as DEMO mode
# - 'INTERACTIVE-DEMO' : Runs this script in 'interactive' mode to setup the 'DEMO'
#
# So for example to run a development container in bash its simply
# './docker-run.sh DEV'
#
# To run a simple demo, with some dummy data (replace <?> with the actual keys)
# './docker-run.sh DEMO -e ALGOLIASEARCH_APPLICATION_ID=<?> -e ALGOLIASEARCH_SEARCH_ONLY_KEY=<?> -e ALGOLIASEARCH_API_KEY=<?>'
#
# Finally to run a working demo, you will need to provide either...
# './docker-run.sh .... -e GITHUB_KEY=<?> -e GITHUB_SECRET=<?> -e GITHUB_TOKEN=<?>
#
# And / Or ...
# './docker-run.sh .... -e TWITTER_ACCESS_TOKEN=<?> -e TWITTER_ACCESS_TOKEN_SECRET=<?> -e TWITTER_KEY=<?> -e TWITTER_SECRET=<?>
#
# Note that all of this can also be configured via ENVIRONMENT variables prior to running the script
#
#---

And does the deployment using docker. Includes option to do a reset prior to deployment.

Optional contextual information provided here : https://dev.to/uilicious/adopt-your-own-devto----with-a-single-command-almost-1c04

Need advice on ...

if someone can guide me on how to run dev.to in "Production" mode, it would be great in improving the overall docker container performance

Added to documentation?

What gif best describes this PR

quick demo

What gif best describes how it makes you feel?

how i feel

  • You can now add prefilled markdown via parameters when writing a new post. https://dev.to/new! More details on this feature in the future! PR by @ben

Add arbitrary prefilled markdown for /new #2108

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This feature allows users to supply a url like dev.to/new?prefill=A BUNCH OF MARKDOWN in order to supply arbitrary templates. This is similar to the tag prefilled templates.

  • We now have some native view tracking for your posts. This helps us display trends a bit easier. PR by @ben

Add organic page view sums and modify seo boostables #2109

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This allows us to store data about organic page views (recent and all time) and display trends this way. For use on side bar to help maintain SEO to pages already doing well with Google.

  • Thanks to @willamesoares, the comment box/textarea is now resizable! Enlarge to your heart's content.

Allow users to resize edit comment textarea element #1866

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Based on complaints, this allows users to resize the text area element while editing a comment.

Related Tickets & Documents

#1554

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

edit_comment

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @davefollett Tag removal textarea changes: replaced placeholder text with improved

Tag removal textarea changes: replaced placeholder text with improved … #2063

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Tag removal textarea changes:

  • Replaced placeholder text with improved sample text Improved placeholder text to be clear that moderators only need to provide a reason.
  • Increased height so all text shows by default

Related Tickets & Documents

Resolves #2001

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Screenshot_20190313_231631

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @ben Add themes to main list, notifications, and chat

Add themes to main list, notifications, and chat #2119

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

More theme goodness!

  • A small feature, but we now set the site logo via an environment variable. PR by @ben

Add ability to set site logo via ENV variable #2123

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This allows admins to set new logos for special events as well as generalized instances of the platform.

  • Thanks to @rhymes for adding clearer error messaging when an image upload fails!

Handle images uploading errors #2018

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Currently, when an image upload results in an error, the server "breaks", a HTTP 500 unhandled error is generated and the user is shown a generic "invalid file" for the comment editor and editor v1 and nothing at all for editor v2.

In this PR I added/changed the following:

  • a proper error handling server side (an image upload error shouldn't result in HTTP 500, because the error is fine, it's the client that sent something wrong)

  • errors that are not client dependent should indeed generate HTTP 500

  • messages returned by CarrierWave that are related to client errors are directly shown to the user (I checked the from CarrierWave's own locale/en.yml and they seem ok to be consumed by the user

  • messages returned by CarrierWave that are related to server errors are still handled but a generic "a server error has occurred" is sent to the client (should these by sent to a bug tracker as well?)

  • I added error handling to the client side

A note: I'm not super confident in the way I chose to display the upload error in the editor v2, let me know if it should be displayed in a different way or if it should have a better styling.

I added screen recordings for the three cases

Related Tickets & Documents

Closes #936, closes #2008

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Editor v1

editor-v1

Editor v2

editor-v2

Comment editor

comment-editor

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

Add a list of followed organizations to dashboard #2157

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Add a list of followed organizations to user's dashboard.

Related Tickets & Documents

#1958

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Screen Shot 2019-03-20 at 15 53 47

Screen Shot 2019-03-21 at 14 36 14

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

alt_text

Add areas for DEV Shop displays on left sidebar #2162

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Adds ability to put shop and other theme day content at bottom of left sidebar

Screen Shot 2019-03-21 at 2 55 56 PM

  • Thanks to @jess, we can now merge accounts via our internal tooling! If you are having an issue with a duplicate account, feel free to email yo@dev.to.

Merge user and give pro users trusted role #2176

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

  • Automatically give "PRO" users trusted role. I'm sure PRO stuff will be moved out of this area soon but I think this makes sense for now.
  • Add merge user functionality to /internal.
  • Prevent merge if account to be deleted has two identities (likely indicator that this account shouldn't be deleted)

  • @ben updated our onboarding with several new recommended tags. Check it out below:

Add several recommended tags for onboarding #2217

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This adds some popular tags to the onboarding flow.

  • Thanks to @mariocsee, you can now block or easily report abuse in Connect chat!

block/report abuse in dev-connect #2074

What type of PR is this? (check all applicable)

  • [x] Feature

Description

Adds blocking and report abuse to DEV Connect to prevent abuse. Users can keep their inbox open and blocked users cannot re-open chat with them.

blocked is now an option for ChatChannel status. This prevents a ChatChannel from being rendered in /connect and doesn't allow status to be changed to active. Currently, there is no way to unblock someone on /connect on the user side.

Related Tickets & Documents

continues off from #1563

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Blocking

blocking

Reporting Abuse

report-abuse

Added to documentation?

  • [x] no documentation needed
  • For April Fool's Day, we tried to do something but it ended up going a bit haywire... Here's the offending PR, and the related post:

Make comic sans default #2257

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Making good choices

  • We now have API endpoints for analytics! This is currently only available to pro members (more details on that to come).

Add API Analytics Endpoints #2293

What type of PR is this? (check all applicable)

  • [x] Feature

Description

This adds analytics endpoints via API for stats! This is currently only available to pro members. Pro members who are also a part of an organization can view their respective organization's stats as well via API.

There are three endpoints currently:

  • /api/analytics/totals, which gives you a summary of all your posts' stats,
  • /api/analytics/past_day which gives you the past 24 hours worth of data, and
  • /api/analytics/historical, which gives you a snapshot of data of each day based on a certain timeframe.

You'll need to generate an API token via https://dev.to/settings/account to authorize yourself. If you'd like view your organization's data, you can add the organization_id parameter. Here's an example endpoint: https://dev.to/api/analytics/totals?api_token=blahblahblah&organization_id=9001

For /historical, you must add at least a starting date parameter start. The ending date parameter end is optional, and leaving it out will give you all data up to the current date. Both date parameters must be in the format of yyyy-mm-dd (ex. 2019-03-29) Example endpoints:

https://dev.to/api/analytics/historical?api_token=blahblahblah&start=2019-03-26
https://dev.to/api/analytics/historical?api_token=blahblahblah&start=2019-03-01&end=2019-03-14

Added to documentation?

Not yet, but will add to docs.dev.to soon!

[optional] What gif best describes this PR or how it makes you feel?

alt_text

  • We also have a dashboard for more detailed analytics for said pro members:

Enable Org Pro Dashboard View #2060

This PR enables the org pro dashboard view. I decided to leave refactoring and making more data available for the next PR.

  • Trusted members of the community can now suggest social copy for posts! PR by @ben:

Add ability for trusted users to suggest social copy for posts #2306

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This feature allows community members to offer Twitter copy for posts that will go out to social accounts. This is the minimum viable version. May be rough around the edges.

  • @bolariinwa added support for the HTML <mark> element in Markdown. This means you can now highlight things as you'd like. Thanks, @bolariinwa!

Add support for mark element in markdown #2089

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [X] Bug Fix
  • [ ] Documentation Update

Description

The <mark> is useful for authors to highlight important text. Following the suggestion made by @link2twenty , I updated the tags list in rendered_markdown_scrubber.rb.

Related Tickets & Documents

The issue number is #1870.

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Text Highlight using mark Element

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [X] no documentation needed
  • https://dev.to/videos is out! It's our landing page for all natively uploaded videos on dev.to. We'll be making more improvements soon. PR by @jess:

"/videos" #2291

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Adds a page (/videos) to see all posts w. native video content.

Bug Fixes / Other Contributions

  • Thanks to @jess for adding Scout config and gem in! I was personally excited to see some preliminary data in the email we received.

add scout config and gem #2219

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

  • Adds scout gem and config file

  • Thanks to @ben for updating our Airbrake (error monitoring service we use) to ignore some extraneous errors, like ActiveRecord::RecordNotFound.

Ignore unnecessary airbrake notices #2283

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [x] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

We don't need to log every recordnotfound, as a lot are natural from articles that are unpublished. They represent a small number of overall requests but a large number of our error tracking. This cleans up some of the mess.

Also adds a filter to randomly not track all JS errors. We're okay to only track some and still get a pretty accurate look in general IMO. We can revisit later.

  • @ben resolved an issue where crossposted posts were improperly sorted because of their original posting date. Thanks, Ben!

Add originally_published_at for more accurate crossposted info #2076

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Currently we set published_at when a post comes in crossposted but the logic is a little messed up in terms of where it fits in the feed. This is not the whole fix, but this is a new column to track the original date more accurately and manually fix a few bad ones.

  • @perigk updated our "Additional Tech" docs to mention we use Git and GitHub for version control and issue tracking. Thanks, @perigk !

Updated addl-tech.md #2078

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [X ] Documentation Update

Description

Update addl-tech, with two kinda-pedanctic options.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ x] docs.dev.to
  • [ ] readme
  • [ ] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

alt_text

  • @ben fixed a possible race condition with our native page view tracking. Details below:

Fix possible race condition with page view tracking #2103

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

When a page view is tracked, we later update that view to track that the user was still on the page.

But sometimes there is an issue creating that first page view. This PR helps account for that scenario.

  • Thanks to @bolariinwa for adding links to tags everywhere they appear. The missing place was in the dashboard.

Add link for tags everywhere they appear #2088

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [X] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

To keep the expectation of tags being clickable, I updated _dashboard_article.html.erb so tags on posts on the dashboard are wrapped in a link tag and link to their respective pages.

Related Tickets & Documents

The issue number is #1991

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [X] no documentation needed
  • @lightalloy fixed a bug where a reaction notification had leftover data from removed reactions. Thanks, Anna!

Fix reaction notification json data when a reaction is destroyed #2112

What type of PR is this? (check all applicable)

  • [x] Bug Fix

Description

Keep only persisted data in the notifications json_data when a destroyed reaction record is passed to the Notification#send_reaction_notification

Related Tickets & Documents

#2111

Enabled Rubocop/Naming Cop #2115

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Enabled Naming/AsciiIdentifier Cop and Naming/FileName Cop

Related Tickets & Documents

#2021

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

alt_text

  • @selbekk fixed a bug by properly making words plural when needed with one of my favorite Rails methods: pluralize. Thanks, @selbekk !

Fix bug where singular values get plural endings #2069

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

I've added two ternaries to add a trailing s to "comment" and "reaction" if and only if the count is not 1.

Related Tickets & Documents

#2067

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

relieved

  • @edisonywh fixed an issue where going to a badge that does not exist would result in a server error instead of a 404 page. Thanks, @edisonywh !

Redirect to 404 if badge not found #2066

Previouly we do not check if @badge exists before redirecting to :show, this commit fixes that by redirecting to 404.

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Related Tickets & Documents

#2051

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

image

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

squash bugs!

  • @rhymes fixed a longstanding issue where a Front Matter description was not escaping properly. Thanks, @rhymes !

Fix unescaped front matter description in MarkdownFixer #1989

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

I set out to fix https://github.com/thepracticaldev/dev.to/issues/96 - the initial idea was to create more meaningful error messages, I then realized the front matter is parsed by a third party library, so I abandonded the idea.

I decided to just fix the bug created by unwrapped chars in the description (which triggered the issue in the first place)

Related Tickets & Documents

Closes #96

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Before

before

After

after

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @rhymes updated our error raising to properly reflect the correct error ActiveRecord::NotFound instead of ActionController::RoutingError. Thanks again, @rhymes !

Change not found 404 raised exception in ApplicationController #2118

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

After the discussion we had around #2066 and this comment by @lightalloy , I'm submitting this PR to change the default exception raised by the not_found method.

FYI Rails renders the 404 page with both ActionController::RoutingError and ActiveRecord::ActionNotFound so there's no change in functionality. I'm not even sure the exception raised makes the code clearer because it's transparent to the pattern:

Model.find_by_(id) || not_found

it just aligns to what the finder methods with the ! raise.

This aforamentioned pattern appears 15 times in the code, instead the Rails default:

Model.find_by!(id)

appears only 3 times, all in the tags_controller.rb file.

Related Tickets & Documents

#2066

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @lightalloy has been refactoring and moving notifications into separate jobs. This PR moved the new follower notification. Thanks, Anna!

Moved sending new follower notification to a separate job #2030

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

  • created a separate Active Job to handle new follower notification
  • pass attributes instead of a Follow instance to the job to get rid of deserialization error. (in this case, we can't just pass follow_id, cause a follow might be destroyed at that moment)
  • moved the new follower notification logic to a service object
  • kept the old Notification interface (send_new_follower_notification and send_new_follower_notification_without_delay)

Related Tickets & Documents

#1996

Enabled Rubocop/Rails cops #2125

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Enabled Rubocop/Rails cops

Related Tickets & Documents

#2021

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @glennmen refactored how we award the yearly badges to a way that is much more flexible than our previous implementation. Thanks, @glennmen !

Refactor award_yearly_club_badges #2035

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Refactor award_yearly_club_badges so that adding new yearly badges will be easier and require less changes.

I got a couple of questions about the refactor:

Any other feedback is welcome!

Related Tickets & Documents

https://dev.to/ben/comment/8inc

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

birthday

  • @venarius made some UX improvements by updating the editor_version field to a <select> field. It was originally a <text> field. Thanks, @venarius !

UX: Changed editor_version to a select field #2107

What type of PR is this? (check all applicable)

  • [ x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Changed the editor_version input is settings/misc to a select field

Related Tickets & Documents

Issue #1775

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Screenshot from 2019-03-18 22-29-23

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [ x] no documentation needed

This is also my first PR to dev.to 🥳

Enabled rubocop/lint #2130

What type of PR is this? (check all applicable)

  • [ x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This enables the rubocop/lint

Related Tickets & Documents

https://github.com/thepracticaldev/dev.to/issues/2021

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [ x] no documentation needed
  • @abraham updated the Faker gem and fixed a deprecated Faker::Overwatch usage. Thanks, @abraham !

Update Faker and fix deprecated Faker::Overwatch use #2142

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Update Faker::Overwatch.quote and fix deprecation notices in tests.

NOTE: Faker::Overwatch.quote is deprecated; use Faker::Games::Overwatch.quote instead. It will be removed on or after 2019-01-01. Faker::Overwatch.quote called from /home/travis/build/abraham/dev.to/spec/factories/badges.rb:7.

Related Tickets & Documents

n/a

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

n/a

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @rhymes added alternative text for organization logo. Thanks, @rhymes !

Add alternative text for organization logo #2148

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Organizations logos are missing the alternative texts in a few places.

Thanks to Lighthouse for catching this on the homepage.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Screenshot 2019-03-21 at 11 04 29 AM

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @rhymes replaced all the Ruby put with proper logging. Thanks for that!

Replace puts with proper logging #2139

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

While examining another PR I noticed there was a puts in the wild in an error handler, I decided to use proper logging instead, ended up replacing all puts.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

Fix sidebar-profile-snapshot width #2145

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

The 3 hardest problems programmers face are

  1. Naming things
  2. Off by 1 errors

.sidebar-profile-snapshot width was wider than the rest of the sidebar by 1px.

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Before: image

After: image

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @abraham switched a gem source to use the published version instead of a fork. Thanks, @abraham !

Switch fix-db-schema-conflicts to published version #2161

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Switch from fork to published version.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

Enable performance rubocop cops #2140

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Enabled all Performance cops. Refactored where needed.

Related Tickets & Documents

https://github.com/thepracticaldev/dev.to/issues/2021

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

alt_text

Remove klipse script unused partial #2164

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

While working on #2153 I noticed this partial isn't used anywhere

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

Add SRI to script tags where applicable #2153

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Security wise all external scripts should have SRI enabled (aka subresource integrity). This allows the browser to check if the external source has been tampered with (and thus not load the script).

I've only added to those <script> sites that had the information publicly available and that pointed to a specific version of the resource.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @mscccc improved how we render our social cards by using HTML/CSS to Image. Check out the PR for the details. Thanks, @mscccc !

Social Card upgrade - Part 1 #2090

Dev.to + HTML/CSS to Image ⚡️

👋 @benhalpern

This gives the SocialPreviewsController the ability to render png's.

Current URL: https://res.cloudinary.com/practicaldev/image/url2png/s--pncSBGoq--/c_fill,g_north,h_400,w_800/https://dev.to/social_previews/article/75561%3Fbust%3D0-Build%20a%20GitHub%20Action%20with%20Ruby-true"

Future: https://dev.to/social_previews/article/89948.png

Fancy Gif

Screen Recording 2019-03-16 at 03 07 PM

Backwards compatible

Implemented this so that this PR is a no-risk deploy. Nothing is breaking. All the old URLs work exactly the same as before. The social_preview routes now also support .png.

How does caching work?

The rendered html is used as the cache key (Dalli SHAs it). This means, we get cache busting "for free", the cache will bust whenever the template changes, or the data included in the template (such as article title or user's name) updates.

To do this, I had to remove some of the randomness in the templates. They are now "deterministically random", meaning the object's ID is used as the seed. So you get the same sequence of random numbers each time.

Release Plan

  • [ ] Set HCTI_API_USER_ID and HCTI_API_KEY env variables.
  • [ ] Ship it
  • [ ] Check some preview urls, make sure they look
  • [ ] Follow up PR to update meta tags to point at new URLs

What type of PR is this? (check all applicable)

  • [X] Feature

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

image (https://hcti.io/v1/image/e632881d-b0f6-4d33-be3f-a5863cf260a2)

image (https://hcti.io/v1/image/7455df4e-636e-4bed-b0f6-90cb419977fb)

image (https://hcti.io/v1/image/6c52de9d-4d37-4008-80f8-67155589e1a1)

Added to documentation?

  • [x] no documentation needed
  • @brylie added the Mastodon instance social.coop to our allow-list. Thanks, @brylie !

Add social.coop #2170

Closes #2169

Add the https://social.coop Mastadon instance to trusted list.

Bug fix broken giphy url #2180

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Fixes incorrect giphy url so that gif gets loaded correctly.

Related Tickets & Documents

Fixes #2179

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @abraham enabled many Rubocop/Rails cops, and resolved some of the issues along the way. Thanks, @abraham !

Enables Rails cops #2186

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

The Ruby on Rails Rubocop rules are disabled by default. This enables most of them.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

dumbo taking a bath

  • @abraham simplified our development setup a bit. Check out the PR for the details. Thanks again, @abraham !

Simplify development setup #2143

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [x] Documentation Update

Description

Reduces the steps for setting up development (11 steps mac/linux and 13 steps windows to 7 steps for mac/linux) by using convention of the default database config, removing manual steps that bin/setup handles, and adding foremen to development gems group.

Related Tickets & Documents

https://github.com/thepracticaldev/dev.to/pull/1162

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

n/a

Added to documentation?

  • [x] docs.dev.to
  • [x] readme
  • [ ] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

working out

  • @lightalloy moved the new reaction notification method to a separate job. Thanks, Anna!

Moved new reaction notification method to a separate ActiveJob #2122

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [x] Bug Fix

Description

  • created a separate Active Job to handle new reaction notification
  • pass attributes instead of a Reaction and receiver instances to the job to avoid deserialization errors
  • moved the new reaction notification logic to a service object
  • kept the old Notification interface (methods send_resend_reaction_notification, send_reaction_notification_without_delay)

Related Tickets & Documents

#1996 #1621

Remove `dashboard/following_users` route #2191

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

The dashboard/following_users route has been deprecated a while ago and replaced with dashboard/following route. This commit removes the old route and updates the code to reflect it.

Related Tickets & Documents

This was discussed briefly with @benhalpern here: https://github.com/thepracticaldev/dev.to/pull/2157#issuecomment-475366986

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

No UI changes

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

wintermoon

  • @jess updated the README. Thanks, Jess!

Update Readme #2206

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [x] Documentation Update

Description

  • remove product roadmap since we never got in that habit
  • ask for design mockups for frontend changes
  • update mario and anna to list of contributors
  • @aspittel fixed some night mode issues with the pro dashboard. Thanks, Ali!

Feature/pro dashboard #2178

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [X] Feature
  • [X] Bug Fix
  • [ ] Documentation Update

Description

Fixes dark theme issues with the pro dashboard (though can still get further cleaned up) and also removes the recent reactors at the bottom.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @lightalloy DRY'ed up some of the Active Jobs tests. Thansk, Anna!

DRY the Active Jobs specs #2215

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

Created a shared example to test that the ActiveJobs are enqueued when #perform_later is called

  • @ben cleaned up some new chat channel functionality and added tests. Thanks, Ben!

Clean up new chat channel functionality and add tests #2220

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Refactor and add tests for chat channel functionality. Kept the general code arrangement about the same.

  • @lito improved our slug generation by using a native Rails implementation instead. Thanks, @lito !

Improved article slug generation #2218

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [X] Feature
  • [X] Bug Fix
  • [ ] Documentation Update

Description

Ruby on Rails has a built-in slug generator since Rails 2.2 https://www.rubydoc.info/github/rails/rails/String:parameterize

This generator fix the slug generation when non english characters are used on title improving SEO. For example: https://dev.to/lito_ordes/redimensionando-imgenes-en-tiempo-de-ejecucin-con-packer-57c6

  • @lightalloy enabled a couple of Rubocop cops which had no violations. Thanks, Anna!

Enabled a couple of rubocop cops which have no violations #2214

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

Enabled a couple of rubocop cops which have no violations

Related Tickets & Documents

#2021

  • @dabrorius refactored the show action in our DashboardsController by extracting the following action out of it. Thanks, @dabrorius !

Extract "following" action from "show" in DashboardsController #2212

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Related Tickets & Documents

Currently several separate pages are all crammed under show action of DashboardsController. This is the first step in an attempt of refactoring that action and separating it into several smaller controller actions.

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

blek

  • @lightalloy fixed a few Rubocop issues. Thanks, Anna!

Rubocop fixes #2232

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

  • fixed a couple of rubocop issues
  • removed the fixed and the same as default parts from the .rubocop.yml
  • moved disabled cops that need to be fixed from the .rubocop.yml to .rubocop_todo.yml

Related Tickets & Documents

#2021

  • @jess resolved an issue by clearing old caches when merging users. Thanks, Jess!

Clear Cache When Merging Users #2229

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

  • Update counter cache
  • Keep older created_at date
  • Bust fastly cache
  • @lightalloy started optimizing the sign in process by adding some uniqueness indices. Thanks, Anna!

Optimize sign in: Identity #2061 #2231

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

  • added missing unique indexes on Identity
  • removed redundant unique validation (provider + uid vs uid + provider)
  • made uniqueness validation conditional: only check for uniqueness when one of the fields of the scope was changed This is a slight optimization to start with for the ticket #2061

Things to consider before merging:

  • Check for existing invalid Identity records, they need to be fixed
  • identities table could be large, so adding indexes may take a long time
  • @jess added HTML form validation to the tag weight forms to prevent nil values. Thanks, Jess!

Add form validation for follow 'points' #2236

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x ] Bug Fix
  • [ ] Documentation Update

Description

  • If a user submits a nil/blank field for follow weight on dashboard/following, it'll give them a 500 next time they try to visit.
  • This adds a form validation but no validations on the server side. We should probably do that too but when i added presence: true on the Follow model, it did some weird stuff so thought getting a quick fix in made more sense.
  • @lightalloy resolved a logic error that caused some new comment notifications were not being sent. Thanks, Anna!

Fix notifications about the new child comments #2233

What type of PR is this? (check all applicable)

  • [x] Bug Fix

Description

When a child comment is posted, the article (commentable) author is notified about it only if there are no other users to notify about this comment. I suppose that sending a notification to an article author should not depend on if it's sent to other users. If the receive_notifications is true, the article author should be either notified about the child comments or not notified about them. I added a couple of tests to illustrate this issue and a fix assuming that the article author should be notified about the child comments.

  • @peiche fixed an organization's summary text color in night mode. Thanks, @peiche !

Fixed sticky nav summary color to use custom property. #2240

What type of PR is this?

  • [ ] Refactor
  • [ ] Feature
  • [X] Bug Fix
  • [ ] Documentation Update

Description

The sticky nav summary text is black, even in dark mode. This fix lets it use the custom property, with black text color as a fallback.

Screenshots

Before

Screenshot of before change

After

Screenshot of after change

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [X] no documentation needed
  • @maestromac removed controller tests in favor of request tests. Thanks, Mac!

Remove controller specs #2224

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

  • Moves controller specs to request spec.
  • Remove rails-controller-testing gem.
  • Reorganize article request specs.
  • Add additional specs.

Related Tickets & Documents

Resolves #1827

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

n/a

Added to documentation?

  • [x] no documentation needed

Fixes Github Repositories not visible #2227 #2241

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Add theme container background color to GitHub repositories container in settings/integrations page. Used background color variable used by sidebar containers.

--theme-container-background 

Related Tickets & Documents

#2227

  • @rhymes fixed an error with articles API where sending a request with an unknown username would return a 500 error. The PR updated it to return an empty array instead. Thanks, @rhymes !

Fix error with articles API and unknown username #2247

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

Currently the articles API breaks with a 500 error if the server is called with an unknown username because not_found is a controller method, not part of the service.

I believe it should return nothing like when the API is called with an unknown tag.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @rhymes refactored the article API endpoints a bit to only show published articles. Thanks again, @rhymes !

Add published in the SQL query to retrieve article #2248

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Since we're already asking the DB to retrieve an article, we can directly ask it to filter out published articles without checking at runtime.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @dabrorius refactored the show action in our DashboardsController by extracting the followers action out of it. Thanks, @dabrorius !

Extract "followers" action from "show" in DashboardsController #2270

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This is the second step in refactoring the DashboardsController in which followers action is separated from the generic show action. I kept all the route names the same for now, we might want to update them in a follow-up PR.

Related Tickets & Documents

This is a follow-up PR to this one: https://github.com/thepracticaldev/dev.to/pull/2212

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed

[optional] What gif best describes this PR or how it makes you feel?

immortal

  • @mjraadi fixed a miscolorization of a post's preview snippet at the top of the post's comment section. Thanks, @mjraadi !

Fixes night mode issue #2244 #2285

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update
  • [x] Patch Night Mode Styling

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Here are the styling fixes:

Screenshot_20190402_114000

Closes: #2244

  • @lightalloy added a uniqueness index to user's emails. Thanks, Anna!

Optimize sign in: User #2237

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

  • added a unique index to users email
  • validate user email and username only if the corresponding field changed

Need to check that there are no users with duplicate emails or usernames.

I would also like to change twitter_username and github_username validations to be conditional, but that would require to change allow_blank to allow_nil invalidations, update blanks to nils and make sure there won't be any attempts to write blank values to the database.

Related Tickets & Documents

#2061

  • @ben made an optimization by validating a user's RSS feed URL only if it changed. Thanks, Ben!

Conditionally run feed validation #2292

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

Checking RSS feed validation is pretty costly in the current setup. We should only do it if something has changed with it.

  • @lightalloy added uniqueness indices to Twitter and GitHub usernames. Thanks, Anna!

Unique twitter and github usernames #2061 #2255

What type of PR is this? (check all applicable)

  • [x] Refactor

Description

I made this pr to prepare to change unique validations for the User github/twitter_usernames to be conditional. That will help with #2061

  • set github and twitter usernames to nil in case they are an empty string: in the User model and in the Admin::UsersController (just in case)
  • added unique indexes to these fields in the database

Before merging:

  • make sure there are no records with duplicate twitter_usernames or github_usernames in the users table
  • make sure there are no records with empty strings values in these fields (update them to nil in this case).

Related Tickets & Documents

#2061

  • @rhymes Added tests for the PodcastEpisodesController. Thanks, @rhymes !

Add tests to PodcastEpisodesController #2297

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This PR does two things:

  • adds tests for the Api::V0::PodcastEpisodesController
  • removes unused routes and code

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @mjraadi fixed the "Upload Video" section's background color in night mode. Thanks, @mjraadi !

Fixes Upload Video Section Background Color in Night Mode Theme #2245 #2296

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update
  • [x] Patch Night Mode Styling

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Here are the styling fixes: Screenshot_20190402_121830

Closes: #2245

  • @lightalloy moved new comment notifications to a separate job. Thanks, Anna!

New comment notifications to Active Jobs #1996 #2287

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [x] Bug Fix

Description

  • moved sending notification about a new comment to a separate ActiveJob
  • ActiveJob receives comment_id instead of a Comment instance. That fixes the possible issues with trying to send notifications about a destroyed comment.
  • moved sending notification about a new comment logic to a service object
  • specs for the comment notifications functionality

Related Tickets & Documents

#1996 #1621

Fix Blogcast styling issues #2298

What type of PR is this? (check all applicable)

  • [ ] Refactor
  • [ ] Feature
  • [x] Bug Fix
  • [ ] Documentation Update

Description

I noticed the Blogcast embed wasn't displaying nicely on mobile devices, and it was also creating some weird spacing around it. This PR should fix both of those problems.

Related Tickets & Documents

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Before: Image 2019-04-03 at 6 12 31 PM

After: Image 2019-04-03 at 6 12 53 PM

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @maestromac migrated all our feature tests to system tests. Thanks, Mac!

Migrate feature test to system test #2301

What type of PR is this? (check all applicable)

  • [x] misc

Description

  • Switch from feature spec to system spec
    • which allows us to removed Database-cleaner and also needs to downgrade Capybara.
  • Fix a few rspec inconsistency.

Related Tickets & Documents

n/a

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

n/a

Added to documentation?

  • [x] no documentation needed
  • @rhymes refactored the AnalyticsService to use SQL queries instead of in-memory calls. This is an ongoing refactor and there's a decent discussion going on about implementation details. Feel free to chime in if you're interested! Thanks again for the help, @rhymes !

Simplify AnalyticsService code #2308

What type of PR is this? (check all applicable)

  • [x] Refactor
  • [ ] Feature
  • [ ] Bug Fix
  • [ ] Documentation Update

Description

This refactoring does mainly three things:

  • simplifies AnalyticsService interface
  • uses SQL queries instead of in memory calculations to retrieve counts
  • uses date objects for ranges

A few things I've left out that should be discussed/decided:

  • AnalyticsService should probably be renamed to Analytics::Pro as suggested by @lightalloy
  • date.strftime("%a, %m/%d") is locale dependent and potentially repeats itself (if start_date and end_date go past a year there could be dates with the same string version). Also, users outside the US could misinterpret dates as "03/04" (3rd of march or 4th of april?). I suggest using the ISO "2019-04-01" as key for the hash.
  • I think the date validation using regexps, now that dates are parsed, is unnecessary:
      def valid_date_params?
        date_regex = /\A\d{4}-\d{1,2}-\d{1,2}\Z/ # for example, 2019-03-22 or 2019-2-1
        if params[:end]
          (params[:start] =~ date_regex)&.zero? && (params[:end] =~ date_regex)&.zero?
        else
          (params[:start] =~ date_regex)&.zero?
        end
      end

Related Tickets & Documents

Closes #2307

Mobile & Desktop Screenshots/Recordings (if there are UI changes)

Added to documentation?

  • [ ] docs.dev.to
  • [ ] readme
  • [x] no documentation needed
  • @lightalloy added conditional validations for a user's GitHub username and Twitter username. Thanks, Anna!

Conditional validations for user github_username and twitter_username #2061 #2312

What type of PR is this? (check all applicable)

  • [x] Optimization

Description

  • validate github_username and twitter_username uniqueness only if the corresponding field was changed to lower amount of requests when signing in and in other cases
  • change allow_blank to allow_nil options in these fields' validations, since only nil is allowed to be written to the database.

Related Tickets & Documents

#2061

New Issues and Discussions

  • @glebec raised an accessibility concern where a diff code block syntax highlighting could use more accessible colors. Thanks, @glebec !

Markdown > code block > `diff`-format syntax highlighting: use accessible colors #2087

Is your feature request related to a problem? Please describe. The diff syntax for language blocks in markdown uses red and green as the contrasting colors for deleted and introduced lines respectively. Over 5% of men and ~0.5% of women have difficulty distinguishing red and green, meaning that some people will struggle to tell apart such lines, relying more on the small - and + characters on each line.

Example in GitHub (which also uses red-green for many UI elements):

this is an unchanged line
- this is a removed line
+ this is a new line
this is more unchanged stuff

Describe the solution you'd like An alternative would be to modify the CSS for highlighting diffs to use variations on orange and blue respectively, which a much higher percentage of the population can distinguish.

Describe alternatives you've considered

  • Red-blue is an imperfect compromise, better than red-green but not as universally distinguishable as orange-blue. However, red-blue might fit in better with cultural expectations of meaning, producing less confusion overall.
  • Alternatively, no action may be taken. This isn't the most accessible choice, but as long as diffs still include ± characters in them, they are technically readable.

Additional context Mockup below; exact values are not literal proposals, just food for thought.

Before:

before

After:

after

  • @co16353sidak reported a bug in night mode when hovering on Reading List Section

Bug(Night Mode):- Hover Issues on Reading List Section #2121

Describe the bug In the night mode, there seems to be some problems with the hover on the reading list section of the page. Shown below. when out cursor moves into the Reading List section, the background colour of the lower section containing the buttons saved posts and comment activity unexpectedly changes colour to merge with that of the background. If we continue over to actually hovering over the buttons, then the whole section completely changes it's background colour to merge with the page.

I have included a gif to help understand this. Mar-20-2019 11-45-37(1)

Also if we compare with the functioning of the default mode, we can see the difference and how this is supposed to work. Mar-20-2019 11-46-40

To Reproduce Steps to reproduce the behavior:

  1. Enable Dark Mode
  2. Goto the main dev.to homepage
  3. try hovering over the elements mentioned (the reading-list section) to see the described error

Expected behavior I believe it should work similarly like the default mode, but with different colour variables depending on the mode selected, I have included a gif for the same on default mode.

Screenshots Linked above.

Desktop (please complete the following information):

  • OS: MacOS
  • Browser: Safari and Firefox
  • Version: 12.0.3 (14606.4.5)[latest] and 67.0b3 (64-bit)[latest developer edition]

Smartphone (please complete the following information):

(Not Tested)

Markdown code contribution error #2126

Describe the bug Unable to write a post containing HTML code for an image.

To Reproduce Contribute this in an new post:

---
title: 'Test post'
---

```
<img src="" … 
```

Expected behavior Saving is possible.

Screenshots Capture d’écran 2019-03-20 à 16 53 14

Desktop (please complete the following information):

  • OS: mac os
  • Browser Chrome
  • Version 73.0.3683.75
  • @peter requested a feature where you can sort the dashboard by views/reactions. Thanks, Peter!

Add ability to sort articles on dashboard by views/reactions #2134

Is your feature request related to a problem? Please describe. As an author, I'd like to be able to sort my posts by criteria such as views / engagement / comments count, instead of strictly viewing in chronological order.

Describe the solution you'd like An option on the dashboard which allows me to filter by certain criteria (views, reactions, comments).

  • @joppedc reported an issue where their profile picture was narrowing in the preview mode of a post. Thanks, @joppedc !

Squished profile picture on preview #2137

Describe the bug When doing a post preview, the profile pic next to the publisher name is squished.

To Reproduce Create a new post, preview it.

  1. Go to write a post
  2. Click on preview
  3. See publisher image

Expected behavior Normal image

Screenshots https://cl.ly/8950bcf37c07

Desktop (please complete the following information):

  • OS: MacOS
  • Browser: Chrome
  • Version 72

Additional context This issue might be good as a first issue or a starter issue.

Display bookmark icon inside "Save" button #2144

Is your feature request related to a problem? Please describe. I've used dev.to for a while now, and I like a lot. It took my a while though to understand what the bookmark icon is. For a long time I thought it was just a "reaction". So every time I found a post I'd like to save, I had to search for the hashtag and in the list click on the "Save" button, to save it for later. And many other posts I "spam" reacted to with heart, unicorn and ...bookmark. So I was a bit confused for a while.

Describe the solution you'd like I'd like to make it clearer that clicking on the bookmark icon in a article detail has the same effect as clicking on "Save" button in the list view.

Describe alternatives you've considered I'd like to add the bookmark button inside the Save button. I'm not a designer or UX, so I don't know if this has other effects thought.

Additional context image

    width: auto;
    min-width: auto;
    margin-right: 5px;
    height: 19px;
    margin-left: 0;
    vertical-align: -4px;
  • @rhymes raised an issue where our static assets have unusually short caching period. Thanks, @rhymes !

Static assets have unusually short caching period #2147

Describe the bug

I was testing the homepage with Google PageSpeed Insights and WebPage Performance Test (both links lead to the reports) and they both signalled that static assets (JavaScript files, images and CSS) have short caches, ranging from 1 day to 7 days.

Since they are all versioned I was wondering if there was a reason for that otherwise I'd like to suggest to set a longer cache for those, following Google's best practice and set the cache to one year.

Expected behavior

A longer cache period for static assets.

Screenshots

Google PageSpeed Insights (same as Lighthouse):

Screenshot_2019-03-21 PageSpeed Insights

WebPage Performance Test:

Screenshot_2019-03-21 WebPageTest Optimization Check Results - Dulles dev to - 03 21 19 10 29 24

Desktop (please complete the following information):

  • OS: macOS
  • Browser: Firefox
  • Version: 67b3

Contrast on special text in night mode #2152

The new spring banner is difficult to read in night mode. Is there a way to automate contrast checks? Or should we just be mindful when making special styles?

image

Ruby themes file #2154

Is it worth having a ruby file that contains the theme's HTML, though we'd only have night mode in there for now?

I'm not that clued up on ruby on rails but I presume we can have a file that contains several thems but will only return the relevant HTML based on some request?

CC: @rhymes @lightalloy

  • @rhymes raised an security issue regarding missing HTTP strict transport security headers (HSTS). Thanks, @rhymes !

Add HTTP strict transport security headers (HSTS) #2155

Is your feature request related to a problem? Please describe.

By playing with dev.to's report of Mozilla Observatory I noticed the website does not send HSTS headers.

The TLDR; of that is that the HSTS header forces the client to connect only using HTTPS (which is different from the server side redirect from HTTP to HTTPS).

Describe the solution you'd like

I'll summarise the recommended plan of action:

  1. all domains and subdomains of dev.to should be checked to make sure they all work in HTTPS (even those handled by third party like shop.dev.to)
  2. ramp up the max-age in steps, for example from max-age=300; includeSubDomains to a month: max-age=2592000; includeSubDomains
  3. once everything works you can set it the recommended two years max-age=63072000; includeSubDomains; preload and add the domain to the HSTS preload list

Header example:

Strict-Transport-Security: max-age=xyz

With Rails it would be enabled like this:

config.ssl_options = { hsts: { expires: 5.minutes } }

Options to enable subdomains and preload are also present.

Resources:

Describe alternatives you've considered

Doing nothing :D

  • @link2twenty raised an issue about the color of the notification bell in the top navigation bar in night mode. Thanks, @link2twenty !

[Theme] Notification color #2156

Do we want to theme the bell number? If we do should it be the same as --theme-top-bar-write-background or perhaps a new property, --theme-top-bar-notification-background?

image

  • @link2twenty also opened a discussion on how a user could select themes. Check out the cool mockup! Thanks again, @link2twenty !

[Discussion] Theme selector #2158

At some point we'll have to talk about theme selection, I find a graphic is better than a name as it gives the user an idea of what to expect.

I made a quick mock-up. https://jsfiddle.net/link2twenty/3pmtew1f/

  • @aturingmachine raised an issue with night mode where external links in posts are difficult to see. Thanks, @turingmachine!

External Links In Posts Are Difficult To See In Dark Mode #2163

Describe the bug Links are only marginally different in color than the post's text. Coupled with the dark background changing the overall contrast of the page, this makes them difficult to see.

To Reproduce Steps to reproduce the behavior:

  1. Log in with Dark Mode Enabled
  2. Click on any post including external links.
  3. Observe link text color.

Expected behavior The link text to be more easily differentiated than the post's main body text.

  • OS: MacOS
  • Browser Chrome
  • Version N/A
  • @rhymes raised an issue where we should only use one version of CodeMirror. Thanks, @rhymes !

Use only one version of CodeMirror #2165

Is your feature request related to a problem? Please describe.

The codebase uses various versions of codemirror:

  • package.json declares ^5.44.0 and yarn.lock is using 5.44.0. This is the version used by the code editor:

https://github.com/thepracticaldev/dev.to/blob/a2fcbdc4a4d1de430ff3ec282b373922632a2d4d/app/javascript/chat/codeEditor.jsx#L7-L8

  • app/views/blocks/_form.html.erb links to another version of CodeMirror, 5.26.0:

https://github.com/thepracticaldev/dev.to/blob/a2fcbdc4a4d1de430ff3ec282b373922632a2d4d/app/views/blocks/_form.html.erb#L1-L5

  • app/views/chat_channels/index.html.erb uses a third version of CodeMirror (only the CSS), 5.38.0:

https://github.com/thepracticaldev/dev.to/blob/a2fcbdc4a4d1de430ff3ec282b373922632a2d4d/app/views/chat_channels/index.html.erb#L6-L7

Describe the solution you'd like

CodeMirror is currently at version 5.45.0. I was wondering if all three sections could use the same version from the package.json

  • @john_papa raised an issue with night mode for the admin section for organizations. Thanks, @john_papa !

need contrast in dark theme for admin page for an org #2172

Notice the two spots here both need some more contrast.

image

  • @equiman reported an issue with the <figcaption> tag in night mode. Thanks, @equiman !

figcaption tag in night mode #2181

for tag color font in night mode needs another lighter color.

IMG_20190323_191124

IMG_20190323_191128

  • @equiman reported an issue with night mode for draft posts in the dashboard. Thanks, @equiman !

Draft articles in Night mode #2182

Draft articles are lighter on Night mode on Dashboard screen

Screenshot_20190323-191607

  • @equiman reported an issue with night mode for the Social icons in profile pages. Thanks again, @equiman !

Social icon in profile on Night mode #2183

Social icons in profile have a different color.

IMG_20190323_192118

  • @equiman reported an issue with night mode for the "Following tags" section in your dashboard. Thanks again, @equiman !

Following tags in Night mode #2184

On night mode active. Following tags and text are in light color.

Screenshot_20190323-192459

  • @rhymes opened a discussion about whether we should use randomly generated IDs in the future REST API. Thanks, @rhymes !

Use randomly generated IDs in the REST API #2187

Is your feature request related to a problem? Please describe.

I'm opening this ticket after having read this great article about data analysis on dev.to's articles.

The question I'd like to set forth, in preparation for a future "publication" of the API, is: should dev.to use randomly generated resource IDs instead of exposing "internal" autoincrementing integer primary keys or not?

A "classic" best practice in API design is not to expose internal details of your app, separating as much as possible how the data is organized from how is accessible from third parties.

Autoincrementing primary keys are usually discouraged in public APIs (by some, not by all) mainly for three reasons:

  1. they expose database IDs to the public. Today you might have data in a relational database, tomorrow that data might be elsewhere and those IDs might not mean much because autoincrementing primary keys are local to one data source.
  2. by exposing incrementing IDs an onlooker (or a malicious attacker) can gather two information: size of the tables and growth rate
  3. it's easier for a malicious attacker to write a script to scrape data

This is more a question of policy than a technical argument because, at least for the second of the three reasons, DEV is perhaps perfectly fine with that.

Some possible alternatives to auto incrementing integer primary keys:

  • UUIDs: PostgreSQL has a native indexable UUID type with functions to generate default UUIDs, like pgcrypto's gen_random_uuid(). UUIDs though are not sortable, they kind of look ugly and they are verbose: https://dev.to/api/articles/2d931510-d99f-494a-8c67-87feb05e1594
  • KSUIDs: they are quite new and were "invented" by Segment. The characteristic they have is that they are sortable and time dependent: https://dev.to/api/articles/0ujsszwN8NRY24YaXiTIE2VWDTS
  • some other random alphanumeric ID generated in the app (eg. Ruby's SecureRandom.alphanumeric(20)): https://dev.to/api/articles/cDAkKyz38cqjTI1bV5lG

My preference goes to one of the last two options

Describe the solution you'd like

Because the API is not public yet, and it's relatively small (only 8 controllers), I think that the transition would be doable if there's consensus on this. After publication and documentation it might be harder, especially because DEV is already a big community and developers are already jumping at the opportunity to use the API (hence the article ;))

For obvious reasons there shouldn't be a situation where both (integer IDs and alphanumeric IDs) would work at the same time. That would only strain the system (because it might result in two queries, instead of one).

The frontend/SPA would also need to be aligned and updated.

What do you think?

Additional context

I did a quick tour of some public APIs (starting from those used by DEV itself and this is what I've found:

  • Fastly uses both URLs (for obvious reasons) and alphanumeric IDs (eg. SU1Z0isxPaozGVKXdv0eY) to identify resources, probably generated by the equivalent of Ruby's SecureRandom.alphanumeric(21)
  • Cloudinary uses a public_id which is a randomly generated string (eg. 8jsb1xofxdqamu2rzwt9q)
  • Stripe uses alphanumeric random strings prefixed by a resource identifier, for example ch_19yUdh2eZvKYlo2CkFVBOZG7 for a charge and cus_El7v7DRE34iBPx for a customer

A few more:

  • StackOverflow uses integer IDs
  • Twilio uses string IDs with a prefix for type of resource, similar to Stripe
  • PayPal uses alphanumeric IDs

Refs #911

  • @kenbellows reported an issue where certain characters, like angle brackets, show up incorrectly in some article previews. Thanks, @kenbellows !

Certain characters, like angle brackets, show up incorrectly in some article previews #2204

Describe the bug When viewing the /comments view of an article, the first line and a half or so of the article is displayed. If that first bit contains inline code with angle brackets, e.g. if you wrote:

this is an article about `<span>` tags

this appears in the article preview as: "this is an article about <span> tags".

To Reproduce Steps to reproduce the behavior:

  1. Go to 'https://dev.to/new'.
  2. Enter minimal front matter, set `published: true, and enter:
this is an article about `<span>` tags
  1. Save the article.
  2. Navigate to {article URL}/comments.
  3. Observe the &lt;span&gt; in the preview text.

Expected behavior I expect the preview to say "This is an article about <span> tags"

Screenshots Example from: https://dev.to/kenbellows/stop-using-so-many-divs-an-intro-to-semantic-html-3i9i/comments Screen Shot 2019-03-25 11:45 AM EST

Desktop (please complete the following information):

  • OS: macOS Mojave 10.14.3
  • Browser: Chrome 72.0.3626.121, Opera 58.0.3135.107
  • @john_papa reported an issue with night mode about how code in comments need contrast. Thanks, @john_papa !

Code block with string containing ⭕ gets changed to ⭕️ #2216

Describe the bug

Code block with string containing :o: (lowercase letter that comes after n surrounded by colons) gets changed to ⭕️ (perhaps an emoji?)

To Reproduce

Using any of these code blocks in a post/comment and previewing it shows the issue. Having any other characters around this sequence doesn't matter as far as I've checked.

```
:o:
```

```python
':o:'
```

```ruby
':o:'
":o:"
```

Expected behavior

Within code blocks, I do not expect any string combination (that I know of) to be interpreted and converted to another string. :o: should just be :o: not ⭕️

Screenshots

The above code blocks produces this output:

code_block_issue

Bug(Night Mode): Embedded comments are hard to read #2221

Describe the bug With Night Mode enabled, embedded comments in articles are hard to read.

They show up as black text against a dark blue background.

To Reproduce With Night Mode enabled, go to an article that embeds comments.

Such as https://dev.to/devteam/top-5-dev-comments-from-the-past-week-gia

Screenshots

An embedded comment

Desktop:

  • OS: Windows 10 OS Build 17134.648
  • Browser: Chrome
  • Version: 73.0.3683.86 (Official Build) (64-bit) (cohort: Stable)
  • @andypiper reported an issue with night mode where an organization's CTA box content is hard to read. Thanks, @andypiper !

Dark mode - org CTA box content is hard to read (needs contrast) #2222

Describe the bug It is difficult to read the black text on dark background in the CTA box on organisation posts.

To Reproduce Steps to reproduce the behavior:

  1. Go to https://dev.to/twilio
  2. Click on any post
  3. Check the sidebar
  4. See below

Screenshots Screenshot 2019-03-26 at 20 40 43

  • @lito requested a feature where we add an HTML <meta> tag with the current deployed git commit hash. Thanks, @lito !

Add a HTML Meta tag with deployed git commit hash #2223

What about to add a html meta tag on header with the current git commit deployed?

On this way it's easy to contributors and developers follow website status and deployment compared with github commits.

I don't know if exists some tag for this proposse, but what about something like:

<meta name="git-commit" content="6e23483b9421c1e1a03d94093306badf277cc19e">

Regards :)

  • @lito reported an issue where non-English characters are deleted in tags. Thanks again, @lito !

Non english characters are deleted on tags #2226

Describe the bug When you write tags with some non english characters, these characters are deleted on article view.

To Reproduce

  1. Use a tag like Optimización (Optimization).
  2. Save
  3. Go to article
  4. Optimización is now optimizacin

Expected behavior Show Optimización as in markdown editor.

Screenshots Tags Bug

  • @brylie reported an issue where service workers and a privacy extension was blocking images from loading. Thanks, @brylie !

Error loading images #2228

I shared a dev.to article on Reddit, and one of the commenters said images wouldn't load.

Here is the rest of their diagnosis:

These images:

https://i.imgur.com/GArpxyC.png

Errors reported in console:

manifest-36a1d0b68d1e3664106b.js:1 Uncaught SyntaxError: Unexpected token <

vendor-a16759536b738a97f545.js:1 Uncaught SyntaxError: Unexpected token <

Search-d6be81c747f6325b6aae.js:1 Uncaught SyntaxError: Unexpected token <

base-55719a78ce4c394706e03834ae49c59cddc235c3ef5dbc299c63b4edf0f0b558.js:1 Uncaught SyntaxError: Unexpected token <

webShare-1698d2d09639b4c8b299.js:1 Uncaught SyntaxError: Unexpected token <

reload-router-view-when-vue-route-changes-3cck:1 Error while trying to use the following icon from the Manifest: https://practicaldev-herokuapp-com.freetls.fastly.net/assets/devlogo-pwa-192-b92c1c02f2f63967c2889ba04a4d7bc61da640a6dbe419d65703b1282c96b46c.png (Download error or resource isn't a valid image)

serviceworker.js:1 Uncaught (in promise) TypeError: Failed to fetch


If I go to "Google chrome dev tools" --> "Application" --> "Service worker" and check "Bypass for network", and reload, everything works


After some more debugging, it seems like the XHR requests to *.freessl.fastly are blocked by the privacy settings in my browser, if I whitelist that origin for XHR requests from your domain, it works
  • @lightalloy raised the issue that merging user accounts should be done in a database transaction. Thanks, Anna!
  • @ben requested a feature where we v2 editor could also handle plain front matter. Thanks, Ben!

Toggle plain frontmatter editor within v2 #2234

Is your feature request related to a problem? Please describe. Currently if you want to write "simple" markdown, you do so with the original editor, which is fine, but has always been a bit weird and occasionally buggy.

The new editor has rich UI controls, but some folks still want the markdown pasting experience (for a lot of valid reasons beyond just taste!)

It would be nice if "v2" (the preact-built editor) supported our whole range of use cases and we could sunset the old code (perhaps to be maintained by the community)

Describe the solution you'd like

Any area to toggle between editor types would be great. Users could have a default editor type but easily switch when needed.

  • @antonrich requested a feature where you can combine tags together in a search query.

Combining tags together in a search query. #2238

It would be great if users could write a search query of the following format: #tag1 #tag2 and receive the results that actually have such tags.

https://dev.to/antonrich/how-can-i-combine-tags-when-searching-on-dev-to-5b19

  • @mte90 Improve the feed using the tags picked by an user

Improve the feed using the tags picked by an user #2249

Mte90 avatar
Mte90 posted on

Describe the bug An user pick the tags that want to follow but there isn't any priority to them on the various feed availables.

To Reproduce Steps to reproduce the behavior:

  1. Set tags on your user
  2. Check the tags of the post in your feed

Expected behavior The feeds has only stuff of the tags that the user is following or else they are useless right now

Screenshots immagine immagine

  • @rhymes reported a strange issue with the API where https://dev.to/api/comments?a_id=some_id wasn't working, even though there seemingly isn't anything wrong with the related code. Thanks for reporting this, @rhymes !

API: can't get comments belonging to an article #2250

Describe the bug

I can't seem to be able to retrieve articles comments from the DEV API. It works on my local installation but not using the live API.

Given the article API response https://dev.to/api/articles/95907 - https://dev.to/kathyra_/what-security-through-obscurity-is-and-why-it-s-evil-47d5 - I tried to retrieve its comments using https://dev.to/api/comments?a_id=95907 but the server returns HTTP 404.

At a first glance it should work, according to the code:

https://github.com/thepracticaldev/dev.to/blob/54ccef47669759b060370c1cde8f527ce6d39333/app/controllers/api/v0/comments_controller.rb#L15-L18

The odd thing is that such call works correctly on a local installation.

I'm probably doing something wrong on my end.

To Reproduce Steps to reproduce the behavior:

  1. Go to https://dev.to/api/comments?a_id=95907
  2. See error

Expected behavior

I'd expect this endpoint to return all the comments of the article with id 95907 which should be the following: https://dev.to/kathyra_/what-security-through-obscurity-is-and-why-it-s-evil-47d5

Screenshots

Screenshot 2019-03-31 at 6 50 42 PM

  • @mjraadi reported an issue with night mode where the comment preview text is unreadable. Thanks, @mjraadi !

[Night Mode]: Article's Comment Preview Needs to be Fixed #2286

Describe the bug Comment preview of an article needs to be updated according to the night mode color scheme. Background color is yellow and font color is white and the text is unreadable.

To Reproduce Steps to reproduce the behavior:

  1. Go to any article
  2. In the comment box type anything
  3. Click on "Preview"
  4. See the behavior

Expected behavior Contrast between background color and text color.

Screenshots Screenshot_20190402_144338

Desktop (please complete the following information):

  • OS: Arch Linux Manjaro
  • Browser Chrome
  • @learnbyexample reported an issue where inline code with double backslash becomes a single backslash if it is part of nested bullet list.

Inline code with double backslash becomes single if it is part of nested bullet list #2288

Describe the bug

Double backslash inside code blocks in nested listing results in single backslash instead of two.

To Reproduce

From any post/comment, try these non-nested and nested bullet lists:

* foo
* use `\\1`, `\\2`, etc

---

* foo
    * baz
* use `\\1`, `\\2`, etc

Expected behavior

Double backslash shouldn't become single, as shown below for GitHub markdown rendering:

  • foo
    • baz
  • use \\1, \\2, etc

Screenshots

Screenshot for above non-nested (correctly rendering) and nested list (incorrect):

nested_bullet_double_backslash

Not sure if this is related to: https://github.com/thepracticaldev/dev.to/issues/960

  • @jess reported an issue where a Code Sandbox Liquid tag w/ focus input causes the page to jump. Thanks, Jess!

Code sandbox liquid tag w/ focus input causes scrolling on page load #2290

Describe the bug Reported by a user trying to embed a codesandbox that focuses an input. The page 'jumps'/scrolls to the embed when it loads.

To Reproduce Create a new post w/ this liquid tag: {% codesandbox pyqq0o9mk7 %}. Make sure it appears below the fold so you can see the jump.

Expected behavior Liquid Tag shouldn't cause scrolling on page load.

  • @forsh3y opened a discussion about the font weight of night mode. Thanks, @forsh3y !

Dark Mode text weight/kerning #2295

Is your feature request related to a problem? Please describe. I'm in no way visually disabled, but reading large groupings of text in nightmode makes my eyes hurt!

Describe the solution you'd like A lighter font weight for regular text in dark mode. Details here:

Describe alternatives you've considered Unsure, I imagine this will be far far far down on the totem pole anyhow.

Additional context This showcases how the font weight is hard to distinguish and how "clumped" the text is. image

  • @jaydm opened a discussion about making reading times an 'opt-in' feature. Thanks, @jaydm !

Consider making reading times an 'opt-in' feature #2304

jaydm avatar
jaydm posted on

Is your feature request related to a problem? Please describe. People with dyslexia may find reading times unpleasant: image

Describe the solution you'd like Suggest that the reading time either be removed or provide an option to opt-in to see them (so that by default they are hidden).

Describe alternatives you've considered See above - either remove reading times or provide an opt-in to enable them (cookie?)

Additional context Here is one blog post showing the reading time: image

  • @rhymes opened a discussion about possible improvements and ideas for handling the data of our analytics. Thanks, @rhymes !

Analytics service: possible improvements and ideas for the future #2311

Is your feature request related to a problem? Please describe.

This has been opened to collect all possible improvements, in case of need, for the analytics API after questions about performance have been raised in #2307 prior to the refactoring in #2308 (AFAIK yet to be measured/verified for the use case that lead to #2307).

Describe the solution you'd like

There are possible incremental solutions (not all alternatives to each other, some can be applied incrementally). Some suggested solutions require a trivial amount of effort, others require more work.

Theoretically all should be measured against the status quo to understand if needed or not.

Possible solutions

Hard limiting the date range of analytics that can be requested

The proposed solution would forcibly limit how wide the range of dates for the analytics can a client request. As mentioned by @Zhao-Andy some public API's like Twitter limit requests up to 30 days.

Pros

  • setting a cap on the amount of data a client can request is a good idea for obvious reasons
  • most analytics clients will use rolling windows on dates anyway or are interested in a specific period

Cons

  • would probably require special care if any client is to be treated differently (for commercial partnership where the client asks to access more data at same time)
  • it could lead to more HTTP requests for clients interested in a wider range and hence more queries if the client is after data for more than 30 days

My recommendation

I think it's a great idea and should definitely be considered, though applied as a result of a clear data policy (maybe even explicitly explained in the documentation) not just for performance reasons (those if encountered should be solved at the best of our abilities, not just "hidden" by limiting the date range)

Adding indexes to columns in where conditions

Most queries in the AnalyticsService work on created_at columns of the tables reactions, comments, page_views. The proposed solution is to add indexes on those columns to improve speed of retrieval for large data sets.

Pros

  • a request that asks for a large number of articles over a large interval of date should be aided by indexes

Cons

  • indexes can slow down writes for tables with a high frequency of writes
  • as it currently stands the code splits the queries over each day, the difference in most cases might not be noticeable

My recommendation

I think this is a quick win and should seriously be considered as a companion to any other solution. Where conditions on dates are a classic place where an index can benefit. Ideally one show open the SQL console and measure the before and after of the query with explain analyze but it's not mandatory. I also don't believe, AFAIK, there's going to be any impact on writes because what I perceive to be the biggest table among the three, reactions, doesn't get millions of INSERTs at a time. Anyhow that can be monitored with the slow query tab on Heroku in case the problem presents itself in the future.

Use grouping

The proposed solution is to let the DB group data and return aggregates instead of computing aggregates with following queries per each day in the range of dates.

Pros

  • the database is generally really good at mixing grouping and where conditions (provided there are indexes on the needed columns)
  • it would lower the amount of queries

Cons

  • it requires testing. Ideally one should write a test that populates the DB with a data sample over 2 or 3 days, write an assertion/expectation about the result, then go about improving the internals of the service to make sure the expected data matches the new structure of querying (usual testing, nothing to see here hehe)
  • it requires some trial and error and knowledge of PostgreSQL group by clause (the link points to a tutorial)

My recommendation

I'm obviously biased in favor of this (let the DB do its job as a mantra) if the expected result allow for it (I haven't looked deeply into it so it might not be feasible). Rails natively supports GROUP BY and HAVING (both clauses needed to grouping and filtering on groups) through ActiveRecord methods group and having. @lightalloy has mentioned the existence of the gem groupdate geared specifically at grouping by dates using an agnostic interface that works on all supported DBs, that could come in handy for this and future date based aggregations (though the syntax in vanilla Rails is pretty straightforward:

[7] pry(main)> PageView.where(created_at: 2.days.ago..Time.current).group("date(created_at)").sum(:counts_for_number_of_views)
   (0.8ms)  SELECT SUM("page_views"."counts_for_number_of_views") AS sum_counts_for_number_of_views, date(created_at) AS date_created_at FROM "page_views" WHERE "page_views"."created_at" BETWEEN $1 AND $2 GROUP BY date(created_at)  [["created_at", "2019-04-03 08:47:39.869415"], ["created_at", "2019-04-05 08:47:39.869509"]] [sql_query]
=> {Thu, 04 Apr 2019=>7}

you can verify how the query works correctly by a quick look at the data:

[8] pry(main)> PageView.all.pluck(:counts_for_number_of_views, :created_at)
   (0.5ms)  SELECT "page_views"."counts_for_number_of_views", "page_views"."created_at" FROM "page_views" [sql_query]
=> [[1, Thu, 04 Apr 2019 21:28:07 UTC +00:00],
 [1, Thu, 04 Apr 2019 21:28:56 UTC +00:00],
 [1, Thu, 04 Apr 2019 21:39:25 UTC +00:00],
 [1, Thu, 04 Apr 2019 22:39:33 UTC +00:00],
 [1, Thu, 04 Apr 2019 22:41:03 UTC +00:00],
 [1, Thu, 04 Apr 2019 22:43:49 UTC +00:00],
 [1, Thu, 04 Apr 2019 22:45:07 UTC +00:00]]

Pre-compute data using batching and compute the difference in real time

The proposed solution is to add an analytics table that contain aggregated data populated by a scheduled recurring job

Pros

  • this has the obvious pro of having near instantaneous read time. The client asks for a date range, a SELECT is issued to the aggregated table and the data is returned
  • it can lead to further optimizations down the line (if combined to caching or other changing business requirements I can't foresee right now)

Cons

  • it requires a bit of effort upfront
  • it requires a merge function (if the aggregated data is less than the required data) that still has to go to the live tables
  • it may require an eviction policy (how long are aggregates kept in storage?)
  • what happens to the old rows of aggregated data if there's a bug in the analytics function or if new metrics are added?

My recommendation

I'd consider this when the other options have been exhausted. If there's a massive amount of data continuously requested by HTTP clients and indexes and grouping are failing you, then a switch in the approach is a way to go. I'm always a big reluctant into going "batching first" because most of the times there are avenues to be exhausted before. Batching also requires some logic on merging, eviction and coping with stale data (or having to recompute older rows in the background)

Low level caching on results

The proposed solution is to guard one or each metric with a cache, so that an individual client requiring a specific range twice will have its data returned from memory the second time

Pros

  • as with batching the data can be returned quickly once the cache is primed
  • by knowing in advance one could pre-compute cached values for specific users/organizations that have particularly massive computations ahead of them
  • it shouldn't have a big impact on the memory occupied by the caching server

Cons

  • it's unlikely that an organization is going to ask for the same date range multiple times often, hence caching might defeat the purpose (organization usually write scheduled scripts that retrieve analytics and update internal dashboards :D)
  • caching individual dates would require too many trips to the caching server, and a SQL query might be faster in that case
  • as with batching (which is basically a cache written to disk), caches need to be handled in the sense that if tomorrow a new metric is added, there has to be a mechanism to re-populate older caches or at least empty all existing ones, this requires a bit of analysis

My recommendation

I'd go down this route after exhausting all "live optimizations" though it can be extremely beneficial for bigger organizations or extremely popular users or organization/users whose analytics are asked in a continuos manner though usually aggregated analytics are asked for once a day by each client so it's easy to plan the impact on the systems.

DEV-iOS

We haven't had any new issues or PRs merged lately. Feel free to check out the iOS repo, or download our iOS app on the App Store.

That's it for this week! Next week, I promise we'll be covering April 6 to April 12 and be on a regular weekly schedule. 🙇‍♂️

The DEV Team

The team behind this very platform. 😄

Discussion

markdown guide
 
 

Wow, lot of awesome new features. It's been a while since I've been on dev.to much, and I'm (happily) surprised how productive the team is. Nice work!

 

Thanks! This is a three week issue so there's a lot more than usual. We get a decent amount of features from contributors as well!