Skip to content
Rob Garrison edited this page Sep 2, 2018 · 10 revisions

Content

Opening the editor

Manager

  • Click on the userstyle name.
  • Ctrl+click on the userstyle name to open the editor in a new tab.
  • Shift+click on the userstyle name to open the editor in a new window.

manager-title

Popup

  • Click on the pencil icon.
  • Ctrl+Click on the userstyle name.
  • Right-click on the userstyle name.

popup-title

Editor Modes

CodeMirror is the editor being used. It was set up with two different modes depending on the type of userstyle being edited. And each mode has some differences:

Plain userstyle

  • Classic userstyle mode.
  • Includes Mozilla Format section in the sidebar.
  • Each @-moz-document has a separate section.
  • The 'applies to' widget between sections has additional actions.

UserCSS userstyle

  • UserCSS mode.
  • No Mozilla Format section.
  • No sections. The entire style can be copy/pasted as one block.
  • Additional "Display 'Applies to' info" option to toggle the view of the 'applies to' line widget.

There is no current method to switch back and forth between these two modes, but you can use a combination of copy/pasting and Mozilla format importing/exporting.

UserCSS to plain CSS
  • Copy the style block immediately after the metadata block.
  • Close the editor.
  • Click "Write new style" with the "as Usercss" unchecked (a non UserCSS style).
  • Paste the style into the editor - a "Paste the Mozilla-format code" popup will open.
  • Click "Overwrite style".
  • Type in a name & save.

Plain CSS to UserCSS
  • Click the "Export" Mozilla Format button.
  • Copy the style to the clipboard.
  • Go back to the manage page.
  • Click "Write new style" with the "as Usercss" checked.
  • Append the plain CSS style.
  • Remove the empty example entry.
  • Modify the @name entry.
  • Save.

Sidebar

All screenshots show the default options set:

Editor modes
Plain CSS UserCSS
edit-sidebar-plain-css edit-sidebar

Name

In plain userstyle mode, the style name is added & edited within the name input.

plain-style-name

In UserCSS mode, the style name input is disabled. The style name is set from the UserCSS @name metadata entry.

usercss-style-name

Enabled

This checkbox allows toggling the overall state of the style. On or off. Altering the checkbox has no effect until the style is saved.

Live preview

This option is not available upon creating a new style. Once the style has been saved, this option appears.

When active, the live preview method will apply the style to the effected page while actively editing the CSS in the editor. This mode does not automatically save the modifications, so leaving the editor will prompt you to save the updated style.

An alert icon will become visible next to the live preview label if there are any parsing errors. Click on it to open a popup showing the issue.

Live preview parsing error

live-preview-error

Save

Action button to save the modified style. It becomes disabled if the style was not modified to any changes were undone.

Once saved, all pages effected by the style will be automatically updated.

Beautify

Once this button is clicked, the style will be beautified by re-indenting and applying the selected formatting rules.

A popup will appear (defaults shown)

beautify

Every select dropdown has two options, a space or \n (symbol for a carriage return). Modifying these dropdowns will automatically apply the changes to the style in the editor.

Preserve new lines, when enabled, will prevent removal of any extra carriage returns within the style, e.g. double carriage returns between certain blocks of CSS will be maintained.

Indent @media, @supports, when enabled, will indent the style within these blocks. Without this enabled, the code within the blocks will be indented to the same level as the wrapper.

Close the popup and keep the beautify changes, if any.

Undo will revert the beautification, but it will not close the popup. To reapply the beautification, alter one of the options in the popup.

Back to manage

Closes the editor and prompts you if the page was modified and not saved. Then goes back to the manage page.

Mozilla Format

This section is only visible when the editor is in plain userstyle mode.

moz-import-export

This section is required because in plain userstyle mode, the @-moz-document wrappers are not visible within the editor. Adding these document rules is accomplished using the 'applies to' block at the bottom of every section. In order to preserve these rules, importing & exporting of the Mozilla format is necessary.

Clicking on the information icon (info-icon) shows the following message: The Mozilla format of the code can be submitted to userstyles.org and used with the classic Stylish for Firefox.

