This may come as a shocker, but I'm really particular about my editor settings. I'm sure no one else is, but I get pretty darn picky about my editor and how it behaves. One issue I've had with Brackets is a feature called "Smart Indent."
Smart Indent will automatically indent your cursor after you hit enter on a block expression. Not sure if "block expression" is the best term, but basically, if you enter a conditional, like if(x), or if you enter a HTML tag that wraps other tags, like <table>, Brackets will indent your cursor one "block" over after you hit enter.
This bugs the heck out of me. While I do use indentation, I don't always use it. So for example, I don't like to indent my HEAD or BODY blocks. It feels silly to me to have one pair of HTML tags at the left gutter and nothing else. I'll not indent TR blocks inside of TABLE tags either, but I do indent the TDs.
Basically - my rule is - and I try to be consistent here - that if the wrapping block has nothing else in it but one main child, I don't see much point in indenting over the text.
When I type in Brackets, I constantly find myself having to hit backspace to return the cursor to where I want it. After a while I begin to see red and start wondering if therapy is in order.
Turns out though it is pretty easy to correct. If you go into the source code and find editor/Editor.js, you can see the following block where the CodeMirror object is instantiated:
I checked the CodeMirror docs and found that I could pass a setting, smartIndent:false, to disable this.
And that's it. To be clear, when I hit enter, the cursor still indents to where the last line began. It isn't flush against the left gutter.
There is no "Preferences" UI yet for Brackets. I could make this an extension, but since I assume I'm probably in the minority when it comes to this preference and the modification is so small, I wouldn't bother creating one.