Warm boots and cold feet
This is going to be a funny one, in some ways. It was for me.
Perfect for moving fast without breaking stuff.
This is going to be a funny one, in some ways. It was for me.
Every few years, I buy a new phone. I am typically an iPhone user, so last year I bought the 16 Pro Max. Overall, great experience, but I also bumped into a few unforseen issues.
A recent study from MIT concluded that despite enterprises pouring $30-40 into generative AI initiatives, 95% of these projects yield no measurable impact. Adoption is widespread—many organizations are experimenting with AI tools—but only about 5 % of pilots reach production with meaningful results.
In this insightful article by Remy Sharp, a web professional since 1999, he explores the various factors that contribute to good and bad web design, drawing from his extensive experience attending design, user experience, and developer conferences for over 15 years.
This article discusses how AI, while capable of handling basic tasks, cannot replace skilled professionals who focus on quality, craftsmanship, and meaningful experiences. It emphasizes that AI is better suited as a tool to augment skilled workers rather than replace them, particularly in areas requiring expertise, creativity, and human understanding.
In his 1983 talk at the International Design Conference in Aspen, Steve Jobs articulated a powerful vision for the future of personal computing. He saw the computer not just as a tool, but as a new medium of communication, on par with the book, the telephone, and the television. Just as each of these mediums had shaped the way we communicate, Jobs believed that the personal computer would profoundly transform our lives.
I have found this guide of productivity again: Pmarca Guide to Personal Productivity so I wanted to write down my version of it.
I have been shiping most of my Go apps with Kamal for a while now. I am sharing the main config files I am using, with two different apps: this blog and a object storage service.
The paper, mentioned in the title, addresses the inherent challenges of the widely adopted microservices architecture in cloud computing, including performance bottlenecks, versioning issues, and increased complexity in application management. While microservices offer scalability, fault tolerance, and agile deployment, they also introduce significant overheads, making applications difficult to manage, reason about, and evolve.
I have been using web components instead of other libraries and their components for about an year now. They have a few key features, like built-in hydration, use of Shadow DOM or not, depending on your preference, that are indispensable in the UIs that I build.>
I found a post today that shows in detail what their potential is and how exactly they are being used to build an actual product.
Even though it's only January, this year has already been very interesting for me. And since most of these interesting things are products on the web, and me being unhappy with design tooling for web products, I decided to build something different, something that fills in my needs primarily, but perhaps is able to help others as well.
Still in very early stage, today I am putting it partially out there for interested folks to provide feedback or even subscribe to progress notifications.
But first, let me tell you what it is.>
Let’s add a different color to the styles of external links, regardless if they open in a new tab or not:
a[href^="http"]::after {
  color: var(--color-secondary-1);
}I have a bold claim: there is a responsive CSS Grid / Flexbox combo layout that can be used to build almost any web layout. At least I haven’t found any layout I wanted to build and couldn’t.
Ahmad did two great reviews of the Threads app. Quite a few interesting CSS or unusual CSS technniques there.
Client component hydration has been a trendy topic these days. Some frameworks like Next, Astro and others are already doing it.
It is not common knowledge that we can achieve a very similar result with pure SSR and declarative shadow DOM.
All typefaces have been instructed to display their ligatures, by default, like this:
body {
  font-variant-ligatures: normal;
  font-feature-settings: "liga" 1, "dlig" 1, "hlig" 1, "clig" 1, "calt" 1;
}On occasion we need to present a summary of content while allowing the user to deep dive if they want to. The details element is a great way to do this, with good browser support as well. Let's see how.
Many times we need to show a modal to the user, to ask for confirmation, or to show some additional information in a manner which covers the rest of the page user interface. The dialog element is a great way to do this, and it is supported by all major browsers.
a hover statesAll a elements on this page have a customised hover effect. Here's how to achive that:
a:hover {
  text-decoration: underline;
  text-decoration-thickness: .1em;
  text-underline-offset: .15em;
  text-decoration-color: var(--color-secondary-1);
}Implementing a consistent brand across various devices and channels has never been easy. The diversity of connected devices and their screen sizes is also not helping simplify the process.
Let's take a stab at how we could improve this.
Previously I shared a very basic example of Go routing. Let's see how we can improve that a little.
The last several years of web development have been going into a direction of needlessly over-engineering even simplest tasks.
Maybe it's time to get back to the basics, to use simple solutions for simple tasks. Let's touch on how I think we should be approaching initial web product development.
In my first not post I mentioned and example of something I find quite interesting in the recent CSS features,that is the has() selector. And while I was preparing to write something about it, which I mightstill do, here's a great article on Smashing Magazine written by Stephanie Eckles about this exact topic.
I have recently been reading a lot given that I had a lot of time on my hands. Many of my readings have been about my work, what I'm passionate about in my work — how to build amazing experiences on the web and native platforms.
So I have quickly put together this not blog to share not posts here. Read along if you're curious what this crazy idea is about.