Import

  • Clicking "Import" will open a "Paste the Mozilla-format code" popup window.
  • Paste in the full userstyle, which includes @-moz-document sections into the editor.
  • Use the "Overwrite style" button to replace any style currently within the editor with the newly pasted in style.
  • Use the "Append to style" button to add the newly pasted in style to the end of the style currently in the editor.

Export

  • Clicking "Export" will open a "Style in Mozilla format" popup window.
  • All content will be initially selected.
  • Copy the content using (Ctrl or Command)+c (depending on the keymap) or right-click and select copy.
  • Paste the style elsewhere.

Options

options-common

Word wrap

When enabled, lines are wrapped at the screen edge. If disabled, no wrapping occurs and a horizontal scrollbar is necessary to view all the code.

Use smart indentation

When enabled, CodeMirror will use the context-sensitive indentation that the mode provides (or just indent the same as the line before).

Use tabs with smart indentation

When enabled, smart indentation is added as a tab instead of the number of spaces as set by the "Tab size" option.

Autoclose brackets and quotes

CodeMirror will auto-close brackets and quotes when typed. By default, it'll auto-close ()[]{}''""

Autocomplete on typing

When enabled, show autocomplete hints.

Double-clicking selects tokens

When enabled, double-clicking will include tokens, e.g. clicking on #bada55 will select the hash (#) and the hex color (bada55). If disabled, only the hex color will be selected.

Colorpickers for CSS colors

When enabled, a clickable color swatch will appear next to every color definition. Clicking or using the defined shortcut key – click the configuration icon (config-icon) next to the label to open the popup – will allow choosing a color.

See the Colorpicker wiki page for more details on how to use the popup & set the shortcut key.

Display 'Applies to' info

applies-to-toggle

This option is only visible when the editor is in UserCSS mode.

When enabled, an "Applies to" line widget is visible above each @-moz-document block within the style. If disabled, the editor will not show any line widgets and appears to contain one uninterrupted style.

Tab size

tab-size

Sets the width of a tab character. Defaults to 4 spaces.

Keymap

keymaps

Set the desired hotkey mapping. Click on the info icon (info-icon) to open a searchable keymap list.

Keymap popup

keymap-popup

Theme

syntax-themes

Select the syntax highlighting theme to be applied to the editor.

Highlight

highlight

Control the automatic highlighting of current word/selection occurrences in the style editor. The occurrences will highlight within the scrollbar.

  • Token under cursor - Highlight the occurrences of the word/token under cursor even if nothing is selected.
  • Selection only - Highlight the occurrences of the currently selected text.
  • Disabled - Disable highlighting.

CSS Linter

linter

Switch between or disable all linters.

  • CSSLint - Reports syntax linting issues. Meaning it performs an analysis of the style. It does basic syntax checking and it applies a set of rules that can look for problematic patterns or signs of inefficiency. This linter cannot check Stylus language or LESS CSS syntaxes.
  • Stylelint - Uses rules to catch errors, apply limits and enforce stylistic conventions. This linter can check LESS and other SugarSS CSS-like syntaxes. Our inclusion of Stylus language support may not be fully supported by this linter.
  • Disabled - Disable all syntax linting. Parsing errors will still be reported if live preview is enabled.

Click the configuration icon (config-icon) next to the dropdown to open the currently selected linter's rule configuration popup.

linter config popup

lint-config


The default rule set contains a minimal set of enabled rules. Modify the settings keeping in mind that the editor must contain valid JSON before it can be saved. A link to the full set rules for the selected linter will also be available within the popup.

Issues

The issues section will only appear if the CSS Linter is not disabled.

lint-issues

Header

  • The issues header includes the number of reported linting errors.
  • Next to the header is an information icon (info-icon). Clicking on it will open an "Issues popup" (shown in the screenshot). The popup contains a link to all the rules supported by the current linter, and links to specific rules with a reported error.

Code header

  • The Code # header reports which block of CSS (relevant only to the plain CSS mode).

