Go to file
2022-01-07 20:16:57 +00:00
.phan
.storybook Update sandbox user menu icon 2021-11-23 11:21:45 -06:00
dev-scripts [Storybook] Add Header component 2021-09-14 18:33:10 +00:00
i18n Merge "Vector is split into 2 skins" 2022-01-07 20:16:57 +00:00
includes Merge "Vector is split into 2 skins" 2022-01-07 20:16:57 +00:00
resources Merge "Reset scroll position when sticky header search input receives focus to fix Safari bug" 2022-01-07 01:30:45 +00:00
screenshots
skinStyles Define sticky header ULS behaviour 2021-12-09 22:18:35 +00:00
stories Merge "Update Abkhaz language name" 2022-01-04 17:01:02 +00:00
tests Vector is split into 2 skins 2022-01-06 15:52:10 -08:00
.eslintignore ES6-ify sticky header code 2021-10-21 23:44:30 +00:00
.eslintrc.json
.gitignore
.gitreview
.nvmrc
.phpcs.xml
.stylelintignore
.stylelintrc.json build: Updating stylelint-config-wikimedia to 0.11.1 2021-09-04 17:38:00 +00:00
.svgo.config.js
bundlesize.config.json Make ULS in header quiet progressive button 2021-12-09 15:27:04 +00:00
CODE_OF_CONDUCT.md
composer.json Add composer test:size as shortcut bundle size test 2021-12-10 19:59:19 +00:00
COPYING
Doxyfile
jsdoc.json Add watchstar to sticky header (alternative) 2021-12-21 09:40:48 -08:00
package-lock.json Move bundlesize test to MediaWikiIntegration test 2021-12-10 08:48:59 +01:00
package.json Move bundlesize test to MediaWikiIntegration test 2021-12-10 08:48:59 +01:00
README.md
skin.json Merge "Vector is split into 2 skins" 2022-01-07 20:16:57 +00:00
tsconfig.json [storybook] Document button usage and update broken stories 2021-09-07 21:23:33 +00:00

Vector Skin

Installation

See https://www.mediawiki.org/wiki/Skin:Vector.

Configuration options

See skin.json.

Development

Node version

It is recommended to use nvm to use the version of node defined in .nvmrc during local development. This ensures consistency amongst development environments.

Coding conventions

We strive for compliance with MediaWiki conventions:

https://www.mediawiki.org/wiki/Manual:Coding_conventions

Additions and deviations from those conventions that are more tailored to this project are noted at:

https://www.mediawiki.org/wiki/Reading/Web/Coding_conventions

URL query parameters

Skin preferences

Vector defines skin-specific user preferences. These are exposed on Special:Preferences when the VectorShowSkinPreferences configuration is enabled. The user's preference state for skin preferences is used for skin previews and any other operation unless specified otherwise.

Version

Vector defines a "version" preference to enable users who prefer the December 2019 version of Vector to continue to do so without any visible changes. This version is called "Legacy Vector." The related preference defaults are configurable via the configurations prefixed with VectorDefaultSkinVersion. Version preference and configuration may be overridden by the useskinversion URL query parameter.

Pre-commit tests

A pre-commit hook is installed when executing npm install. By default, it runs npm test which is useful for automatically validating everything that can be in a reasonable amount of time. If you wish to defer these tests to be executed by continuous integration only, set the PRE_COMMIT environment variable to 0:

$ export PRE_COMMIT=0
$ git commit

Or more succinctly:

$ PRE_COMMIT=0 git commit

Skipping the pre-commit tests has no impact on Gerrit change identifier hooks.

Hooks

See hooks.txt.