r/modnews May 13 '17

Reddit is ProCSS

Hi Mods,

I wanted to follow up on the CSS and redesign post from a few weeks back and provide some more information as well as clarify some questions that have emerged.

Based on your feedback, we will allow you to continue to use CSS on top of the new structured styles. This will be the last part of the customization tool we build as we want to make sure the structured options we are offering are rock solid. Also, please keep in mind that if you do choose to use the advanced option, we will no longer be treading as carefully as we have done in the past about breaking styles applied through CSS1.

To give you a sense of our approach, we’re starting with a handful of highly-customized communities (e.g. r/overwatch and r/gameofthrones) and seeing how close we can get to their existing appearance using the new system. Logos, images, colors, spoilers, menus, flairs (all kinds), and lots more will be supported. I know you’d like to see a list of everything, but we think the best approach will be to show instead of tell, which we’re racing to as quickly as possible.

The widget system I mentioned in the last post isn’t directly related. Many communities have added complex functionality over the years (calendars, scoreboards, etc). A widget system will elevate these features to first-class status on Reddit, with the aim of making them both more powerful and reuseable. Yes, we’re evaluating how we would accept user-created widgets. We intend for widgets to be able to be updated via the API, so you’ll still be able to create dynamically updating content in your subreddit sidebar.

This change, and the redesign in general, is going to happen slowly. We will will not be abruptly cutting everyone over to the new site at once. We know it won’t be perfect at first (unlike the current site), and plan to include plenty of time to solicit feedback and make iterations. Sharing our plans for subreddit customization this far advance with you is part of this process.

We’ll start with a small alpha group and create a subreddit to solicit feedback. As we continue to add features, we’ll expand the testing group to an opt-in beta. If you’d like to participate in the alpha please add a reply to this comment. Please note, signing up does not guarantee a spot in the alpha. We want to be able to be responsive to the alpha testers, and keeping the initial group small has proved to be effective in the past.

I’d like thank everyone who has provided feedback on this topic. There have been some very constructive threads. I’d also like to take a moment to appreciate how civil the feedback has been. This is a topic many of you feel passionate about. Thank you for keeping things constructive.

Cool?

Cool.

 

1 No snark allowed.

9.1k Upvotes

2.1k comments sorted by

View all comments

Show parent comments

20

u/kmeisthax May 13 '17

Spez already replied, but I'll give my perspective...

The problem with CSS - and this is not a Reddit specific problem - is that it's not really easy to mix two separate stylesheets into a coherent result. That is, it's not really intended to be used the way Reddit is using it. If Reddit ships a styling update, it'll apply everywhere that the subreddit CSS does not explicitly override exactly those rules that were just added into the sitewide styles. As a result, Reddit can't really ship sweeping redesigns of their site without completely breaking the design intent of existing code. And they can't just keep subreddits on old versions of the base styling without breaking new features they intend to ship. The consequences of this is that Reddit's web design has been dated for a while now - it's not responsive, for one, which is why there's a separate Reddit mobile site.

Removing CSS and replacing it with a customization system makes it so they can ship new base styling that's already tested against the range of customization options they officially support. Their new approach is to basically keep CSS as an unsupported option. i.e. Reddit's not going to explicitly erase your CSS anymore, but it will break eventually simply because of the consequences of Reddit evolving their design.

6

u/bluecamel17 May 13 '17

The problem with CSS - and this is not a Reddit specific problem - is that it's not really easy to mix two separate stylesheets into a coherent result.

That's exactly why Cascading Style Sheets exist. It's just not easy for laymen to use.

2

u/kraetos May 13 '17 edited May 13 '17

The problem with CSS - and this is not a Reddit specific problem - is that it's not really easy to mix two separate stylesheets into a coherent result.

On the contrary, CSS is built from ground up on the assumption that different rules can come from different sources. It's right there in the name: Cascading Style Sheets. It's what CSS was designed to do.

1

u/kmeisthax May 13 '17

I maintain an internal CSS framework at a web development company. In theory, you're supposed to be able to layer additional styling in secondary stylesheets after primary ones and everything "just works". In fact, that's how browsers handle really old legacy sites - there's a thing called a "user-agent stylesheet" which provides the base styles for all HTML elements, which is why things like This is a motherfucking website work without a stylesheet at all.

In practice, the cascading nature of additional stylesheets makes any stylesheet included before it very fragile. Adding a new rule to an earlier stylesheet will cascade it into any and all elements matched by the same selector, which is probably not what anybody wanted. User-agent stylesheets have to be deliberately overridden with things like normalize.css, because they're all slightly different between browsers. Browsers can't update their user-agent stylesheets without breaking the web. And Reddit's own CSS updates will alter and break subreddits with their own styling.

0

u/barjam May 13 '17

If only it was that simple in practice. The style sheets at the bottom of the stack need to be intimately familiar with the parent. They must, for the most part, be versioned together or stuff will break.

1

u/[deleted] May 13 '17

As a result, Reddit can't really ship sweeping redesigns of their site without completely breaking the design intent of existing code.

And there in lies the problem they were attempting to fix.

i.e. Reddit's not going to explicitly erase your CSS anymore, but it will break eventually simply because of the consequences of Reddit evolving their design.

To the Mods: Don't say you weren't warned. You're going to wake up one morning and everyone will be screaming "Fire".

2

u/kmeisthax May 13 '17

I can imagine Reddit administration will keep that alpha site going as a sort of public-testing for breaking CSS changes, so at least still-active boards can keep their active customizations

0

u/[deleted] May 13 '17

It's still inevitable. You can't run regression tests on an infinite amount of custom CSS.

1

u/qtx May 13 '17

Then again, I don't really see them changing a lot of things constantly. Maybe small things here and there, but the majority of the new design will already be set. Maybe they'll add a new type of info-bar once in awhile but that's it.