JGirault has uploaded a new change for review. https://gerrit.wikimedia.org/r/268842
Change subject: Revert "Revert "Adding postCSS & changing blue."" ...................................................................... Revert "Revert "Adding postCSS & changing blue."" This reverts commit 80955536c3c03868129646798738d5702194ffd7. Change-Id: Iacfddfc2feaea527b08a04aa3c8e13833d2d900f --- A dev/wikipedia.org/assets/css/README.txt A dev/wikipedia.org/assets/css/style.css A dev/wikipedia.org/assets/cssnext/README.txt R dev/wikipedia.org/assets/cssnext/_base.css R dev/wikipedia.org/assets/cssnext/_buttons.css R dev/wikipedia.org/assets/cssnext/_forms.css R dev/wikipedia.org/assets/cssnext/_pab1.css R dev/wikipedia.org/assets/cssnext/_pab2.css A dev/wikipedia.org/assets/cssnext/_vars.css R dev/wikipedia.org/assets/cssnext/_wm-portal.css A dev/wikipedia.org/assets/cssnext/style.css M dev/wikipedia.org/index.handlebars M gulpfile.js M package.json M prod/wikipedia.org/index.html A tests/lint.js 16 files changed, 1,001 insertions(+), 27 deletions(-) git pull ssh://gerrit.wikimedia.org:29418/wikimedia/portals refs/changes/42/268842/1 diff --git a/dev/wikipedia.org/assets/css/README.txt b/dev/wikipedia.org/assets/css/README.txt new file mode 100644 index 0000000..c7e71c0 --- /dev/null +++ b/dev/wikipedia.org/assets/css/README.txt @@ -0,0 +1,3 @@ +Do not edit the CSS files in this directory. +They will be overridden during the build process. +Instead, make your changes to the files in the cssnext folder. \ No newline at end of file diff --git a/dev/wikipedia.org/assets/css/style.css b/dev/wikipedia.org/assets/css/style.css new file mode 100644 index 0000000..cdf47bc --- /dev/null +++ b/dev/wikipedia.org/assets/css/style.css @@ -0,0 +1,915 @@ +/** +* Colors from https://phabricator.wikimedia.org/diffusion/WMUI/browse/master/base.less +*/ +/*! +Pure v0.6.1-pre +Copyright 2014 Yahoo! Inc. All rights reserved. +Licensed under the BSD License. +https://github.com/yahoo/pure/blob/master/LICENSE.md +*/ +/*! +normalize.css v^3.0 | MIT License | git.io/normalize +Copyright (c) Nicolas Gallagher and Jonathan Neal +*/ +/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */ +/** + * 1. Set default font family to sans-serif. + * 2. Prevent iOS and IE text size adjust after device orientation change, + * without disabling user zoom. + */ +html { + font-family: sans-serif; /* 1 */ + -ms-text-size-adjust: 100%; /* 2 */ + -webkit-text-size-adjust: 100%; /* 2 */ +} +/** + * Remove default margin. + */ +body { + margin: 0; +} +/* HTML5 display definitions + ========================================================================== */ +/** + * Correct `block` display not defined for any HTML5 element in IE 8/9. + * Correct `block` display not defined for `details` or `summary` in IE 10/11 + * and Firefox. + * Correct `block` display not defined for `main` in IE 11. + */ +article, +aside, +details, +figcaption, +figure, +footer, +header, +hgroup, +main, +menu, +nav, +section, +summary { + display: block; +} +/** + * 1. Correct `inline-block` display not defined in IE 8/9. + * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. + */ +audio, +canvas, +progress, +video { + display: inline-block; /* 1 */ + vertical-align: baseline; /* 2 */ +} +/** + * Prevent modern browsers from displaying `audio` without controls. + * Remove excess height in iOS 5 devices. + */ +audio:not([controls]) { + display: none; + height: 0; +} +/** + * Address `[hidden]` styling not present in IE 8/9/10. + * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22. + */ +[hidden], +template { + display: none; +} +/* Links + ========================================================================== */ +/** + * Remove the gray background color from active links in IE 10. + */ +a { + background-color: transparent; +} +/** + * Improve readability of focused elements when they are also in an + * active/hover state. + */ +a:active, +a:hover { + outline: 0; +} +/* Text-level semantics + ========================================================================== */ +/** + * Address styling not present in IE 8/9/10/11, Safari, and Chrome. + */ +abbr[title] { + border-bottom: 1px dotted; +} +/** + * Address style set to `bolder` in Firefox 4+, Safari, and Chrome. + */ +b, +strong { + font-weight: bold; +} +/** + * Address styling not present in Safari and Chrome. + */ +dfn { + font-style: italic; +} +/** + * Address variable `h1` font-size and margin within `section` and `article` + * contexts in Firefox 4+, Safari, and Chrome. + */ +h1 { + font-size: 2em; + margin: 0.67em 0; +} +/** + * Address styling not present in IE 8/9. + */ +mark { + background: #ff0; + color: #000; +} +/** + * Address inconsistent and variable font size in all browsers. + */ +small { + font-size: 85%; /* CHANGED from 80% to 85% */ +} +/** + * Prevent `sub` and `sup` affecting `line-height` in all browsers. + */ +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; +} +sup { + top: -0.5em; +} +sub { + bottom: -0.25em; +} +/* Embedded content + ========================================================================== */ +/** + * Remove border when inside `a` element in IE 8/9/10. + */ +img { + border: 0; +} +/** + * Correct overflow not hidden in IE 9/10/11. + */ +svg:not(:root) { + overflow: hidden; +} +/* Grouping content + ========================================================================== */ +/** + * Address margin not present in IE 8/9 and Safari. + */ +figure { + margin: 1em 40px; +} +/** + * Address differences between Firefox and other browsers. + */ +hr { + box-sizing: content-box; + height: 0; +} +/** + * Contain overflow in all browsers. + */ +pre { + overflow: auto; +} +/** + * Address odd `em`-unit font size rendering in all browsers. + */ +code, +kbd, +pre, +samp { + font-family: monospace, monospace; + font-size: 1em; +} +/* Forms + ========================================================================== */ +/** + * Known limitation: by default, Chrome and Safari on OS X allow very limited + * styling of `select`, unless a `border` property is set. + */ +/** + * 1. Correct color not being inherited. + * Known issue: affects color of disabled elements. + * 2. Correct font properties not being inherited. + * 3. Address margins set differently in Firefox 4+, Safari, and Chrome. + */ +button, +input, +optgroup, +select, +textarea { + color: inherit; /* 1 */ + font: inherit; /* 2 */ + margin: 0; /* 3 */ +} +/** + * Address `overflow` set to `hidden` in IE 8/9/10/11. + */ +button { + overflow: visible; +} +/** + * Address inconsistent `text-transform` inheritance for `button` and `select`. + * All other form control elements do not inherit `text-transform` values. + * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. + * Correct `select` style inheritance in Firefox. + */ +button, +select { + text-transform: none; +} +/** + * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` + * and `video` controls. + * 2. Correct inability to style clickable `input` types in iOS. + * 3. Improve usability and consistency of cursor style between image-type + * `input` and others. + */ +button, +html input[type="button"], /* 1 */ +input[type="reset"], +input[type="submit"] { + -webkit-appearance: button; /* 2 */ + cursor: pointer; /* 3 */ +} +/** + * Re-set default cursor for disabled elements. + */ +button[disabled], +html input[disabled] { + cursor: default; +} +/** + * Remove inner padding and border in Firefox 4+. + */ +button::-moz-focus-inner, +input::-moz-focus-inner { + border: 0; + padding: 0; +} +/** + * Address Firefox 4+ setting `line-height` on `input` using `!important` in + * the UA stylesheet. + */ +input { + line-height: normal; +} +/** + * It's recommended that you don't attempt to style these elements. + * Firefox's implementation doesn't respect box-sizing, padding, or width. + * + * 1. Address box sizing set to `content-box` in IE 8/9/10. + * 2. Remove excess padding in IE 8/9/10. + */ +input[type="checkbox"], +input[type="radio"] { + box-sizing: border-box; /* 1 */ + padding: 0; /* 2 */ +} +/** + * Fix the cursor style for Chrome's increment/decrement buttons. For certain + * `font-size` values of the `input`, it causes the cursor style of the + * decrement button to change from `default` to `text`. + */ +input[type="number"]::-webkit-inner-spin-button, +input[type="number"]::-webkit-outer-spin-button { + height: auto; +} +/** + * 1. Address `appearance` set to `searchfield` in Safari and Chrome. + * 2. Address `box-sizing` set to `border-box` in Safari and Chrome. + */ +input[type="search"] { + -webkit-appearance: textfield; /* 1 */ + box-sizing: content-box; /* 2 */ +} +/** + * Remove inner padding and search cancel button in Safari and Chrome on OS X. + * Safari (but not Chrome) clips the cancel button when the search input has + * padding (and `textfield` appearance). + */ +input[type="search"]::-webkit-search-cancel-button, +input[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; +} +/** + * ADDED + * + * Remove extra space between input borders and input outline. + * Needed for Safari. + */ +input[type="search"]:focus { + outline-offset: -2px; +} +/** + * Define consistent border, margin, and padding. + */ +fieldset { + border: 1px solid #c0c0c0; + margin: 0 2px; + padding: 0.35em 0.625em 0.75em; +} +/** + * 1. Correct `color` not being inherited in IE 8/9/10/11. + * 2. Remove padding so people aren't caught out if they zero out fieldsets. + */ +legend { + border: 0; /* 1 */ + padding: 0; /* 2 */ +} +/** + * Remove default vertical scrollbar in IE 8/9/10/11. + */ +textarea { + overflow: auto; +} +/** + * Don't inherit the `font-weight` (applied by a rule above). + * NOTE: the default cannot safely be changed in Chrome and Safari on OS X. + */ +optgroup { + font-weight: bold; +} +/* Tables + ========================================================================== */ +/** + * Remove most spacing between table cells. + */ +table { + border-collapse: collapse; + border-spacing: 0; +} +td, +th { + padding: 0; +} +/*csslint important:false*/ +/* ========================================================================== + Pure Base Extras + ========================================================================== */ +/** + * Extra rules that Pure adds on top of Normalize.css + */ +/** + * Always hide an element when it has the `hidden` HTML attribute. + */ +.hidden, +[hidden] { + display: none !important; +} +/** + * Add this class to an image to make it fit within it's fluid parent wrapper while maintaining + * aspect ratio. + */ +.pure-img { + max-width: 100%; + height: auto; + display: block; +} +/** + * This is the stylesheet for the [[m:Project portal]] templates. + * It should loosely match the style of MediaWiki's Vector theme + * for consistency. + * Colors from ./skins/Vector/screen.css + * + * Indention style: 1 tab + * + */ +body { + background-color: white; + font: 13px/1.5 sans-serif; + margin: 0.3em 0; +} +a, +a:active, +a:focus { + unicode-bidi: embed; + white-space: nowrap; + outline: 0; + color: #165c91; + text-decoration: none; +} +a:focus { + outline: 1px solid #165c91; +} +a:hover { + text-decoration: underline; +} +img { + border: none; + vertical-align: middle; +} +hr { + clear: both; + height: 0; + border: none; + border-bottom: 1px solid #aaa; + margin: 0.2em 1em; +} +/** + * Central logo area for wiki-project portals + * (e.g. where the globe is on www.wikipedia.org) + */ +.central-textlogo { + margin: 1em 0 0.3em 0; + text-align: center; + font-size: 30px; + line-height: 110%; + font-family: 'Linux Libertine', 'Hoefler Text', Georgia, 'Times New Roman', Times, serif; + font-weight: normal; + padding: 10px 0; + /* Crossed W in Linux Libertine */ + -webkit-font-feature-settings: "ss05"; + -ms-font-feature-settings: "ss05"; + font-feature-settings: "ss05"; +} +.central-featured { + position: relative; + text-align: center; + vertical-align: middle; + max-width: 100%; + width: 42em; + margin: 0 auto; + height: 26em; +} +.central-featured-logo-wrapper{ + vertical-align: middle; + line-height: 26em; +} +.central-featured-lang { + position: absolute; + width: 12em; +} +/* Make entire block clickable, surpress hover underline */ +.central-featured-lang .link-box { + display: block; + padding: 0; + text-decoration: none; +} +/* Restore underline on main label */ +.central-featured-lang .link-box:hover strong { + text-decoration: underline; +} +/* Surpress blue color */ +.central-featured-lang .link-box em, +.central-featured-lang .link-box small { + color: black; + text-decoration: none; +} +.central-featured-lang strong { + font-size: larger; +} +.central-featured-lang em { + font-style: italic; +} +.central-featured-lang .emNonItalicLang { + font-style: normal; +} +/* Serbo-Croatian is dual-script, so it needs some tweaking to fit in the top 10 ring. */ +/* .digraphic strong { + font-size: 110%; + line-height: 1em; +} +.digraphic em, +.digraphic em + br { + display: none; +} */ +.lang1 { + top: 0; + right: 60%; +} +.lang2 { + top: 0; + left: 60%; +} +.lang3 { + top: 20%; + right: 70%; +} +.lang4 { + top: 20%; + left: 70%; +} +.lang5 { + top: 40%; + right: 72%; +} +.lang6 { + top: 40%; + left: 72%; +} +.lang7 { + top: 60%; + right: 70%; +} +.lang8 { + top: 60%; + left: 70%; +} +.lang9 { + top: 80%; + right: 60%; +} +.lang10 { + top: 80%; + left: 60%; +} +/** + * Search bar below the central logo area + */ +.search-container { + float: none; + margin: 1em auto 1.5em auto; + max-width: 95%; + padding: 0.3em; + text-align: center; + vertical-align: middle; + width: 540px; +} +.search-form fieldset { + background-color: #f9f9f9; + border: 1px solid #aaa; + margin-top: 0.5em; + padding: 0.7em; + width: auto; +} +.search-form #searchInput { + font-size: 1.2em; + margin: 0; + padding: 0; + vertical-align: top; +} +.search-form select { + margin: 0 0.4em; + padding: 0; + vertical-align: middle; + max-width: 12em; + width: 12em; /* otherwise the width is inconsistent between browsers */ +} +/** + * Language lists, bookshelves, etc. + */ +.bookshelf-container { + width: 100%; + overflow: hidden; + margin: 2em 0 0.5em 0; + font-size: 13px; + font-weight: bold; + line-height: 20px; +} +.bookshelf-container .text { + padding: 0 0.5em; +} +.bookshelf { + display: block; + width: 300%; + overflow: hidden; + position: relative; + left: -100%; + text-align: center; + white-space: nowrap; +} +.bookshelf-container .bookend { + display: inline-block; + vertical-align: top; + +} +.langlist { + text-align: center; + margin: 0.5em 3em 2.5em 3em; +} +.langlist-large { + font-size: larger; +} +.langlist-tiny { + margin: 0.5em 3em 3em 3em; +} +.langlist-others { + margin: 0 3em 2em 3em; + font-weight: bold; +} +.otherprojects { + font-weight: bold; + margin: 1.5em auto; + text-align: left; + vertical-align: middle; + width: 90%; +} +.otherprojects-item { + float: left; + height: 60px; + min-width: 12em; + width: 24.75%; + line-height: 60px; +} +.otherprojects-item a { + display: block; + width: 10em; + margin: 0 auto; +} +.sprite-project-logos-wrapper{ + width: 47px; + display: -moz-inline-stack; display: inline-block; + text-align: center; + vertical-align: middle; +} +.otherprojects-item .sprite-project-logos{ + display: -moz-inline-stack; display: inline-block; + text-align: center; + vertical-align: middle; +} +.otherprojects-item .otherprojects-item-name { + vertical-align: middle; +} +.sprite-project-logos-Wikispecies-logo_sister { + background-position: -0px -324px !important; + width: 35px !important; + height: 40px !important; +} +.wm-site-info { + clear: both; + margin: 2.5em 0 2em 0; + text-align: center; + padding-top: 1.5em; +} +/** + * Style for horizontal lists (separator following item). + * @note Support for unused tags like <dt> has been stripped out, and the + * dependency on :last-child and JavaScript has been removed in favor of + * :before. + * @source mediawiki.org/wiki/Snippets/Horizontal_lists + * @revision 6 (2014-05-09) + * @author [[User:Edokter]] + */ +.hlist ul { + margin: 0; + padding: 0; +} +/* Display list items inline */ +.hlist li { + display: inline; +} +/* Display nested lists inline */ +.hlist ul ul { + display: inline; +} +/* Generate interpuncts */ +.hlist li:before { + content: " · "; + font-weight: bold; +} +.hlist li:first-child:before { + content: none; +} +/* Add parentheses around nested lists */ +.hlist li + ul:before { + content: "\00a0("; +} +.hlist li + ul:after { + content: ") "; +} +/** + * Print stylesheet + */ +@media print { + + body { + background-color: transparent; + } + + a { + color: black !important; + background: none !important; + padding: 0 !important; + } + + a:link, + a:visited { + color: #520; + background: transparent; + } + + img { + border: none; + } + +} +@media all and (max-width:480px) { + .central-textlogo { + line-height: normal; + padding: 0; + margin: 0; + height: 70px; + text-align: left; + padding-left: 84px; + position: relative; + } + .central-textlogo img { + height: 35px; + width: auto; + margin-top: 22.5px; + } + .central-featured { + width: auto; + height: auto; + padding-top: 2em; + text-align: left; + font-size: 0.8em; + margin-top: 4em; + } + .central-featured-logo { + right: 0; + left: 0.8em; + top: -70px; + margin-top: -4em; + width: 70px; + position: absolute; + } + .central-featured-lang { + right: auto; + top: auto; + position: relative; + left: auto; + text-align: left; + margin-left: 1em; + display: block; + float: left; + width: 40%; + height: 5em; + } + .search-container { + margin-top: 0; + height: 6em; + position: absolute; + top: 5em; + left: 0; + right: 0; + max-width: 100%; + width: auto; + padding: 0; + text-align: left; + } + .search-container label { + display: none; + } + .search-form #searchInput { + max-width: 40%; + vertical-align:middle; + } + .search-form #searchLanguage, + .search-form .formBtn { + max-width: 25%; + vertical-align: middle; + } + form fieldset { + margin: 0; + border-left: none; + border-right: none; + } + .language-search { + display: none; + } + .bookshelf { + width: auto; + left: auto; + overflow: hidden; + text-align: left; + } + .bookshelf-container .bookend { + width: 40px !important; + } + .bookshelf-container .bookend:last-child { + display: none; + } + .langlist a { + word-wrap: break-word; + white-space: normal; + } + .langlist { + font-size: 0.7em + } + .otherprojects-item { + width: 50%; + text-align: left; + } + .bookshelf-container, + .langlist { + margin: 1em 1em 0 1em; + text-align: left; + width: auto; + } + hr { + margin-top: 0.5em; + } +} +@media all and (max-width:240px) { + .central-featured-lang, + .otherprojects-item { + width: 100%; + } + .central-textlogo img { + width: 100px; + height: auto; + } +} +@media all and (max-width: 45em) { + .otherprojects { + width: 100%; + } + .otherprojects-item { + width: 33.33%; + } +} +@media all and (max-width: 30em) { + .otherprojects-item { + width: 50%; + } +} +@media all and (max-width: 20em) { + .otherprojects-item { + width: 100%; + } +} +@media (-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (min-resolution: 1.5dppx), (min-resolution: 144dpi) { + .bookshelf-container .bookend { + background-size: 40px auto; + } +} +@media (-webkit-min-device-pixel-ratio: 2), (min--moz-device-pixel-ratio: 2), (min-resolution: 2dppx), (min-resolution: 192dpi) { + .bookshelf-container .bookend { + background-size: 40px auto; + } +} +/* Subpixel borders supported in Gecko, Trident */ +@media (min--moz-device-pixel-ratio: 2), (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx), (min-resolution: 192dpi) { + #footer, + .search-form fieldset { + border-width: 0.5px; + } + + hr { + border-bottom-width: 0.5px; + } +} +/* Subpixel borders not supported in older releases of Blink, WebKit */ +@supports (-webkit-transform: rotate(30deg)) { + #footer, + .search-form fieldset { + border-width: 1px; + } + + hr { + border-bottom-width: 1px; + } +} +/* Gives the button its previous native look */ +.formBtn { + background-color: white; + border: 1px solid #E4E4E4; + border-radius: 4px; + border-top: 1px solid #e8e8e8; + border-bottom: 1px solid #CECECE; + font-size: 11px; + padding: 1px 8px; + margin-left: .3em; + vertical-align: top; +} +.formBtn .sprite-bookshelf_icons-search_icon { + display: inline-block; + vertical-align: middle; +} +.formBtn:focus { + background-color: #c0c0c0; + outline: 0; +} +.formBtn:active { + background-color: #b0b0b0; +} +/* Gives the inputs their previous look */ +.search-container .search-form #searchInput { + font-size: 13px; + padding: 1px 3px; + width: 15em; /* otherwise the width is inconsistent between browsers */ +} +#langsearch-input { + padding: 1px 2px; + font-size: 11px; + vertical-align: top; +} +/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["_vars.css","_base.css","_wm-portal.css"],"names":[],"mappings":"AAAA;;EAEE;ACFF;;;;;EAKE;AACF;;;EAGE;AACF,4EAA4E;AAE5E;;;;GAIG;AAEH;EACE,wBAAwB,CAAC,OAAO;EAChC,2BAA2B,CAAC,OAAO;EACnC,+BAA+B,CAAC,OAAO;CACxC;AAED;;GAEG;AAEH;EACE,UAAU;CACX;AAED;gFACgF;AAEhF;;;;;GAKG;AAEH;;;;;;;;;;;;;EAaE,eAAe;CAChB;AAED;;;GAGG;AAEH;;;;EAIE,sBAAsB,CAAC,OAAO;EAC9B,yBAAyB,CAAC,OAAO;CAClC;AAED;;;GAGG;AAEH;EACE,cAAc;EACd,UAAU;CACX;AAED;;;GAGG;AAEH;;EAEE,cAAc;CACf;AAED;gFACgF;AAEhF;;GAEG;AAEH;EACE,8BAA8B;CAC/B;AAED;;;GAGG;AAEH;;EAEE,WAAW;CACZ;AAED;gFACgF;AAEhF;;GAEG;AAEH;EACE,0BAA0B;CAC3B;AAED;;GAEG;AAEH;;EAEE,kBAAkB;CACnB;AAED;;GAEG;AAEH;EACE,mBAAmB;CACpB;AAED;;;GAGG;AAEH;EACE,eAAe;EACf,iBAAiB;CAClB;AAED;;GAEG;AAEH;EACE,iBAAiB;EACjB,YAAY;CACb;AAED;;GAEG;AAEH;EACE,eAAe,CAAC,6BAA6B;CAC9C;AAED;;GAEG;AAEH;;EAEE,eAAe;EACf,eAAe;EACf,mBAAmB;EACnB,yBAAyB;CAC1B;AAED;EACE,YAAY;CACb;AAED;EACE,gBAAgB;CACjB;AAED;gFACgF;AAEhF;;GAEG;AAEH;EACE,UAAU;CACX;AAED;;GAEG;AAEH;EACE,iBAAiB;CAClB;AAED;gFACgF;AAEhF;;GAEG;AAEH;EACE,iBAAiB;CAClB;AAED;;GAEG;AAEH;EACE,wBAAwB;EACxB,UAAU;CACX;AAED;;GAEG;AAEH;EACE,eAAe;CAChB;AAED;;GAEG;AAEH;;;;EAIE,kCAAkC;EAClC,eAAe;CAChB;AAED;gFACgF;AAEhF;;;GAGG;AAEH;;;;;GAKG;AAEH;;;;;EAKE,eAAe,CAAC,OAAO;EACvB,cAAc,CAAC,OAAO;EACtB,UAAU,CAAC,OAAO;CACnB;AAED;;GAEG;AAEH;EACE,kBAAkB;CACnB;AAED;;;;;GAKG;AAEH;;EAEE,qBAAqB;CACtB;AAED;;;;;;GAMG;AAEH;;;;EAIE,2BAA2B,CAAC,OAAO;EACnC,gBAAgB,CAAC,OAAO;CACzB;AAED;;GAEG;AAEH;;EAEE,gBAAgB;CACjB;AAED;;GAEG;AAEH;;EAEE,UAAU;EACV,WAAW;CACZ;AAED;;;GAGG;AAEH;EACE,oBAAoB;CACrB;AAED;;;;;;GAMG;AAEH;;EAEE,uBAAuB,CAAC,OAAO;EAC/B,WAAW,CAAC,OAAO;CACpB;AAED;;;;GAIG;AAEH;;EAEE,aAAa;CACd;AAED;;;GAGG;AAEH;EACE,8BAA8B,CAAC,OAAO;EACtC,wBAAwB,CAAC,OAAO;CACjC;AAED;;;;GAIG;AAEH;;EAEE,yBAAyB;CAC1B;AAED;;;;;GAKG;AACH;IACI,qBAAqB;CACxB;AAED;;GAEG;AAEH;EACE,0BAA0B;EAC1B,cAAc;EACd,+BAA+B;CAChC;AAED;;;GAGG;AAEH;EACE,UAAU,CAAC,OAAO;EAClB,WAAW,CAAC,OAAO;CACpB;AAED;;GAEG;AAEH;EACE,eAAe;CAChB;AAED;;;GAGG;AAEH;EACE,kBAAkB;CACnB;AAED;gFACgF;AAEhF;;GAEG;AAEH;EACE,0BAA0B;EAC1B,kBAAkB;CACnB;AAED;;EAEE,WAAW;CACZ;AAED,2BAA2B;AAE3B;;gFAEgF;AAEhF;;GAEG;AAEH;;GAEG;AAEH;;IAEI,yBAAyB;CAC5B;AAED;;;GAGG;AACH;IACI,gBAAgB;IAChB,aAAa;IACb,eAAe;CAClB;ACxdD;;;;;;;;GAQG;AAEH;IACI,wBAAwB;IACxB,0BAA0B;IAC1B,gBAAgB;CACnB;AAED;;;IAGI,oBAAoB;IACpB,oBAAoB;IACpB,WAAW;IACX,eAAwB;IACxB,sBAAsB;CACzB;AACD;IACI,2BAAoC;CACvC;AAED;IACI,2BAA2B;CAC9B;AAED;IACI,aAAa;IACb,uBAAuB;CAC1B;AAED;IACI,YAAY;IACZ,UAAU;IACV,aAAa;IACb,8BAA8B;IAC9B,kBAAkB;CACrB;AAED;;;GAGG;AACH;IACI,sBAAsB;IACtB,mBAAmB;IACnB,gBAAgB;IAChB,kBAAkB;IAClB,yFAAyF;IACzF,oBAAoB;IACpB,gBAAgB;IAChB,kCAAkC;IAElC,sCAAsC;IACtC,kCAAkC;IAClC,8BAA8B;CACjC;AAED;IACI,mBAAmB;IACnB,mBAAmB;IACnB,uBAAuB;IACvB,gBAAgB;IAChB,YAAY;IACZ,eAAe;IACf,aAAa;CAChB;AAED;IACI,uBAAuB;IACvB,kBAAkB;CACrB;AAED;IACI,mBAAmB;IACnB,YAAY;CACf;AAED,2DAA2D;AAC3D;IACI,eAAe;IACf,WAAW;IACX,sBAAsB;CACzB;AACD,qCAAqC;AACrC;IACI,2BAA2B;CAC9B;AACD,yBAAyB;AACzB;;IAEI,aAAa;IACb,sBAAsB;CACzB;AAED;IACI,kBAAkB;CACrB;AAED;IACI,mBAAmB;CACtB;AAED;IACI,mBAAmB;CACtB;AAED,yFAAyF;AACzF;;;;;;;IAOI;AAEJ;IACI,OAAO;IACP,WAAW;CACd;AACD;IACI,OAAO;IACP,UAAU;CACb;AACD;IACI,SAAS;IACT,WAAW;CACd;AACD;IACI,SAAS;IACT,UAAU;CACb;AACD;IACI,SAAS;IACT,WAAW;CACd;AACD;IACI,SAAS;IACT,UAAU;CACb;AACD;IACI,SAAS;IACT,WAAW;CACd;AACD;IACI,SAAS;IACT,UAAU;CACb;AACD;IACI,SAAS;IACT,WAAW;CACd;AACD;IACI,SAAS;IACT,UAAU;CACb;AAED;;GAEG;AACH;IACI,YAAY;IACZ,4BAA4B;IAC5B,eAAe;IACf,eAAe;IACf,mBAAmB;IACnB,uBAAuB;IACvB,aAAa;CAChB;AAED;IACI,0BAA0B;IAC1B,uBAAuB;IACvB,kBAAkB;IAClB,eAAe;IACf,YAAY;CACf;AAED;IACI,iBAAiB;IACjB,UAAU;IACV,WAAW;IACX,oBAAoB;CACvB;AAED;IACI,gBAAgB;IAChB,WAAW;IACX,uBAAuB;IACvB,gBAAgB;IAChB,YAAY,CAAC,0DAA0D;CAC1E;AAED;;GAEG;AACH;IACI,YAAY;IACZ,iBAAiB;IACjB,sBAAsB;IACtB,gBAAgB;IAChB,kBAAkB;IAClB,kBAAkB;CACrB;AAED;IACI,iBAAiB;CACpB;AAED;IACI,eAAe;IACf,YAAY;IACZ,iBAAiB;IACjB,mBAAmB;IACnB,YAAY;IACZ,mBAAmB;IACnB,oBAAoB;CACvB;AAED;IACI,sBAAsB;IACtB,oBAAoB;;CAEvB;AAED;IACI,mBAAmB;IACnB,4BAA4B;CAC/B;AAED;IACI,kBAAkB;CACrB;AAED;IACI,0BAA0B;CAC7B;AAED;IACI,sBAAsB;IACtB,kBAAkB;CACrB;AAED;IACI,kBAAkB;IAClB,mBAAmB;IACnB,iBAAiB;IACjB,uBAAuB;IACvB,WAAW;CACd;AAED;IACI,YAAY;IACZ,aAAa;IACb,gBAAgB;IAChB,cAAc;IACd,kBAAkB;CACrB;AAED;IACI,eAAe;IACf,YAAY;IACZ,eAAe;CAClB;AAED;IACI,YAAY;IACZ,2BAA2B,CAAC,sBAAsB;IAClD,mBAAmB;IACnB,uBAAuB;CAC1B;AAED;IACI,2BAA2B,CAAC,sBAAsB;IAClD,mBAAmB;IACnB,uBAAuB;CAC1B;AACD;IACI,uBAAuB;CAC1B;AAED;IACI,4CAA4C;IAC5C,uBAAuB;IACvB,wBAAwB;CAC3B;AAED;IACI,YAAY;IACZ,sBAAsB;IACtB,mBAAmB;IACnB,mBAAmB;CACtB;AAED;;;;;;;;GAQG;AACH;IACI,UAAU;IACV,WAAW;CACd;AACD,+BAA+B;AAC/B;IACI,gBAAgB;CACnB;AACD,iCAAiC;AACjC;IACI,gBAAgB;CACnB;AACD,0BAA0B;AAC1B;IACI,eAAe;IACf,kBAAkB;CACrB;AACD;IACI,cAAc;CACjB;AACD,yCAAyC;AACzC;IACI,kBAAkB;CACrB;AACD;IACI,cAAc;CACjB;AAED;;GAEG;AACH;;IAEI;QACI,8BAA8B;KACjC;;IAED;QACI,wBAAwB;QACxB,4BAA4B;QAC5B,sBAAsB;KACzB;;IAED;;QAEI,YAAY;QACZ,wBAAwB;KAC3B;;IAED;QACI,aAAa;KAChB;;CAEJ;AAED;IACI;QACI,oBAAoB;QACpB,WAAW;QACX,UAAU;QACV,aAAa;QACb,iBAAiB;QACjB,mBAAmB;QACnB,mBAAmB;KACtB;IACD;QACI,aAAa;QACb,YAAY;QACZ,mBAAmB;KACtB;IACD;QACI,YAAY;QACZ,aAAa;QACb,iBAAiB;QACjB,iBAAiB;QACjB,iBAAiB;QACjB,gBAAgB;KACnB;IACD;QACI,SAAS;QACT,YAAY;QACZ,WAAW;QACX,iBAAiB;QACjB,YAAY;QACZ,mBAAmB;KACtB;IACD;QACI,YAAY;QACZ,UAAU;QACV,mBAAmB;QACnB,WAAW;QACX,iBAAiB;QACjB,iBAAiB;QACjB,eAAe;QACf,YAAY;QACZ,WAAW;QACX,YAAY;KACf;IACD;QACI,cAAc;QACd,YAAY;QACZ,mBAAmB;QACnB,SAAS;QACT,QAAQ;QACR,SAAS;QACT,gBAAgB;QAChB,YAAY;QACZ,WAAW;QACX,iBAAiB;KACpB;IACD;QACI,cAAc;KACjB;IACD;QACI,eAAe;QACf,sBAAsB;KACzB;IACD;;QAEI,eAAe;QACf,uBAAuB;KAC1B;IACD;QACI,UAAU;QACV,kBAAkB;QAClB,mBAAmB;KACtB;IACD;QACI,cAAc;KACjB;IACD;QACI,YAAY;QACZ,WAAW;QACX,iBAAiB;QACjB,iBAAiB;KACpB;IACD;QACI,uBAAuB;KAC1B;IACD;QACI,cAAc;KACjB;IACD;QACI,sBAAsB;QACtB,oBAAoB;KACvB;IACD;QACI,gBAAgB;KACnB;IACD;QACI,WAAW;QACX,iBAAiB;KACpB;IACD;;QAEI,sBAAsB;QACtB,iBAAiB;QACjB,YAAY;KACf;IACD;QACI,kBAAkB;KACrB;CACJ;AAED;IACI;;QAEI,YAAY;KACf;IACD;QACI,aAAa;QACb,aAAa;KAChB;CACJ;AAED;IACI;QACI,YAAY;KACf;IACD;QACI,cAAc;KACjB;CACJ;AACD;IACI;QACI,WAAW;KACd;CACJ;AACD;IACI;QACI,YAAY;KACf;CACJ;AAED;IACI;QACI,2BAA2B;KAC9B;CACJ;AAED;IACI;QACI,2BAA2B;KAC9B;CACJ;AAED,kDAAkD;AAClD;IACI;;QAEI,oBAAoB;KACvB;;IAED;QACI,2BAA2B;KAC9B;CACJ;AAED,uEAAuE;AACvE;IACI;;QAEI,kBAAkB;KACrB;;IAED;QACI,yBAAyB;KAC5B;CACJ;AAED,+CAA+C;AAC/C;IACI,wBAAwB;IACxB,0BAA0B;IAC1B,mBAAmB;IACnB,8BAA8B;IAC9B,iCAAiC;IACjC,gBAAgB;IAChB,iBAAiB;IACjB,kBAAkB;IAClB,oBAAoB;CACvB;AACD;IACI,sBAAsB;IACtB,uBAAuB;CAC1B;AACD;IACI,0BAA0B;IAC1B,WAAW;CACd;AACD;IACI,0BAA0B;CAC7B;AAED,0CAA0C;AAC1C;IACI,gBAAgB;IAChB,iBAAiB;IACjB,YAAY,CAAC,0DAA0D;CAC1E;AACD;IACI,iBAAiB;IACjB,gBAAgB;IAChB,oBAAoB;CACvB","file":"style.css","sourcesContent":["/**\n* Colors from https://phabricator.wikimedia.org/diffusion/WMUI/browse/master/base.less\n*/\n:root {\n    --c-primary: #165c91;\n}","/*!\nPure v0.6.1-pre\nCopyright 2014 Yahoo! Inc. All rights reserved.\nLicensed under the BSD License.\nhttps://github.com/yahoo/pure/blob/master/LICENSE.md\n*/\n/*!\nnormalize.css v^3.0 | MIT License | git.io/normalize\nCopyright (c) Nicolas Gallagher and Jonathan Neal\n*/\n/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */\n\n/**\n * 1. Set default font family to sans-serif.\n * 2. Prevent iOS and IE text size adjust after device orientation change,\n *    without disabling user zoom.\n */\n\nhtml {\n  font-family: sans-serif; /* 1 */\n  -ms-text-size-adjust: 100%; /* 2 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/**\n * Remove default margin.\n */\n\nbody {\n  margin: 0;\n}\n\n/* HTML5 display definitions\n   ========================================================================== */\n\n/**\n * Correct `block` display not defined for any HTML5 element in IE 8/9.\n * Correct `block` display not defined for `details` or `summary` in IE 10/11\n * and Firefox.\n * Correct `block` display not defined for `main` in IE 11.\n */\n\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nmenu,\nnav,\nsection,\nsummary {\n  display: block;\n}\n\n/**\n * 1. Correct `inline-block` display not defined in IE 8/9.\n * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.\n */\n\naudio,\ncanvas,\nprogress,\nvideo {\n  display: inline-block; /* 1 */\n  vertical-align: baseline; /* 2 */\n}\n\n/**\n * Prevent modern browsers from displaying `audio` without controls.\n * Remove excess height in iOS 5 devices.\n */\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * Address `[hidden]` styling not present in IE 8/9/10.\n * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.\n */\n\n[hidden],\ntemplate {\n  display: none;\n}\n\n/* Links\n   ========================================================================== */\n\n/**\n * Remove the gray background color from active links in IE 10.\n */\n\na {\n  background-color: transparent;\n}\n\n/**\n * Improve readability of focused elements when they are also in an\n * active/hover state.\n */\n\na:active,\na:hover {\n  outline: 0;\n}\n\n/* Text-level semantics\n   ========================================================================== */\n\n/**\n * Address styling not present in IE 8/9/10/11, Safari, and Chrome.\n */\n\nabbr[title] {\n  border-bottom: 1px dotted;\n}\n\n/**\n * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.\n */\n\nb,\nstrong {\n  font-weight: bold;\n}\n\n/**\n * Address styling not present in Safari and Chrome.\n */\n\ndfn {\n  font-style: italic;\n}\n\n/**\n * Address variable `h1` font-size and margin within `section` and `article`\n * contexts in Firefox 4+, Safari, and Chrome.\n */\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/**\n * Address styling not present in IE 8/9.\n */\n\nmark {\n  background: #ff0;\n  color: #000;\n}\n\n/**\n * Address inconsistent and variable font size in all browsers.\n */\n\nsmall {\n  font-size: 85%; /* CHANGED from 80% to 85% */\n}\n\n/**\n * Prevent `sub` and `sup` affecting `line-height` in all browsers.\n */\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsup {\n  top: -0.5em;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\n/* Embedded content\n   ========================================================================== */\n\n/**\n * Remove border when inside `a` element in IE 8/9/10.\n */\n\nimg {\n  border: 0;\n}\n\n/**\n * Correct overflow not hidden in IE 9/10/11.\n */\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Grouping content\n   ========================================================================== */\n\n/**\n * Address margin not present in IE 8/9 and Safari.\n */\n\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n * Address differences between Firefox and other browsers.\n */\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n}\n\n/**\n * Contain overflow in all browsers.\n */\n\npre {\n  overflow: auto;\n}\n\n/**\n * Address odd `em`-unit font size rendering in all browsers.\n */\n\ncode,\nkbd,\npre,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\n/* Forms\n   ========================================================================== */\n\n/**\n * Known limitation: by default, Chrome and Safari on OS X allow very limited\n * styling of `select`, unless a `border` property is set.\n */\n\n/**\n * 1. Correct color not being inherited.\n *    Known issue: affects color of disabled elements.\n * 2. Correct font properties not being inherited.\n * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  color: inherit; /* 1 */\n  font: inherit; /* 2 */\n  margin: 0; /* 3 */\n}\n\n/**\n * Address `overflow` set to `hidden` in IE 8/9/10/11.\n */\n\nbutton {\n  overflow: visible;\n}\n\n/**\n * Address inconsistent `text-transform` inheritance for `button` and `select`.\n * All other form control elements do not inherit `text-transform` values.\n * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.\n * Correct `select` style inheritance in Firefox.\n */\n\nbutton,\nselect {\n  text-transform: none;\n}\n\n/**\n * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n *    and `video` controls.\n * 2. Correct inability to style clickable `input` types in iOS.\n * 3. Improve usability and consistency of cursor style between image-type\n *    `input` and others.\n */\n\nbutton,\nhtml input[type=\"button\"], /* 1 */\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n  -webkit-appearance: button; /* 2 */\n  cursor: pointer; /* 3 */\n}\n\n/**\n * Re-set default cursor for disabled elements.\n */\n\nbutton[disabled],\nhtml input[disabled] {\n  cursor: default;\n}\n\n/**\n * Remove inner padding and border in Firefox 4+.\n */\n\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\n\n/**\n * Address Firefox 4+ setting `line-height` on `input` using `!important` in\n * the UA stylesheet.\n */\n\ninput {\n  line-height: normal;\n}\n\n/**\n * It's recommended that you don't attempt to style these elements.\n * Firefox's implementation doesn't respect box-sizing, padding, or width.\n *\n * 1. Address box sizing set to `content-box` in IE 8/9/10.\n * 2. Remove excess padding in IE 8/9/10.\n */\n\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Fix the cursor style for Chrome's increment/decrement buttons. For certain\n * `font-size` values of the `input`, it causes the cursor style of the\n * decrement button to change from `default` to `text`.\n */\n\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Address `appearance` set to `searchfield` in Safari and Chrome.\n * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.\n */\n\ninput[type=\"search\"] {\n  -webkit-appearance: textfield; /* 1 */\n  box-sizing: content-box; /* 2 */\n}\n\n/**\n * Remove inner padding and search cancel button in Safari and Chrome on OS X.\n * Safari (but not Chrome) clips the cancel button when the search input has\n * padding (and `textfield` appearance).\n */\n\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * ADDED\n *\n * Remove extra space between input borders and input outline.\n * Needed for Safari.\n */\ninput[type=\"search\"]:focus {\n    outline-offset: -2px;\n}\n\n/**\n * Define consistent border, margin, and padding.\n */\n\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\n/**\n * 1. Correct `color` not being inherited in IE 8/9/10/11.\n * 2. Remove padding so people aren't caught out if they zero out fieldsets.\n */\n\nlegend {\n  border: 0; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Remove default vertical scrollbar in IE 8/9/10/11.\n */\n\ntextarea {\n  overflow: auto;\n}\n\n/**\n * Don't inherit the `font-weight` (applied by a rule above).\n * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.\n */\n\noptgroup {\n  font-weight: bold;\n}\n\n/* Tables\n   ========================================================================== */\n\n/**\n * Remove most spacing between table cells.\n */\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\ntd,\nth {\n  padding: 0;\n}\n\n/*csslint important:false*/\n\n/* ==========================================================================\n   Pure Base Extras\n   ========================================================================== */\n\n/**\n * Extra rules that Pure adds on top of Normalize.css\n */\n\n/**\n * Always hide an element when it has the `hidden` HTML attribute.\n */\n\n.hidden,\n[hidden] {\n    display: none !important;\n}\n\n/**\n * Add this class to an image to make it fit within it's fluid parent wrapper while maintaining\n * aspect ratio.\n */\n.pure-img {\n    max-width: 100%;\n    height: auto;\n    display: block;\n}\n","/**\n * This is the stylesheet for the [[m:Project portal]] templates.\n * It should loosely match the style of MediaWiki's Vector theme\n * for consistency.\n * Colors from ./skins/Vector/screen.css\n *\n * Indention style: 1 tab\n *\n */\n\nbody {\n    background-color: white;\n    font: 13px/1.5 sans-serif;\n    margin: 0.3em 0;\n}\n\na,\na:active,\na:focus {\n    unicode-bidi: embed;\n    white-space: nowrap;\n    outline: 0;\n    color: var(--c-primary);\n    text-decoration: none;\n}\na:focus {\n    outline: 1px solid var(--c-primary);\n}\n\na:hover {\n    text-decoration: underline;\n}\n\nimg {\n    border: none;\n    vertical-align: middle;\n}\n\nhr {\n    clear: both;\n    height: 0;\n    border: none;\n    border-bottom: 1px solid #aaa;\n    margin: 0.2em 1em;\n}\n\n/**\n * Central logo area for wiki-project portals\n * (e.g. where the globe is on www.wikipedia.org)\n */\n.central-textlogo {\n    margin: 1em 0 0.3em 0;\n    text-align: center;\n    font-size: 30px;\n    line-height: 110%;\n    font-family: 'Linux Libertine', 'Hoefler Text', Georgia, 'Times New Roman', Times, serif;\n    font-weight: normal;\n    padding: 10px 0;\n    /* Crossed W in Linux Libertine */\n    -moz-font-feature-settings: \"ss05=1\"; -moz-font-feature-settings: \"ss05\";\n    -webkit-font-feature-settings: \"ss05\";\n    -ms-font-feature-settings: \"ss05\";\n    font-feature-settings: \"ss05\";\n}\n\n.central-featured {\n    position: relative;\n    text-align: center;\n    vertical-align: middle;\n    max-width: 100%;\n    width: 42em;\n    margin: 0 auto;\n    height: 26em;\n}\n\n.central-featured-logo-wrapper{\n    vertical-align: middle;\n    line-height: 26em;\n}\n\n.central-featured-lang {\n    position: absolute;\n    width: 12em;\n}\n\n/* Make entire block clickable, surpress hover underline */\n.central-featured-lang .link-box {\n    display: block;\n    padding: 0;\n    text-decoration: none;\n}\n/* Restore underline on main label */\n.central-featured-lang .link-box:hover strong {\n    text-decoration: underline;\n}\n/* Surpress blue color */\n.central-featured-lang .link-box em,\n.central-featured-lang .link-box small {\n    color: black;\n    text-decoration: none;\n}\n\n.central-featured-lang strong {\n    font-size: larger;\n}\n\n.central-featured-lang em {\n    font-style: italic;\n}\n\n.central-featured-lang .emNonItalicLang {\n    font-style: normal;\n}\n\n/* Serbo-Croatian is dual-script, so it needs some tweaking to fit in the top 10 ring. */\n/* .digraphic strong {\n    font-size: 110%;\n    line-height: 1em;\n}\n.digraphic em,\n.digraphic em + br {\n    display: none;\n} */\n\n.lang1 {\n    top: 0;\n    right: 60%;\n}\n.lang2 {\n    top: 0;\n    left: 60%;\n}\n.lang3 {\n    top: 20%;\n    right: 70%;\n}\n.lang4 {\n    top: 20%;\n    left: 70%;\n}\n.lang5 {\n    top: 40%;\n    right: 72%;\n}\n.lang6 {\n    top: 40%;\n    left: 72%;\n}\n.lang7 {\n    top: 60%;\n    right: 70%;\n}\n.lang8 {\n    top: 60%;\n    left: 70%;\n}\n.lang9 {\n    top: 80%;\n    right: 60%;\n}\n.lang10 {\n    top: 80%;\n    left: 60%;\n}\n\n/**\n * Search bar below the central logo area\n */\n.search-container {\n    float: none;\n    margin: 1em auto 1.5em auto;\n    max-width: 95%;\n    padding: 0.3em;\n    text-align: center;\n    vertical-align: middle;\n    width: 540px;\n}\n\n.search-form fieldset {\n    background-color: #f9f9f9;\n    border: 1px solid #aaa;\n    margin-top: 0.5em;\n    padding: 0.7em;\n    width: auto;\n}\n\n.search-form #searchInput {\n    font-size: 1.2em;\n    margin: 0;\n    padding: 0;\n    vertical-align: top;\n}\n\n.search-form select {\n    margin: 0 0.4em;\n    padding: 0;\n    vertical-align: middle;\n    max-width: 12em;\n    width: 12em; /* otherwise the width is inconsistent between browsers */\n}\n\n/**\n * Language lists, bookshelves, etc.\n */\n.bookshelf-container {\n    width: 100%;\n    overflow: hidden;\n    margin: 2em 0 0.5em 0;\n    font-size: 13px;\n    font-weight: bold;\n    line-height: 20px;\n}\n\n.bookshelf-container .text {\n    padding: 0 0.5em;\n}\n\n.bookshelf {\n    display: block;\n    width: 300%;\n    overflow: hidden;\n    position: relative;\n    left: -100%;\n    text-align: center;\n    white-space: nowrap;\n}\n\n.bookshelf-container .bookend {\n    display: inline-block;\n    vertical-align: top;\n\n}\n\n.langlist {\n    text-align: center;\n    margin: 0.5em 3em 2.5em 3em;\n}\n\n.langlist-large {\n    font-size: larger;\n}\n\n.langlist-tiny {\n    margin: 0.5em 3em 3em 3em;\n}\n\n.langlist-others {\n    margin: 0 3em 2em 3em;\n    font-weight: bold;\n}\n\n.otherprojects {\n    font-weight: bold;\n    margin: 1.5em auto;\n    text-align: left;\n    vertical-align: middle;\n    width: 90%;\n}\n\n.otherprojects-item {\n    float: left;\n    height: 60px;\n    min-width: 12em;\n    width: 24.75%;\n    line-height: 60px;\n}\n\n.otherprojects-item a {\n    display: block;\n    width: 10em;\n    margin: 0 auto;\n}\n\n.sprite-project-logos-wrapper{\n    width: 47px;\n    display: -moz-inline-stack; display: inline-block;\n    text-align: center;\n    vertical-align: middle;\n}\n\n.otherprojects-item .sprite-project-logos{\n    display: -moz-inline-stack; display: inline-block;\n    text-align: center;\n    vertical-align: middle;\n}\n.otherprojects-item .otherprojects-item-name {\n    vertical-align: middle;\n}\n\n.sprite-project-logos-Wikispecies-logo_sister {\n    background-position: -0px -324px !important;\n    width: 35px !important;\n    height: 40px !important;\n}\n\n.wm-site-info {\n    clear: both;\n    margin: 2.5em 0 2em 0;\n    text-align: center;\n    padding-top: 1.5em;\n}\n\n/**\n * Style for horizontal lists (separator following item).\n * @note Support for unused tags like <dt> has been stripped out, and the\n *\t\t dependency on :last-child and JavaScript has been removed in favor of\n *\t\t :before.\n * @source mediawiki.org/wiki/Snippets/Horizontal_lists\n * @revision 6 (2014-05-09)\n * @author [[User:Edokter]]\n */\n.hlist ul {\n    margin: 0;\n    padding: 0;\n}\n/* Display list items inline */\n.hlist li {\n    display: inline;\n}\n/* Display nested lists inline */\n.hlist ul ul {\n    display: inline;\n}\n/* Generate interpuncts */\n.hlist li:before {\n    content: \" · \";\n    font-weight: bold;\n}\n.hlist li:first-child:before {\n    content: none;\n}\n/* Add parentheses around nested lists */\n.hlist li + ul:before {\n    content: \"\\00a0(\";\n}\n.hlist li + ul:after {\n    content: \") \";\n}\n\n/**\n * Print stylesheet\n */\n@media print {\n\n    body {\n        background-color: transparent;\n    }\n\n    a {\n        color: black !important;\n        background: none !important;\n        padding: 0 !important;\n    }\n\n    a:link,\n    a:visited {\n        color: #520;\n        background: transparent;\n    }\n\n    img {\n        border: none;\n    }\n\n}\n\n@media all and (max-width:480px) {\n    .central-textlogo {\n        line-height: normal;\n        padding: 0;\n        margin: 0;\n        height: 70px;\n        text-align: left;\n        padding-left: 84px;\n        position: relative;\n    }\n    .central-textlogo img {\n        height: 35px;\n        width: auto;\n        margin-top: 22.5px;\n    }\n    .central-featured {\n        width: auto;\n        height: auto;\n        padding-top: 2em;\n        text-align: left;\n        font-size: 0.8em;\n        margin-top: 4em;\n    }\n    .central-featured-logo {\n        right: 0;\n        left: 0.8em;\n        top: -70px;\n        margin-top: -4em;\n        width: 70px;\n        position: absolute;\n    }\n    .central-featured-lang {\n        right: auto;\n        top: auto;\n        position: relative;\n        left: auto;\n        text-align: left;\n        margin-left: 1em;\n        display: block;\n        float: left;\n        width: 40%;\n        height: 5em;\n    }\n    .search-container {\n        margin-top: 0;\n        height: 6em;\n        position: absolute;\n        top: 5em;\n        left: 0;\n        right: 0;\n        max-width: 100%;\n        width: auto;\n        padding: 0;\n        text-align: left;\n    }\n    .search-container label {\n        display: none;\n    }\n    .search-form #searchInput {\n        max-width: 40%;\n        vertical-align:middle;\n    }\n    .search-form #searchLanguage,\n    .search-form .formBtn {\n        max-width: 25%;\n        vertical-align: middle;\n    }\n    form fieldset {\n        margin: 0;\n        border-left: none;\n        border-right: none;\n    }\n    .language-search {\n        display: none;\n    }\n    .bookshelf {\n        width: auto;\n        left: auto;\n        overflow: hidden;\n        text-align: left;\n    }\n    .bookshelf-container .bookend {\n        width: 40px !important;\n    }\n    .bookshelf-container .bookend:last-child {\n        display: none;\n    }\n    .langlist a {\n        word-wrap: break-word;\n        white-space: normal;\n    }\n    .langlist {\n        font-size: 0.7em\n    }\n    .otherprojects-item {\n        width: 50%;\n        text-align: left;\n    }\n    .bookshelf-container,\n    .langlist {\n        margin: 1em 1em 0 1em;\n        text-align: left;\n        width: auto;\n    }\n    hr {\n        margin-top: 0.5em;\n    }\n}\n\n@media all and (max-width:240px) {\n    .central-featured-lang,\n    .otherprojects-item {\n        width: 100%;\n    }\n    .central-textlogo img {\n        width: 100px;\n        height: auto;\n    }\n}\n\n@media all and (max-width: 45em) {\n    .otherprojects {\n        width: 100%;\n    }\n    .otherprojects-item {\n        width: 33.33%;\n    }\n}\n@media all and (max-width: 30em) {\n    .otherprojects-item {\n        width: 50%;\n    }\n}\n@media all and (max-width: 20em) {\n    .otherprojects-item {\n        width: 100%;\n    }\n}\n\n@media (-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (min-resolution: 1.5dppx), (min-resolution: 144dpi) {\n    .bookshelf-container .bookend {\n        background-size: 40px auto;\n    }\n}\n\n@media (-webkit-min-device-pixel-ratio: 2), (min--moz-device-pixel-ratio: 2), (-o-min-device-pixel-ratio: 2), (min-resolution: 2dppx), (min-resolution: 192dpi) {\n    .bookshelf-container .bookend {\n        background-size: 40px auto;\n    }\n}\n\n/* Subpixel borders supported in Gecko, Trident */\n@media (min--moz-device-pixel-ratio: 2), (min-resolution: 2dppx), (min-resolution: 192dpi) {\n    #footer,\n    .search-form fieldset {\n        border-width: 0.5px;\n    }\n\n    hr {\n        border-bottom-width: 0.5px;\n    }\n}\n\n/* Subpixel borders not supported in older releases of Blink, WebKit */\n@supports (-webkit-transform: rotate(30deg)) {\n    #footer,\n    .search-form fieldset {\n        border-width: 1px;\n    }\n\n    hr {\n        border-bottom-width: 1px;\n    }\n}\n\n/* Gives the button its previous native look */\n.formBtn {\n    background-color: white;\n    border: 1px solid #E4E4E4;\n    border-radius: 4px;\n    border-top: 1px solid #e8e8e8;\n    border-bottom: 1px solid #CECECE;\n    font-size: 11px;\n    padding: 1px 8px;\n    margin-left: .3em;\n    vertical-align: top;\n}\n.formBtn .sprite-bookshelf_icons-search_icon {\n    display: inline-block;\n    vertical-align: middle;\n}\n.formBtn:focus {\n    background-color: #c0c0c0;\n    outline: 0;\n}\n.formBtn:active {\n    background-color: #b0b0b0;\n}\n\n/* Gives the inputs their previous look */\n.search-container .search-form #searchInput {\n    font-size: 13px;\n    padding: 1px 3px;\n    width: 15em; /* otherwise the width is inconsistent between browsers */\n}\n#langsearch-input {\n    padding: 1px 2px;\n    font-size: 11px;\n    vertical-align: top;\n}\n"]} */ \ No newline at end of file diff --git a/dev/wikipedia.org/assets/cssnext/README.txt b/dev/wikipedia.org/assets/cssnext/README.txt new file mode 100644 index 0000000..a6e4706 --- /dev/null +++ b/dev/wikipedia.org/assets/cssnext/README.txt @@ -0,0 +1,10 @@ +The files in the directory are processed by cssnext. +style.css is the 'main' file. All other files are +treated as 'partials' that should be included in style.css +via @import statements. PostCSS-import will expand the @import +statements and merge these files in style.css. + +All other files should be treated as 'partials' and +should begin with an underscore. + +_vars.css is reserved for css variables (css custom properties). \ No newline at end of file diff --git a/dev/wikipedia.org/assets/css/base.css b/dev/wikipedia.org/assets/cssnext/_base.css similarity index 100% rename from dev/wikipedia.org/assets/css/base.css rename to dev/wikipedia.org/assets/cssnext/_base.css diff --git a/dev/wikipedia.org/assets/css/buttons.css b/dev/wikipedia.org/assets/cssnext/_buttons.css similarity index 100% rename from dev/wikipedia.org/assets/css/buttons.css rename to dev/wikipedia.org/assets/cssnext/_buttons.css diff --git a/dev/wikipedia.org/assets/css/forms.css b/dev/wikipedia.org/assets/cssnext/_forms.css similarity index 100% rename from dev/wikipedia.org/assets/css/forms.css rename to dev/wikipedia.org/assets/cssnext/_forms.css diff --git a/dev/wikipedia.org/assets/css/pab1.css b/dev/wikipedia.org/assets/cssnext/_pab1.css similarity index 100% rename from dev/wikipedia.org/assets/css/pab1.css rename to dev/wikipedia.org/assets/cssnext/_pab1.css diff --git a/dev/wikipedia.org/assets/css/pab2.css b/dev/wikipedia.org/assets/cssnext/_pab2.css similarity index 100% rename from dev/wikipedia.org/assets/css/pab2.css rename to dev/wikipedia.org/assets/cssnext/_pab2.css diff --git a/dev/wikipedia.org/assets/cssnext/_vars.css b/dev/wikipedia.org/assets/cssnext/_vars.css new file mode 100644 index 0000000..037f11c --- /dev/null +++ b/dev/wikipedia.org/assets/cssnext/_vars.css @@ -0,0 +1,6 @@ +/** +* Colors from https://phabricator.wikimedia.org/diffusion/WMUI/browse/master/base.less +*/ +:root { + --c-primary: #165c91; +} \ No newline at end of file diff --git a/dev/wikipedia.org/assets/css/wm-portal.css b/dev/wikipedia.org/assets/cssnext/_wm-portal.css similarity index 95% rename from dev/wikipedia.org/assets/css/wm-portal.css rename to dev/wikipedia.org/assets/cssnext/_wm-portal.css index 93311d4..96304e6 100644 --- a/dev/wikipedia.org/assets/css/wm-portal.css +++ b/dev/wikipedia.org/assets/cssnext/_wm-portal.css @@ -6,14 +6,6 @@ * * Indention style: 1 tab * - * Don't be afraid to document changes here with comments, this stylesheet - * is loaded through ResourceLoader on the portal pages and as such is minified - * and squeezed into a tiny package delivered from bits.wikimedia.org - * - * Usage: - * <link rel="stylesheet" href="//meta.wikimedia.org/w/load.php?debug=false&lang=en&modules=ext.gadget.wm-portal&only=styles&skin=vector&*"> - * - * (if RTL flipping is needed, replace lang=en with the correct language) */ body { @@ -28,13 +20,12 @@ unicode-bidi: embed; white-space: nowrap; outline: 0; - color: #0645AD; + color: var(--c-primary); text-decoration: none; } a:focus { - outline: 1px solid #0645AD; + outline: 1px solid var(--c-primary); } - a:hover { text-decoration: underline; diff --git a/dev/wikipedia.org/assets/cssnext/style.css b/dev/wikipedia.org/assets/cssnext/style.css new file mode 100644 index 0000000..2ab91f2 --- /dev/null +++ b/dev/wikipedia.org/assets/cssnext/style.css @@ -0,0 +1,3 @@ +@import '_vars.css'; +@import '_base.css'; +@import '_wm-portal.css'; \ No newline at end of file diff --git a/dev/wikipedia.org/index.handlebars b/dev/wikipedia.org/index.handlebars index d83803f..835e696 100644 --- a/dev/wikipedia.org/index.handlebars +++ b/dev/wikipedia.org/index.handlebars @@ -8,8 +8,7 @@ <link rel="apple-touch-icon" href="/static/apple-touch/wikipedia.png"> <link rel="shortcut icon" href="/static/favicon/wikipedia.ico"> <link rel="license" href="//creativecommons.org/licenses/by-sa/3.0/"> -<link rel="stylesheet" href="assets/css/base.css"> -<link rel="stylesheet" href="assets/css/wm-portal.css"> +<link rel="stylesheet" href="assets/css/style.css"> <link rel="stylesheet" href="assets/css/sprites.css"> <!--[if lt IE 8]><style type="text/css"> diff --git a/gulpfile.js b/gulpfile.js index d49c785..8e17cf3 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -10,7 +10,8 @@ siteStats = require( './site-stats' ), fs = require( 'fs' ), sprity = require( 'sprity' ), - gulpif = require( 'gulp-if' ); + postCSSNext = require( 'postcss-cssnext' ), + postCSSImport = require( 'postcss-import' ); var baseDir, prodDir, plugins = gulpLoadPlugins(), @@ -96,12 +97,17 @@ }; config.watch = { - hb: [ baseDir + 'templates/*.handlebars', baseDir + '.json', baseDir + 'controller.js' ], - sprites: [ baseDir + 'assets/img/sprite_assets/**/*' ] + sprites: [ baseDir + 'assets/img/sprite_assets/**/*' ], + cssnext: baseDir + 'assets/cssnext/*.css', + hb: [ baseDir + '*.handlebars', + baseDir + '.json', + baseDir + 'controller.js', + baseDir + 'templates/**/*' + ] }; config.optImage = { - src: baseDir + 'assets/img/*', + src: [ baseDir + 'assets/img/*', '!' + baseDir + 'assets/img/sprite_assets' ], pngQuantOptions: { quality: '57-95', speed: 1 }, dest: prodDir + 'assets/img' }; @@ -129,10 +135,30 @@ } ); /** + * Compiles CSSNext files into regular CSS and + * outputs them into the CSS dev folder. + */ +gulp.task( 'cssnext', function () { + + if ( !baseDir ) { + gulp.start( 'build' ); + } + + return gulp.src( baseDir + 'assets/cssnext/style.css' ) + .pipe( plugins.postcss( [ + postCSSImport(), + postCSSNext() + ], + { map: { inline: true } } + ) ) + .pipe( gulp.dest( baseDir + 'assets/css/' ) ); +} ); + +/** * Inlines assets of index.html in dev folder, * moves index.html into prod folder */ -gulp.task( 'inline-assets', [ 'compile-handlebars' ], function () { +gulp.task( 'inline-assets', [ 'compile-handlebars', 'cssnext' ], function () { return gulp.src( config.inline.src ) .pipe( plugins.inline( config.inline.options ) ) .pipe( gulp.dest( prodDir ) ); @@ -174,7 +200,7 @@ /** * Optimizes images in dev folder and moves them into prod folder */ -gulp.task( 'optimize-images', [ 'build', 'sprite' ], function () { +gulp.task( 'optimize-images', [ 'build' ], function () { return gulp.src( config.optImage.src ) .pipe( plugins.imagemin() ) .pipe( imageminPngquant( config.optImage.pngQuantOptions )() ) @@ -182,13 +208,15 @@ } ); /** - * Watches for changes in dev folder and compiles handlebars + * Watches for changes in dev folder and compiles: + * - handlebars templates + * - CSSNext files * into dev folder. */ -gulp.task( 'watch', [ 'build', 'compile-handlebars', 'sprite' ], function () { +gulp.task( 'watch', [ 'build', 'compile-handlebars', 'sprite', 'cssnext' ], function () { gulp.watch( config.watch.hb, [ 'compile-handlebars' ] ); gulp.watch( config.watch.sprites, [ 'sprite' ] ); - + gulp.watch( config.watch.cssnext, [ 'cssnext' ] ); } ); /** @@ -257,8 +285,9 @@ split: true, margin: 0 } ) - .pipe( gulpif( '*.png', gulp.dest( baseDir + 'assets/img/' ), gulp.dest( baseDir + 'assets/css/' ) ) ); + .pipe( plugins[ 'if' ]( '*.png', gulp.dest( baseDir + 'assets/img/' ), gulp.dest( baseDir + 'assets/css/' ) ) ); } ); -gulp.task( 'default', [ 'build', 'lint', 'compile-handlebars', 'sprite', 'inline-assets', 'clean-prod-js', 'concat-minify-js', 'minify-html', 'optimize-images' ] ); +gulp.task( 'default', [ 'build', 'lint', 'compile-handlebars', 'sprite', 'cssnext', 'inline-assets', 'clean-prod-js', 'concat-minify-js', 'minify-html', 'optimize-images' ] ); + gulp.task( 'test', [ 'lint' ] ); diff --git a/package.json b/package.json index f0384b7..20ef7de 100644 --- a/package.json +++ b/package.json @@ -1,11 +1,12 @@ { "private": true, "scripts": { - "test": "gulp lint" + "test": "node ./tests/lint.js" }, "devDependencies": { "bluebird": "^3.0.5", "del": "^2.2.0", + "cssnext": "^1.8.4", "gulp": "^3.9.0", "gulp-compile-handlebars": "^0.5.0", "gulp-downloader": "^1.0.4", @@ -17,6 +18,7 @@ "gulp-jshint": "^1.11.2", "gulp-load-plugins": "^1.0.0", "gulp-minify-css": "^1.2.1", + "gulp-postcss": "^6.0.1", "gulp-rename": "^1.2.2", "gulp-rev": "^6.0.1", "gulp-rev-replace": "^0.4.3", @@ -26,6 +28,8 @@ "imagemin-pngquant": "^4.2.0", "lwip": "0.0.8", "moment": "^2.10.6", + "postcss-cssnext": "^2.4.0", + "postcss-import": "^8.0.2", "preq": "^0.4.6", "sprity": "^1.0.8", "underscore": "^1.8.3", diff --git a/prod/wikipedia.org/index.html b/prod/wikipedia.org/index.html index deee21a..56d24cc 100644 --- a/prod/wikipedia.org/index.html +++ b/prod/wikipedia.org/index.html @@ -8,8 +8,7 @@ <link rel="apple-touch-icon" href="/static/apple-touch/wikipedia.png"> <link rel="shortcut icon" href="/static/favicon/wikipedia.ico"> <link rel="license" href="//creativecommons.org/licenses/by-sa/3.0/"> -<style>img,legend{border:0}legend,td,th{padding:0}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,optgroup,strong{font-weight:700}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background:#ff0;color:#000}small{font-size:85%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{box-sizing:content-box;height:0}pre,textarea{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}input[type=search]:focus{outline-offset:-2px}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}table{border-collapse:collapse;border-spacing:0}.hidden,[hidden]{display:none!important}.pure-img{max-width:100%;height:auto;display:block}</style> -<style>hr,img{border:none}.central-featured,.search-container,img{vertical-align:middle}body{background-color:#fff;font:13px/1.5 sans-serif;margin:.3em 0}a,a:active,a:focus{unicode-bidi:embed;white-space:nowrap;outline:0;color:#0645AD;text-decoration:none}a:focus{outline:#0645AD solid 1px}a:hover{text-decoration:underline}hr{clear:both;height:0;border-bottom:1px solid #aaa;margin:.2em 1em}.central-textlogo{margin:1em 0 .3em;text-align:center;font-size:30px;line-height:110%;font-family:'Linux Libertine','Hoefler Text',Georgia,'Times New Roman',Times,serif;font-weight:400;padding:10px 0;-moz-font-feature-settings:"ss05=1";-moz-font-feature-settings:"ss05";-webkit-font-feature-settings:"ss05";-ms-font-feature-settings:"ss05";font-feature-settings:"ss05"}.central-featured{position:relative;text-align:center;max-width:100%;width:42em;margin:0 auto;height:26em}.central-featured-logo-wrapper{vertical-align:middle;line-height:26em}.central-featured-lang{position:absolute;width:12em}.central-featured-lang .link-box{display:block;padding:0;text-decoration:none}.central-featured-lang .link-box:hover strong{text-decoration:underline}.central-featured-lang .link-box em,.central-featured-lang .link-box small{color:#000;text-decoration:none}.central-featured-lang strong{font-size:larger}.central-featured-lang em{font-style:italic}.central-featured-lang .emNonItalicLang{font-style:normal}.lang1{top:0;right:60%}.lang2{top:0;left:60%}.lang3{top:20%;right:70%}.lang4{top:20%;left:70%}.lang5{top:40%;right:72%}.lang6{top:40%;left:72%}.lang7{top:60%;right:70%}.lang8{top:60%;left:70%}.lang9{top:80%;right:60%}.lang10{top:80%;left:60%}.search-container{float:none;margin:1em auto 1.5em;max-width:95%;padding:.3em;text-align:center;width:540px}.search-form fieldset{background-color:#f9f9f9;border:1px solid #aaa;margin-top:.5em;padding:.7em;width:auto}.search-form #searchInput{font-size:1.2em;margin:0;padding:0;vertical-align:top}.search-form select{margin:0 .4em;padding:0;vertical-align:middle;max-width:12em;width:12em}.bookshelf-container{width:100%;overflow:hidden;margin:2em 0 .5em;font-size:13px;font-weight:700;line-height:20px}.bookshelf-container .text{padding:0 .5em}.bookshelf{display:block;width:300%;overflow:hidden;position:relative;left:-100%;text-align:center;white-space:nowrap}.bookshelf-container .bookend{display:inline-block;vertical-align:top}.langlist{text-align:center;margin:.5em 3em 2.5em}.langlist-large{font-size:larger}.langlist-tiny{margin:.5em 3em 3em}.langlist-others{margin:0 3em 2em;font-weight:700}.otherprojects{font-weight:700;margin:1.5em auto;text-align:left;vertical-align:middle;width:90%}.otherprojects-item{float:left;height:60px;min-width:12em;width:24.75%;line-height:60px}.otherprojects-item a{display:block;width:10em;margin:0 auto}.sprite-project-logos-wrapper{width:47px;display:-moz-inline-stack;display:inline-block;text-align:center;vertical-align:middle}.otherprojects-item .sprite-project-logos{display:-moz-inline-stack;display:inline-block;text-align:center;vertical-align:middle}.otherprojects-item .otherprojects-item-name{vertical-align:middle}.sprite-project-logos-Wikispecies-logo_sister{background-position:0 -324px!important;width:35px!important;height:40px!important}.wm-site-info{clear:both;margin:2.5em 0 2em;text-align:center;padding-top:1.5em}.hlist ul{margin:0;padding:0}.hlist li,.hlist ul ul{display:inline}.hlist li:before{content:" · ";font-weight:700}.hlist li:first-child:before{content:none}.hlist li+ul:before{content:"\00a0("}.hlist li+ul:after{content:") "}@media print{body{background-color:transparent}a{color:#000!important;background:0 0!important;padding:0!important}a:link,a:visited{color:#520;background:0 0}img{border:none}}@media all and (max-width:480px){.central-textlogo{line-height:normal;padding:0 0 0 84px;margin:0;height:70px;text-align:left;position:relative}.central-textlogo img{height:35px;width:auto;margin-top:22.5px}.central-featured{width:auto;height:auto;padding-top:2em;text-align:left;font-size:.8em;margin-top:4em}.central-featured-logo{right:0;left:.8em;top:-70px;margin-top:-4em;width:70px;position:absolute}.central-featured-lang{right:auto;top:auto;position:relative;left:auto;text-align:left;margin-left:1em;display:block;float:left;width:40%;height:5em}.language-search,.search-container label{display:none}.search-container{margin-top:0;height:6em;position:absolute;top:5em;left:0;right:0;max-width:100%;width:auto;padding:0;text-align:left}.search-form #searchInput{max-width:40%;vertical-align:middle}.search-form #searchLanguage,.search-form .formBtn{max-width:25%;vertical-align:middle}form fieldset{margin:0;border-left:none;border-right:none}.bookshelf{width:auto;left:auto;overflow:hidden;text-align:left}.bookshelf-container .bookend{width:40px!important}.bookshelf-container .bookend:last-child{display:none}.langlist a{word-wrap:break-word;white-space:normal}.langlist{font-size:.7em}.otherprojects-item{width:50%;text-align:left}.bookshelf-container,.langlist{margin:1em 1em 0;text-align:left;width:auto}hr{margin-top:.5em}}@media all and (max-width:240px){.central-featured-lang,.otherprojects-item{width:100%}.central-textlogo img{width:100px;height:auto}}@media all and (max-width:45em){.otherprojects{width:100%}.otherprojects-item{width:33.33%}}@media all and (max-width:30em){.otherprojects-item{width:50%}}@media all and (max-width:20em){.otherprojects-item{width:100%}}@media (-webkit-min-device-pixel-ratio:1.5),(min--moz-device-pixel-ratio:1.5),(-o-min-device-pixel-ratio:3/2),(min-resolution:1.5dppx),(min-resolution:144dpi){.bookshelf-container .bookend{background-size:40px auto}}@media (-webkit-min-device-pixel-ratio:2),(min--moz-device-pixel-ratio:2),(-o-min-device-pixel-ratio:2),(min-resolution:2dppx),(min-resolution:192dpi){.bookshelf-container .bookend{background-size:40px auto}}@media (min--moz-device-pixel-ratio:2),(min-resolution:2dppx),(min-resolution:192dpi){#footer,.search-form fieldset{border-width:.5px}hr{border-bottom-width:.5px}}@supports (-webkit-transform:rotate(30deg)){#footer,.search-form fieldset{border-width:1px}hr{border-bottom-width:1px}}.formBtn{background-color:#fff;border:1px solid #E4E4E4;border-radius:4px;border-top:1px solid #e8e8e8;border-bottom:1px solid #CECECE;font-size:11px;padding:1px 8px;margin-left:.3em;vertical-align:top}.formBtn .sprite-bookshelf_icons-search_icon{display:inline-block;vertical-align:middle}.formBtn:focus{background-color:silver;outline:0}.formBtn:active{background-color:#b0b0b0}.search-container .search-form #searchInput{font-size:13px;padding:1px 3px;width:15em}#langsearch-input{padding:1px 2px;font-size:11px;vertical-align:top}</style> +<style>legend,td,th{padding:0}hr,img{border:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,optgroup,strong{font-weight:700}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background:#ff0;color:#000}small{font-size:85%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}.central-featured,.search-container,img{vertical-align:middle}sup{top:-.5em}sub{bottom:-.25em}svg:not(:root){overflow:hidden}figure{margin:1em 40px}pre,textarea{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}input[type=search]:focus{outline-offset:-2px}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0}table{border-collapse:collapse;border-spacing:0}.hidden,[hidden]{display:none!important}.pure-img{max-width:100%;height:auto;display:block}body{background-color:#fff;font:13px/1.5 sans-serif;margin:.3em 0}a,a:active,a:focus{unicode-bidi:embed;white-space:nowrap;outline:0;color:#165c91;text-decoration:none}a:focus{outline:#165c91 solid 1px}a:hover{text-decoration:underline}hr{box-sizing:content-box;clear:both;height:0;border-bottom:1px solid #aaa;margin:.2em 1em}.central-textlogo{margin:1em 0 .3em;text-align:center;font-size:30px;line-height:110%;font-family:'Linux Libertine','Hoefler Text',Georgia,'Times New Roman',Times,serif;font-weight:400;padding:10px 0;-webkit-font-feature-settings:"ss05";-ms-font-feature-settings:"ss05";font-feature-settings:"ss05"}.central-featured{position:relative;text-align:center;max-width:100%;width:42em;margin:0 auto;height:26em}.central-featured-logo-wrapper{vertical-align:middle;line-height:26em}.central-featured-lang{position:absolute;width:12em}.central-featured-lang .link-box{display:block;padding:0;text-decoration:none}.central-featured-lang .link-box:hover strong{text-decoration:underline}.central-featured-lang .link-box em,.central-featured-lang .link-box small{color:#000;text-decoration:none}.central-featured-lang strong{font-size:larger}.central-featured-lang em{font-style:italic}.central-featured-lang .emNonItalicLang{font-style:normal}.lang1{top:0;right:60%}.lang2{top:0;left:60%}.lang3{top:20%;right:70%}.lang4{top:20%;left:70%}.lang5{top:40%;right:72%}.lang6{top:40%;left:72%}.lang7{top:60%;right:70%}.lang8{top:60%;left:70%}.lang9{top:80%;right:60%}.lang10{top:80%;left:60%}.search-container{float:none;margin:1em auto 1.5em;max-width:95%;padding:.3em;text-align:center;width:540px}.search-form fieldset{background-color:#f9f9f9;border:1px solid #aaa;margin-top:.5em;padding:.7em;width:auto}.search-form #searchInput{font-size:1.2em;margin:0;padding:0;vertical-align:top}.search-form select{margin:0 .4em;padding:0;vertical-align:middle;max-width:12em;width:12em}.bookshelf-container{width:100%;overflow:hidden;margin:2em 0 .5em;font-size:13px;font-weight:700;line-height:20px}.bookshelf-container .text{padding:0 .5em}.bookshelf{display:block;width:300%;overflow:hidden;position:relative;left:-100%;text-align:center;white-space:nowrap}.bookshelf-container .bookend{display:inline-block;vertical-align:top}.langlist{text-align:center;margin:.5em 3em 2.5em}.langlist-large{font-size:larger}.langlist-tiny{margin:.5em 3em 3em}.langlist-others{margin:0 3em 2em;font-weight:700}.otherprojects{font-weight:700;margin:1.5em auto;text-align:left;vertical-align:middle;width:90%}.otherprojects-item{float:left;height:60px;min-width:12em;width:24.75%;line-height:60px}.otherprojects-item a{display:block;width:10em;margin:0 auto}.sprite-project-logos-wrapper{width:47px;display:-moz-inline-stack;display:inline-block;text-align:center;vertical-align:middle}.otherprojects-item .sprite-project-logos{display:-moz-inline-stack;display:inline-block;text-align:center;vertical-align:middle}.otherprojects-item .otherprojects-item-name{vertical-align:middle}.sprite-project-logos-Wikispecies-logo_sister{background-position:0 -324px!important;width:35px!important;height:40px!important}.wm-site-info{clear:both;margin:2.5em 0 2em;text-align:center;padding-top:1.5em}.hlist ul{margin:0;padding:0}.hlist li,.hlist ul ul{display:inline}.hlist li:before{content:" · ";font-weight:700}.hlist li:first-child:before{content:none}.hlist li+ul:before{content:"\00a0("}.hlist li+ul:after{content:") "}@media print{body{background-color:transparent}a{color:#000!important;background:0 0!important;padding:0!important}a:link,a:visited{color:#520;background:0 0}img{border:none}}@media all and (max-width:480px){.central-textlogo{line-height:normal;padding:0 0 0 84px;margin:0;height:70px;text-align:left;position:relative}.central-textlogo img{height:35px;width:auto;margin-top:22.5px}.central-featured{width:auto;height:auto;padding-top:2em;text-align:left;font-size:.8em;margin-top:4em}.central-featured-logo{right:0;left:.8em;top:-70px;margin-top:-4em;width:70px;position:absolute}.central-featured-lang{right:auto;top:auto;position:relative;left:auto;text-align:left;margin-left:1em;display:block;float:left;width:40%;height:5em}.language-search,.search-container label{display:none}.search-container{margin-top:0;height:6em;position:absolute;top:5em;left:0;right:0;max-width:100%;width:auto;padding:0;text-align:left}.search-form #searchInput{max-width:40%;vertical-align:middle}.search-form #searchLanguage,.search-form .formBtn{max-width:25%;vertical-align:middle}form fieldset{margin:0;border-left:none;border-right:none}.bookshelf{width:auto;left:auto;overflow:hidden;text-align:left}.bookshelf-container .bookend{width:40px!important}.bookshelf-container .bookend:last-child{display:none}.langlist a{word-wrap:break-word;white-space:normal}.langlist{font-size:.7em}.otherprojects-item{width:50%;text-align:left}.bookshelf-container,.langlist{margin:1em 1em 0;text-align:left;width:auto}hr{margin-top:.5em}}@media all and (max-width:240px){.central-featured-lang,.otherprojects-item{width:100%}.central-textlogo img{width:100px;height:auto}}@media all and (max-width:45em){.otherprojects{width:100%}.otherprojects-item{width:33.33%}}@media all and (max-width:30em){.otherprojects-item{width:50%}}@media all and (max-width:20em){.otherprojects-item{width:100%}}@media (-webkit-min-device-pixel-ratio:1.5),(min--moz-device-pixel-ratio:1.5),(min-resolution:1.5dppx),(min-resolution:144dpi){.bookshelf-container .bookend{background-size:40px auto}}@media (-webkit-min-device-pixel-ratio:2),(min--moz-device-pixel-ratio:2),(min-resolution:2dppx),(min-resolution:192dpi){.bookshelf-container .bookend{background-size:40px auto}}@media (min--moz-device-pixel-ratio:2),(-webkit-min-device-pixel-ratio:2),(min-resolution:2dppx),(min-resolution:192dpi){#footer,.search-form fieldset{border-width:.5px}hr{border-bottom-width:.5px}}@supports (-webkit-transform:rotate(30deg)){#footer,.search-form fieldset{border-width:1px}hr{border-bottom-width:1px}}.formBtn{background-color:#fff;border:1px solid #E4E4E4;border-radius:4px;border-top:1px solid #e8e8e8;border-bottom:1px solid #CECECE;font-size:11px;padding:1px 8px;margin-left:.3em;vertical-align:top}.formBtn .sprite-bookshelf_icons-search_icon{display:inline-block;vertical-align:middle}.formBtn:focus{background-color:silver;outline:0}.formBtn:active{background-color:#b0b0b0}.search-container .search-form #searchInput{font-size:13px;padding:1px 3px;width:15em}#langsearch-input{padding:1px 2px;font-size:11px;vertical-align:top}</style> <style>.sprite-bookshelf_icons{background-image:url(portal/wikipedia.org/assets/img/sprite-bookshelf_icons.png)}@media (-webkit-min-device-pixel-ratio:1.5),(min-resolution:144dpi){.sprite-bookshelf_icons{background-image:url(portal/wikipedia.org/assets/img/sprite-bookshelf_ic...@1.5x.png);background-size:40px 57px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.sprite-bookshelf_icons{background-image:url(portal/wikipedia.org/assets/img/sprite-bookshelf_ic...@2x.png);background-size:40px 57px}}.sprite-bookshelf_icons-caretDown{background-position:0 0;width:12px;height:12px}.sprite-bookshelf_icons-search-ltr-invert{background-position:0 -12px;width:12px;height:12px}.sprite-bookshelf_icons-search_icon{background-position:0 -24px;width:12px;height:13px}.sprite-bookshelf_icons-Bookshelf{background-position:0 -37px;width:40px;height:20px}.sprite-project-logos{background-image:url(portal/wikipedia.org/assets/img/sprite-project-logos.png)}@media (-webkit-min-device-pixel-ratio:1.5),(min-resolution:144dpi){.sprite-project-logos{background-image:url(portal/wikipedia.org/assets/img/sprite-project-lo...@1.5x.png);background-size:88px 452px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.sprite-project-logos{background-image:url(portal/wikipedia.org/assets/img/sprite-project-lo...@2x.png);background-size:88px 453px}}.sprite-project-logos-Wikinews-logo_sister{background-position:0 0;width:47px;height:26px}.sprite-project-logos-Wikidata-logo_sister{background-position:0 -26px;width:47px;height:27px}.sprite-project-logos-Wikiversity-logo_sister{background-position:0 -52px;width:35px;height:28px}.sprite-project-logos-wikimedia-button{background-position:0 -80px;width:88px;height:31px}.sprite-project-logos-Wikibooks-logo_sister{background-position:0 -111px;width:35px;height:35px}.sprite-project-logos-Meta-logo_sister{background-position:0 -146px;width:35px;height:35px}.sprite-project-logos-Wikivoyage-logo_sister{background-position:0 -181px;width:35px;height:35px}.sprite-project-logos-Wiktionary-logo_sister{background-position:0 -216px;width:35px;height:35px}.sprite-project-logos-MediaWiki-logo_sister{background-position:0 -251px;width:47px;height:36px}.sprite-project-logos-Wikisource-logo_sister{background-position:0 -287px;width:35px;height:37px}.sprite-project-logos-Wikispecies-logo_sister{background-position:0 -323px;width:35px;height:41px}.sprite-project-logos-Wikiquote-logo_sister{background-position:0 -364px;width:35px;height:42px}.sprite-project-logos-Commons-logo_sister{background-position:0 -406px;width:35px;height:47px}</style> <!--[if lt IE 8]><style type="text/css"> .bookshelf-container .bookend,.otherprojects-icon{zoom:1;display:inline} diff --git a/tests/lint.js b/tests/lint.js new file mode 100644 index 0000000..5ee6b69 --- /dev/null +++ b/tests/lint.js @@ -0,0 +1,15 @@ +var gulp = require( 'gulp' ), + jshint = require( 'gulp-jshint' ), + jscs = require( 'gulp-jscs' ); + +gulp.task( 'lint', function () { + var devFolder = 'dev/**/*.js'; + + gulp.src( [ '*.js', devFolder ] ) + .pipe( jshint( '.jshintrc' ) ) + .pipe( jshint.reporter( 'default' ) ) + .pipe( jscs() ) + .pipe( jscs.reporter() ); +} ); + +gulp.start( 'lint' ); -- To view, visit https://gerrit.wikimedia.org/r/268842 To unsubscribe, visit https://gerrit.wikimedia.org/r/settings Gerrit-MessageType: newchange Gerrit-Change-Id: Iacfddfc2feaea527b08a04aa3c8e13833d2d900f Gerrit-PatchSet: 1 Gerrit-Project: wikimedia/portals Gerrit-Branch: master Gerrit-Owner: JGirault <jgira...@wikimedia.org> _______________________________________________ MediaWiki-commits mailing list MediaWiki-commits@lists.wikimedia.org https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits