sm

Tagged "Articles"

  1. in Articles
    Defaults 2026
    A list of the default apps that I use in 2026
  2. in Articles
    AI use case: Asking questions of large files
    When file search isn't enough to surface answers, using an LLM to ask questions of large files is a valuable use case for AI.
  3. in Articles
    Install curl with apt (and not snap)
    When trying to install Node, I encountered an issue that was resolved by installed curl with apt.
  4. in Articles
    Four perspectives on AI
    I respond to Maxi Ferreira's thesis on the two stages of AI adoption among developers with a four-quadrant model based on an individual's beliefs about AI. These gives us four perspectives: Skeptical, Wary, Pragmatic, and Optimistic.
  5. in Articles
    Axe DevTools doesn't flag multiple h1 elements on a page
    Rendering multiple h1 elements on a page isn't technically an issue, but you probably want to avoid it anyway. Here I explain how to configure a snippet in your browser to check the heading levels on a webpage.
  6. in Articles
    Writing code was never the bottleneck in software engineering
    In "Writing Code Was Never the Bottleneck", Pedro Tavares challenges a common assumption in the LLM age. I agree and add some thoughts based on my experience in software-development environments.
  7. in Articles
    Colocate functionally-related code
    My preference is to colocate code based on functional relation–what it does–and not domain relation–what it is.
  8. in Articles
    My on-again-off-again relationship with AI assistants
  9. in Articles
    Zed still isn't ready
    Zed is a nice light-weight editor, but the slow searching and memory issues make it a non-option for my work.
  10. in Articles
    Deleting my GPTs
    GPTs provided little value to me now, little potential value in the future, and were the only thing locking me in my Open AI subscription.
  11. in Articles
    Pittsburgh TechFest 2024
    Pittsburgh TechFest 2024 was a good experience and valuable opportunity to connect with the local tech scene
  12. in Articles
    Bypass "Error: There are no prompts" in promptfoo
    Adding a space to the end of the prompt text appears to be a workaround for this error
  13. in Articles
    Use state callbacks in React
    When you need to reference the previous state, pass a callback function to React's setState.
  14. in Articles
    VIVO sit/stand desk
    Issues and solutions for my VIVO sit/stand desk
  15. in Articles
    Simplify event delegation with the Element.closest method
    Event delegation is a useful pattern for managing descendant interactions and Element.closest helps with simple and robust code
  16. in Articles
    Align content in Markdown tables
    You can use colons in the header row separator to align content in a Markdown table
  17. in Articles
    CSS nesting is (almost) ready
    It's not quite ready for production use, but we are very close to getting native CSS nesting
  18. in Articles
    Looking over the fence at Eleventy
    Eleventy is looking better and better as an alternative to Astro for simple or long-lived websites
  19. in Articles
    Getting started with Eleventy
    The missing getting-started guide for the Eleventy (11ty) static-site generator.
  20. in Articles
    ChatGPT 4o isn't a good researcher yet
    When asked, ChatGPT provides sources but they don't contain the information provided
  21. in Articles
    Astro and release velocity
    Astro is a great framework, but it's frequent updates are overwhelming
  22. in Articles
    Render and effect call order in React
    Renders are called top-down, but effects are called bottom-up.
  23. in Articles
    Manage your photo archive
    Take a minute to review all photos from today's date and delete the ones you don't need
  24. in Articles
    Measuring and cutting
    Measuring twice, cut once is good advice for woodworking but maybe not for software engineering
  25. in Articles
    Create a custom search for a static site
    A high-level overview of why and how I built a URL-powered fuzzy search feature for this site
  26. in Articles
    Fix missing Astro files on GitHub pages
    Astro generated CSS files start with an underscore which causes them to be ignored by GitHub Pages
  27. in Articles
    Create a useIsOnline React hook
    Using the Navigator's onLine property and online/offline events to create a custom React hook
  28. in Articles
    Fix static file endpoints after Astro v4 upgrade
    I needed to change the name of the exported function and make sure that it was returning a Response or Promise.
  29. in Articles
    Why Microsoft Edge?
    Edge has all of the features of Chrome with some additional features
  30. in Articles
    Switching from Ubuntu to Linux Mint
    I switched for performance reasons on an older device, and so far Linux Mint seems to be an improvement
  31. in Articles
    Running Ollama without a GPU
    You can run Ollama on an older device, but the response will be slow and/or low quality.
  32. in Articles
    Use Ollama with the official Python library
    Get started working with AI, Ollama, and large-language models in four steps
  33. in Articles
    Get started prompt engineering with local LLMs
    Ollama makes it easy to run LLMs locally and provides experimental compatibility with OpenAI's APIs
  34. in Articles
    Python Reference
    A quick reference guide for working in Python
  35. in Articles
    Did OpenAI's Web Browser GPT leak its prompt?
    When given a simple prompt, OpenAI's Web Browser GPT seems to leak its prompt.
  36. in Articles
    Migrating from Google Domains to Porkbun was...
    I was able to transfer two domains from Google to Porkbun without any issues or downtime
  37. in Articles
    Normalizing data is a good idea
    By transforming your data into a consistent structure, you can reduce the complexity of your code
  38. in Articles
    How I'm using AI in November 2023
    Chat GPT and Khanmigo join Copilot in the regular category this month
  39. in Articles
    Sli.dev review
    A great tool that gets out of the way when creating slides
  40. in Articles
    Is it better to have one large file or multiple small files with GPTs?
    Using a single file seems to reduce response times, but there is more to the story
  41. in Articles
    What is the file limit for GTPs?
    As of November 15, 2023, the limit is 10 files.
  42. in Articles
    How I'm using AI in October 2023
    GitHub Copilot is still the most popular, but I found myself using ChatGPT more frequently in October.
  43. in Articles
    GPTs read text files better than markdown
    Use text files instead of markdown with OpenAI’s custom GPTs
  44. in Articles
    Thoughts on Web Speech API
    Browser native text-to-speech is neat, but it lacks the polish that most users expect
  45. in Articles
    Declarative code and cognitive load
    Maxi Ferreira in Frontend At Scale on how declarative code can reduce cognitive load.
  46. in Articles
    Attempting #divtober 2023
    #divtober seems like a fun alternative to Hacktoberfest for October
  47. in Articles
    How I'm using AI in August & September 2023
    GitHub Copilot and Warp are the only two AI-powered products that I used in August and September, with Copilot being by far the most valuable
  48. in Articles
    See what object properties are accessed in JavaScript
    JavaScript's Proxy object can be used to watch an object and respond whenever any of its properties are accessed or reassigned
  49. in Articles
    Remove duplicates from an array in JavaScript
    Using sets to de-dupe arrays of primitive and object-like values
  50. in Articles
    How I'm using AI in July 2023
    Some more competitors are entering the ring, but GitHub Copilot remains the only AI-powered product that I use regularly
  51. in Articles
    Timeboxing types
    In order to maximize the value of types and your time, consider timeboxing the amount of time that you spend writing any given type
  52. in Articles
    CSS columns are neat
    The columns property is CSS divides content among a set number or width of columns
  53. in Articles
    Quality requires iteration
    You're not going to write the perfect program on your first attempt; it's going to take multiple iterations to arrive at the best solution
  54. in Articles
    A workable emoji picker on Ubuntu
    The default GNOME emoji picker is limited to certain applications, but you can find copyable emojis in the Activities view
  55. in Articles
    Writing Prompts for Programmers
    A list of software-engineering focused writing prompts to help programmers get started writing
  56. in Articles
    Reviewing "Go By Example"
    Go By Example is a great resource for learning the syntax and patterns of Go, but you might need to supplement it with other resources to learn how to work in the language
  57. in Articles
    How I'm Using AI in June 2023
    GitHub Copilot has pulled away from the rest as the only AI product/service that I use regularly
  58. in Articles
    A quick comparison of JavaScript and Go executables
    Go is the superior for executables based file size and execution time, but Bun and Deno offer a competitive option for developers familiar with the JavaScript ecosystem
  59. in Articles
    Compairing Objects, Maps, and WeakMaps for lookup tables in JavaScript
    You could use an Object, but Maps are probably best for lookup tables and WeakMaps are useful for memory performance
  60. in Articles
    Web-browser Accessibility Tools
    Chrome, Edge, Firefox, and Safari all have built-in accessibility tools to help you create accessible experiences for all
  61. in Articles
    Linux Update in 2023
    After experimenting with Linux last year, I am happily using Ubuntu on a Lenovo Yoga as my personal computer
  62. in Articles
    How I'm using AI in May 2023
    GitHub Copilot is the top product this month, but Bard, Bing, ChatGPT, and Warp all have their uses
  63. in Articles
    Declaring variables in Go
    You can declare variables with var, :=, and const depending on your use case
  64. in Articles
    What is nullish in JavaScript?
    Nullish values are null and undefined, and it's important to thing of them separately from falsy values
  65. in Articles
    QA questions for everyone to ask
    Everyone on the product team should ask verifying, discovery, and critical questions to ensure quality
  66. in Articles
    Learning Go
    Learning the Go programming language for professionanl development has been an enjoyable experience
  67. in Articles
    Set up Decap CMS
    Decap CMS is the official successor to Netlify CMS and works well with the old tooling.
  68. in Articles
    Zed is a rocket-powered skateboard
    Zed is a new Rust-powered editor by the creator of Atom that focuses on speed but lacks a lot of features
  69. in Articles
    Fix failed Fastify deploy on Render
    To get a boilerplate Fastify app to deploy on Render.com, you need to read to listen on PORT environment variable
  70. in Articles
    Find and replace with Regex groups
    Create Regex groups with parentheses for powerful find/replace patterns
  71. in Articles
    Fix SVG CSS animation issue in Safari
    Safari 16 has trouble with CSS animations on SVG child elements, but you can resolve them by using a combined transform property.
  72. in Articles
    Listen for class change in JavaScript
    There isn’t an event for class list changes, but you can write a function that listens for class changes on an element with the MutationObserver API
  73. in Articles
    Create Axios-style articles with CSS
    We can use inline blocks to bring subheadings on the same line as the following text while preserving the visual spacing
  74. in Articles
    CSS :empty pseudo class
    Empty elements in a flex or grid container can result in double gaps, but CSS has an pseudo class to select and remove those elements
  75. in Articles
    Fix trailing whitespace in Astro components
    There is an issue with the Astro compiler that leaves unwanted whitespace in your elements, and this workaround will solve the problem until it's resolved
  76. in Articles
    Farewell Create React App
    The React team is looking to transition Create React App from a project scaffold to a launcher that includes options other than client-side rendering
  77. in Articles
    Valid JavaScript variable names
    Mathias Bynen has a handy tool for determining what characters are allowed in a JS variable name
  78. in Articles
    Migrating to IndieWeb.social
    A little write-up about my migration from Fosstodon to IndieWeb.social
  79. in Articles
    Publishing a Qwik component
    The Qwik team has made creating and publish Qwik components a smooth and painless process.
  80. in Articles
    Fix Astro dev server hanging with new collections API
    The issue for me was calling useCollection on an entry with a layout.
  81. in Articles
    Be careful parsing formatted numbers in JavaScript
    JavaScript's parseInt, parseFloat, and Number constructors struggle with comma-separated number strings.
  82. in Articles
    New command palette
    I added a new new command/control K command palette to my site. You can use the keyboard shortcut or activate it by clicking the magnifying glass in the header.
  83. in Articles
    Fix "package esbuild-linux-64 could not be found" error on Netlify
    I don't know how applicable this solution will be to your situation, but it worked for me!
  84. in Articles
    Portable custom search engines
    Custom search engines (sometimes called site search) are a great browser feature, but they aren't easily ported from one browser to the next. I created a portable web app to handle your custom search engines from any browser.
  85. in Articles
    A first look at Static CMS with Astro
    Documenting my first attempt at switching from Netlify CMS to Static CMS
  86. in Articles
    Astro components do not merge HTML attributes
    Props are merged, but attributes are not. This is an important rule to know when authoring Astro components.
  87. in Articles
    Run Netlify CMS and your dev server in one command
    The npm-run-all package allows you to run multiple scripts from your package.json in parallel
  88. in Articles
    Fix Netlify Dev's 'Multiple possible start commands found' issue
    You need to include additional properties in your netlify.toml to get it working correctly.
  89. in Articles
    Astro components for Netlify features
    Announcing astro-netlify-components, a library for using Netlify features in your Astro projects.
  90. in Articles
    Create a "Dave Rupert"-inspired activity graph
    A little code walk through a the new Activity Graph on my homepage.
  91. in Articles
    Use your domain on Mastodon with Astro
    A quick guide on using an Astro endpoint to generate the webfinger you need to use your domain on Mastodon.
  92. in Articles
    Are command bars the future?
    Command bars are a great way to access functionality through a single user interface, but how much potential does this pattern have to change the way we interact with products?
  93. in Articles
    Node.js is great for scripting
    Node.js and JavaScript are a great option for scripting for the language features and the large ecosystem. Oh, and it's pretty fast too!
  94. in Articles
    There is no multi-tasking on the Raspberry Pi
    Detailing some of the struggles that I've encountered while trying to do front-end development on a Raspberry Pi.
  95. in Articles
    Finding a Linux distro and software that work
    After a lot of trial an error, I settled on Raspberry Pi OS and Firefox for my little Linux-powered computer.
  96. in Articles
    Giving Linux another try
    It's been about 10 years since I last tried using Linux, so I think it's time to explore what it has to offer in 2022.
  97. in Articles
    Awesome browser extensions
    A curated list of helpful browser extensions.
  98. in Articles
    Using dynamic routes to organize blog posts in Astro
    If you want to display multiple blog posts on a single page, then you might want to use a dynamic route to generate pages for your content.
  99. in Articles
    Jest
    A growing list of little things that make working with Jest a little better
  100. in Articles
    How to use StackBlitz with Firefox
    Disable enhanced tracking protections to use StackBlitz with Firefox
  101. in Articles
    How to replace Math.random with crypto in JavaScript
    A drop-in replacement for Math.random that generates cryptographically strong random values
  102. in Articles
    Use multiple Chrome Profiles when debugging
    With specialized profiles, you can help identify issues without messing with your favorite settings.
  103. in Articles
    When to use React's memo HOC
    The memo higher-order component can prevent your component for re-rendering unnecessarily, but you should use caution before using it
  104. in Articles
    Calculate the sum of everything up to a given number
    A little tool to calculate 5 + 4 + 3 + 2 + 1
  105. in Articles
    English words by consonant-vowel pattern
    A tool to look up common words by their consonant-vowel pattern and resources for the rest
  106. in Articles
    Add a custom emulated device in Chrome
    Walking through the steps within the Google Chrome dev tools to better mimic your users' devices.
  107. in Articles
    Upgrading an Eleventy site to 1.0.0
    Make sure the you are using Node.js version 12 or later
  108. in Articles
    Make a web component
    How to make a custom web component with only a few lines of code
  109. in Articles
    Prevent Chrome from adjusting audio input levels on Mac
    A clever extension can prevent Google Meet from muting your bluetooth microphone
  110. in Articles
    Helpful online tools for diagramming
    Features and examples for some of the tools that I use to create illustrations and diagrams
  111. in Articles
    What is a build.gradle file?
    An brief explanation of Gradle and build.gradle files for JavaScript developers
  112. in Articles
    Three new games on Toollama
    Turtle Guide, Paint Pig, and Spotlight all help children build computer literacy
  113. in Articles
    React Native Glossary
    A growing list of terms you need to recognize when working in React Native
  114. in Articles
    What happened to @react-native-community packages?
    Why you won't be installing any community packages on your next React Native project
  115. in Articles
    Find an iOS simulator identifier
    How to find a simulator ID using the Xcode UI or terminal
  116. in Articles
    Using BEM names in React Native
    A quick how-to without committing to whether it's a good idea or not
  117. in Articles
    What is Hermes in React Native?
    Hermes is a JavaScript engine that is designed to run on mobile devices. It helps power React Native on Android – and now iOS – devices.
  118. in Articles
    Add a YouTube-embedder shortcode to your Eleventy site
    A quick guide to writing a time-saving shortcode to create the embeddable code from a YouTube url
  119. in Articles
    Get innerHTML of Enzyme wrapper
    Writing a little helper function to grab the HTML of all children of a shallow wrapper in Enzyme
  120. in Articles
    Use remark to covert markdown into HTML
    The missing "hello world" example to get up and running with remark
  121. in Articles
    Count class methods in JavaScript
    Although JS treats them like object, finding the methods of a class programmatically is trickier than I thought.
  122. in Articles
    Git
    A practical resource for Git
  123. in Articles
    Read URL search parameters with JavaScript
    How to use URLSearchParams to parse any search parameters string like window.location.search
  124. in Articles
    Fix 'downloadable font: rejected by sanitizer' error in Firefox
    Make sure that the path to your font is correct before going down the debugging rabbit hole.
  125. in Articles
    Fix Netlify CMS YAML error 'Implicit map keys need to be on a single line'
    Make sure that your configuration file is being copied to the destination directory.
  126. in Articles
    Copy the last git commit hash on macOS
    A one liner to copy the last commit hash to the clipboard on a Mac
  127. in Articles
    Add Heroicons to an Eleventy site
    A guide to using the eleventy-plugin-heroicons package in your Eleventy projects
  128. in Articles
    Create a URL shortener with Netlify
    Build your very own shortener in six quick steps
  129. in Articles
    Set innerHTML of an element in Svelte
    You can use an HTML expression to add valid markup to an element
  130. in Articles
    Let's stop skinning cats
    Proposing an alternative, more constructive idiom to "there's more than one way to skin a cat"
  131. in Articles
    Search all files for two strings
    A terminal command to search for all the files in the current directory that contain two independent strings.
  132. in Articles
    Fix "Error: Could not resolve pagination key in template data" in Eleventy
    Not a true fix, but a decent workaround when paginating collections in Eleventy
  133. in Articles
    Geddes' Guide to Crafting
    When building something new, get your foundation in place before building upon it.
  134. in Articles
    Send data to the window with Eleventy
    How to create a shortcode to expose data for client-side scripts
  135. in Articles
    Checkout the previous git branch
    Using a git shorthand to checkout the most recent branch
  136. in Articles
    Make all properties required in TypeScript
    Using the Required utility type to required all properties of a type
  137. in Articles
    Add text to the beginning of every file
    Using a shell script to add a line to every file with a given extension
  138. in Articles
    Sass converts hsla to hex incorrectly
    A simple solution to stop Sass from transparent hsla colors to opaque hex colors.
  139. in Articles
    Increase the playback speed on any audio or video online
    Since audio and video are native HTML elements, you can change the playing speed with a quick console script
  140. in Articles
    Standardize character width with CSS
    Two CSS properties that make letters and numbers the same width.
  141. in Articles
    See all package versions in npm cli
    How to use npm view to see all the published versions of a package on the registry.
  142. in Articles
    TypeScript without TypeScript
    TypeScript provides valuable features but complicate the development process. What are some alternatives that provide the features without the headache?
  143. in Articles
    Emulate iPhone & iPad in Safari
    Simulating your web pages on Apple devices is easy with Safari's responsive design mode
  144. in Articles
    Make a POST request with fetch
    A sample POST with fetch for those of us who can never remember how.
  145. in Articles
    Remove an item at a given index in JavaScript
    Sidestep slicing and splicing and use Array's filter method for a no-hassle solution.
  146. in Articles
    Tab focus not working in Safari?
    For some unknown reason, you need to enable tab highlighting in the browser's settings.
  147. in Articles
    Fix 'EMFILE: too many open files' error in Jest
    When trying to run Jest in watch mode, this error may mean that you are missing a dependency.
  148. in Articles
    Updated TypeScript mega-course on Egghead.io
    Reviewing and updating my TypeScript mega-course on Egghead.io
  149. in Articles
    Access the home directory in Deno
    Using Deno's environment to determine your computer's home directory
  150. in Articles
    Before You Debug
    An organized approach to debugging your code
  151. in Articles
    Before Debugging
    An organized approach to debugging your code
  152. in Articles
    Nodemon for Deno
    Denon is a utility for Deno that provides source watching and process restarting just like Nodemon
  153. in Articles
    Parse argument aliases in Deno
    Using Deno's standard flags module to parse command-line arguments with aliases
  154. in Articles
    Await multiple promises in JavaScript
    By calling your asynchronous functions before awaiting, you can save valuable time in your JavaScript programs
  155. in Articles
    TypeScript mega-course on Egghead.io
    Creating a playlist to learn TypeScript
  156. in Articles
    Six video update
    Lessons learned from publishing six videos on YouTube
  157. in Articles
    Read a json file in Deno
    How to use Deno's standard library to read and parse data from a json file.
  158. in Articles
    Read a json file in Node.js
    How to use Node.js's file system to read and parse data from a json file.
  159. in Articles
    Publishing my first YouTube video
    Why I started a YouTube channel and what I learned in the process
  160. in Articles
    How to get the browser and version in JavaScript
    A brief journey into the dangerous world of user agent sniffing
  161. in Articles
    Logging with Eleventy and Nunjucks
    Adding a simple filter to save you a lot of grief.
  162. in Articles
    Store readable data
    When forced between storing data for humans or computers, choose the former.
  163. in Articles
    How to open the Dev Tools
    A comprehensive guide for opening the dev tools in Chrome and Firefox
  164. in Articles
    Tools for custom Slack emojis
    The full toolbelt for making your own custom Slack emojis
  165. in Articles
    Programming reads
    A list of articles, books, and resources for software engineers
  166. in Articles
    Free to grow
    Why tests (should) free you to grow with confidence
  167. in Articles
    How to check npm scripts in current directory
    Writing a script to read the package.json for you
  168. in Articles
    How to remove duplicates from an object array?
    Not as easy as we'd like it, but not as hard as it could be
  169. in Articles
    Write a draft script for your SSG blog
    Easily spin up a new article when you don't have a CMS
  170. in Articles
    What default parameters do (and don't do)
    Correcting my mental model
  171. in Articles
    "Stop Teaching Code" in JavaScript
    A quick review of Jeff Olson's article on teaching code with translated examples
  172. in Articles
    5 Lessons from 10k open-source downloads
    A few things I've learned from managing a modestly popular open-source package.
  173. in Articles
    Should I snapshot my UI components?
    The temptation is strong, but consider some of the tradeoffs.
  174. in Articles
    Edit a previous commit message
    The steps to edit recent or ancient commit messages
  175. in Articles
    Arguments or parameters?
    An attempt to remember the difference between the two
  176. in Articles
    Add event listener for class change
    How to create a custom event listener for class names using the MutationObserver API
  177. in Articles
    Storing data in state vs. class variable
    Why do we store data in state as opposed to on the class?
  178. in Articles
    Filter out premium Medium articles
    Using a console script to alter the content on a webpage
  179. in Articles
    Adding accessibility checks to your React app
    A few tools to help you build more accessible React applications
  180. in Articles
    Three reasons to learn Python
    A few reasons why you should learn Python.
  181. in Articles
    JS Basics: Generate a random number
    Using JavaScript's Math object to generate random numbers
  182. in Articles
    JS Basics: Ternary Operator
    Demystifying the inline if statement
  183. in Articles
    Convert class components to functions with React Hooks
    A step by step guide to converting old components to modern React
  184. in Articles
    Accessibility Wednesday
    Learning and sharing about accessibility for everyone
  185. in Articles
    How to create a render prop component
    Render props are a popular technique in modern React, but they can be tricky. Here is a brief explanation and guide to creating your own.