Extension:TemplateStyles

The TemplateStyles extension introduces a tag to specify that a stylesheet should be loaded from a wiki page. Placing this in a template allows the template to have custom styles without having to place them in.

For instructions on how to use the extension as an editor on a wiki, see.

Usage
First, the CSS page must be created. By default any subpage in the Template namespace with a title ending in ".css" will be created with the "Sanitized CSS" if it contains no syntax errors.

The set of namespaces may be adjusted with, or  may be used on any page. Then, in the template's wikitext, add the tag to load the styles.

The CSS saved using the "Sanitized CSS" content model must meet strict validity requirements: invalid CSS, unrecognized at-rules, and unrecognized or unsupported properties or property values cannot be saved. If invalid CSS is somehow saved anyway, the offending constructs will be removed when the CSS is output to the browser.

The value of the attribute on the tag is the title of the page, defaulting to the Template namespace. (This default can be changed via .) For example, will load the page " Template:Example/styles.css ". This will fail if that page does not exist or has a content model other than "Sanitized CSS".

Styles can be scoped within the page by using the optional parameter to the tag, e.g.  would scope the styles loaded to any  inside the main parsed content. Any CSS simple selector sequence can be used for the parameter. This is intended to allow side-by-side comparison of live and sandbox versions of a template.

Use of sanitized CSS is tracked like transclusion of templates, and will show up as a transclusion on.

Caveats

 * Styles added by TemplateStyles are scoped into to avoid tampering with the user interface outside of the main parsed content.


 * To use TemplateStyles to style something like w:MediaWiki:Protectedpagetext, you would need to enclose the message's contents in.


 * The styles should be written to target specific CSS classes, and anything that generates elements with those classes should be sure to also include the styles itself rather than relying on some other template to have done so.


 * Styles included by a template can currently affect content on the page outside of the content generated by that template, but this ability may be removed in the future and should not be relied upon. (See discussion from phab:T155813 and in phab:T176272.)
 * Including styles on a template that affects contents outside of that template, will cause those styles to not be applied when editing a section that doesn't contain that template. Example: including styles on an infobox that affect all tables of the page, when editing a section that doesn't contain the infobox, those tables won't be styled when previewing that section.


 * TemplateStyles allows few non-standardized CSS properties. Requests to support additional properties should be [ https://phabricator.wikimedia.org/maniphest/task/edit/form/1/?tags=TemplateStyles,css-sanitizer filed in Phabricator in the css-sanitizer and TemplateStyles projects].


 * Requests should include links to standards-track documents (e.g. on w3.org) describing the syntax of the properties being requested, and an analysis of current browser support for the properties (e.g. a link to a caniuse.com page about the properties).


 * Vendor-prefixed properties (e.g. anything starting with,  , or  ) are likely to be declined if they're not needed for modern browsers.


 * rules must use a prefixed with "TemplateStyles".  This should largely prevent redefining fonts used elsewhere in the document.


 * To target styles based on skins, use a selector such as ; specification of the  element is required and must be followed by a descendant combinator (i.e. the space).  Other classes on the  or  elements may be targeted in the same manner.

Other dependencies
should be configured to use no tidying or RemexHtml. If used with any of the Raggett drivers, a tag in the middle of a paragraph (including in an inline template) will cause tidy to break the paragraph at that point. The other drivers have not been tested for this issue.

Potential errors
It may help to enable in your  to determine if you are experiencing any of the errors below.


 * This means a required library has not been installed. The error may come up when attempting to import a wiki CSS page or when changing the content model of a page to "santized-css".  This was common in the past due to a bug in the extension distributor; shouldn't happen anymore.
 * Happens when you try to import a wiki page created via TemplateStyles, but TemplateStyles is not installed on your wiki.
 * Happens when you try to import a wiki page created via TemplateStyles, but TemplateStyles is not installed on your wiki.
 * Happens when you try to import a wiki page created via TemplateStyles, but TemplateStyles is not installed on your wiki.