Custom JSBin Settings
settings = {
jshint: true,
editor: {
theme: "monokai",
indentUnit: 4,
smartIndent: true,
tabSize: 4,
indentWithTabs: true,
autoClearEmptyLines: true,
lineWrapping: true,
lineNumbers: true,
matchBrackets: true
}
};
You may already know about the JSBin tool created by Remy Sharp. It was the first website of it's kind that I'm aware of that lets you quickly prototype and play around with web concepts in a way that is social and fun. Although it has been around for a while Remy has been adding more and more features to it recently. One of the ones that I want to point out is the ability to modify the settings of it's internal code editor.
JSBin internally uses the CodeMirror library for it's HTML, JavaScript, and CSS code editors. JSBin exposes the Configuration Settings of CodeMirror and allows you to set them yourself. The settings are stored in localStorage so they are available the next time you use JSBin. CodeMirror supports a whole suite of settings, but the following are the ones that I am most interested in:
theme
- Color scheme that will be used for the editor. Currently the following themes exist: solarized-light, solarized-dark, monokai, vibrant-ink, cobalt, blackboard, ambiance, & jsbin (default)You can set these options manually in your browser's console like the following snippet of code...
If you want to share with others your settings for a specific JSBin you can add an api
URL parameter pointing to a configuration file.
The following URL will load JSBin with a custom set of code editor options.
http://jsbin.com?api=http://j.mp/jsbin-settings
The http://j.mp/jsbin-settings
file I am using looks like the following...
jsbin.settings.editor.theme = "monokai";
jsbin.settings.editor.indentUnit = 4;
jsbin.settings.editor.smartIndent = true;
jsbin.settings.editor.tabSize = 4;
jsbin.settings.editor.indentWithTabs = true;
jsbin.settings.editor.autoClearEmptyLines = true;
jsbin.settings.editor.lineWrapping = true;
jsbin.settings.editor.lineNumbers = true;
jsbin.settings.editor.matchBrackets = true;