Code issues

  • A red x or yellow warning sign will appear reporting the set severity (by the config) of the linting issue.
  • Next to the icon will be the line number where the issue occurred.
  • Followed by the reported issue. The issue message may be truncated, but hovering over the issue will show the full text.
  • Clicking on the issue will scroll the editor window and highlight the line where the issue occurs.
  • Within the editor, the same issue icon will appear on the line. Hovering over the icon will report the same error message.

Editor

Plain CSS mode

Editor instances

Based on the number of @-moz-document entries, there will be the same number of independent editor windows open. Meaning you will not be able to select all of the CSS for the style unless the Mozilla format export button is used.

Applies to blocks

An "Applies to" block will appear after every editor.

plain-css-applies-to

Applies to row for plain CSS

  • Clicking on the info icon (info-icon) will display this message in a popup: Use the 'Applies to' controls to limit what URLs the code in this section applies to.

  • Select the @-moz-document rule to apply: (ref)

    • URL (url()) matches an exact URL.
    • URLs starting with (url-prefix()) matches if the document URL starts with the value provided.
    • URLs on the domain (domain()) matches if the document URL is on the domain provided (or a subdomain of it).
    • URLs matching the regexp (regexp()) matches if the document URL is matched by the regular expression provided. The expression must match the entire URL. Make sure to escape special characters as needed using two backslashes (. becomes \\.)
  • Enter the URL, partial URL or regular expression in the input next to the dropdown.

  • Use the - button to delete the entry. Deleting the last entry will hide the dropdown & input and show "Everything". Meaning the style will be applied to every page.

    applies-to-everything

  • Use the + button to add a new dropdown & input to include even more URLs or regular expressions.

Section actions

  • Add another section When only one section is open, this button is visible. Clicking on it will add a new editor instance and applies to block.

    add-section

  • Clone when clicked will duplicate the style and all entries of the applies to block.

  • Beautify when clicked will apply the same stylistic formatting as the global beautify except only to the specific section.

  • Remove section is visible with more than one section is active in the userstyle. Clicking it will remove the section above the button and the applies to block.

    remove-section

  • Add performs the same actions as "Add another section" but is only visible when more than one section is active.

  • Up and Down arrows will move the selected section before or after the surrounding sections, respectively.

  • Restore removed section button is only visible after removing a section allowing you to undo the last action. Hovering over the button will show a short preview of the CSS contained in the section that was removed.

    restore-section

Pasting into the editor

Right-clicking (or use Ctrl+v depending on the keymap) and pasting CSS that contains a @-moz-document wrapper into any editor section will open a "Paste the Mozilla-format code" popup.

Paste Mozilla-format popup

paste-moz-popup


Use Overwrite style to replace all the current CSS in the editor with the newly pasted in code, or use Append to style to add a new section with the pasted in code added to the end of the current style.

UserCSS mode

Editor instances

In this mode, there will only be one instance of the editor. In this case, you will be able to select all of the CSS for the style to copy & paste it elsewhere.

Applies to blocks

An "Applies to" block will appear before every @-moz-document block.

usercss-section

Applies to row for UserCSS

  • Select the @-moz-document rule to apply: (ref)
    • URL (url()) matches an exact URL.
    • URLs starting with (url-prefix()) matches if the document URL starts with the value provided.
    • URLs on the domain (domain()) matches if the document URL is on the domain provided (or a subdomain of it).
    • URLs matching the regexp (regexp()) matches if the document URL is matched by the regular expression provided. The expression must match the entire URL. Make sure to escape special characters as needed using two backslashes (. becomes \\.)
  • Enter the URL, partial URL or regular expression in the input next to the dropdown.
  • Use the - button to delete the entry. Deleting the last entry will show a popup stating that you cannot remove the last 'applies to' entry. To make the style apply to every page, remove the @-moz-document wrapper.
  • Use the + button to add a new dropdown & input to include even more URLs or regular expressions.

Pasting into the editor

Right-clicking (or use Ctrl+v depending on the keymap) and pasting CSS that contains a @-moz-document wrapper into the editor while in UserCSS mode will paste the CSS at the current cursor position and add a new applies to block above it the wrapper.

Clone this wiki locally