Bring Back Idiomatic Design

(essays.johnloeber.com)

162 points | by phil294 4 hours ago

27 comments

  • uhoh-itsmaciek 43 minutes ago
    In text boxes in some applications, enter submits the entered text, and ctrl-enter forces a newline (not at my computer, but I think Slack does this). In others, it's the other way around (pretty sure GitHub does this for comments).

    I don't know how we got here and I don't know how to fix it, but "bring back idiomatic design" doesn't help when we don't have enough idioms. I'm not even sure if those two behaviors are wrong to be inconsistent: you're probably more likely to want fancier formatting in a PR review comment than a chat message. But as a user, it's frustrating to have to keep track of which is which.

    • physicles 5 minutes ago
      In Slack it can get even worse.

      If you turn on Markdown formatting, shift+enter adds a new line, unless you’re in a multi-line code block started with three backticks, and then enter adds a new line and shift+enter sends the message.

      I can see why someone thought this was a good idea, but it’s just not.

    • rightofcourse 25 minutes ago
      For Slack at least you have the option to change that back to use Enter for new line (which is what I do), but other software is not that generous. I think Grafana introduced yet another way, Shift-Enter to submit, that I alway mix up.
    • Nemi 28 minutes ago
      Thats funny because I thought it was shift-enter that creates a newline in a field where an enter submits. Just shows the fractured nature of this whole thing.
      • lytedev 4 minutes ago
        This is my thinking. Ctrl-Enter is usually "submit the form this input is a part of" in my experience, especially if you're in a multilinear text input (or textarea).
    • carlosjobim 21 minutes ago
      Apart from a chat interface, when should enter ever submit your text?
      • binarymax 3 minutes ago
        In a multiline text box, enter should NOT submit the form. Chat interfaces violate this rule and it results in lots of premature chat submissions.
      • somehnguy 14 minutes ago
        A search box, I think
  • JojoFatsani 2 hours ago
    Most software is not designed by intelligent and thoughtful people anymore. It is designed by hastily promoted middle manager PM/Product type people who, as has been mentioned elsewhere, simply were not around when thoughtful human interface design was borderline mandatory for efficiency’s sake.

    There is incompetence and there is also malevolence in the encouragement of dark patterns by the revenue side of the business.

    • bfbf 58 minutes ago
      It’s amazing how many blank stares I get when I, as mobile engineer, tell stakeholders that we shouldn’t just implement some random interface idea they thought up in the shower and we instead need design input!

      “But why can’t you just do it?” Because I recognise the importance of consistent UX and an IA that can actually be followed.

      Just like developers, (proper) designers solve problems, an we need to stop asking them for faster bikes.

      • jstanley 11 minutes ago
        There's a time and a place for it. If you already know exactly what the program needs to do, then sure, design a user interface. If you are still exploring the design space then it's better to try things out as quickly as possible even if the ui is rough.
    • api 1 hour ago
      Software is now media, not tooling. Media tends to come with a lot of baked in perverse incentives.
    • polkapie 1 hour ago
      [flagged]
      • exe34 28 minutes ago
        Would it be better to bring this up in the retro? We're getting sidetracked here. We could set up a meeting with the stakeholders.
  • iamcalledrob 1 hour ago
    As the author identifies, the idioms come from the use of system frameworks that steer you towards idiomatic implementations.

    The system UI frameworks are tremendously detailed and handle so many corner cases you'd never think of. They allow you to graduate into being a power user over time.

    Windows has Win32, and it was easier to use its controls than rolling your own custom ones. (Shame they left the UI side of win32 to rot)

    macOS has AppKit, which enforces a ton. You can't change the height of a native button, for example.

    iOS has UIKit, similar deal.

    The web has nothing. You gotta roll your own, and it'll be half-baked at best. And since building for modern desktop platforms is horrible, the framework-less web is being used there too.

    • hn_throwaway_99 52 minutes ago
      The author may have identified that "the idioms come from the use of system frameworks", but they absolutely got wrong just about everything about why apps are not consistent on the web (e.g. I was baffled by their reasons listed in under "this lack of homogeneity is for two reasons" section).

      First, what he calls "the desktop era" wasn't so much a desktop era as a Windows era - Windows ran the vast majority of desktops (and furthermore, there were plenty of inconsistencies between Windows and Mac). So, as you point out regarding the Win32 API, developers had essentially one way to do things, or at least the far easiest way to do things. Developers weren't so much "following design idioms" as "doing what is easy to do on Windows".

      The web started out as a document sharing system, and it only gradually and organically turned over to an app system. There was simply no single default, "easiest" way to do things (and despite that, I remember when it seemed like the web converged all at once onto Bootstrap, because it became the easiest and most "standard" way to do things).

      In other words, I totally agree with you. You can have all the "standard idioms" that you want, but unless you have a single company providing and writing easy to use, default frameworks, you'll always have lots of different ways of doing things.

      • mike_hearn 10 minutes ago
        Well, and worse, Windows was itself a hive of inconsistency. The most obvious example of UI consistency failing as an idea was that Microsoft's own teams didn't care about it at all. People my age always have rose tinted glasses about this. Even the screenshot of Word the author chose is telling because Office rolled its own widget toolkit. No other Windows apps had menus that looked like that, with the stripe down the left hand side, or that kind of redundant menu-duplicating sidebar. They made many other apps that ignored or duplicated core UI paradigms too. Visual Studio, Encarta, Windows Media Player... the list went on and on.

        The Windows I remember was in some ways actually less consistent than what we have now. It was common for apps to be themeable, to use weirdly shaped windows, to have very different icon themes or button colors, etc. Every app developer wanted to have a strong brand, which meant not using the default UI choices. And Microsoft's UI guidelines weren't strong enough to generate consistency - even basic things like where the settings window could be found weren't consistent. Sometimes it was Edit > Preferences. Sometimes File > Settings. Sometimes zooming was under View, sometimes under Window.

        The big problem with the web and the newer web-derived mobile paradigms is the conflation between theme and widget library, under the name "design system". The native desktop era was relatively good at keeping these concepts separated but the web isn't, the result is a morass of very low effort and crappy widgets that often fail at the subtle details MS/Apple got right. And browsers can't help because every other year designers decide that the basic behaviors of e.g. text fields needs to change in ways that wouldn't be supported by the browser's own widgets.

      • namdnay 38 minutes ago
        Yeah the author conveniently ignores the fact that the UX of Mac apps was radically different to that of PC apps, so it’s not that designers/developers were somehow more enlightened back then, it’s just that they were “on rails”
      • skydhash 30 minutes ago
        > Developers weren't so much "following design idioms" as "doing what is easy to do on Windows".

        Most people only uses one computer. Inconsistency between platforms have no bearing on users. But inconsistency of applications on one platform is a nightmare for training. And accessibility suffers.

    • xg15 21 minutes ago
      > The web has nothing. You gotta roll your own, and it'll be half-baked at best. And since building for modern desktop platforms is horrible, the framework-less web is being used there too.

      This feels like the root cause to me as well. Or more specifically, the web does have idioms, the problem is that those idioms are still stuck in 1980 and assume the web is a collection of science papers with hyperlinks and the occasional image, data table and submittable form.

      This is where the "favourites" list and the ability to select any text on a web pages came from.

      Web apps not only have to build an application UI completely from scratch, they also have to do it on top of a document UI that "wants" to do something completely different.

      Modern browsers have toned down those idioms and essentially made it "easier to fight them", but didn't remove or improve them.

    • Klonoar 35 minutes ago
      > You can't change the height of a native button, for example.

      You can definitely do so, it's just not obvious or straightforward in many contexts.

    • skydhash 41 minutes ago
      The web was designed for interactive documents,not desktop applications. The layout engine was inspired by typesetting (floating, block) and lot of components only make sense for text (<i>, <span>, <strong>,...). There's also no allowance for dynamic data (virtualization of lists) and custom components (canvas and svgs are not great in that regard).

      > building for modern desktop platforms is horrible, the framework-less web is being used there too.

      I think it's more related to PM wanting to "brand" their product and developers optimizing things for themselves (in the short term), not for their users.

    • postepowanieadm 44 minutes ago
      Bootstrap was nice.
  • teeray 2 hours ago
    > There are hundreds of ways that different websites ask you to pick dates

    Ugh, date pickers. So many of these violently throw up when I try to do the obvious thing: type in the damn date. Instead they force me to click through their inane menu, as if the designer wanted to force me into a showcase of their work. Let your power users type. Just call your user’s attention back to the field if they accidentally typed 03/142/026.

    • el_benhameen 1 hour ago
      No no, I find that having to click back through almost 40 years’ worth of months to get to my birthday allows for a nice pause to consider the fleeting and ever-accelerating nature of life.
    • nkrisc 2 hours ago
      Is 03/04/2026 March 4th or the 3rd of April?

      If you have an international audience that’s going to mess someone up.

      Better yet require YYYY-MM-DD.

      • microsoftedging 5 minutes ago
      • RobotToaster 55 minutes ago
        <input type="date"> is automatically formatted based on the user's locale.
        • 8organicbits 29 minutes ago
          This is still a partial solution as the user needs to know that their locale is being used and know how their locale is configured to understand the format. This is most problematic on shared computers or kiosks, especially when traveling.
          • stephbook 8 minutes ago
            I don't even know my locale.

            Is is the device display language, the keyboard input language, my geo location, my browser language, my legal location, my browser-preferred website language, the language I set last time, the language of the domain (looking at amazon.co.uk), the language that was auto-selected last time for me on mobile or... something else entirely?

      • anamexis 1 hour ago
        Or:

        - Use localization context to show the right order for the user

        - Display context to the user that makes obvious what the order is

        - Show the month name during/immediately after input so the user can verify

      • andai 2 hours ago
        I've seen some that had a drop-down for the month name. But since it was native, I could type the month name and my browser selected the right one.
      • cush 1 hour ago
        This has a solved problem for a long time
    • kjkjadksj 10 minutes ago
      Most of these I just say I am 200 years old or so.
    • parpfish 1 hour ago
      I hate how scrolling through a list of years to enter my birthday forces me to confront my mortality
      • SoftTalker 1 hour ago
        I hate how websites that are trying to verify my age make me scroll through 13, 18, or 21 years that I could not legitmately select if I want to use the site.
  • pkphilip 2 hours ago
    UX has really gone downhill. This is particularly true of banking websites.

    Also, the trend of hiding scrollbars, huge wasted spaces, making buttons look really flat, confusing icons, confusing ways of using drop downs rather than using the select/option html controls etc have all made the whole experience far inferior to where desktop UI was even decades ago

  • raincole 10 minutes ago
    The real reason that apps used to feel homogeneous is simple. Because Windows used to dominate the whole market. The whole mindshare. For many people, learning to use computers was synonym of learning Windows and Office. My mom took a community college course for 'computer literacy' and it was literally just Word.

    Apps not born within Windows's realm were not homogeneous. Blender today is far more homogeneous with other apps than it used to be.

  • finghin 3 hours ago
    > Prefer words to icons. Use only icons that are universally understood.

    Underrated. Except for dyslexic people, and the most obvious icon forms, I am pretty sure most people are just better and faster at recognising single words at a glance than icons.

    • tgv 1 hour ago
      I am pretty sure icons are easier and faster to recognize, except when you make them (too) small. In particular, they probably are easier in the long run, as long as they don't change position. But in a context where things change or you need a lot of buttons, words probably win.
      • kevincox 45 minutes ago
        This is why you need both. Icons are faster to recognize, but words tell you what the icons need. So you need the words at first to discover the icons, then the icons serve as valuable tools for scanning and quickly locating the click target that you are looking for.
    • PhilipRoman 2 hours ago
      ...except for HN "unvote"/"undown" feedback which is especially unfortunate due to the shared prefix. Every time I upvote something I squint at the unvote/undown to make sure I didn't misclick.
  • zetanor 6 minutes ago
    Day-to-day usability doesn't bring much "wow" factor to a sales pitch.
  • jcoq 33 minutes ago
    Much of this is foisted upon us by visual designers who wandered into product design. It's a category error the profession has never quite corrected. (maybe more controversially, it's caused by having anyone with the word "designer" in their title on a project that doesn't need such a person - this category is larger than anyone thinks)
  • foobarbecue 3 hours ago
    Lately I've occasionally been running into round check boxes that look like radio buttons. Why????
    • LunicLynx 3 hours ago
      UX want to put their own spin on things. I’ve noticed this repeatedly.

      UX has gotten from something with a cause to being the cause for something

    • andai 2 hours ago
      I think the answer is they just don't know.
    • iamcalledrob 1 hour ago
      iOS decided square checkboxes were ugly, and design patterns are flowing from mobile->desktop these days.
    • aspensmonster 1 hour ago
  • pilingual 25 minutes ago
    Interesting that Apple is praised.

    > that a link? Maybe!

    When Apple transitioned from skeuomorphic to flat design this was a huge issue. It was difficult to determine what was a button on iOS and whether you tapped it (and the removal of loading gifs across platforms further aggravated problems like double submits).

    Another absurdity with iOS is the number of ways you can gesture. It started simply, now it is complex to the point where the OS can confuse one gesture for another.

  • alienbaby 1 hour ago
    designers are creatives and will always believe the visual elements of a design need to be updated, refreshed, modernized etc.. then we get flavour of the month nand new trends in visual language and ui design that things must be updated to.

    As soon as UI design became a creative visual thing rather than a functional thing , everything started to go crazy in UI land..

    • ako 26 minutes ago
      That is because they know the users. Users are very sensitive to this: if the outside wasn't changed then the internals cannot be much improved. You see this with cars, cars need a new design otherwise customer will think nothing much changed. Customer will usually buy newer over better because they think newer must have improvements, and styling signals new. Same with computers, all the disappointments when apple releases a new macbook without changing the exterior....
  • lxe 1 hour ago
    Yall remember https://en.wikipedia.org/wiki/Mystery_meat_navigation? Back in 2004-ish era, there was an explosion of very creative interaction methods due to flash and browser performance improvements, and general hardware improvements which led to "mystery meat navigation" and the community's pushback.

    Since then, the "idiomatic design" seems to have been completely lost.

    • the__alchemist 1 hour ago
      Is this what the hamburger button is made of?
  • kennywinker 1 hour ago
    > You don’t want to have to remember to use CTRL + Shift + C in certain circumstances or right-click → copy in others, that’d be annoying.

    laughs in linux wouldn’t that be nice.

    • ux266478 9 minutes ago
      Plan 9 fixes this.
    • davemp 52 minutes ago
      I’m a decade+ linux power user and I still do insane things like pipe outputs into vim so I can copy paste without having to remember tmux copy paste modes when I have vertical panes open.
    • skydhash 21 minutes ago
      Terminal UX existed before the CUA guidelines from IBM. People complains about Ctrl + Shift + C behavior when it exists only in one category of application, terminal emulators.
  • chapz 1 hour ago
    This kinda hurt. The world is in a rush to be the ASAP, so nobodys interest is to do design good, it needs to be fast. And now we have this sh*tshow.
  • xnx 2 hours ago
    My hope is that since tools like Google Stitch have made fancy looking design free that it will become obvious how functionally worthless fancy looking design always was. It used to signal that a site paid a lot of money and was therefore legitimate. Now it signals nothing.
    • jonahx 2 hours ago
      This is a good point, but there's usually a long tail on transitions like this.
  • brycewray 10 minutes ago
    (2023)
  • andyfilms1 2 hours ago
    And while we're at it, stop with the popups and notifications.

    I don't care about the new features in a browser update. Ideally, nothing at all has changed.

    I don't want a "tour" of the software I just installed. I, presumably, installed it to do something, and I just want to do that thing.

    I don't want to have to select a preference for how a specific action is performed in your software. If it's not what I expected, I will learn it.

    And for the love of GOD, nobody wants to subscribe to your newsletter.

  • sph 30 minutes ago
    Shows a picture of Office 2000 and says "The visuals feel a little ugly and dated: it’s blocky, the font isn’t great, and the colors are dull."

    Are you serious? Nothing has come close to it. Yeah we have higher resolution screens, but everything else is much less legible and accessible than that screenshot.

  • satvikpendem 2 hours ago
    Not sure how you can put the genie back in the bottle, every app wants to have its own design so how can you enforce them to all obey the same design principles? You simply can't.
  • mcculley 2 hours ago
    The web needs a HIG.

    All of these people who keep saying that webapps can replace desktop applications were simply never desktop power users. They don’t know what they don’t know.

  • readitalready 1 hour ago
    This is a really huge and a fundamental flaw in AI-driven design. AI-driven design is completely inconsistent. If you re-ran an AI generated layout, even with the same prompt, the output for a user interface will look completely different between two runs.
    • ceejayoz 1 hour ago
      You can steer it towards reusable components, though.

      Find a run you like, and build off that.

  • allthetime 1 hour ago
    Apple was doing a pretty good job until whatever happened with v 26.

    On the web, the rise of component libraries and consistent theming is promising.

    • SoftTalker 1 hour ago
      They were not. Their own apps on iOS are wildly inconsistent.
  • ufocia 2 hours ago
    UIs are inconsistent even in the same app. Nevermind plugins or suites. It would be great if menus were customizable so you could plug in your own template.
    • jfengel 2 hours ago
      I prefer to avoid customizing apps. I want to be able to sit down at a fresh install (or someone else's) and not spend time learning their preferences.

      When someone asks me for a checkbox so they can have my app work their way instead and everyone else can do theirs, the hair stands up on the back of my neck. The check boxes are hard to discover unless you put them front and center, in which case they remain there forever serving no purpose.

      I would rather redesign the entire interface, either to find the right answer that works for everyone, or to learn what makes one class of users different from another. The check box is a mode, and nodes are to be avoided if I possibly can.

      I realize that this puts me at odds with a whole class of users who want to make their box do their thing. It's your box and you should do what you want. And I really love style sheets for that. Rather than cobbling together my own set of possible preferences you should have something Turing complete. Go nuts with it.

      • carlosjobim 1 hour ago
        I think most non-Linux users haven't made a fresh install in 5-10 years. Preferences files and apps get transferred when you buy a new computer or update your os.
        • jfengel 45 minutes ago
          I was pleased how much was passed over from my last phone. I got the same brand so it's not surprising, but wow it is so much better than The Good Old Days (tm).
          • kjkjadksj 4 minutes ago
            I remember the old days being surprisingly smooth. There was some verizon tool that transferred all my contacts from the dumb phone to my first smart phone.
  • amakhov 3 hours ago
    ... and please stop doing paralax...
    • dxdm 2 hours ago
      Such a nice way to give more depth to your content. </s>
  • DoneWithAllThat 1 hour ago
    Idiomatic design will never come back. The reason being companies believe (correctly) that they design language is part of their brand. The uniqueness is, basically, the point.
    • strongpigeon 39 minutes ago
      That was one of the problem with the original Material framework: every app looked too similar making it hard to distinguish one from another. Google was concerned about people associating bad third party app with itself.

      They added more customizability in Material 2 (or was it 3?), but yeah at that point some of the damage was done.

  • hungryhobbit 1 hour ago
    "Avoid JavaScript reimplementations of HTML basics, e.g. React Button components instead of styled <button> elements."

    Tell me you know nothing about web development without saying you know nothing about web dev ...

    1. React is an irrelevant implementation detail. You can have a plain HTML button in a button component, or you can have an image or whatever else. React has nothing to do with the design choices.

    2. React is also how you get consistent design across a major web app. Can you imagine if every button on every site was the same Windows button gray color, regardless of the site's color? It'd be awful! React components (with CSS classes) are a way for a site like Amazon to make all their buttons orange (although I don't actually know if Amazon uses React specifically). But again, whether they look and act like standard buttons comes down to Amazon's design choices ... not whether their tech stack includes React or not.

    Look idiomatic design is incredibly important to web design. One of the most popular web design/usability books, Don't Make Me Think, is all about idiomatic design!

    But ultimately it's a design choice, which has very little, if anything at all, to do with which development tools you use.

    • davemp 35 minutes ago
      > Tell me you know nothing about web development without saying you know nothing about web dev

      This Twitterism really bugs me.

      You took the time to write a really detailed response (much appreciated, you convinced me). There’s no need to explicitly dunk on the OP. Though if you really want to be a little mean (a little bit is fair imo), I think it should be closer to level of creativity of the rest of your comment. Call them ignorant and say you can’t take them seriously or something. The twitterism wouldn’t really stand on its own as a comment.

      Sorry for the nitpicky rant.

    • 201984 1 hour ago
      > Can you imagine if every button on every site was the same Windows button gray color, regardless of the site's color?

      Not a webdev, but can't you just use CSS on the <button> element for that?

      • hungryhobbit 1 hour ago
        Yes you can, on a small/simple site. But on a serious web application sticking to plain HTML/CSS will be far too limiting, in many ways.

        There's a reason why 99.9% of web apps use JavaScript, and with it a tool (framework) like React, Astro, Angular, or Vue. And if you're using such tools, you use them (eg. you use React "components") to create a consistent UI across the site.

        But again, which tool you use to develop a site has very little to do with what design choices you make. A React dev with no designer to guide him might pick the most popular date picker component for React, and have the React community influence design that way, but ... A) if everyone picks the most popular tool, it becomes more idiomatic (it's not doing this that creates divergence), and B) if there is a human designer, they can pick from 20+ date picker libraries AND they can ask the dev team to further customize them.

        It's designers (or developers playing at being designers) that result in wacky new UI that's not idiomatic. It has (almost) nothing to do with React and that layer of tooling, and if anything those tools lead to more idiomatic design.