Skip to content

Latest commit

 

History

History
145 lines (121 loc) · 5.13 KB

README.md

File metadata and controls

145 lines (121 loc) · 5.13 KB

AutoFileName Improved

Autocomplete Filenames in Sublime Text

Do you ever find yourself sifting through folders in the sidebar trying to remember what you named that file? Can't remember if it was a jpg or a png? Maybe you just wish you could type filenames faster. No more.

Whether you're making a img tag in html, setting a background image in css, or linking a .js file to your html (or whatever else people use filename paths for these days...), you can now autocomplete the filename. Plus, it uses the built-in autocomplete, so no need to learn another pesky shortcut.

Features

  • Display filenames and folders
  • Show dimensions next to image files
  • Autoinsert dimensions in img tags (can be disabled in settings)
  • Support for both '/' and '' for all you Windows hooligans

Installation

By Package Control

  1. Download & Install Sublime Text 3 (https://www.sublimetext.com/3)
  2. Go to the menu Tools -> Install Package Control, then, wait few seconds until the installation finishes up
  3. Now, Go to the menu Preferences -> Package Control
  4. Type Add Channel on the opened quick panel and press Enter
  5. Then, input the following address and press Enter
    https://raw.githubusercontent.com/evandrocoan/StudioChannel/master/channel.json
    
  6. Go to the menu Tools -> Command Palette... (Ctrl+Shift+P)
  7. Type Preferences: Package Control Settings – User on the opened quick panel and press Enter
  8. Then, find the following setting on your Package Control.sublime-settings file:
    "channels":
    [
        "https://packagecontrol.io/channel_v3.json",
        "https://raw.githubusercontent.com/evandrocoan/StudioChannel/master/channel.json",
    ],
  9. And, change it to the following, i.e., put the https://raw.githubusercontent... line as first:
    "channels":
    [
        "https://raw.githubusercontent.com/evandrocoan/StudioChannel/master/channel.json",
        "https://packagecontrol.io/channel_v3.json",
    ],
    • The https://raw.githubusercontent... line must to be added before the https://packagecontrol.io... one, otherwise, you will not install this forked version of the package, but the original available on the Package Control default channel https://packagecontrol.io...
  10. Now, go to the menu Preferences -> Package Control
  11. Type Install Package on the opened quick panel and press Enter
  12. Then, search for AutoFileName and press Enter

See also:

  1. ITE - Integrated Toolset Environment
  2. Package control docs for details.

Usage

Nothing!

For example:

If you are looking to autocomplete an image path in an HTML <img> tag:

    <img src="../|" />

Pressing ctrl+space, will activate AutoFileName. I list of available files where be ready to select.

Looking for an even more automatic and seemless completion? Add the following to your User Settings file:

"auto_complete_triggers":
[
  {
     "characters": "<",
     "selector": "text.html"
  },
  {
     "characters": "/",
     "selector": "string.quoted.double.html,string.quoted.single.html, source.css"
  }
]

With this, there's no need to worry about pressing ctrl+space, autocompletion with appear upon pressing /.

Ultimate setup for JavaScript/Node.js development:

  1. Open any JavaScript file
  2. Go to "Preferences" -> "Settings - Syntax Specific"
  3. Paste this code:
{
  "extensions": ["js", "vue"],
  "auto_complete_triggers" : [
    {
      "characters": ".",
      "selector": "source.js"
    },
    {
      "characters": "./@abcdefghijklmnopqrstuvwxyz",
      "selector": "string.quoted.single.js,string.quoted.double.js"
    }
  ],
  "word_separators": ".\\/()\"':,.;<>~!#%^&*|+=[]{}`~?@",
  "afn_scopes": [
    {
      "scope": "\\.jsx?\\s",
      "prefixes": ["require", "define", "import", "from"], // trigger only if prefix matches
      "replace_on_insert": [
        ["^@?(\\w+)/?$", "\\1"], // remove trailing slash when importing module from node_modules
        ["\\.(jsx?|vue)$", ""] // after insertion, remove .js or .vue from path
      ],
      "aliases": [
        ["^(@?\\w+)", "<project_root>/node_modules/\\1"], // for resolving from node_modules
        ["^@/", "<project_root>/src/"] // custom alias
      ],
    },
  ],
}
  1. If you are like me and using Vue Components, repeat the above steps for .vue files as well, or create a symlink (for MacOS use bash code below).
cd ~/Library/Application\ Support/Sublime\ Text\ 3/Packages/User
ln -s JavaScript.sublime-settings Vue\ Component.sublime-settings

NOTE: I encourage you to create a language-specific setting files, rather than editing common settings. This way the above settings will override any package's settings (like "TypeScript" package, which messes up "auto_complete_triggers" and "word_separators" for JavaScript)