How I work (2020 edition)
Written by Regis Freyd and published on May 13, 2020
As a developer, few things are as important as your setup to help you have productive days. After years of trials and errors, I’m currently in a state where I love every single tool that I use every day.
After years of working with Sublime Text and Vim, I've been using VS Code as my primary editor for a couple of years now. Even though it’s built on top of Electron, it’s just great. I agree it’s not as fast as Sublime Text for opening and manipulating files, but the amount of usefulness it brings, whereas as core features or through extensions, is unmatched. I've also tried PHPStorm multiple times, but this IDE tries to do too much and I miss some keyboard shortcuts. I probably could fine tune it to my taste, as I know everything is customizable inside PHPStorm, but I’m a developer, so I’m lazy.
Therefore, VS Code. In the editor, I try to reduce the noise as much as possible. I would never understand why you would need the minimap, for instance. Yes, it’s pretty, but do you need to browse your files that way? Anyway...
Here is a screenshot of my editor.
- Monokai is my go-to theme. It's not the prettiest, but it has the right readibility/noise ratio that allows me to browse and write code efficiently. It also ships by default with VS Code.
- Auto Close Tag: this extension automatically closes HTML tags. Useful when doing front-end stuff.
- Color Highlight: adds a border of color around every hexadecimal color defined in your CSS. Somewhat useful.
- DotENV: adds syntax highlighting to .env files. Very useful for all my Laravel projects.
- EditConfig for VS Code: Adds support to editorconfig files. This lets you maintain consistent coding styles for multiple developers working on the same project across various editors and IDEs.
- GitLens: I use for only one feature: the ability to see who last changed the current line, straight inside the editor. It’s an easy way to git blame any lines, basically.
- IntelliSense for CSS class names in HTML: this provides CSS class name completion in your HTML files. Really useful, especially since I barely write CSS anymore thanks to functional CSS. I've been using functional CSS for 2-3 years now and I couldn't go back to writing regular CSS. Want to know more about it? Read this awesome article by Adam Wathan or dive into those great CSS frameworks (Tachyions and TailwindCSS).
- laravel-blade: adds syntax highlighting for Laravel's blade.
- Markdown TOC: generates table of contents automatically in all the markdown documents I write (specifically Monica's technical documentation).
- PHP DocBlocker: this automatically adds the necessary docblocks above your methods as you type
- PHP Extension Pack: contains the core PHP extensions that you need to get PHP up and running in VS Code.
- PHP Intelephense: The best extension to provide code completion for your PHP. Also, it also imports classes as you type, and this is awesome.
- Sublime Text Keymap and Settings Importer: because I come from Sublime, there are some texts that I wanted to use in VS Code.
- Syncing: I have multiple computers, and I need to sync my settings, shortcuts, themes and everything else between those machines easily. I use Syncing to achieve this goal. It’s not a popular extension but it works better than the most used one.
- Vetur: adds syntax highlighting and linting to your Vue files.
- vscode-icons: a set of nice eye-candy icons that I enjoy.
- Wakatime: I've been using Wakatime to automatically track the time I spent in my code editor on a weekly basis. The free plan sends me an email every week about the number of hours I spend in each of my projects. Right now, as everything I do is done on the side, I spend around 20 hours per week on my projects.
- I develop mainly in PHP, so I use Valet to take care of whatever is needed to make everything works locally. I used to run Valet+, but it caused errors when I tried to upgrade the PHP versions.
- I use MySQL and SQLite equally. Locally, apps run on MySQL, but test suites are run against SQLite for performance reasons (it’s probably at least 10 times faster). To make sure tests are also working fine with MySQL, I have two GitHub actions, one using MySQL and the other SQLite, that give me an additional peace of mind.
- I used to use Sequel Pro to manage databases, but now I use Table Plus as I have to manage SQLite databases now. Also, Table Plus has constant updates.
- I mainly use GitHub Desktop to pull and push changes.
I use iTerm2 as my terminal of choice. It still uses Bash, unfortunately, but I know I’ll have to migrate to ZSH when I’ll migrate to a new computer.
MacOS is my OS of choice. My friends think I’m an Apple fan boy, but it’s not true. I just adore this OS, even though they keep adding stuff that I don't value at all (Twitter and Facebook integration right in the OS – wtf), and removing features that I valued a lot (the ability to switch desktops without animation). But despite those changes, macOS is extremely elegant. No other OSes come close to this level of polish.
- I don't like dark mode in macOS. So I've simply disabled it entirely.
- The dock is always on the left part of the screen, and is always hidden.
- I disable or change a lot of default features that are in macOS through a bunch of commands run into the terminal.
- Whenever I can, I install all softwares with brew cask. If you know Homebrew, Cask works in a similar fashion. For instance, to install 1Password, you would just need to run
brew cask install 1passwordand the install process is handled automatically. But the really good part is that you can actually automate this process in a dotfile. That way when you setup a new machine, you just run your script and all is set for you. This is the script that I use for this purpose.
- Speaking of 1password. I don't think we have to explain why having a password manager in 2020 is essential. I’ve been a very happy 1password subscriber for years now, and don't plan to switch anytime soon. The app is very elegant, very powerful and gets out of the way.
- I use Firefox as my main browser. The dev tools used to lag behind Chrome, but are now much better. Also, privacy.
- I don't use todo lists. I've tried them all, but I can't keep up with all the todos so I usually delete the clients one week after installation. I just focus on 1 or 2 tasks and move on.
- I use Apple Music as it’s much better than Spotify.
- I use the official Twitter client.
- Telegram is my go-to communication medium with friends and family.
- I use Alfred as a task launcher. It’s great, but I don't really need it.
- I use Typinator (a text expander like software) and it’s awesome.
- I don't use a VPN, but I do use NextDNS as DNS resolver that also acts as an hosted Pi-Hole. Can't recommend it enough.
- I’ve been a Fastmail subscriber for 9 years now. I can't say enough good things about them. They have the best support for IMAP (if those things matter to you) and the most impressive sync mechanisms I've seen. They have an insanely fast email client on both desktop and mobile. They don't display ads once you pay. They support unlimited aliases and custom domains.
- I use iStats Menu to keep track of the CPU usage and the current bandwidth usage. I don't care about how the OS manages RAM or fan spinners though. But knowing if a process destroys the CPU is really important on a laptop (or it drains the battery too much), and knowing that something in the OS takes all the bandwidth for no apparent reason is also important to me.
Hi from Canada 🇨🇦
You are not being tracked. Analytics of this site are provided by Fathom, a privacy-friendly analytics tool.