├── src
├── bin
│ └── .keep
└── scss
│ ├── theme
│ └── .keep
│ ├── components
│ ├── .keep
│ ├── _footer.scss
│ ├── _sidebar.scss
│ └── _navbar.scss
│ ├── tools
│ ├── function
│ │ ├── _strip-unit.scss
│ │ ├── _unitless.scss
│ │ └── _functions.scss
│ └── mixin
│ │ ├── _border_radius.scss
│ │ ├── _space.scss
│ │ ├── _vertical-rhythm.scss
│ │ ├── _font-size.scss
│ │ ├── _grid.scss
│ │ ├── _clearfix.scss
│ │ ├── _animations.scss
│ │ ├── _background-triangle.scss
│ │ ├── _mixins.scss
│ │ ├── _type.scss
│ │ └── _shadows.scss
│ ├── settings
│ ├── _default.scss
│ └── _settings.scss
│ └── theme.scss
├── views
├── .keep
├── editor.pug
├── settings.pug
├── layout.pug
└── includes
│ └── sprite.pug
├── app
├── models
│ ├── .keep
│ └── sidebar.js
├── controller
│ ├── sidebar.js
│ └── config.js
├── config.json
└── routes.js
├── assets
├── css
│ ├── .keep
│ ├── theme.min.css
│ ├── utilities.0.12.0.min.css
│ ├── theme.css
│ ├── theme.min.css.map
│ ├── utilities.0.12.0.css
│ └── utilities.0.12.0.min.css.map
├── img
│ └── .keep
└── js
│ ├── .keep
│ └── script.js
├── tests
├── all
│ ├── js
│ │ └── .keep
│ ├── img
│ │ └── .keep
│ ├── scss
│ │ ├── components
│ │ │ ├── .keep
│ │ │ ├── _paging.scss
│ │ │ ├── _menu.scss
│ │ │ ├── _toolbar.scss
│ │ │ ├── _forum.scss
│ │ │ ├── _list.scss
│ │ │ └── _topic.scss
│ │ ├── tools
│ │ │ ├── function
│ │ │ │ ├── _strip-unit.scss
│ │ │ │ ├── _unitless.scss
│ │ │ │ └── _functions.scss
│ │ │ └── mixin
│ │ │ │ ├── _border_radius.scss
│ │ │ │ ├── _space.scss
│ │ │ │ ├── _vertical-rhythm.scss
│ │ │ │ ├── _font-size.scss
│ │ │ │ ├── _grid.scss
│ │ │ │ ├── _clearfix.scss
│ │ │ │ ├── _animations.scss
│ │ │ │ ├── _background-triangle.scss
│ │ │ │ ├── _mixins.scss
│ │ │ │ ├── _type.scss
│ │ │ │ └── _shadows.scss
│ │ ├── utilities
│ │ │ ├── _resets.scss
│ │ │ ├── _clearfix.scss
│ │ │ ├── _print.scss
│ │ │ └── _visability.scss
│ │ ├── generic
│ │ │ ├── _box-sizing.scss
│ │ │ └── reset
│ │ │ │ ├── _groupings.scss
│ │ │ │ ├── _tables.scss
│ │ │ │ ├── _other.scss
│ │ │ │ ├── _type.scss
│ │ │ │ ├── _global.scss
│ │ │ │ └── _forms.scss
│ │ ├── base
│ │ │ ├── _global.scss
│ │ │ ├── _links.scss
│ │ │ ├── _type.scss
│ │ │ ├── _table.scss
│ │ │ └── _code.scss
│ │ ├── objects
│ │ │ ├── _icon.scss
│ │ │ ├── _tag.scss
│ │ │ ├── _grid.scss
│ │ │ ├── _button.scss
│ │ │ └── _col.scss
│ │ ├── settings
│ │ │ ├── _default.scss
│ │ │ └── _settings.scss
│ │ ├── utilities.scss
│ │ └── core.scss
│ ├── templates
│ │ ├── layout
│ │ │ └── layout.twig
│ │ ├── topic.twig
│ │ ├── includes
│ │ │ └── list-item.twig
│ │ └── forum.twig
│ └── css
│ │ ├── utilities.0.12.0.min.css
│ │ ├── utilities.0.12.0.css
│ │ └── utilities.0.12.0.min.css.map
└── prosilver
│ ├── img
│ └── .keep
│ ├── js
│ └── .keep
│ ├── template
│ └── .keep
│ └── scss
│ ├── theme
│ └── _temp.scss
│ ├── components
│ └── _temp.scss
│ ├── objects
│ └── _action-bar.scss
│ └── theme.scss
├── .gitignore
├── .travis.yml
├── .editorconfig
├── README.md
├── app.js
├── LICENSE
├── package.json
├── gulpfile.js
└── .postcss-sorting.json
/src/bin/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/views/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/app/models/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/assets/css/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/assets/img/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/assets/js/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/all/js/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/src/scss/theme/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/all/img/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/src/scss/components/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/prosilver/img/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/prosilver/js/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/all/scss/components/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/prosilver/template/.keep:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/prosilver/scss/theme/_temp.scss:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/prosilver/scss/components/_temp.scss:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # Dependencies Directory
2 | node_modules
--------------------------------------------------------------------------------
/.travis.yml:
--------------------------------------------------------------------------------
1 | language: node_js
2 | node_js:
3 | - "6"
4 | - "7"
--------------------------------------------------------------------------------
/views/editor.pug:
--------------------------------------------------------------------------------
1 | extends layout.pug
2 |
3 | block content
4 | .sidebar-app
5 | .c-sidebar
6 | ul.c-sidebar-menu
7 | sidebar-list(v-for="item in sidebarList", v-bind:sidebar="item")
--------------------------------------------------------------------------------
/app/controller/sidebar.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | var model = require('../models/sidebar');
4 |
5 | var sidebar = module.exports = {};
6 |
7 | sidebar.getData = function () {
8 | return model.get();
9 | };
10 |
--------------------------------------------------------------------------------
/views/settings.pug:
--------------------------------------------------------------------------------
1 | extends layout.pug
2 |
3 | block content
4 | .app
5 | .wrap
6 | .o-container
7 | h2.c-config-head Settings
8 | form
9 | config-list(v-for="item in configList", v-bind:config="item")
10 |
--------------------------------------------------------------------------------
/.editorconfig:
--------------------------------------------------------------------------------
1 | # editorconfig.org
2 |
3 | root = true
4 |
5 | [*]
6 | indent_style = tab
7 | indent_size = 4
8 | end_of_line = lf
9 | charset = utf-8
10 | trim_trailing_whitespace = true
11 | insert_final_newline = true
12 |
13 | [*.md]
14 | trim_trailing_whitespace = true
--------------------------------------------------------------------------------
/app/config.json:
--------------------------------------------------------------------------------
1 | [
2 | {
3 | "id": 1,
4 | "name": "Root",
5 | "setting": "../test/"
6 | },
7 |
8 | {
9 | "id": 2,
10 | "name": "Globals",
11 | "setting": "../test/all/"
12 | },
13 |
14 | {
15 | "id": 3,
16 | "name": "Current Theme",
17 | "setting": "../test/prosilver/"
18 | }
19 | ]
--------------------------------------------------------------------------------
/src/scss/components/_footer.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Footer
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 |
13 |
14 | //
15 | // @scss
16 | .c-footer {
17 | text-align: center;
18 | }
19 |
--------------------------------------------------------------------------------
/src/scss/tools/function/_strip-unit.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Strip Units
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A function for striping a value of units
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @scss
12 | @function strip-units($number) {
13 | @return $number / ($number * 0 + 1);
14 | }
15 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/function/_strip-unit.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Strip Units
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A function for striping a value of units
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @scss
12 | @function strip-units($number) {
13 | @return $number / ($number * 0 + 1);
14 | }
15 |
--------------------------------------------------------------------------------
/src/scss/tools/function/_unitless.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Unitless
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A function for returning unitless numer based on root font-size
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @scss
12 | @function unitless($line-height, $font-size: $default-font-size) {
13 | @return $line-height / $font-size;
14 | }
15 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_border_radius.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Border Radius
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //
7 | // Helper to make only top, bottom radius
8 | //
9 | //------------------------------------------------------------------------------
10 |
11 | //
12 | // @scss
13 | @mixin border-radius($type, $radius) {
14 | border-#{$type}-left-radius: $radius;
15 | border-#{$type}-right-radius: $radius;
16 | }
17 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/function/_unitless.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Unitless
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A function for returning unitless numer based on root font-size
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @scss
12 | @function unitless($line-height, $font-size: $default-font-size) {
13 | @return $line-height / $font-size;
14 | }
15 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_border_radius.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Border Radius
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //
7 | // Helper to make only top, bottom radius
8 | //
9 | //------------------------------------------------------------------------------
10 |
11 | //
12 | // @scss
13 | @mixin border-radius($type, $radius) {
14 | border-#{$type}-left-radius: $radius;
15 | border-#{$type}-right-radius: $radius;
16 | }
17 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Styleguide Designer
2 | [](https://travis-ci.org/sahil505/StyleGuideDesigner)
3 |
4 | ## What is it
5 | A Styleguide Driven Development System for Creating, Managing, customizing, & editing themes for PHPBB. GSoC 2017 project (https://www.phpbb.com/development/gsoc/ideas/#styleguide)
6 |
7 | ## What can you do with it
8 | Dynamically build & manage components in styleguides. Styleguides provide the ability to create/view/edit individual components directly in the documentation using (CSS/SCSS/PUG/JS).
9 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_space.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Space
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Space elements by an amount based on your magic number. Pass in the property
7 | // to be indented as a paramater
8 | //
9 | // Based on Typeset
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // @scss
15 | @mixin space($property) {
16 | #{$property}: 2 * $default-line-height;
17 | }
18 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_space.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Space
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Space elements by an amount based on your magic number. Pass in the property
7 | // to be indented as a paramater
8 | //
9 | // Based on Typeset
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // @scss
15 | @mixin space($property) {
16 | #{$property}: 2 * $default-line-height;
17 | }
18 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_vertical-rhythm.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Vertical Rhythm
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A lot of elements need to share some declarations (mainly for
7 | // vertical rhythm), so we `extend` some silent classes.
8 | //
9 | // based on Typeset
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // @scss
15 | @mixin vertical-rhythm {
16 | margin: 0 0 $default-line-height;
17 | }
18 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_vertical-rhythm.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Vertical Rhythm
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A lot of elements need to share some declarations (mainly for
7 | // vertical rhythm), so we `extend` some silent classes.
8 | //
9 | // based on Typeset
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // @scss
15 | @mixin vertical-rhythm {
16 | margin: 0 0 $default-line-height;
17 | }
18 |
--------------------------------------------------------------------------------
/tests/all/scss/utilities/_resets.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #utilities: Resets
3 | //------------------------------------------------------------------------------
4 | // #description
5 | //
6 | // Suppress the focus outline on elements that cannot be accessed via keyboard.
7 | // This prevents an unwanted focus outline from appearing around elements that
8 | // might still respond to pointer events.
9 | //
10 | //------------------------------------------------------------------------------
11 |
12 | //
13 | // #scss
14 |
15 | [tabindex="-1"]:focus {
16 | outline: none !important;
17 | }
18 |
--------------------------------------------------------------------------------
/tests/all/scss/generic/_box-sizing.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Box Sizing
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // Set the global `box-sizing` state to `border-box`.
7 | //
8 | // css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice
9 | // paulirish.com/2012/box-sizing-border-box-ftw
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // #scss
15 |
16 | html {
17 | box-sizing: border-box;
18 | }
19 |
20 | * {
21 | &,
22 | &:before,
23 | &:after {
24 | box-sizing: inherit;
25 | }
26 | }
27 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_font-size.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Font-size
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //
7 | // Typecsset Mixins
8 | //
9 | // Quickly generate a font-size in rems, with a pixel fallback, based on the
10 | // value we pass into the mixin
11 | //
12 | //------------------------------------------------------------------------------
13 |
14 | //
15 | // @scss
16 | @mixin font-size($font-size, $line-height: true) {
17 | font-size: rem($font-size);
18 | @if $line-height == true {
19 | line-height: ceil($font-size / $default-line-height) * ($default-line-height / $font-size);
20 | }
21 | }
22 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_font-size.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Font-size
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //
7 | // Typecsset Mixins
8 | //
9 | // Quickly generate a font-size in rems, with a pixel fallback, based on the
10 | // value we pass into the mixin
11 | //
12 | //------------------------------------------------------------------------------
13 |
14 | //
15 | // @scss
16 | @mixin font-size($font-size, $line-height: true) {
17 | font-size: rem($font-size);
18 | @if $line-height == true {
19 | line-height: ceil($font-size / $default-line-height) * ($default-line-height / $font-size);
20 | }
21 | }
22 |
--------------------------------------------------------------------------------
/app.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | var path = require('path');
4 | var express = require('express');
5 | var bodyParser = require('body-parser');
6 |
7 | var app = express();
8 |
9 | var routes = require('./app/routes');
10 |
11 | // All environments
12 | app.set('port', process.env.PORT || 3000);
13 | app.set('views', './views');
14 | app.set('view engine', 'pug');
15 |
16 | // Set static path
17 | app.use(express.static(path.join(__dirname, 'assets')));
18 |
19 | app.use(bodyParser.json());
20 |
21 | app.use('/', routes);
22 |
23 | // Express Server Setup
24 | app.listen(app.get('port'), function (err) {
25 | if (err) {
26 | console.log('Express Server Error!');
27 | } else {
28 | console.log('Express server listening on port ' + app.get('port'));
29 | }
30 | });
31 |
--------------------------------------------------------------------------------
/tests/all/scss/generic/reset/_groupings.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Groupings
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #scss
10 |
11 | //
12 | // 1. Reset browser default `rem`s
13 | // 2. code should wrap not cause horizontal scrolling
14 | // 3. Normalize v4 removed this property, causing `
` content to break out
15 | // of wrapping code snippets
16 | //
17 | pre {
18 | @include vertical-rhythm(); // [1]
19 | white-space: pre-wrap; // [2]
20 | overflow: auto; // [3]
21 | }
22 |
23 | figure {
24 | @include vertical-rhythm();
25 | }
26 |
--------------------------------------------------------------------------------
/app/controller/config.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | var config = module.exports = {};
4 |
5 | var fs = require('fs');
6 |
7 | config.data = [];
8 |
9 | config.update = function (req) {
10 | config.get();
11 | config.set(req);
12 | config.write();
13 | };
14 |
15 | config.get = function () {
16 | var data = require('../config.json');
17 |
18 | config.data = data;
19 | return data;
20 | };
21 |
22 | config.set = function (req) {
23 | var newConfig = {
24 | id: req.body.id,
25 | name: req.body.name,
26 | setting: req.body.setting
27 | };
28 | config.data[newConfig.id - 1] = newConfig;
29 | };
30 |
31 | config.write = function () {
32 | // Note: data has to be a string, before sending it to the server
33 | var data = JSON.stringify(config.get());
34 | fs.writeFile('app/config.json', data, 'utf8');
35 | };
36 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_grid.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Grid
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Mixin for generating the grid col widths
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @settings
12 |
13 | // Layout Variables
14 | $grid-gutter: $default-grid-gutter !default;
15 |
16 | // Breakpoints sizes are global
17 |
18 | //
19 | // @scss
20 |
21 | @mixin col-width($w: 0) {
22 | flex: 0 0 percentage($w / 12);
23 | width: percentage($w / 12);
24 | }
25 |
26 | @mixin pull($w: 0) {
27 | right: percentage($w / 12);
28 | }
29 |
30 | @mixin push($w: 0) {
31 | left: percentage($w / 12);
32 | }
33 |
34 | @mixin offset($w: 0) {
35 | margin-left: percentage($w / 12);
36 | }
37 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_grid.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Grid
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Mixin for generating the grid col widths
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @settings
12 |
13 | // Layout Variables
14 | $grid-gutter: $default-grid-gutter !default;
15 |
16 | // Breakpoints sizes are global
17 |
18 | //
19 | // @scss
20 |
21 | @mixin col-width($w: 0) {
22 | flex: 0 0 percentage($w / 12);
23 | width: percentage($w / 12);
24 | }
25 |
26 | @mixin pull($w: 0) {
27 | right: percentage($w / 12);
28 | }
29 |
30 | @mixin push($w: 0) {
31 | left: percentage($w / 12);
32 | }
33 |
34 | @mixin offset($w: 0) {
35 | margin-left: percentage($w / 12);
36 | }
37 |
--------------------------------------------------------------------------------
/tests/all/scss/base/_global.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #base: Global
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // High-level, page-level styling.
7 | //
8 | // 1. Set the default `font-size` and `line-height` for the entire project,
9 | // sourced from our default variables. The `font-size` is calculated to exist
10 | // in rems, the `line-height` is calculated to exist unitlessly.
11 | //
12 | //------------------------------------------------------------------------------
13 |
14 |
15 | //
16 | // #scss
17 |
18 | html {
19 | font-family: $default-font;
20 | font-size: $default-font-size; // [1]
21 | font-weight: 400;
22 | line-height: unitless($default-line-height); // [1]
23 | background-color: $default-body-bg;
24 | color: $default-body-color;
25 | }
26 |
--------------------------------------------------------------------------------
/tests/all/scss/utilities/_clearfix.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #utilities: Clearfix
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // Clearfix: contain floats
7 | //
8 | // For modern browsers
9 | // 1. The space content is one way to avoid an Opera bug when the
10 | // `contenteditable` attribute is included anywhere else in the document.
11 | // Otherwise it causes space to appear at the top and bottom of elements
12 | // that receive the `clearfix` class.
13 | // 2. The use of `table` rather than `block` is only necessary if using
14 | // `:before` to contain the top-margins of child elements.
15 | //
16 | //------------------------------------------------------------------------------
17 |
18 | //
19 | // #scss
20 |
21 | .u-clearfix {
22 | @include clearfix;
23 | }
24 |
--------------------------------------------------------------------------------
/tests/all/scss/objects/_icon.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #object: Icon
3 | //------------------------------------------------------------------------------
4 | // #description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #settings
10 | $icon-size: 24px !default;
11 | $icon-spacing: 8px !default;
12 |
13 | //
14 | // #scss
15 |
16 | //
17 | // Most commonly we want specific sizing and alignment for icons in links
18 | // as such we target tthe most common approach to including icons svgs.
19 | // However a modifier is available if you are usinf icon fonts
20 | //
21 |
22 | .o-icon {
23 | vertical-align: middle;
24 | width: $icon-size;
25 | height: $icon-size;
26 | margin-right: $icon-spacing;
27 |
28 | &.fa {
29 | font-size: $icon-size;
30 | vertical-align: baseline;
31 | }
32 | }
33 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_clearfix.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Clearfix
3 | //------------------------------------------------------------------------------
4 | // @description:
5 | //
6 | // Clearfix: contain floats
7 | //
8 | // For modern browsers
9 | // 1. The space content is one way to avoid an Opera bug when the
10 | // `contenteditable` attribute is included anywhere else in the document.
11 | // Otherwise it causes space to appear at the top and bottom of elements
12 | // that receive the `clearfix` class.
13 | // 2. The use of `table` rather than `block` is only necessary if using
14 | // `:before` to contain the top-margins of child elements.
15 | //
16 | //------------------------------------------------------------------------------
17 |
18 | //
19 | // @scss
20 | @mixin clearfix {
21 | &:after {
22 | display: table; // [2]
23 | clear: both;
24 | content: " "; // [1]
25 | }
26 | }
27 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_clearfix.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Clearfix
3 | //------------------------------------------------------------------------------
4 | // @description:
5 | //
6 | // Clearfix: contain floats
7 | //
8 | // For modern browsers
9 | // 1. The space content is one way to avoid an Opera bug when the
10 | // `contenteditable` attribute is included anywhere else in the document.
11 | // Otherwise it causes space to appear at the top and bottom of elements
12 | // that receive the `clearfix` class.
13 | // 2. The use of `table` rather than `block` is only necessary if using
14 | // `:before` to contain the top-margins of child elements.
15 | //
16 | //------------------------------------------------------------------------------
17 |
18 | //
19 | // @scss
20 | @mixin clearfix {
21 | &:after {
22 | display: table; // [2]
23 | clear: both;
24 | content: " "; // [1]
25 | }
26 | }
27 |
--------------------------------------------------------------------------------
/app/routes.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | var express = require('express');
4 | var config = require('./controller/config');
5 | var sidebar = require('./controller/sidebar');
6 |
7 | var router = express.Router();
8 |
9 | // Route to UPDATE the config
10 | router.post('/settings/config', function (req, res) {
11 | req.params.update = config.update(req);
12 | res.send(req.params.update);
13 | });
14 |
15 | // Route to READ the config
16 | router.get('/settings/config', function (req, res) {
17 | req.params.fetch = config.get();
18 | res.send(req.params.fetch);
19 | });
20 |
21 | // Render settings page
22 | router.get('/settings', function (req, res) {
23 | res.render('settings');
24 | });
25 |
26 | // Render editors page
27 | router.get('/editor', function (req, res) {
28 | res.render('editor');
29 | });
30 |
31 | // Route to READ the file
32 | router.get('/editor/sidebar', function (req, res) {
33 | req.params.fetch = sidebar.getData();
34 | res.send(req.params.fetch);
35 | });
36 |
37 | module.exports = router;
38 |
--------------------------------------------------------------------------------
/assets/css/theme.min.css:
--------------------------------------------------------------------------------
1 | .c-navbar{display:flex;overflow:hidden;flex-direction:row;flex-wrap:nowrap}.c-navbar-logo{font-size:1.25rem;font-weight:500;line-height:1.6;line-height:1;letter-spacing:.02em;float:left;flex:1;margin-bottom:0;padding:1rem}.c-navbar-menu{margin:0;padding:0;list-style-type:none}.c-navbar-menu-item{display:flex;float:right}.c-navbar-menu-link{font-size:1rem;line-height:3.5;text-decoration:none;color:#757575;display:inline-block;padding:0 1rem}.c-navbar-menu-link:hover{color:#258cf4}.c-navbar-menu-text{padding:.5rem}.c-navbar-icon{margin-right:0}.c-footer{text-align:center}.c-sidebar{border:1px solid transparent;border-right-color:#e7e7e7;display:flex;overflow:hidden;flex-wrap:nowrap;width:16%}.c-sidebar-menu{margin:0;padding:0;list-style-type:none}.c-sidebar-menu-item{display:flex}.c-sidebar-menu-link{font-size:1rem;line-height:3.5;text-decoration:none;color:#757575;display:block;padding:0 1rem}.c-sidebar-menu-link:hover{color:#258cf4}.c-sidebar-menu-text{padding:.5rem}
2 | /*# sourceMappingURL=theme.min.css.map */
3 |
--------------------------------------------------------------------------------
/tests/all/scss/generic/reset/_tables.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Tables
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #scss
10 |
11 | //
12 | // 1. Reset for nesting within parents with `background-color`.
13 | // 2. No longer part of Normalize since v4
14 | //
15 | table {
16 | @include vertical-rhythm();
17 | background-color: transparent; // [1]
18 | width: 100%;
19 | border-spacing: 0;
20 | border-collapse: collapse; // [2]
21 | }
22 |
23 | caption {
24 | text-align: left;
25 | color: $default-gray;
26 | margin: 0;
27 | padding: ($default-line-height / 3) 0;
28 | caption-side: bottom;
29 | }
30 |
31 | //
32 | // Centered by default, but left-aligned to match the `td`s below.
33 | //
34 | th {
35 | text-align: left;
36 | }
37 |
38 | th,
39 | td {
40 | margin: 0;
41 | padding: ($default-line-height / 2);
42 | }
43 |
--------------------------------------------------------------------------------
/tests/all/scss/objects/_tag.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #object: Tag
3 | //------------------------------------------------------------------------------
4 | // #description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #settings
10 |
11 | // Layout Variables
12 | $tag-spacing: 8px !default;
13 | $tag-border-radius: $default-border-radius !default;
14 |
15 | // Theme Variables
16 | $tag-background-color: $yellow-100 !default;
17 | $tag-color: $black-54 !default;
18 |
19 | //
20 | // #scss
21 |
22 | .o-tag {
23 | text-align: center;
24 | vertical-align: middle;
25 | background-color: $tag-background-color;
26 | border-radius: $tag-border-radius;
27 | color: $tag-color;
28 | display: inline-block;
29 | margin: 0 $tag-spacing 0 0;
30 | padding: ($tag-spacing / 4) $tag-spacing;
31 |
32 | // Empty tags collapse automatically
33 | &:empty {
34 | display: none;
35 | }
36 | @media (min-width: $bp-md) {
37 | white-space: nowrap;
38 | }
39 | }
40 |
--------------------------------------------------------------------------------
/app/models/sidebar.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | var model = module.exports = {};
4 | var fs = require('fs');
5 |
6 | model.newData = [];
7 |
8 | // Logic to read an array of files inside a directory
9 | model.get = function () {
10 | var allData = fs.readdirSync('tests/all/scss');
11 | var prosilverData = fs.readdirSync('tests/prosilver/scss');
12 | var localData = model.newData;
13 | for (var i = 0; i < allData.length; i++) {
14 | if (allData[i] === 'base' || allData[i] === 'settings' || allData[i] === 'objects' || allData[i] === 'components') {
15 | localData.push(allData[i]);
16 | }
17 | }
18 | localData.push('--------------');
19 | for (var j = 0; j < prosilverData.length; j++) {
20 | if (prosilverData[j] === 'theme' || prosilverData[j] === 'components' || prosilverData[j] === 'objects') {
21 | localData.push(prosilverData[j]);
22 | }
23 | }
24 | var swap = localData[1];
25 | localData[1] = localData[3];
26 | localData[3] = swap;
27 |
28 | var temp = localData[0];
29 | localData[0] = localData[1];
30 | localData[1] = temp;
31 |
32 | return localData;
33 | };
34 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | The MIT License (MIT)
2 |
3 | Copyright (c) 2017
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
--------------------------------------------------------------------------------
/src/scss/components/_sidebar.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Sidebar
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 |
13 |
14 | // Theme Variables
15 | $menu-link-color: $black-54 !default;
16 | $menu-link-hover-color: $default-action-color-hover !default;
17 |
18 |
19 | //
20 | // @scss
21 | .c-sidebar {
22 | overflow: hidden;
23 | display: flex;
24 | flex-wrap: nowrap;
25 | width: 16%;
26 | border: 1px solid transparent;
27 | border-right-color: #e7e7e7;
28 |
29 | &-menu {
30 | list-style-type: none;
31 | margin: 0;
32 | padding: 0;
33 | }
34 |
35 | &-menu-item {
36 | display: flex;
37 | }
38 |
39 | &-menu-link {
40 | display: block;
41 | font-size: 16px;
42 | line-height: 3.5;
43 | text-decoration: none;
44 | color: $menu-link-color;
45 | padding: 0 16px;
46 |
47 | &:hover {
48 | color: $menu-link-hover-color;
49 | }
50 | }
51 |
52 | &-menu-text {
53 | padding: 8px;
54 | }
55 | }
56 |
--------------------------------------------------------------------------------
/tests/all/templates/layout/layout.twig:
--------------------------------------------------------------------------------
1 | {# layout.twig #}
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
36 |
37 |
38 | {% include '../includes/imageset.twig' %}
39 |
40 |
41 |
42 | {% block component %}{% endblock %}
43 |
44 | {% include '../includes/icons.twig' %}
45 |
46 |
47 |
48 |
49 |
--------------------------------------------------------------------------------
/tests/all/scss/generic/reset/_other.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Other
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #scss
10 |
11 | //
12 | // Images
13 | // -----------------------------------------------------------------------------
14 | //
15 | // 1. Fluid images for responsive purposes.
16 | // 2. Offset `alt` text from surrounding copy.
17 | // 3. Setting `vertical-align` removes the whitespace that appears under `img`
18 | // elements when they are dropped into a page as-is. Safer alternative to
19 | // using `display: block;`.
20 | // 4. If a `width` and/or `height` attribute have been explicitly defined, let’s
21 | // not make the image fluid.
22 | //
23 | img {
24 | font-style: italic; // [2]
25 | vertical-align: middle; // [3]
26 | max-width: 100%; // [1]
27 |
28 | &[width],
29 | &[height] {
30 | max-width: none; // [4]
31 | }
32 | }
33 |
34 | //
35 | // A better looking default horizontal rule
36 | //
37 | hr {
38 | @include vertical-rhythm();
39 | border: 0;
40 | border-top: $default-border-size solid $default-gray;
41 | display: block;
42 | height: 1px;
43 | padding: 0;
44 | }
45 |
--------------------------------------------------------------------------------
/tests/all/scss/components/_paging.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Paging
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $paging-spacing: 8px !default;
13 | $paging-border-radius: $default-border-radius !default;
14 | $paging-icon-size: 24px !default;
15 |
16 | // Theme Variables
17 | $paging-link-background-hover-color: $default-action-bg-hover !default;
18 |
19 |
20 | //
21 | // @scss
22 | .c-paging {
23 | display: flex;
24 | margin: 0;
25 | padding: 0;
26 | list-style: none;
27 | align-content: center;
28 |
29 | &-item {
30 | margin: 0;
31 | }
32 |
33 | &-link {
34 | font-size: 18px;
35 | line-height: (30 / 18);
36 | border-radius: $paging-border-radius;
37 | margin: 0;
38 | padding: ($paging-spacing / 2) $paging-spacing;
39 |
40 | &:hover {
41 | text-decoration: none;
42 | background: $paging-link-background-hover-color;
43 | }
44 |
45 | &-icon {
46 | width: $paging-icon-size;
47 | height: $paging-icon-size;
48 | margin: 0;
49 | }
50 | }
51 |
52 | &-item:first-of-type .c-paging-link,
53 | &-item:last-of-type .c-paging-link {
54 | padding: ($paging-spacing / 2);
55 | }
56 | }
57 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_animations.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Animations
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 | $animation-curve-fast-out-slow-in: cubic-bezier(0.4, 0, 0.2, 1) !default;
11 | $animation-curve-linear-out-slow-in: cubic-bezier(0, 0, 0.2, 1) !default;
12 | $animation-curve-fast-out-linear-in: cubic-bezier(0.4, 0, 1, 1) !default;
13 |
14 | $default-animation-curve: $animation-curve-fast-out-slow-in !default;
15 |
16 | //
17 | // @scss
18 | @mixin material-animation-fast-out-slow-in($duration: 0.2s) {
19 | transition-timing-function: $animation-curve-fast-out-slow-in;
20 | transition-duration: $duration;
21 | }
22 |
23 | @mixin material-animation-linear-out-slow-in($duration: 0.2s) {
24 | transition-timing-function: $animation-curve-linear-out-slow-in;
25 | transition-duration: $duration;
26 | }
27 |
28 | @mixin material-animation-fast-out-linear-in($duration: 0.2s) {
29 | transition-timing-function: $animation-curve-fast-out-linear-in;
30 | transition-duration: $duration;
31 | }
32 |
33 | @mixin material-animation-default($duration: 0.2s) {
34 | transition-timing-function: $animation-curve-default;
35 | transition-duration: $duration;
36 | }
37 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_background-triangle.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Backround Triangle
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Adds a downward-facing triangle as a background image to an element.
7 | // The image is formatted as an SVG, making it easy to change the color.
8 | // Because Internet Explorer doesn't support encoded SVGs as background images,
9 | // a fallback is also included.
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // @scss
15 | @mixin background-triangle($color: $black) {
16 | /* stylelint-disable string-quotes */
17 | background-image: url('data:image/svg+xml;utf8,');
18 | /* stylelint-enable string-quotes */
19 | @media screen and (min-width: 0\0) {
20 | /* stylelint-disable string-quotes */
21 | background-image: url('');
22 | /* stylelint-enable string-quotes */
23 | }
24 | }
25 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_animations.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Animations
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 | $animation-curve-fast-out-slow-in: cubic-bezier(0.4, 0, 0.2, 1) !default;
11 | $animation-curve-linear-out-slow-in: cubic-bezier(0, 0, 0.2, 1) !default;
12 | $animation-curve-fast-out-linear-in: cubic-bezier(0.4, 0, 1, 1) !default;
13 |
14 | $default-animation-curve: $animation-curve-fast-out-slow-in !default;
15 |
16 | //
17 | // @scss
18 | @mixin material-animation-fast-out-slow-in($duration: 0.2s) {
19 | transition-timing-function: $animation-curve-fast-out-slow-in;
20 | transition-duration: $duration;
21 | }
22 |
23 | @mixin material-animation-linear-out-slow-in($duration: 0.2s) {
24 | transition-timing-function: $animation-curve-linear-out-slow-in;
25 | transition-duration: $duration;
26 | }
27 |
28 | @mixin material-animation-fast-out-linear-in($duration: 0.2s) {
29 | transition-timing-function: $animation-curve-fast-out-linear-in;
30 | transition-duration: $duration;
31 | }
32 |
33 | @mixin material-animation-default($duration: 0.2s) {
34 | transition-timing-function: $animation-curve-default;
35 | transition-duration: $duration;
36 | }
37 |
--------------------------------------------------------------------------------
/src/scss/components/_navbar.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Navbar
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $navbar-spacing: 16px !default;
13 |
14 |
15 | // Theme Variables
16 | $menu-link-color: $black-54 !default;
17 | $menu-link-hover-color: $default-action-color-hover !default;
18 |
19 |
20 | //
21 | // @scss
22 | .c-navbar {
23 | overflow: hidden;
24 | display: flex;
25 | flex-direction: row;
26 | flex-wrap: nowrap;
27 |
28 | &-logo {
29 | @include type(title);
30 | line-height: 1;
31 | float: left;
32 | flex: 1;
33 | margin-bottom: 0;
34 | padding: $navbar-spacing;
35 | }
36 |
37 | &-menu {
38 | list-style-type: none;
39 | margin: 0;
40 | padding: 0;
41 | }
42 |
43 | &-menu-item {
44 | display: flex;
45 | float: right;
46 | }
47 |
48 | &-menu-link {
49 | display: inline-block;
50 | font-size: 16px;
51 | line-height: 3.5;
52 | color: $menu-link-color;
53 | padding: 0 16px;
54 | text-decoration: none;
55 |
56 | &:hover {
57 | color: $menu-link-hover-color;
58 | }
59 | }
60 |
61 | &-menu-text {
62 | padding: 8px;
63 | }
64 |
65 | &-icon {
66 | margin-right: 0;
67 | }
68 | }
69 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_background-triangle.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Backround Triangle
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Adds a downward-facing triangle as a background image to an element.
7 | // The image is formatted as an SVG, making it easy to change the color.
8 | // Because Internet Explorer doesn't support encoded SVGs as background images,
9 | // a fallback is also included.
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // @scss
15 | @mixin background-triangle($color: $black) {
16 | /* stylelint-disable string-quotes */
17 | background-image: url('data:image/svg+xml;utf8,');
18 | /* stylelint-enable string-quotes */
19 | @media screen and (min-width: 0\0) {
20 | /* stylelint-disable string-quotes */
21 | background-image: url('');
22 | /* stylelint-enable string-quotes */
23 | }
24 | }
25 |
--------------------------------------------------------------------------------
/tests/all/scss/base/_links.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #base: Links
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // Establish the default link look
7 | //
8 | // And undo it for placeholder links/named anchors (without href)
9 | // which have not been made explicitly keyboard-focusable (without tabindex).
10 | //
11 | // It would be more straightforward to just use a[href] in previous block, but
12 | // that causes specificity issues in many other styles that are too complex to
13 | // fix.
14 | //
15 | //
16 | // See https://github.com/twbs/bootstrap/issues/19402
17 | //
18 | // 1. Its more problematic when setting text-decoration globally so we remove in
19 | // favour of specific components/helpers setting it as needed.
20 | //
21 | //------------------------------------------------------------------------------
22 |
23 | //
24 | // #settings
25 |
26 | // Theme Variables
27 | $link-color: $default-link-color !default;
28 | $link-hover-color: $default-link-color-hover !default;
29 |
30 | //
31 | // #scss
32 |
33 | a {
34 | text-decoration: none;
35 | color: $link-color;
36 |
37 | &:focus,
38 | &:hover {
39 | text-decoration: none; // [1]
40 | color: $link-hover-color;
41 | }
42 |
43 | &:focus {
44 | // Default
45 | outline: thin dotted;
46 | // WebKit
47 | outline: 4px auto -webkit-focus-ring-color;
48 | outline-offset: -1px;
49 | }
50 | }
51 |
--------------------------------------------------------------------------------
/tests/all/scss/base/_type.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #base: Type
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 |
9 | //
10 | // #scss
11 |
12 | h1 small,
13 | h2 small,
14 | h3 small,
15 | h4 small,
16 | h5 small,
17 | h6 small {
18 | @include type(display3, true);
19 | font-size: 60%;
20 | display: block;
21 | }
22 |
23 | h1 {
24 | @include type(display3);
25 | }
26 |
27 | h2 {
28 | @include type(display2);
29 | }
30 |
31 | h3 {
32 | @include type(display1);
33 | }
34 |
35 | h4 {
36 | @include type(headline);
37 | }
38 |
39 | h5 {
40 | @include type(title);
41 | }
42 |
43 | h6 {
44 | @include type(subhead2);
45 | }
46 |
47 | p {
48 | @include type(body2);
49 | }
50 |
51 | blockquote {
52 | @include type(blockquote);
53 | @include space(margin-left);
54 |
55 | p {
56 | font-size: inherit;
57 | font-weight: inherit;
58 | line-height: inherit;
59 |
60 | &:before {
61 | content: "“";
62 | }
63 |
64 | &:after {
65 | content: "";
66 | }
67 |
68 | &:last-of-type:after {
69 | content: "”";
70 | }
71 | }
72 | }
73 |
74 | mark {
75 | background-color: $yellow-200;
76 | }
77 |
78 | cite {
79 | @include type(caption);
80 | }
81 |
82 | address {
83 | @include type(body1);
84 | }
85 |
86 | ul,
87 | ol {
88 | @include type(body1);
89 | }
90 |
--------------------------------------------------------------------------------
/assets/css/utilities.0.12.0.min.css:
--------------------------------------------------------------------------------
1 | [tabindex="-1"]:focus{outline:none!important}.u-clearfix:after{display:table;clear:both;content:" "}.u-sr-only{border:0;position:absolute;overflow:hidden;clip:rect(0,0,0,0);width:1px;height:1px;margin:-.0625rem;padding:0}.u-sr-only.focusable:active,.u-sr-only.focusable:focus{position:static;overflow:visible;clip:auto;width:auto;height:auto;margin:0}.u-hidden,.u-hidden-xs-up{display:none!important}@media (max-width:575px){.u-hidden-xs-down{display:none!important}}@media (min-width:576px){.u-hidden-sm-up{display:none!important}}@media (max-width:767px){.u-hidden-sm-down{display:none!important}}@media (min-width:768px){.u-hidden-md-up{display:none!important}}@media (max-width:991px){.u-hidden-md-down{display:none!important}}@media (min-width:992px){.u-hidden-lg-up{display:none!important}}@media (max-width:1199px){.u-hidden-lg-down{display:none!important}}@media (min-width:1200px){.u-hidden-xl-up{display:none!important}}.u-hidden-xl-down{display:none!important}@media print{*,:after,:before,:first-letter,:first-line{background:transparent!important;box-shadow:none!important;text-shadow:none!important;color:#000!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="#"]:after,a[href^="javascript:"]:after{content:""}blockquote,pre{border:1px solid #9e9e9e;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}}
2 | /*# sourceMappingURL=utilities.0.12.0.min.css.map */
3 |
--------------------------------------------------------------------------------
/tests/all/css/utilities.0.12.0.min.css:
--------------------------------------------------------------------------------
1 | [tabindex="-1"]:focus{outline:none!important}.u-clearfix:after{display:table;clear:both;content:" "}.u-sr-only{border:0;position:absolute;overflow:hidden;clip:rect(0,0,0,0);width:1px;height:1px;margin:-.0625rem;padding:0}.u-sr-only.focusable:active,.u-sr-only.focusable:focus{position:static;overflow:visible;clip:auto;width:auto;height:auto;margin:0}.u-hidden,.u-hidden-xs-up{display:none!important}@media (max-width:575px){.u-hidden-xs-down{display:none!important}}@media (min-width:576px){.u-hidden-sm-up{display:none!important}}@media (max-width:767px){.u-hidden-sm-down{display:none!important}}@media (min-width:768px){.u-hidden-md-up{display:none!important}}@media (max-width:991px){.u-hidden-md-down{display:none!important}}@media (min-width:992px){.u-hidden-lg-up{display:none!important}}@media (max-width:1199px){.u-hidden-lg-down{display:none!important}}@media (min-width:1200px){.u-hidden-xl-up{display:none!important}}.u-hidden-xl-down{display:none!important}@media print{*,:after,:before,:first-letter,:first-line{background:transparent!important;box-shadow:none!important;text-shadow:none!important;color:#000!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="#"]:after,a[href^="javascript:"]:after{content:""}blockquote,pre{border:1px solid #9e9e9e;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}}
2 | /*# sourceMappingURL=utilities.0.12.0.min.css.map */
3 |
--------------------------------------------------------------------------------
/tests/all/scss/objects/_grid.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #object: Grid
3 | //------------------------------------------------------------------------------
4 | // #description
5 | //
6 | // This grid system is uses flex-box based on the BS4 grid system
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // #settings
12 |
13 | //
14 | // #scss
15 |
16 | //
17 | // Set up the default container and grid class for mobile browsers
18 | .o-container {
19 | position: relative;
20 | max-width: 100%;
21 | margin-right: auto;
22 | margin-left: auto;
23 | padding-right: $default-grid-gutter;
24 | padding-left: $default-grid-gutter;
25 |
26 | //
27 | // Establist container sizes for all devices larger than mobile
28 |
29 | //
30 | // small
31 | @media (min-width: $bp-sm) {
32 | width: $sm;
33 | }
34 |
35 | //
36 | // medium
37 | @media (min-width: $bp-md) {
38 | width: $md;
39 | }
40 |
41 | //
42 | // large
43 | @media (min-width: $bp-lg) {
44 | width: $lg;
45 | }
46 |
47 | //
48 | // extre-large
49 | @media (min-width: $bp-xl) {
50 | width: $xl;
51 | }
52 | }
53 |
54 | /* stylelint-disable value-no-vendor-prefix */
55 | .o-row {
56 | display: flex;
57 | flex-wrap: wrap;
58 | margin-right: -$grid-gutter;
59 | margin-left: -$grid-gutter;
60 | }
61 | /* stylelint-enable value-no-vendor-prefix */
62 |
63 | .o-col {
64 | position: relative;
65 | flex-basis: 0;
66 | flex-grow: 1;
67 | width: 100%;
68 | max-width: 100%;
69 | min-height: 1px;
70 | padding-right: $grid-gutter;
71 | padding-left: $grid-gutter;
72 | }
73 |
--------------------------------------------------------------------------------
/tests/all/templates/topic.twig:
--------------------------------------------------------------------------------
1 | {# forum.twig #}
2 | {% extends "./layout/layout.twig" %}
3 |
4 | {% block component %}
5 |
6 |
16 | {% for topic in topics %}
17 | {% if topic.type === "announce" %}
18 | {% include './includes/list-item.twig' %}
19 | {% endif %}
20 | {% endfor %}
21 |
22 |
23 |
33 | {% for topic in topics %}
34 | {% if topic.type === "sticky" %}
35 | {% include './includes/list-item.twig' %}
36 | {% endif %}
37 | {% endfor %}
38 | {% for topic in topics %}
39 | {% if topic.type === "topic" %}
40 | {% include './includes/list-item.twig' %}
41 | {% endif %}
42 | {% endfor %}
43 |
44 | {% endblock %}
45 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "sdd",
3 | "version": "0.0.1",
4 | "description": "Styleguide Driven Development System for creating, managing, customizing, & editing themesfor phpBB.",
5 | "main": "app.js",
6 | "xo": {
7 | "env": [
8 | "browser",
9 | "node",
10 | "jquery"
11 | ]
12 | },
13 | "scripts": {
14 | "test": "xo && gulp test && stylelint --config ./.stylelintrc './**/*.scss'"
15 | },
16 | "repository": {
17 | "type": "git",
18 | "url": "git+https://github.com/phpbb/StyleGuideDesigner.git"
19 | },
20 | "keywords": [
21 | "sdd",
22 | "style",
23 | "themes"
24 | ],
25 | "author": "Sahil Khokhar",
26 | "license": "MIT",
27 | "bugs": {
28 | "url": "https://github.com/phpbb/StyleGuideDesigner/issues"
29 | },
30 | "homepage": "https://github.com/phpbb/StyleGuideDesigner#readme",
31 | "dependencies": {
32 | "body-parser": "^1.17.2",
33 | "del": "^2.2.2",
34 | "express": "^4.15.3",
35 | "express-validator": "^3.2.0",
36 | "gulp": "^3.9.1",
37 | "gulp-autoprefixer": "^4.0.0",
38 | "gulp-cssnano": "^2.1.2",
39 | "gulp-data": "^1.2.1",
40 | "gulp-nunjucks-render": "^2.2.1",
41 | "gulp-postcss": "^7.0.0",
42 | "gulp-rename": "^1.2.2",
43 | "gulp-sass": "^3.1.0",
44 | "gulp-sourcemaps": "^2.6.0",
45 | "gulp-stylefmt": "^1.1.0",
46 | "postcss-pxtorem": "^4.0.1",
47 | "postcss-rtl": "^0.5.10",
48 | "postcss-sorting": "^2.1.0",
49 | "pug": "^2.0.0-rc.2",
50 | "stylelint": "^7.10.1",
51 | "stylelint-order": "^0.4.4",
52 | "stylelint-scss": "^1.4.4",
53 | "vue": "^2.3.4",
54 | "vue-resource": "^1.3.4",
55 | "xo": "^0.16.0"
56 | }
57 | }
58 |
--------------------------------------------------------------------------------
/tests/all/scss/utilities/_print.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #utilities: Print
3 | //------------------------------------------------------------------------------
4 | // #description
5 | //
6 | // Inlined to avoid the additional HTTP request:
7 | // http://www.phpied.com/delay-loading-your-print-css/
8 | //
9 | // 1. Black prints faster: http://www.sanbeiji.com/archives/953
10 | //
11 | //------------------------------------------------------------------------------
12 |
13 | //
14 | // #scss
15 | @media print {
16 | *,
17 | *:before,
18 | *:after,
19 | *:first-letter,
20 | *:first-line {
21 | background: transparent !important;
22 | box-shadow: none !important;
23 | text-shadow: none !important;
24 | color: $black !important; // [1]
25 | }
26 |
27 | a,
28 | a:visited {
29 | text-decoration: underline;
30 | }
31 |
32 | a[href]:after {
33 | content: " (" attr(href) ")";
34 | }
35 |
36 | abbr[title]:after {
37 | content: " (" attr(title) ")";
38 | }
39 |
40 | //
41 | // Don"t show links that are fragment identifiers, or use the `javascript:`
42 | // pseudo protocol
43 | a[href^="#"]:after,
44 | a[href^="javascript:"]:after {
45 | content: "";
46 | }
47 |
48 | pre,
49 | blockquote {
50 | border: $default-border-size solid $default-gray;
51 | page-break-inside: avoid;
52 | }
53 |
54 | //
55 | // Printing Tables:
56 | // http://css-discuss.incutio.com/wiki/Printing_Tables
57 | thead {
58 | display: table-header-group;
59 | }
60 |
61 | tr,
62 | img {
63 | page-break-inside: avoid;
64 | }
65 |
66 | img {
67 | max-width: 100% !important;
68 | }
69 |
70 | p,
71 | h2,
72 | h3 {
73 | orphans: 3;
74 | widows: 3;
75 | }
76 |
77 | h2,
78 | h3 {
79 | page-break-after: avoid;
80 | }
81 | }
82 |
--------------------------------------------------------------------------------
/assets/css/theme.css:
--------------------------------------------------------------------------------
1 | .c-navbar {
2 | display: -webkit-flex;
3 | display: flex;
4 | overflow: hidden;
5 | -webkit-flex-direction: row;
6 | flex-direction: row;
7 | -webkit-flex-wrap: nowrap;
8 | flex-wrap: nowrap;
9 | }
10 |
11 | .c-navbar-logo {
12 | font-size: 1.25rem;
13 | font-weight: 500;
14 | line-height: 1.6;
15 | line-height: 1;
16 | letter-spacing: 0.02em;
17 | float: left;
18 | -webkit-flex: 1;
19 | flex: 1;
20 | margin-bottom: 0;
21 | padding: 1rem;
22 | }
23 |
24 | .c-navbar-menu {
25 | margin: 0;
26 | padding: 0;
27 | list-style-type: none;
28 | }
29 |
30 | .c-navbar-menu-item {
31 | display: -webkit-flex;
32 | display: flex;
33 | float: right;
34 | }
35 |
36 | .c-navbar-menu-link {
37 | font-size: 1rem;
38 | line-height: 3.5;
39 | text-decoration: none;
40 | color: #757575;
41 | display: inline-block;
42 | padding: 0 1rem;
43 | }
44 |
45 | .c-navbar-menu-link:hover {
46 | color: #258cf4;
47 | }
48 |
49 | .c-navbar-menu-text {
50 | padding: 0.5rem;
51 | }
52 |
53 | .c-navbar-icon {
54 | margin-right: 0;
55 | }
56 |
57 | .c-footer {
58 | text-align: center;
59 | }
60 |
61 | .c-sidebar {
62 | border: 1px solid transparent;
63 | border-right-color: #e7e7e7;
64 | display: -webkit-flex;
65 | display: flex;
66 | overflow: hidden;
67 | -webkit-flex-wrap: nowrap;
68 | flex-wrap: nowrap;
69 | width: 16%;
70 | }
71 |
72 | .c-sidebar-menu {
73 | margin: 0;
74 | padding: 0;
75 | list-style-type: none;
76 | }
77 |
78 | .c-sidebar-menu-item {
79 | display: -webkit-flex;
80 | display: flex;
81 | }
82 |
83 | .c-sidebar-menu-link {
84 | font-size: 1rem;
85 | line-height: 3.5;
86 | text-decoration: none;
87 | color: #757575;
88 | display: block;
89 | padding: 0 1rem;
90 | }
91 |
92 | .c-sidebar-menu-link:hover {
93 | color: #258cf4;
94 | }
95 |
96 | .c-sidebar-menu-text {
97 | padding: 0.5rem;
98 | }
99 |
100 | /*# sourceMappingURL=theme.css.map */
101 |
--------------------------------------------------------------------------------
/views/layout.pug:
--------------------------------------------------------------------------------
1 | doctype html
2 |
3 | html(lang="en")
4 | head
5 | meta(charset="UTF-8")
6 | meta(http-equiv="X-UA-Compatible" content="IE-edge, chrome=1")
7 | meta(name="viewport" content="width=device-width, initial-scale=1")
8 | title Styleguide Driven Development
9 | link(rel="stylesheet", href="/css/core.0.12.0.css")
10 | link(rel="stylesheet", href="/css/theme.css")
11 | body
12 | include includes/sprite.pug
13 | block head
14 | .c-navbar
15 | h3.c-navbar-logo Logo
16 | ul.c-navbar-menu
17 | li.c-navbar-menu-item
18 | a.c-navbar-menu-link(href="https://github.com/phpbb/StyleGuideDesigner", target="_blank")
19 | svg.o-icon.c-navbar-icon
20 | use(xlink:href="#github")
21 | li.c-navbar-menu-item
22 | a.c-navbar-menu-link(href="/documentation")
23 | svg.o-icon.c-navbar-icon
24 | use(xlink:href="#faq")
25 | span.c-navbar-menu-text Documentation
26 | li.c-navbar-menu-item
27 | a.c-navbar-menu-link(href="/settings")
28 | svg.o-icon.c-navbar-icon
29 | use(xlink:href="#settings")
30 | span.c-navbar-menu-text Settings
31 | li.c-navbar-menu-item
32 | a.c-navbar-menu-link(href="/demo")
33 | svg.o-icon.c-navbar-icon
34 | use(xlink:href="#app")
35 | span.c-navbar-menu-text Demo
36 | li.c-navbar-menu-item
37 | a.c-navbar-menu-link(href="/")
38 | svg.o-icon.c-navbar-icon
39 | use(xlink:href="#home")
40 | span.c-navbar-menu-text Home
41 | block content
42 | block foot
43 | footer.c-footer
44 | a.c-footer-icon-link(href="https://github.com/phpbb/StyleGuideDesigner", target="_blank")
45 | svg.o-icon.c-footer-icon
46 | use(xlink:href="#github")
47 | p.c-footer-text Developed for phpBB
48 | script(src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js")
49 | script(src="https://unpkg.com/vue@2.0.3/dist/vue.js")
50 | script(src="https://cdn.jsdelivr.net/g/vue@2.0.0-rc.4,vue.resource@1.0.0")
51 | script(src='/js/script.js')
--------------------------------------------------------------------------------
/assets/js/script.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | window.onload = function () {
4 | Vue.component('config-list', {
5 | props: ['config'],
6 | template: ``,
8 | data() {
9 | return {
10 | configList: {}
11 | };
12 | },
13 | methods: {
14 | // Method called on blur of the input
15 | changeConfig(e) {
16 | // This new object will record values on event change
17 | let newConfig = {
18 | id: e.path[1].firstChild.id,
19 | name: e.path[1].innerText,
20 | setting: e.target.value
21 | };
22 | // Send the new object on the post route
23 | this.$http.post('/settings/config', newConfig)
24 | .then(function (res) {
25 | console.log(res.body);
26 | });
27 | }
28 | }
29 | });
30 | new Vue({
31 | el: '.app',
32 | data() {
33 | return {
34 | configList: []
35 | };
36 | },
37 | created: function () {
38 | // Call this method as soon as the page loads
39 | this.fetchConfig();
40 | },
41 | methods: {
42 | /* This method is called as soon as the page loads
43 | and it makes a get request on the get route */
44 | fetchConfig() {
45 | this.$http.get('/settings/config')
46 | .then(function (res) {
47 | this.configList = res.body;
48 | });
49 | }
50 | }
51 | });
52 |
53 | Vue.component('sidebar-list', {
54 | props: ['sidebar'],
55 | template: ``,
57 | });
58 | new Vue({
59 | el: '.sidebar-app',
60 | data() {
61 | return {
62 | sidebarList: []
63 | };
64 | },
65 | created: function () {
66 | // Call this method as soon as the page loads
67 | this.fetchSideContent();
68 | },
69 | methods: {
70 | /* This method is called as soon as the page loads
71 | and it makes a get request on the get route */
72 | fetchSideContent() {
73 | this.$http.get('/editor/sidebar')
74 | .then(function (res) {
75 | this.sidebarList = res.body;
76 | });
77 | }
78 | }
79 | });
80 | };
81 |
--------------------------------------------------------------------------------
/tests/prosilver/scss/objects/_action-bar.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @object: Action Bar
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $action-spacing: 16px !default;
13 | $action-size: 40px !default;
14 |
15 |
16 | // Theme Variables
17 | $action-bg-color: $gray-100 !default;
18 | $action-bg-hover-color: $default-action-bg-hover !default;
19 | $action-color: $black-54 !default;
20 | $action-hover-color: $default-action-color-hover !default;
21 |
22 |
23 | //
24 | // @scss
25 | .o-action-bar {
26 | background-color: $action-bg-color;
27 | display: flex;
28 | flex-direction: row;
29 | flex-wrap: nowrap;
30 |
31 | &-avatar {
32 | width: $action-size;
33 | height: $action-size;
34 | margin: ($action-spacing / 2) 0 ($action-spacing / 2) $action-spacing;
35 | padding: 0;
36 | }
37 |
38 | &-title {
39 | @include type(title);
40 | line-height: 1;
41 | float: left;
42 | flex: 1;
43 | margin-bottom: 0;
44 | padding: $action-spacing;
45 | }
46 |
47 | &-list {
48 | float: left;
49 | flex: 1;
50 | margin: 0;
51 | padding: 0;
52 | list-style: none;
53 | }
54 |
55 | &-list-item {
56 | display: flex;
57 | float: left;
58 | padding: $action-spacing;
59 |
60 | &:first-of-type {
61 | padding-right: 0;
62 | }
63 | }
64 |
65 | &-actions {
66 | margin: 0;
67 | padding: 0;
68 | list-style: none;
69 | }
70 |
71 | &-action {
72 | display: flex;
73 | float: right;
74 |
75 | &-item {
76 | position: relative;
77 | }
78 |
79 | &-link {
80 | color: $action-color;
81 | display: inline-block;
82 | padding: $action-spacing;
83 |
84 | &:hover,
85 | &:focus {
86 | background-color: $action-bg-hover-color;
87 | color: $action-hover-color;
88 | }
89 | }
90 |
91 | &-icon {
92 | margin-right: 0;
93 |
94 | &:hover {
95 | text-decoration: none;
96 | }
97 | }
98 | }
99 | }
100 |
--------------------------------------------------------------------------------
/assets/css/theme.min.css.map:
--------------------------------------------------------------------------------
1 | {"version":3,"sources":["theme.css"],"names":[],"mappings":"AAAA,UAEC,aAAc,AACd,gBAAiB,AAEjB,mBAAoB,AAEpB,gBAAkB,CAClB,AAED,eACC,kBAAmB,AACnB,gBAAiB,AACjB,gBAAiB,AACjB,cAAe,AACf,qBAAuB,AACvB,WAAY,AAEZ,OAAQ,AACR,gBAAiB,AACjB,YAAc,CACd,AAED,eACC,SAAU,AACV,UAAW,AACX,oBAAsB,CACtB,AAED,oBAEC,aAAc,AACd,WAAa,CACb,AAED,oBACC,eAAgB,AAChB,gBAAiB,AACjB,qBAAsB,AACtB,cAAe,AACf,qBAAsB,AACtB,cAAgB,CAChB,AAED,0BACC,aAAe,CACf,AAED,oBACC,aAAgB,CAChB,AAED,eACC,cAAgB,CAChB,AAED,UACC,iBAAmB,CACnB,AAED,WACC,6BAA8B,AAC9B,2BAA4B,AAE5B,aAAc,AACd,gBAAiB,AAEjB,iBAAkB,AAClB,SAAW,CACX,AAED,gBACC,SAAU,AACV,UAAW,AACX,oBAAsB,CACtB,AAED,qBAEC,YAAc,CACd,AAED,qBACC,eAAgB,AAChB,gBAAiB,AACjB,qBAAsB,AACtB,cAAe,AACf,cAAe,AACf,cAAgB,CAChB,AAED,2BACC,aAAe,CACf,AAED,qBACC,aAAgB,CAChB","file":"theme.min.css","sourcesContent":[".c-navbar {\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n\toverflow: hidden;\n\t-webkit-flex-direction: row;\n\tflex-direction: row;\n\t-webkit-flex-wrap: nowrap;\n\tflex-wrap: nowrap;\n}\n\n.c-navbar-logo {\n\tfont-size: 1.25rem;\n\tfont-weight: 500;\n\tline-height: 1.6;\n\tline-height: 1;\n\tletter-spacing: 0.02em;\n\tfloat: left;\n\t-webkit-flex: 1;\n\tflex: 1;\n\tmargin-bottom: 0;\n\tpadding: 1rem;\n}\n\n.c-navbar-menu {\n\tmargin: 0;\n\tpadding: 0;\n\tlist-style-type: none;\n}\n\n.c-navbar-menu-item {\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n\tfloat: right;\n}\n\n.c-navbar-menu-link {\n\tfont-size: 1rem;\n\tline-height: 3.5;\n\ttext-decoration: none;\n\tcolor: #757575;\n\tdisplay: inline-block;\n\tpadding: 0 1rem;\n}\n\n.c-navbar-menu-link:hover {\n\tcolor: #258cf4;\n}\n\n.c-navbar-menu-text {\n\tpadding: 0.5rem;\n}\n\n.c-navbar-icon {\n\tmargin-right: 0;\n}\n\n.c-footer {\n\ttext-align: center;\n}\n\n.c-sidebar {\n\tborder: 1px solid transparent;\n\tborder-right-color: #e7e7e7;\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n\toverflow: hidden;\n\t-webkit-flex-wrap: nowrap;\n\tflex-wrap: nowrap;\n\twidth: 16%;\n}\n\n.c-sidebar-menu {\n\tmargin: 0;\n\tpadding: 0;\n\tlist-style-type: none;\n}\n\n.c-sidebar-menu-item {\n\tdisplay: -webkit-flex;\n\tdisplay: flex;\n}\n\n.c-sidebar-menu-link {\n\tfont-size: 1rem;\n\tline-height: 3.5;\n\ttext-decoration: none;\n\tcolor: #757575;\n\tdisplay: block;\n\tpadding: 0 1rem;\n}\n\n.c-sidebar-menu-link:hover {\n\tcolor: #258cf4;\n}\n\n.c-sidebar-menu-text {\n\tpadding: 0.5rem;\n}\n\n/*# sourceMappingURL=theme.css.map */\n"]}
--------------------------------------------------------------------------------
/tests/all/scss/utilities/_visability.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #utilities: Visability
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // Responsive visability classes derived from bootstrap.
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // #scss
12 |
13 | //
14 | // Only display content to screen readers
15 | // http://snook.ca/archives/html_and_css/hiding-content-for-accessibility
16 | .u-sr-only {
17 | border: 0;
18 | position: absolute;
19 | overflow: hidden;
20 | clip: rect(0, 0, 0, 0);
21 | width: 1px;
22 | height: 1px;
23 | margin: -1px;
24 | padding: 0;
25 | }
26 |
27 | //
28 | // Extends the .sr-only class to allow the element
29 | // to be focusable when navigated to via the keyboard:
30 | // https://www.drupal.org/node/897638
31 | .u-sr-only.focusable:active,
32 | .u-sr-only.focusable:focus {
33 | position: static;
34 | overflow: visible;
35 | clip: auto;
36 | width: auto;
37 | height: auto;
38 | margin: 0;
39 | }
40 |
41 | // Hide visually and from screen readers
42 | .u-hidden {
43 | display: none !important;
44 | }
45 |
46 | // Responsive visibility utilities
47 |
48 | .u-hidden-xs-up {
49 | display: none !important;
50 | }
51 |
52 | @media (max-width: ($bp-sm - 1)) {
53 | .u-hidden-xs-down {
54 | display: none !important;
55 | }
56 | }
57 |
58 | @media (min-width: $bp-sm) {
59 | .u-hidden-sm-up {
60 | display: none !important;
61 | }
62 | }
63 |
64 | @media (max-width: ($bp-md - 1)) {
65 | .u-hidden-sm-down {
66 | display: none !important;
67 | }
68 | }
69 |
70 | @media (min-width: $bp-md) {
71 | .u-hidden-md-up {
72 | display: none !important;
73 | }
74 | }
75 |
76 | @media (max-width: ($bp-lg - 1)) {
77 | .u-hidden-md-down {
78 | display: none !important;
79 | }
80 | }
81 |
82 | @media (min-width: $bp-lg) {
83 | .u-hidden-lg-up {
84 | display: none !important;
85 | }
86 | }
87 |
88 | @media (max-width: ($bp-xl - 1)) {
89 | .u-hidden-lg-down {
90 | display: none !important;
91 | }
92 | }
93 |
94 | @media (min-width: $bp-xl) {
95 | .u-hidden-xl-up {
96 | display: none !important;
97 | }
98 | }
99 |
100 | .u-hidden-xl-down {
101 | display: none !important;
102 | }
103 |
--------------------------------------------------------------------------------
/tests/all/scss/base/_table.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #base: Tables
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #settings
10 |
11 | // Layout Variables
12 | $table-row-height: 48px;
13 | $table-last-row-height: 56px;
14 | $table-header-height: $table-last-row-height;
15 | $table-header-padding-bottom: 8px;
16 | $table-column-spacing: 36px;
17 | $table-column-padding: $table-column-spacing / 2;
18 | $table-card-header-height: 64px;
19 | $table-card-title-top: 20px;
20 | $table-card-padding: 24px;
21 | $table-button-padding-right: 16px;
22 | $table-cell-top: $table-card-padding / 2;
23 |
24 | //Theme Variables
25 | $table-header-color: $default-action-color;
26 | $table-divider-color: $default-gray-light;
27 | $table-hover-color: $default-action-bg-hover;
28 | $table-selection-color: $default-action-bg;
29 |
30 |
31 | //
32 | // #scss
33 |
34 | table {
35 | @include type(body2);
36 | white-space: nowrap;
37 | background-color: $white;
38 | border: 1px solid $table-divider-color;
39 | display: block;
40 | overflow-x: auto;
41 | width: 100%;
42 |
43 | thead {
44 | padding-bottom: ($table-header-padding-bottom / 2);
45 | }
46 |
47 | tbody {
48 | tr {
49 | position: relative;
50 | height: $table-row-height;
51 | transition: background-color 0.28s $default-animation-curve;
52 |
53 | &:hover {
54 | background-color: $table-hover-color;
55 | }
56 | }
57 | }
58 |
59 | td,
60 | th {
61 | text-align: right;
62 | box-sizing: border-box;
63 | height: $table-row-height;
64 | padding: 0 $table-column-padding;
65 |
66 | &:first-of-type {
67 | padding-left: $table-card-padding;
68 | }
69 |
70 | &:last-of-type {
71 | padding-right: $table-card-padding;
72 | }
73 | }
74 |
75 | td {
76 | vertical-align: top;
77 | border-top: 1px solid $table-divider-color;
78 | border-bottom: 1px solid $table-divider-color;
79 | padding-top: $table-cell-top;
80 | }
81 |
82 | th {
83 | @include type(body2);
84 | vertical-align: bottom;
85 | text-overflow: ellipsis;
86 | color: $table-header-color;
87 | padding-bottom: $table-header-padding-bottom;
88 | }
89 | @media (min-width: $bp-md) {
90 | display: table;
91 | }
92 |
93 | @media (min-width: $bp-md) {
94 | width: auto;
95 | }
96 | }
97 |
--------------------------------------------------------------------------------
/tests/all/scss/base/_code.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #base: Code
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #settings
10 |
11 | // Layout Variables
12 | $kbd-padding: 4px !default;
13 | $pre-padding: 16px !default;
14 |
15 | // Theme Variables
16 | $code-font-family: $default-code-font;
17 | $code-bg: $default-action-bg-hover !default;
18 | $code-color: $default-primary-light-color !default;
19 | $code-border-radius: $default-border-radius !default;
20 | $kbd-nested-font-weight: 700 !default;
21 | $kbd-bg: $gray-900 !default;
22 | $kbd-color: $white !default;
23 | $kbd-border-color: rgba(0, 0, 0, 0.25) !default;
24 | $pre-bg: $gray-800 !default;
25 | $pre-border-width: 0 !default;
26 | $pre-border-style: solid !default;
27 | $pre-border-color: $default-gray !default;
28 | $pre-border-radius: $default-border-radius !default;
29 | $pre-color: $white !default;
30 |
31 | //
32 | // #scss
33 |
34 | // Inline and block code styles
35 | code,
36 | kbd,
37 | pre,
38 | samp {
39 | font-family: $code-font-family;
40 | }
41 |
42 | // Inline code
43 | code,
44 | kbd {
45 | font-size: 90%;
46 | background-color: $code-bg;
47 | border-radius: $code-border-radius;
48 | color: $code-color;
49 | padding: ($kbd-padding / 2) $kbd-padding;
50 | }
51 |
52 | // User input typically entered via keyboard
53 | kbd {
54 | background-color: $kbd-bg;
55 | box-shadow: inset 0 -1px 0 $kbd-border-color;
56 | color: $kbd-color;
57 | display: inline-block;
58 |
59 | kbd {
60 | font-size: 100%;
61 | font-weight: $kbd-nested-font-weight;
62 | box-shadow: none;
63 | padding: 0;
64 | }
65 | }
66 |
67 | // Blocks of code
68 | pre {
69 | font-size: 90%;
70 | word-wrap: break-word;
71 | word-break: break-all;
72 | background-color: $pre-bg;
73 | border-width: $pre-border-width;
74 | border-style: $pre-border-style;
75 | border-color: $pre-border-color;
76 | border-radius: $pre-border-radius;
77 | color: $pre-color;
78 | display: block;
79 | margin-top: 0;
80 | margin-bottom: $pre-padding;
81 | padding: $pre-padding;
82 |
83 | // Account for some code outputs that place code tags in pre tags
84 | code {
85 | font-size: inherit;
86 | white-space: pre-wrap;
87 | background-color: transparent;
88 | border-radius: 0;
89 | color: inherit;
90 | padding: 0;
91 | }
92 | }
93 |
--------------------------------------------------------------------------------
/gulpfile.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | var del = require('del');
4 | var gulp = require('gulp');
5 | var autoprefixer = require('gulp-autoprefixer');
6 | var sass = require('gulp-sass');
7 | var rename = require('gulp-rename');
8 | var sourcemaps = require('gulp-sourcemaps');
9 | var cssnano = require('gulp-cssnano');
10 | var postcss = require('gulp-postcss');
11 | var stylefmt = require('gulp-stylefmt');
12 | var sorting = require('postcss-sorting');
13 | var torem = require('postcss-pxtorem');
14 | var sortOrder = require('./.postcss-sorting.json');
15 |
16 | // Config
17 | var build = {
18 | css: './assets/css',
19 | scss: './src/scss/'
20 | };
21 |
22 | var AUTOPREFIXER_BROWSERS = [
23 | 'ie >= 11',
24 | 'edge >= 12',
25 | 'ff >= 38',
26 | 'chrome >= 35',
27 | 'safari >= 8',
28 | 'opera >= 35',
29 | 'ios >= 8'
30 | ];
31 |
32 | gulp.task('css', function () {
33 | var css = gulp
34 | .src(build.scss + '*.scss')
35 | .pipe(sourcemaps.init())
36 | .pipe(sass({
37 | indentType: 'tab',
38 | indentWidth: 1,
39 | outputStyle: 'expanded',
40 | precision: 10,
41 | onError: console.error.bind(console, 'Sass error:')
42 | }))
43 | .pipe(autoprefixer(AUTOPREFIXER_BROWSERS))
44 | .pipe(
45 | postcss([
46 | sorting(sortOrder),
47 | torem({
48 | rootValue: 16,
49 | unitPrecision: 7,
50 | propWhiteList: [
51 | 'font',
52 | 'font-size',
53 | 'margin',
54 | 'margin-left',
55 | 'margin-right',
56 | 'margin-top',
57 | 'margin-bottom',
58 | 'padding',
59 | 'padding-left',
60 | 'padding-right',
61 | 'padding-top',
62 | 'padding-bottom'],
63 | selectorBlackList: [],
64 | replace: true,
65 | mediaQuery: false,
66 | minPixelValue: 0
67 | })
68 | ])
69 | )
70 | .pipe(stylefmt())
71 | .pipe(sourcemaps.write('./'))
72 | .pipe(gulp.dest(build.css));
73 |
74 | return css;
75 | });
76 |
77 | gulp.task('clean', function () {
78 | del(['dist']);
79 | });
80 |
81 | gulp.task('minify', ['css'], function () {
82 | var css = gulp
83 | .src(build.css + '/theme.css')
84 | .pipe(sourcemaps.init())
85 | .pipe(cssnano())
86 | .pipe(rename({
87 | suffix: '.min',
88 | extname: '.css'
89 | }))
90 | .pipe(sourcemaps.write('./'))
91 | .pipe(gulp.dest(build.css));
92 |
93 | return css;
94 | });
95 |
96 | gulp.task('watch', function () {
97 | gulp.watch('src/scss/**/*.scss', ['css', 'minify']);
98 | });
99 |
100 | gulp.task('serve', ['watch']);
101 | gulp.task('test', ['css', 'minify']);
102 | gulp.task('default', ['css', 'minify', 'watch']);
103 |
--------------------------------------------------------------------------------
/tests/all/scss/components/_menu.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Menu
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $menu-spacing-vertical: 8px !default;
13 | $menu-spacing-horizontal: 16px !default;
14 | $menu-icon-margin: 24px !default;
15 | $menu-icon-size: 32px !default;
16 | $menu-link-size: 48px !default;
17 | $menu-border-radius: $default-border-radius !default;
18 | $menu-divider-height: 1px !default;
19 |
20 | // Theme Variables
21 | $menu-background-color: $white !default;
22 | $menu-link-color: $default-text-color !default;
23 | $menu-icon-color: $default-action-icon-color !default;
24 | $menu-link-hover-color: $default-action-color-hover !default;
25 | $menu-link-hover-background-color: $default-action-bg-hover !default;
26 | $menu-divider-color: rgba(0, 0, 0, 0.125) !default;
27 |
28 |
29 | //
30 | // @scss
31 | .c-menu-container {
32 | @include shadow(1);
33 | text-align: left;
34 | background-color: $menu-background-color;
35 | border-radius: $menu-border-radius;
36 | position: absolute;
37 | z-index: 999;
38 | top: auto;
39 | right: 0;
40 | display: none;
41 | overflow: auto;
42 | }
43 |
44 | .c-menu {
45 | margin: 0;
46 | padding: $menu-spacing-vertical 0;
47 | list-style: none;
48 |
49 | &-item {
50 | position: relative;
51 | }
52 |
53 | &-toggle {
54 | cursor: pointer;
55 |
56 | &:hover,
57 | &:focus {
58 | > .c-menu-container,
59 | a > .c-menu-container {
60 | display: block;
61 | }
62 | }
63 | }
64 |
65 | &-link {
66 | @include type(menu);
67 | white-space: nowrap;
68 | text-decoration: none;
69 | color: $menu-link-color;
70 | display: flex;
71 | flex-direction: row;
72 | align-items: center;
73 | height: $menu-link-size;
74 | padding: 0 $menu-spacing-horizontal 0 $menu-spacing-horizontal;
75 | cursor: pointer;
76 |
77 | &-icon {
78 | color: $menu-icon-color;
79 | width: $menu-icon-size;
80 | height: $menu-icon-size;
81 | margin-right: $menu-icon-margin;
82 | }
83 |
84 | &:hover {
85 | text-decoration: none;
86 | background-color: $menu-link-hover-background-color;
87 | color: $menu-link-hover-color;
88 |
89 | .c-menu-link-icon {
90 | color: $menu-link-hover-color;
91 | }
92 | }
93 | }
94 |
95 | &-divider {
96 | background-color: $menu-divider-color;
97 | height: $menu-divider-height;
98 | margin-top: $menu-spacing-vertical;
99 | margin-bottom: $menu-spacing-vertical;
100 | }
101 | }
102 |
--------------------------------------------------------------------------------
/tests/all/scss/components/_toolbar.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Toolbar
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $toolbar-spacing: 16px !default;
13 | $toolbar-height: ($toolbar-spacing * 2.375) !default;
14 | $toolbar-border-radius: $default-border-radius !default;
15 |
16 | // Theme Variables
17 | $toolbar-background-color: $default-action-bg !default;
18 | $toolbar-action-color: $default-action-color !default;
19 | $toolbar-action-hover-bg: $default-action-bg-hover !default;
20 | $toolbar-action-hover-color: $default-action-color-hover !default;
21 |
22 |
23 | //
24 | // @scss
25 |
26 | //
27 | // 1. Allow us to style box model properties.
28 | // 2. Line different sized buttons up a little nicer.
29 | // 3. Make buttons inherit font styles (often necessary when styling `input`s as
30 | // buttons).
31 | // 4. Reset/normalize some styles.
32 | // 5. Force all button-styled elements to appear clickable.
33 | // 6. Fixes odd inner spacing in IE7.
34 | // 7. Subtract the border size from the padding value so that buttons do not
35 | // grow larger as we add borders.
36 | // 8. Prevent button text from being selectable.
37 | // 9. Prevent deafult browser outline halo
38 | //
39 | .c-toolbar {
40 | @include shadow(2);
41 | background-color: $toolbar-background-color;
42 | border-radius: $toolbar-border-radius;
43 | position: relative;
44 | display: inline-block;
45 | margin: 0;
46 | margin-bottom: $toolbar-spacing;
47 | padding: 0;
48 | list-style: none;
49 |
50 | &-item {
51 | position: relative;
52 | display: inline-block;
53 | }
54 |
55 | &-action {
56 | @include type(button);
57 | line-height: unitless($toolbar-height, map-get(map-get($type-styles, button), font-size));
58 | text-align: center; // [4]
59 | vertical-align: middle; // [2]
60 | white-space: nowrap; // bs only
61 | text-decoration: none; // [4]
62 | outline: none; // [9]
63 | color: $toolbar-action-color;
64 | position: relative;
65 | display: inline-block; // [1]
66 | overflow: hidden; // [6]
67 | margin: 0; // [4]
68 | padding: 0 $toolbar-spacing; // [7]
69 | cursor: pointer;
70 | user-select: none; // [8]
71 | transition:
72 | box-shadow 0.2s $animation-curve-fast-out-linear-in,
73 | background-color 0.2s $default-animation-curve,
74 | color 0.2s $default-animation-curve;
75 |
76 | &:hover,
77 | &:focus {
78 | background-color: $toolbar-action-hover-bg;
79 | color: $toolbar-action-hover-color;
80 | }
81 | }
82 |
83 | &-icon {
84 | margin-right: 0;
85 |
86 | &:hover {
87 | text-decoration: none;
88 | }
89 | }
90 | }
91 |
--------------------------------------------------------------------------------
/assets/css/utilities.0.12.0.css:
--------------------------------------------------------------------------------
1 | [tabindex="-1"]:focus {
2 | outline: none !important;
3 | }
4 |
5 | .u-clearfix:after {
6 | display: table;
7 | clear: both;
8 | content: " ";
9 | }
10 |
11 | .u-sr-only {
12 | border: 0;
13 | position: absolute;
14 | overflow: hidden;
15 | clip: rect(0, 0, 0, 0);
16 | width: 1px;
17 | height: 1px;
18 | margin: -0.0625rem;
19 | padding: 0;
20 | }
21 |
22 | .u-sr-only.focusable:active,
23 | .u-sr-only.focusable:focus {
24 | position: static;
25 | overflow: visible;
26 | clip: auto;
27 | width: auto;
28 | height: auto;
29 | margin: 0;
30 | }
31 |
32 | .u-hidden {
33 | display: none !important;
34 | }
35 |
36 | .u-hidden-xs-up {
37 | display: none !important;
38 | }
39 |
40 | @media (max-width: 575px) {
41 | .u-hidden-xs-down {
42 | display: none !important;
43 | }
44 | }
45 |
46 | @media (min-width: 576px) {
47 | .u-hidden-sm-up {
48 | display: none !important;
49 | }
50 | }
51 |
52 | @media (max-width: 767px) {
53 | .u-hidden-sm-down {
54 | display: none !important;
55 | }
56 | }
57 |
58 | @media (min-width: 768px) {
59 | .u-hidden-md-up {
60 | display: none !important;
61 | }
62 | }
63 |
64 | @media (max-width: 991px) {
65 | .u-hidden-md-down {
66 | display: none !important;
67 | }
68 | }
69 |
70 | @media (min-width: 992px) {
71 | .u-hidden-lg-up {
72 | display: none !important;
73 | }
74 | }
75 |
76 | @media (max-width: 1199px) {
77 | .u-hidden-lg-down {
78 | display: none !important;
79 | }
80 | }
81 |
82 | @media (min-width: 1200px) {
83 | .u-hidden-xl-up {
84 | display: none !important;
85 | }
86 | }
87 |
88 | .u-hidden-xl-down {
89 | display: none !important;
90 | }
91 |
92 | @media print {
93 | *,
94 | *:before,
95 | *:after,
96 | *:first-letter,
97 | *:first-line {
98 | background: transparent !important;
99 | box-shadow: none !important;
100 | text-shadow: none !important;
101 | color: #000000 !important;
102 | }
103 |
104 | a,
105 | a:visited {
106 | text-decoration: underline;
107 | }
108 |
109 | a[href]:after {
110 | content: " (" attr(href) ")";
111 | }
112 |
113 | abbr[title]:after {
114 | content: " (" attr(title) ")";
115 | }
116 |
117 | a[href^="#"]:after,
118 | a[href^="javascript:"]:after {
119 | content: "";
120 | }
121 |
122 | pre,
123 | blockquote {
124 | border: 1px solid #9e9e9e;
125 | page-break-inside: avoid;
126 | }
127 |
128 | thead {
129 | display: table-header-group;
130 | }
131 |
132 | tr,
133 | img {
134 | page-break-inside: avoid;
135 | }
136 |
137 | img {
138 | max-width: 100% !important;
139 | }
140 |
141 | p,
142 | h2,
143 | h3 {
144 | orphans: 3;
145 | widows: 3;
146 | }
147 |
148 | h2,
149 | h3 {
150 | page-break-after: avoid;
151 | }
152 | }
153 |
154 | /*# sourceMappingURL=utilities.0.12.0.css.map */
155 |
--------------------------------------------------------------------------------
/tests/all/css/utilities.0.12.0.css:
--------------------------------------------------------------------------------
1 | [tabindex="-1"]:focus {
2 | outline: none !important;
3 | }
4 |
5 | .u-clearfix:after {
6 | display: table;
7 | clear: both;
8 | content: " ";
9 | }
10 |
11 | .u-sr-only {
12 | border: 0;
13 | position: absolute;
14 | overflow: hidden;
15 | clip: rect(0, 0, 0, 0);
16 | width: 1px;
17 | height: 1px;
18 | margin: -0.0625rem;
19 | padding: 0;
20 | }
21 |
22 | .u-sr-only.focusable:active,
23 | .u-sr-only.focusable:focus {
24 | position: static;
25 | overflow: visible;
26 | clip: auto;
27 | width: auto;
28 | height: auto;
29 | margin: 0;
30 | }
31 |
32 | .u-hidden {
33 | display: none !important;
34 | }
35 |
36 | .u-hidden-xs-up {
37 | display: none !important;
38 | }
39 |
40 | @media (max-width: 575px) {
41 | .u-hidden-xs-down {
42 | display: none !important;
43 | }
44 | }
45 |
46 | @media (min-width: 576px) {
47 | .u-hidden-sm-up {
48 | display: none !important;
49 | }
50 | }
51 |
52 | @media (max-width: 767px) {
53 | .u-hidden-sm-down {
54 | display: none !important;
55 | }
56 | }
57 |
58 | @media (min-width: 768px) {
59 | .u-hidden-md-up {
60 | display: none !important;
61 | }
62 | }
63 |
64 | @media (max-width: 991px) {
65 | .u-hidden-md-down {
66 | display: none !important;
67 | }
68 | }
69 |
70 | @media (min-width: 992px) {
71 | .u-hidden-lg-up {
72 | display: none !important;
73 | }
74 | }
75 |
76 | @media (max-width: 1199px) {
77 | .u-hidden-lg-down {
78 | display: none !important;
79 | }
80 | }
81 |
82 | @media (min-width: 1200px) {
83 | .u-hidden-xl-up {
84 | display: none !important;
85 | }
86 | }
87 |
88 | .u-hidden-xl-down {
89 | display: none !important;
90 | }
91 |
92 | @media print {
93 | *,
94 | *:before,
95 | *:after,
96 | *:first-letter,
97 | *:first-line {
98 | background: transparent !important;
99 | box-shadow: none !important;
100 | text-shadow: none !important;
101 | color: #000000 !important;
102 | }
103 |
104 | a,
105 | a:visited {
106 | text-decoration: underline;
107 | }
108 |
109 | a[href]:after {
110 | content: " (" attr(href) ")";
111 | }
112 |
113 | abbr[title]:after {
114 | content: " (" attr(title) ")";
115 | }
116 |
117 | a[href^="#"]:after,
118 | a[href^="javascript:"]:after {
119 | content: "";
120 | }
121 |
122 | pre,
123 | blockquote {
124 | border: 1px solid #9e9e9e;
125 | page-break-inside: avoid;
126 | }
127 |
128 | thead {
129 | display: table-header-group;
130 | }
131 |
132 | tr,
133 | img {
134 | page-break-inside: avoid;
135 | }
136 |
137 | img {
138 | max-width: 100% !important;
139 | }
140 |
141 | p,
142 | h2,
143 | h3 {
144 | orphans: 3;
145 | widows: 3;
146 | }
147 |
148 | h2,
149 | h3 {
150 | page-break-after: avoid;
151 | }
152 | }
153 |
154 | /*# sourceMappingURL=utilities.0.12.0.css.map */
155 |
--------------------------------------------------------------------------------
/tests/all/scss/generic/reset/_type.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Type
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #scss
10 |
11 | //
12 | // Remove top margins from headings
13 | //
14 | // By default, ``-`` all receive top and bottom margins. We nuked the
15 | // top margin for easier control within type scales as it avoids margin
16 | // collapsing.
17 | //
18 | h1,
19 | h2,
20 | h3,
21 | h4,
22 | h5,
23 | h6 {
24 | @include vertical-rhythm();
25 | }
26 |
27 | //
28 | // Reestablish margins on paragraphs
29 | //
30 | p {
31 | @include vertical-rhythm();
32 | }
33 |
34 | // Remove underlines from potentially troublesome elements.
35 | u,
36 | ins,
37 | abbr[title] {
38 | text-decoration: none;
39 | }
40 |
41 | abbr[title] {
42 | border-bottom: $default-border-size dotted $default-gray;
43 | }
44 |
45 | // Apply faux underlines to inserted text via `border-bottom`.
46 | ins {
47 | border-bottom: $default-border-size solid;
48 | }
49 |
50 | // Give a help cursor to elements that give extra info on `:hover`.
51 | abbr[title],
52 | dfn[title] {
53 | cursor: help;
54 | }
55 |
56 | address {
57 | @include vertical-rhythm();
58 | font-style: normal;
59 | line-height: inherit;
60 | }
61 |
62 | ol,
63 | ul,
64 | dd {
65 | @include vertical-rhythm();
66 | @include space(margin-left);
67 | }
68 |
69 | dl {
70 | @include vertical-rhythm();
71 | }
72 |
73 | li > ul,
74 | li > ol {
75 | margin-bottom: 0;
76 | }
77 |
78 | nav ol,
79 | nav ul {
80 | list-style: none;
81 | }
82 |
83 | nav > ol,
84 | nav > ul {
85 | @include vertical-rhythm();
86 | padding: 0;
87 | }
88 |
89 | dt {
90 | font-weight: 700;
91 | }
92 |
93 | //
94 | // 1. Hang the opening quote of the blockquote.
95 | //
96 | blockquote {
97 | @include vertical-rhythm();
98 | /* stylelint-disable unit-blacklist, declaration-property-unit-whitelist */
99 | text-indent: -0.41em; // [1]
100 | /* stylelint-enable unit-blacklist, declaration-property-unit-whitelist */
101 | }
102 |
103 | q {
104 | quotes: "‘" "’" "“" "”";
105 |
106 | &:before {
107 | content: "‘";
108 | }
109 |
110 | &:after {
111 | content: "’";
112 | }
113 |
114 | q:before {
115 | content: "“";
116 | }
117 |
118 | q:after {
119 | content: "”";
120 | }
121 |
122 | //
123 | // If an element opens with an inline quote, let’s hang that.
124 | //
125 | &:first-child {
126 | /* stylelint-disable unit-blacklist, declaration-property-unit-whitelist */
127 | text-indent: -0.22em;
128 | /* stylelint-enable unit-blacklist, declaration-property-unit-whitelist */
129 | display: inline-block;
130 | }
131 | }
132 |
--------------------------------------------------------------------------------
/tests/all/scss/objects/_button.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #object: Button
3 | //------------------------------------------------------------------------------
4 | // #description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #settings
10 |
11 | // Layout Variables
12 | $btn-spacing: 16px !default;
13 | $btn-border-radius: $default-border-radius !default;
14 | $btn-min-width: ($btn-spacing * 4) !default;
15 | $btn-height: ($btn-spacing * 2.375) !default;
16 |
17 | // Theme Variables
18 | $btn-background-color: $default-action-bg !default;
19 | $btn-hover-color: $default-action-bg-hover !default;
20 | $btn-text-color: $default-action-color !default;
21 | $btn-text-hover-color: $default-link-color !default;
22 |
23 | //
24 | // #scss
25 |
26 | //
27 | // 1. Allow us to style box model properties.
28 | // 2. Line different sized buttons up a little nicer.
29 | // 3. Make buttons inherit font styles (often necessary when styling `input`s as
30 | // buttons).
31 | // 4. Reset/normalize some styles.
32 | // 5. Force all button-styled elements to appear clickable.
33 | // 6. Fixes odd inner spacing in IE7.
34 | // 7. Subtract the border size from the padding value so that buttons do not
35 | // grow larger as we add borders.
36 | // 8. Prevent button text from being selectable.
37 | // 9. Prevent deafult browser outline halo
38 | //
39 | .o-btn {
40 | @include type(button);
41 | @include shadow(2);
42 | line-height: unitless($btn-height, map-get(map-get($type-styles, button), font-size));
43 | text-align: center; // [4]
44 | vertical-align: middle; // [2]
45 | white-space: nowrap; // bs only
46 | text-decoration: none; // [4]
47 | background-color: $btn-background-color;
48 | border: none;
49 | border-radius: $btn-border-radius;
50 | outline: none; // [9]
51 | color: $btn-text-color;
52 | position: relative;
53 | display: inline-block; // [1]
54 | overflow: hidden; // [6]
55 | min-width: $btn-min-width; // google material design
56 | margin: 0; // [4]
57 | padding: 0 $btn-spacing; // [7]
58 | cursor: pointer;
59 | user-select: none; // [8]
60 | transition:
61 | box-shadow 0.2s $animation-curve-fast-out-linear-in,
62 | background-color 0.2s $default-animation-curve,
63 | color 0.2s $default-animation-curve;
64 | will-change: box-shadow; // google material design
65 |
66 | // UI states
67 | &:hover {
68 | text-decoration: none; // [4]
69 | background-color: $btn-hover-color;
70 | color: $btn-text-hover-color;
71 | }
72 |
73 | &:focus {
74 | @include shadow(focus);
75 | outline: none; // [9]
76 | }
77 |
78 | &:disabled {
79 | background-color: transparent;
80 | box-shadow: none;
81 | cursor: default;
82 | }
83 |
84 | // Remove excess padding and border in Firefox 4+
85 | &::-moz-focus-inner {
86 | border: 0;
87 | padding: 0;
88 | }
89 | }
90 |
--------------------------------------------------------------------------------
/tests/all/templates/includes/list-item.twig:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 | {{topic.name}}
9 | {% if topic.pages %}
10 |
11 | {% for page in topic.pages %}
12 | {% if loop.last %}
13 |
14 | {% else %}
15 | - {{ page }}
16 | {% endif %}
17 | {% endfor %}
18 |
19 | {% endif %}
20 |
21 |
22 |
34 |

35 |
36 |
37 |
52 |
53 |
54 |
--------------------------------------------------------------------------------
/assets/css/utilities.0.12.0.min.css.map:
--------------------------------------------------------------------------------
1 | {"version":3,"sources":["utilities.0.12.0.css"],"names":[],"mappings":"AAAA,sBACC,sBAAyB,CACzB,AAED,kBACC,cAAe,AACf,WAAY,AACZ,WAAa,CACb,AAED,WACC,SAAU,AACV,kBAAmB,AACnB,gBAAiB,AACjB,mBAAuB,AACvB,UAAW,AACX,WAAY,AACZ,iBAAmB,AACnB,SAAW,CACX,AAED,uDAEC,gBAAiB,AACjB,iBAAkB,AAClB,UAAW,AACX,WAAY,AACZ,YAAa,AACb,QAAU,CACV,AAMD,0BACC,sBAAyB,CACzB,AAED,yBACC,kBACC,sBAAyB,CACzB,CACD,AAED,yBACC,gBACC,sBAAyB,CACzB,CACD,AAED,yBACC,kBACC,sBAAyB,CACzB,CACD,AAED,yBACC,gBACC,sBAAyB,CACzB,CACD,AAED,yBACC,kBACC,sBAAyB,CACzB,CACD,AAED,yBACC,gBACC,sBAAyB,CACzB,CACD,AAED,0BACC,kBACC,sBAAyB,CACzB,CACD,AAED,0BACC,gBACC,sBAAyB,CACzB,CACD,AAED,kBACC,sBAAyB,CACzB,AAED,aACC,2CAKC,iCAAmC,AACnC,0BAA4B,AAC5B,2BAA6B,AAC7B,oBAA0B,CAC1B,AAED,YAEC,yBAA2B,CAC3B,AAED,cACC,2BAA6B,CAC7B,AAED,kBACC,4BAA8B,CAC9B,AAED,gDAEC,UAAY,CACZ,AAED,eAEC,yBAA0B,AAC1B,uBAAyB,CACzB,AAED,MACC,0BAA4B,CAC5B,AAED,OAEC,uBAAyB,CACzB,AAED,IACC,wBAA2B,CAC3B,AAED,QAGC,UAAW,AACX,QAAU,CACV,AAED,MAEC,sBAAwB,CACxB,CACD","file":"utilities.0.12.0.min.css","sourcesContent":["[tabindex=\"-1\"]:focus {\n\toutline: none !important;\n}\n\n.u-clearfix:after {\n\tdisplay: table;\n\tclear: both;\n\tcontent: \" \";\n}\n\n.u-sr-only {\n\tborder: 0;\n\tposition: absolute;\n\toverflow: hidden;\n\tclip: rect(0, 0, 0, 0);\n\twidth: 1px;\n\theight: 1px;\n\tmargin: -0.0625rem;\n\tpadding: 0;\n}\n\n.u-sr-only.focusable:active,\n.u-sr-only.focusable:focus {\n\tposition: static;\n\toverflow: visible;\n\tclip: auto;\n\twidth: auto;\n\theight: auto;\n\tmargin: 0;\n}\n\n.u-hidden {\n\tdisplay: none !important;\n}\n\n.u-hidden-xs-up {\n\tdisplay: none !important;\n}\n\n@media (max-width: 575px) {\n\t.u-hidden-xs-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 576px) {\n\t.u-hidden-sm-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (max-width: 767px) {\n\t.u-hidden-sm-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 768px) {\n\t.u-hidden-md-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (max-width: 991px) {\n\t.u-hidden-md-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 992px) {\n\t.u-hidden-lg-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (max-width: 1199px) {\n\t.u-hidden-lg-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 1200px) {\n\t.u-hidden-xl-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n.u-hidden-xl-down {\n\tdisplay: none !important;\n}\n\n@media print {\n\t*,\n\t*:before,\n\t*:after,\n\t*:first-letter,\n\t*:first-line {\n\t\tbackground: transparent !important;\n\t\tbox-shadow: none !important;\n\t\ttext-shadow: none !important;\n\t\tcolor: #000000 !important;\n\t}\n\n\ta,\n\ta:visited {\n\t\ttext-decoration: underline;\n\t}\n\n\ta[href]:after {\n\t\tcontent: \" (\" attr(href) \")\";\n\t}\n\n\tabbr[title]:after {\n\t\tcontent: \" (\" attr(title) \")\";\n\t}\n\n\ta[href^=\"#\"]:after,\n\ta[href^=\"javascript:\"]:after {\n\t\tcontent: \"\";\n\t}\n\n\tpre,\n\tblockquote {\n\t\tborder: 1px solid #9e9e9e;\n\t\tpage-break-inside: avoid;\n\t}\n\n\tthead {\n\t\tdisplay: table-header-group;\n\t}\n\n\ttr,\n\timg {\n\t\tpage-break-inside: avoid;\n\t}\n\n\timg {\n\t\tmax-width: 100% !important;\n\t}\n\n\tp,\n\th2,\n\th3 {\n\t\torphans: 3;\n\t\twidows: 3;\n\t}\n\n\th2,\n\th3 {\n\t\tpage-break-after: avoid;\n\t}\n}\n\n/*# sourceMappingURL=utilities.0.12.0.css.map */\n"]}
--------------------------------------------------------------------------------
/tests/all/css/utilities.0.12.0.min.css.map:
--------------------------------------------------------------------------------
1 | {"version":3,"sources":["utilities.0.12.0.css"],"names":[],"mappings":"AAAA,sBACC,sBAAyB,CACzB,AAED,kBACC,cAAe,AACf,WAAY,AACZ,WAAa,CACb,AAED,WACC,SAAU,AACV,kBAAmB,AACnB,gBAAiB,AACjB,mBAAuB,AACvB,UAAW,AACX,WAAY,AACZ,iBAAmB,AACnB,SAAW,CACX,AAED,uDAEC,gBAAiB,AACjB,iBAAkB,AAClB,UAAW,AACX,WAAY,AACZ,YAAa,AACb,QAAU,CACV,AAMD,0BACC,sBAAyB,CACzB,AAED,yBACC,kBACC,sBAAyB,CACzB,CACD,AAED,yBACC,gBACC,sBAAyB,CACzB,CACD,AAED,yBACC,kBACC,sBAAyB,CACzB,CACD,AAED,yBACC,gBACC,sBAAyB,CACzB,CACD,AAED,yBACC,kBACC,sBAAyB,CACzB,CACD,AAED,yBACC,gBACC,sBAAyB,CACzB,CACD,AAED,0BACC,kBACC,sBAAyB,CACzB,CACD,AAED,0BACC,gBACC,sBAAyB,CACzB,CACD,AAED,kBACC,sBAAyB,CACzB,AAED,aACC,2CAKC,iCAAmC,AACnC,0BAA4B,AAC5B,2BAA6B,AAC7B,oBAA0B,CAC1B,AAED,YAEC,yBAA2B,CAC3B,AAED,cACC,2BAA6B,CAC7B,AAED,kBACC,4BAA8B,CAC9B,AAED,gDAEC,UAAY,CACZ,AAED,eAEC,yBAA0B,AAC1B,uBAAyB,CACzB,AAED,MACC,0BAA4B,CAC5B,AAED,OAEC,uBAAyB,CACzB,AAED,IACC,wBAA2B,CAC3B,AAED,QAGC,UAAW,AACX,QAAU,CACV,AAED,MAEC,sBAAwB,CACxB,CACD","file":"utilities.0.12.0.min.css","sourcesContent":["[tabindex=\"-1\"]:focus {\n\toutline: none !important;\n}\n\n.u-clearfix:after {\n\tdisplay: table;\n\tclear: both;\n\tcontent: \" \";\n}\n\n.u-sr-only {\n\tborder: 0;\n\tposition: absolute;\n\toverflow: hidden;\n\tclip: rect(0, 0, 0, 0);\n\twidth: 1px;\n\theight: 1px;\n\tmargin: -0.0625rem;\n\tpadding: 0;\n}\n\n.u-sr-only.focusable:active,\n.u-sr-only.focusable:focus {\n\tposition: static;\n\toverflow: visible;\n\tclip: auto;\n\twidth: auto;\n\theight: auto;\n\tmargin: 0;\n}\n\n.u-hidden {\n\tdisplay: none !important;\n}\n\n.u-hidden-xs-up {\n\tdisplay: none !important;\n}\n\n@media (max-width: 575px) {\n\t.u-hidden-xs-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 576px) {\n\t.u-hidden-sm-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (max-width: 767px) {\n\t.u-hidden-sm-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 768px) {\n\t.u-hidden-md-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (max-width: 991px) {\n\t.u-hidden-md-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 992px) {\n\t.u-hidden-lg-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (max-width: 1199px) {\n\t.u-hidden-lg-down {\n\t\tdisplay: none !important;\n\t}\n}\n\n@media (min-width: 1200px) {\n\t.u-hidden-xl-up {\n\t\tdisplay: none !important;\n\t}\n}\n\n.u-hidden-xl-down {\n\tdisplay: none !important;\n}\n\n@media print {\n\t*,\n\t*:before,\n\t*:after,\n\t*:first-letter,\n\t*:first-line {\n\t\tbackground: transparent !important;\n\t\tbox-shadow: none !important;\n\t\ttext-shadow: none !important;\n\t\tcolor: #000000 !important;\n\t}\n\n\ta,\n\ta:visited {\n\t\ttext-decoration: underline;\n\t}\n\n\ta[href]:after {\n\t\tcontent: \" (\" attr(href) \")\";\n\t}\n\n\tabbr[title]:after {\n\t\tcontent: \" (\" attr(title) \")\";\n\t}\n\n\ta[href^=\"#\"]:after,\n\ta[href^=\"javascript:\"]:after {\n\t\tcontent: \"\";\n\t}\n\n\tpre,\n\tblockquote {\n\t\tborder: 1px solid #9e9e9e;\n\t\tpage-break-inside: avoid;\n\t}\n\n\tthead {\n\t\tdisplay: table-header-group;\n\t}\n\n\ttr,\n\timg {\n\t\tpage-break-inside: avoid;\n\t}\n\n\timg {\n\t\tmax-width: 100% !important;\n\t}\n\n\tp,\n\th2,\n\th3 {\n\t\torphans: 3;\n\t\twidows: 3;\n\t}\n\n\th2,\n\th3 {\n\t\tpage-break-after: avoid;\n\t}\n}\n\n/*# sourceMappingURL=utilities.0.12.0.css.map */\n"]}
--------------------------------------------------------------------------------
/tests/all/scss/components/_forum.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @component: Forum
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $forum-spacing: 16px !default;
13 | $forum-spacing-sm: 12px !default;
14 | $forum-spacing-lg: 24px !default;
15 | $forum-border-radius: $default-border-radius !default;
16 | $forum-media-size: 40px !default;
17 | $forum-media-margin: 0 !default;
18 | $forum-border-style: solid !default;
19 | $forum-border-size: 1px !default;
20 |
21 |
22 | // Theme Variables
23 | $forum-background-color: $white !default;
24 | $forum-border-color: rgba(0, 0, 0, 0.125) !default;
25 | $forum-media-color: $default-secondary-color !default;
26 | $forum-media-read-color: $default-primary-color !default;
27 |
28 |
29 | //
30 | // @scss
31 | .c-forum {
32 | @include shadow(2);
33 | background-color: $forum-background-color;
34 | border-radius: $forum-border-radius;
35 | position: relative;
36 | display: flex;
37 | flex-direction: column;
38 | margin-bottom: $forum-spacing;
39 |
40 | &-body {
41 | flex: 1 1 auto;
42 | margin-bottom: $forum-spacing;
43 | }
44 |
45 | &-media {
46 | display: flex;
47 | float: left;
48 | flex: 1;
49 | flex-direction: column;
50 | margin: $forum-spacing $forum-spacing 0;
51 | }
52 |
53 | &-media-icon {
54 | color: $forum-media-color;
55 | width: $forum-media-size;
56 | height: $forum-media-size;
57 | margin-right: $forum-media-margin;
58 |
59 | &-read {
60 | color: $forum-media-read-color;
61 | }
62 | }
63 |
64 | &-info {
65 | display: flex;
66 | flex-direction: column;
67 | margin-right: $forum-spacing;
68 | }
69 |
70 | &-title {
71 | @include type(headline);
72 | margin-top: $forum-spacing-lg;
73 | margin-bottom: $forum-spacing-sm;
74 |
75 | &-link {
76 | line-height: 1;
77 | }
78 | @media (min-width: $bp-lg) {
79 | margin-bottom: 0;
80 | }
81 | }
82 |
83 | &-text {
84 | @include type(body1);
85 | margin: $forum-spacing 0 0;
86 |
87 | }
88 |
89 | &-footer {
90 | border-top: $forum-border-size $forum-border-style $forum-border-color;
91 | border-radius: 0 0 $forum-border-radius $forum-border-radius;
92 | }
93 |
94 | &-cat {
95 | &-title {
96 | @include type(headline);
97 | border-bottom: $forum-border-size $forum-border-style $forum-border-color;
98 | margin-top: $forum-spacing;
99 | margin-bottom: $forum-spacing-lg;
100 | padding-bottom: ($forum-spacing / 4);
101 |
102 | &-link {
103 | line-height: 1;
104 | }
105 | }
106 | }
107 |
108 | @media (min-width: $bp-lg) {
109 | &-deck {
110 | display: flex;
111 | flex-flow: row wrap;
112 | }
113 |
114 | &-deck .c-forum {
115 | display: flex;
116 | flex: 1 0 0%;
117 | flex-direction: column;
118 | min-width: calc((100% / 2) - (12px));
119 | max-width: calc((100% / 2) - (12px));
120 | margin-bottom: $forum-spacing-lg;
121 | margin-left: $forum-spacing-lg;
122 |
123 | &:first-child,
124 | &:nth-child(2n+1) {
125 | margin-left: 0;
126 | }
127 | }
128 | }
129 | }
130 |
--------------------------------------------------------------------------------
/src/scss/settings/_default.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @setting: Default
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | $default-font-size: 16px !default;
12 | $default-line-height: 24px !default;
13 |
14 | $default-border-size: 1px !default;
15 | $default-border-radius: 2px !default;
16 |
17 | $default-grid-gutter: 16px !default;
18 |
19 | // Grid
20 | $sm: 540px !default;
21 | $md: 720px !default;
22 | $lg: 960px !default;
23 | $xl: 1140px !default;
24 |
25 | $bp-sm: 576px !default;
26 | $bp-md: 768px !default;
27 | $bp-lg: 992px !default;
28 | $bp-xl: 1200px !default;
29 |
30 | // Fonts
31 | $default-font: Roboto, Helvetica, Arial, sans-serif !default;
32 | $default-code-font: Monaco, Andale Mono, Courier New, Courier, Mono !default;
33 |
34 | // icons
35 | $default-icon-sm: $default-font-size !default;
36 | $default-icon-md: $default-line-height !default;
37 | $default-icon-lg: 2 * $default-font-size !default;
38 |
39 | //
40 | // color scheme
41 |
42 | // body
43 | $default-body-bg: $white !default;
44 | $default-body-color: $gray-800 !default;
45 | $default-text-color: $black-87 !default; // 87%
46 | $default-gray-light: $black-12 !default; // 12%
47 | $default-gray: $black-38 !default; // 38%
48 | $default-gray-dark: $black-54 !default; // 54%
49 |
50 | // color scheme Main
51 | $default-primary-color: $blue-500 !default;
52 | $default-secondary-color: $pink-500 !default;
53 | $default-accent-color: $yellow-500 !default;
54 | $default-warning-color: $amber-500 !default;
55 | $default-info-color: $blue-gray-500 !default;
56 | $default-important-color: $red-500 !default;
57 | $default-success-color: $green-500 !default;
58 |
59 | // color scheme Light
60 | $default-primary-light-color: $blue-300 !default;
61 | $default-secondary-light-color: $pink-300 !default;
62 | $default-accent-light-color: $yellow-300 !default;
63 | $default-warning-light-color: $amber-300 !default;
64 | $default-info-light-color: $blue-gray-300 !default;
65 | $default-important-light-color: $red-300 !default;
66 | $default-success-light-color: $green-300 !default;
67 |
68 | // color scheme Dark
69 | $default-primary-dark-color: $blue-700 !default;
70 | $default-secondary-dark-color: $pink-700 !default;
71 | $default-accent-dark-color: $yellow-700 !default;
72 | $default-warning-dark-color: $amber-700 !default;
73 | $default-info-dark-color: $blue-gray-700 !default;
74 | $default-important-dark-color: $red-700 !default;
75 | $default-success-dark-color: $green-700 !default;
76 |
77 | // color scheme
78 | $default-link-color: $blue-500 !default;
79 | $default-link-color-hover: $blue-700 !default;
80 | $default-action-bg: $gray-100 !default;
81 | $default-action-bg-hover: $gray-200 !default;
82 | $default-action-color: $black-54 !default;
83 | $default-action-color-hover: $blue-500 !default;
84 | $default-action-icon-color: $black-54 !default;
85 |
--------------------------------------------------------------------------------
/tests/all/scss/settings/_default.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @setting: Default
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | $default-font-size: 16px !default;
12 | $default-line-height: 24px !default;
13 |
14 | $default-border-size: 1px !default;
15 | $default-border-radius: 2px !default;
16 |
17 | $default-grid-gutter: 16px !default;
18 |
19 | // Grid
20 | $sm: 540px !default;
21 | $md: 720px !default;
22 | $lg: 960px !default;
23 | $xl: 1140px !default;
24 |
25 | $bp-sm: 576px !default;
26 | $bp-md: 768px !default;
27 | $bp-lg: 992px !default;
28 | $bp-xl: 1200px !default;
29 |
30 | // Fonts
31 | $default-font: Roboto, Helvetica, Arial, sans-serif !default;
32 | $default-code-font: Monaco, Andale Mono, Courier New, Courier, Mono !default;
33 |
34 | // icons
35 | $default-icon-sm: $default-font-size !default;
36 | $default-icon-md: $default-line-height !default;
37 | $default-icon-lg: 2 * $default-font-size !default;
38 |
39 | //
40 | // color scheme
41 |
42 | // body
43 | $default-body-bg: $white !default;
44 | $default-body-color: $gray-800 !default;
45 | $default-text-color: $black-87 !default; // 87%
46 | $default-gray-light: $black-12 !default; // 12%
47 | $default-gray: $black-38 !default; // 38%
48 | $default-gray-dark: $black-54 !default; // 54%
49 |
50 | // color scheme Main
51 | $default-primary-color: $blue-500 !default;
52 | $default-secondary-color: $pink-500 !default;
53 | $default-accent-color: $yellow-500 !default;
54 | $default-warning-color: $amber-500 !default;
55 | $default-info-color: $blue-gray-500 !default;
56 | $default-important-color: $red-500 !default;
57 | $default-success-color: $green-500 !default;
58 |
59 | // color scheme Light
60 | $default-primary-light-color: $blue-300 !default;
61 | $default-secondary-light-color: $pink-300 !default;
62 | $default-accent-light-color: $yellow-300 !default;
63 | $default-warning-light-color: $amber-300 !default;
64 | $default-info-light-color: $blue-gray-300 !default;
65 | $default-important-light-color: $red-300 !default;
66 | $default-success-light-color: $green-300 !default;
67 |
68 | // color scheme Dark
69 | $default-primary-dark-color: $blue-700 !default;
70 | $default-secondary-dark-color: $pink-700 !default;
71 | $default-accent-dark-color: $yellow-700 !default;
72 | $default-warning-dark-color: $amber-700 !default;
73 | $default-info-dark-color: $blue-gray-700 !default;
74 | $default-important-dark-color: $red-700 !default;
75 | $default-success-dark-color: $green-700 !default;
76 |
77 | // color scheme
78 | $default-link-color: $blue-500 !default;
79 | $default-link-color-hover: $blue-700 !default;
80 | $default-action-bg: $gray-100 !default;
81 | $default-action-bg-hover: $gray-200 !default;
82 | $default-action-color: $black-54 !default;
83 | $default-action-color-hover: $blue-500 !default;
84 | $default-action-icon-color: $black-54 !default;
85 |
--------------------------------------------------------------------------------
/tests/all/scss/objects/_col.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #object: Col
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // This grid system is uses flex-box based on the BS4 grid system
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 |
11 | //
12 | // #scss
13 |
14 | //
15 | // Setup all grid columns to use table cell layout and use the default gutter
16 | @for $i from 1 through 12 {
17 | .o-col-#{$i} {
18 | @include col-width($i);
19 | }
20 | }
21 |
22 | @for $i from 1 through 12 {
23 | .o-pull-#{$i} {
24 | @include pull($i);
25 | }
26 | }
27 |
28 | @for $i from 1 through 12 {
29 | .o-push-#{$i} {
30 | @include push($i);
31 | }
32 | }
33 |
34 | @for $i from 1 through 12 {
35 | .o-offset-#{$i} {
36 | @include offset($i);
37 | }
38 | }
39 |
40 | //
41 | // small widths
42 | @media (min-width: $bp-sm) {
43 | .o-pull-sm-0 {
44 | right: auto;
45 | }
46 |
47 | .o-push-sm-0 {
48 | left: auto;
49 | }
50 | @for $i from 1 through 12 {
51 | .o-col-sm-#{$i} {
52 | @include col-width($i);
53 | }
54 | }
55 |
56 | @for $i from 1 through 12 {
57 | .o-pull-sm-#{$i} {
58 | @include pull($i);
59 | }
60 | }
61 |
62 | @for $i from 1 through 12 {
63 | .o-push-sm-#{$i} {
64 | @include push($i);
65 | }
66 | }
67 |
68 | @for $i from 1 through 12 {
69 | .o-offset-sm-#{$i} {
70 | @include offset($i);
71 | }
72 | }
73 | }
74 |
75 | //
76 | // medium widths
77 | @media (min-width: $bp-md) {
78 | .o-pull-md-0 {
79 | right: auto;
80 | }
81 |
82 | .o-push-md-0 {
83 | left: auto;
84 | }
85 | @for $i from 1 through 12 {
86 | .o-col-md-#{$i} {
87 | @include col-width($i);
88 | }
89 | }
90 |
91 | @for $i from 1 through 12 {
92 | .o-pull-md-#{$i} {
93 | @include pull($i);
94 | }
95 | }
96 |
97 | @for $i from 1 through 12 {
98 | .o-push-md-#{$i} {
99 | @include push($i);
100 | }
101 | }
102 |
103 | @for $i from 1 through 12 {
104 | .o-offset-md-#{$i} {
105 | @include offset($i);
106 | }
107 | }
108 | }
109 |
110 | //
111 | // large widths
112 | @media (min-width: $bp-lg) {
113 | .o-pull-lg-0 {
114 | right: auto;
115 | }
116 |
117 | .o-push-lg-0 {
118 | left: auto;
119 | }
120 | @for $i from 1 through 12 {
121 | .o-col-lg-#{$i} {
122 | @include col-width($i);
123 | }
124 | }
125 |
126 | @for $i from 1 through 12 {
127 | .o-pull-lg-#{$i} {
128 | @include pull($i);
129 | }
130 | }
131 |
132 | @for $i from 1 through 12 {
133 | .o-push-lg-#{$i} {
134 | @include push($i);
135 | }
136 | }
137 |
138 | @for $i from 1 through 12 {
139 | .o-offset-lg-#{$i} {
140 | @include offset($i);
141 | }
142 | }
143 | }
144 |
145 | //
146 | // extra-large widths
147 | @media (min-width: $bp-xl) {
148 | .o-pull-xl-0 {
149 | right: auto;
150 | }
151 |
152 | .o-push-xl-0 {
153 | left: auto;
154 | }
155 | @for $i from 1 through 12 {
156 | .o-col-xl-#{$i} {
157 | @include col-width($i);
158 | }
159 | }
160 |
161 | @for $i from 1 through 12 {
162 | .o-pull-xl-#{$i} {
163 | @include pull($i);
164 | }
165 | }
166 |
167 | @for $i from 1 through 12 {
168 | .o-push-xl-#{$i} {
169 | @include push($i);
170 | }
171 | }
172 |
173 | @for $i from 1 through 12 {
174 | .o-offset-xl-#{$i} {
175 | @include offset($i);
176 | }
177 | }
178 | }
179 |
180 | .o-pull-0 {
181 | right: auto;
182 | }
183 |
184 | .o-push-0 {
185 | left: auto;
186 | }
187 |
--------------------------------------------------------------------------------
/views/includes/sprite.pug:
--------------------------------------------------------------------------------
1 | div(style="position: absolute; width: 0; height: 0;")
2 | svg.app-icons(xmlns="http://www.w3.org/2000/svg" style="position: absolute; width: 0; height: 0;")
3 | symbol#app(viewbox="0 0 24 24")
4 | path(fill-rule="evenodd" d="M19 8.999c1.654 0 3-1.346 3-3s-1.346-3-3-3a2.993 2.993 0 0 0-2.815 2H2v2h14.185a2.993 2.993 0 0 0 2.815 2zm0-4a1 1 0 1 1 0 2 1 1 0 0 1 0-2zm-10 4c1.302 0 2.401.838 2.815 2H22v2H11.815a2.994 2.994 0 0 1-2.815 2 2.994 2.994 0 0 1-2.815-2H2v-2h4.185a2.993 2.993 0 0 1 2.815-2zm0 4a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm10 2c1.654 0 3 1.346 3 3s-1.346 3-3 3a2.994 2.994 0 0 1-2.815-2H2v-2h14.185a2.993 2.993 0 0 1 2.815-2zm0 4a1 1 0 1 0 0-2 1 1 0 0 0 0 2z")
5 | symbol#settings(viewbox="0 0 24 24")
6 | path(fill-rule="nonzero" d="M19.713 12c0 .34-.031.66-.072.98l2.169 1.65c.195.15.247.42.123.64l-2.056 3.46c-.123.22-.39.31-.627.22l-2.56-1a7.94 7.94 0 0 1-1.737.98l-.39 2.65a.497.497 0 0 1-.505.42H9.946a.497.497 0 0 1-.504-.42l-.39-2.65a7.564 7.564 0 0 1-1.738-.98l-2.56 1a.524.524 0 0 1-.627-.22l-2.056-3.46a.495.495 0 0 1 .124-.64l2.169-1.65a7.718 7.718 0 0 1-.072-.98c0-.33.03-.66.072-.98l-2.17-1.65a.484.484 0 0 1-.123-.64l2.056-3.46a.508.508 0 0 1 .627-.22l2.56 1c.535-.39 1.11-.73 1.738-.98l.39-2.65A.498.498 0 0 1 9.946 2h4.112c.257 0 .473.18.504.42l.39 2.65c.628.25 1.204.58 1.738.98l2.56-1c.226-.08.504 0 .627.22l2.056 3.46c.124.22.072.49-.123.64l-2.17 1.65c.042.32.073.64.073.98zm-3.316-3.79l-.848-.635a5.66 5.66 0 0 0-1.302-.736l-1.019-.406-.16-1.085-.216-1.443-1.706.018-.37 2.51-1.019.406a6.05 6.05 0 0 0-1.32.75l-.843.615-.973-.38-1.471-.546-.791 1.345 2.034 1.548-.14 1.092c-.038.295-.056.53-.056.737 0 .206.018.442.056.737l.14 1.092-.876.667-1.164.885.823 1.36 2.432-.95.847.634c.414.31.845.553 1.302.736l1.02.406.16 1.085.214 1.443 1.702.016.375-2.544 1.02-.406a6.05 6.05 0 0 0 1.32-.75l.843-.615.972.38 1.457.57.812-1.364-2.04-1.553.14-1.092c.038-.302.056-.525.056-.737 0-.212-.018-.435-.057-.737l-.14-1.092.877-.667 1.164-.885-.79-1.33-2.465.92zM12 13.429A1.43 1.43 0 0 1 10.571 12c0-.788.641-1.429 1.429-1.429s1.429.641 1.429 1.429A1.43 1.43 0 0 1 12 13.429z")
7 | symbol#faq(viewbox="0 0 24 24")
8 | path(fill-rule="evenodd" d="M12 22C6.486 22 2 17.515 2 12 2 6.487 6.486 2 12 2s10 4.486 10 10c0 5.515-4.486 10-10 10zm0-18c4.411 0 8 3.589 8 8s-3.589 8-8 8-8-3.589-8-8 3.589-8 8-8zm1 11v-1.125A4.011 4.011 0 0 0 16 10c0-2.205-1.795-4-4-4s-4 1.795-4 4h2a2 2 0 1 1 2 2h-1v3h2zm-1 3.25a1.25 1.25 0 1 0 0-2.5 1.25 1.25 0 0 0 0 2.5z")
9 | symbol#home(viewbox="0 0 24 24")
10 | path(fill-rule="nonzero" d="M5.828 11l-2 2h-2l-.242-.586L3 11h2.828zM6 11v9h2v-7h8v7h2v-9l-6-6.172L6 11zm4 11H4v-9H1L12 2l11 11h-3v9h-6v-7h-4v7z")
11 | symbol#github(viewbox="0 0 24 24")
12 | path(d="M13.9 16.653c.4-.103.8-.103 1.199-.206 1.198-.31 2.197-.93 2.696-2.067.6-1.24.699-2.48.4-3.823-.1-.62-.4-1.033-.8-1.55-.1-.103-.1-.206-.1-.31.2-.826.2-1.549-.1-2.376 0-.103-.1-.206-.299-.206-.5 0-.899.206-1.298.413-.4.207-.7.413-.999.62-.1.103-.2.103-.3.103a9.039 9.039 0 0 0-4.693 0c-.1 0-.2 0-.3-.103-.698-.413-1.298-.827-2.096-.93-.5-.103-.5-.103-.6.413a4 4 0 0 0 0 2.17v.207c-.898 1.033-1.098 2.376-.898 3.616.1.413.1.723.2 1.136.499 1.447 1.497 2.273 2.995 2.687.4.103.8.206 1.298.31-.3.31-.499.826-.599 1.24 0 .103-.1.103-.1.103-.998.413-2.097.31-2.796-.827-.3-.516-.699-.93-1.398-1.033h-.5c-.199 0-.199.207-.099.31l.2.207c.499.31.898.826 1.098 1.446.4.93 1.099 1.343 2.097 1.447.4 0 .9 0 1.398-.104v1.963c0 .31-.3.517-.699.414a13.25 13.25 0 0 1-2.396-1.24c-2.996-2.17-4.594-5.166-4.394-8.989.2-4.753 3.595-8.575 8.089-9.505C15.298 1.156 20.29 4.462 21.69 9.73c1.298 5.166-1.598 10.538-6.392 12.192-.499.206-.799 0-.799-.62v-2.48c.1-.827 0-1.55-.599-2.17z")
--------------------------------------------------------------------------------
/src/scss/tools/function/_functions.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 2.1 Functions
78 | @import "strip-unit";
79 | @import "unitless";
80 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/function/_functions.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 2.1 Functions
78 | @import "strip-unit";
79 | @import "unitless";
80 |
--------------------------------------------------------------------------------
/src/scss/settings/_settings.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 1. Global Settings
78 | //-------------------------
79 | @import "color";
80 | @import "default";
81 |
--------------------------------------------------------------------------------
/tests/all/scss/settings/_settings.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 1. Global Settings
78 | //-------------------------
79 | @import "color";
80 | @import "default";
81 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_mixins.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 2.2 Mixins
78 | @import "animations";
79 | @import "background-triangle";
80 | @import "clearfix";
81 | @import "font-size";
82 | @import "grid";
83 | @import "shadows";
84 | @import "space";
85 | @import "type";
86 | @import "vertical-rhythm";
87 | @import "border_radius";
88 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_mixins.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 2.2 Mixins
78 | @import "animations";
79 | @import "background-triangle";
80 | @import "clearfix";
81 | @import "font-size";
82 | @import "grid";
83 | @import "shadows";
84 | @import "space";
85 | @import "type";
86 | @import "vertical-rhythm";
87 | @import "border_radius";
88 |
--------------------------------------------------------------------------------
/tests/all/scss/utilities.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 1. Global Settings
78 | //-------------------------
79 | @import "settings/settings";
80 |
81 |
82 | // 2. Tools
83 | //-------------------------
84 | @import "tools/function/functions";
85 | @import "tools/mixin/mixins";
86 |
87 |
88 | // 8. Utilities
89 | //-------------------------
90 | @import "utilities/resets";
91 | @import "utilities/clearfix";
92 | @import "utilities/visability";
93 | @import "utilities/print";
94 |
--------------------------------------------------------------------------------
/src/scss/theme.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 1. Global Settings
78 | //-------------------------
79 | @import "settings/settings";
80 |
81 |
82 | // 2. Tools
83 | //-------------------------
84 | @import "tools/function/functions";
85 | @import "tools/mixin/mixins";
86 |
87 |
88 | // 6. Components
89 | //-------------------------
90 | @import "components/_navbar";
91 | @import "components/_footer";
92 | @import "components/_sidebar";
93 |
94 |
95 | // 7. Theme
96 | //-------------------------
97 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_type.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Type
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A mixin for generating type settings based on Google Material Design types
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //@settings
11 | $type-font-weight: (
12 | thin: 100,
13 | light: 300,
14 | regular: 400,
15 | medium: 500,
16 | bold: 700,
17 | black: 900
18 | );
19 |
20 | $type-styles: (
21 | display4: (
22 | font-size: 112px,
23 | letter-spacing: -0.04em,
24 | font-weight: map-get($type-font-weight, light),
25 | line-height: unitless(112px, 112px),
26 | opacity: 0.54
27 | ),
28 | display3: (
29 | font-size: 56px,
30 | letter-spacing: -0.02em,
31 | font-weight: map-get($type-font-weight, regular),
32 | line-height: unitless(56px, 56px),
33 | opacity: 0.54
34 | ),
35 | display2: (
36 | font-size: 45px,
37 | letter-spacing: normal,
38 | font-weight: map-get($type-font-weight, regular),
39 | line-height: unitless(48px, 45px),
40 | opacity: 0.54
41 | ),
42 | display1: (
43 | font-size: 34px,
44 | letter-spacing: normal,
45 | font-weight: map-get($type-font-weight, regular),
46 | line-height: unitless(40px, 34px),
47 | opacity: 0.87
48 | ),
49 | headline: (
50 | font-size: 24px,
51 | letter-spacing: normal,
52 | font-weight: map-get($type-font-weight, regular),
53 | line-height: unitless(32px, 24px),
54 | opacity: 0.87
55 | ),
56 | blockquote: (
57 | font-size: 24px,
58 | letter-spacing: 0.02em,
59 | font-weight: map-get($type-font-weight, thin),
60 | line-height: normal,
61 | opacity: 0.54
62 | ),
63 | title: (
64 | font-size: 20px,
65 | letter-spacing: 0.02em,
66 | font-weight: map-get($type-font-weight, medium),
67 | line-height: unitless(32px, 20px),
68 | opacity: 0.87
69 | ),
70 | subhead2: (
71 | font-size: 16px,
72 | letter-spacing: 0.04em,
73 | font-weight: map-get($type-font-weight, regular),
74 | line-height: unitless(28px),
75 | opacity: 0.87
76 | ),
77 | subhead1: (
78 | font-size: 15px,
79 | letter-spacing: 0.04em,
80 | font-weight: map-get($type-font-weight, regular),
81 | line-height: unitless(24px, 15px),
82 | opacity: 0.87
83 | ),
84 | body2: (
85 | font-size: 14px,
86 | letter-spacing: 0.04em,
87 | font-weight: map-get($type-font-weight, medium),
88 | line-height: unitless(24px, 14px),
89 | opacity: 0.87
90 | ),
91 | body1: (
92 | font-size: 14px,
93 | letter-spacing: 0.04em,
94 | font-weight: map-get($type-font-weight, regular),
95 | line-height: unitless(20px, 14px),
96 | opacity: 0.87
97 | ),
98 | button: (
99 | font-size: 14px,
100 | letter-spacing: normal,
101 | font-weight: map-get($type-font-weight, medium),
102 | line-height: 1,
103 | opacity: 0.54
104 | ),
105 | menu: (
106 | font-size: 14px,
107 | letter-spacing: normal,
108 | font-weight: map-get($type-font-weight, medium),
109 | line-height: normal,
110 | opacity: 0.54
111 | ),
112 | caption: (
113 | font-size: 12px,
114 | letter-spacing: 0.08em,
115 | font-weight: map-get($type-font-weight, regular),
116 | line-height: unitless(20px, 12px),
117 | opacity: 0.87
118 | )
119 | );
120 |
121 | //
122 | // @scss
123 | @mixin type($type, $color-contrast: false) {
124 | $type-props: map-get($type-styles, $type);
125 | @if not map-has-key($type-styles, $type) {
126 | @error "Invalid style specified! Choose one of #{map-keys($type-styles)}";
127 | }
128 | @if $type == blockquote {
129 | font-style: italic;
130 | }
131 | @if $type == button {
132 | text-transform: uppercase;
133 | }
134 | @if $type == blockquote {
135 | position: relative;
136 | }
137 | @if $color-contrast {
138 | opacity: map-get($type-props, opacity);
139 | }
140 | font-size: map-get($type-props, font-size);
141 | font-weight: #{map-get($type-props, font-weight)};
142 | line-height: map-get($type-props, line-height);
143 | letter-spacing: map-get($type-props, letter-spacing);
144 | }
145 |
--------------------------------------------------------------------------------
/tests/all/templates/forum.twig:
--------------------------------------------------------------------------------
1 | {# forum.twig #}
2 | {% extends "./layout/layout.twig" %}
3 |
4 | {% block component %}
5 | {% for item in forums %}
6 | {% if item.cat === 1 %}
7 | {% if loop.first %}
8 |
9 |
12 |
13 | {% else %}
14 |
15 |
16 |
17 |
20 |
21 | {% endif %}
22 | {% else %}
23 |
24 |
25 |
26 |
27 |
28 |
29 |
32 | {% if item.desc %}
33 |
34 | {{ item.desc }}
35 |
36 | {% endif %}
37 |
38 |
39 |
72 |
73 | {% if loop.last %}
74 |
75 |
76 | {% endif %}
77 | {% endif %}
78 | {% endfor %}
79 | {% endblock %}
80 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_type.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Type
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // A mixin for generating type settings based on Google Material Design types
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //@settings
11 | $type-font-weight: (
12 | thin: 100,
13 | light: 300,
14 | regular: 400,
15 | medium: 500,
16 | bold: 700,
17 | black: 900
18 | );
19 |
20 | $type-styles: (
21 | display4: (
22 | font-size: 112px,
23 | letter-spacing: -0.04em,
24 | font-weight: map-get($type-font-weight, light),
25 | line-height: unitless(112px, 112px),
26 | opacity: 0.54
27 | ),
28 | display3: (
29 | font-size: 56px,
30 | letter-spacing: -0.02em,
31 | font-weight: map-get($type-font-weight, regular),
32 | line-height: unitless(56px, 56px),
33 | opacity: 0.54
34 | ),
35 | display2: (
36 | font-size: 45px,
37 | letter-spacing: normal,
38 | font-weight: map-get($type-font-weight, regular),
39 | line-height: unitless(48px, 45px),
40 | opacity: 0.54
41 | ),
42 | display1: (
43 | font-size: 34px,
44 | letter-spacing: normal,
45 | font-weight: map-get($type-font-weight, regular),
46 | line-height: unitless(40px, 34px),
47 | opacity: 0.87
48 | ),
49 | headline: (
50 | font-size: 24px,
51 | letter-spacing: normal,
52 | font-weight: map-get($type-font-weight, regular),
53 | line-height: unitless(32px, 24px),
54 | opacity: 0.87
55 | ),
56 | blockquote: (
57 | font-size: 24px,
58 | letter-spacing: 0.02em,
59 | font-weight: map-get($type-font-weight, thin),
60 | line-height: normal,
61 | opacity: 0.54
62 | ),
63 | title: (
64 | font-size: 20px,
65 | letter-spacing: 0.02em,
66 | font-weight: map-get($type-font-weight, medium),
67 | line-height: unitless(32px, 20px),
68 | opacity: 0.87
69 | ),
70 | subhead2: (
71 | font-size: 16px,
72 | letter-spacing: 0.04em,
73 | font-weight: map-get($type-font-weight, regular),
74 | line-height: unitless(28px),
75 | opacity: 0.87
76 | ),
77 | subhead1: (
78 | font-size: 15px,
79 | letter-spacing: 0.04em,
80 | font-weight: map-get($type-font-weight, regular),
81 | line-height: unitless(24px, 15px),
82 | opacity: 0.87
83 | ),
84 | body2: (
85 | font-size: 14px,
86 | letter-spacing: 0.04em,
87 | font-weight: map-get($type-font-weight, medium),
88 | line-height: unitless(24px, 14px),
89 | opacity: 0.87
90 | ),
91 | body1: (
92 | font-size: 14px,
93 | letter-spacing: 0.04em,
94 | font-weight: map-get($type-font-weight, regular),
95 | line-height: unitless(20px, 14px),
96 | opacity: 0.87
97 | ),
98 | button: (
99 | font-size: 14px,
100 | letter-spacing: normal,
101 | font-weight: map-get($type-font-weight, medium),
102 | line-height: 1,
103 | opacity: 0.54
104 | ),
105 | menu: (
106 | font-size: 14px,
107 | letter-spacing: normal,
108 | font-weight: map-get($type-font-weight, medium),
109 | line-height: normal,
110 | opacity: 0.54
111 | ),
112 | caption: (
113 | font-size: 12px,
114 | letter-spacing: 0.08em,
115 | font-weight: map-get($type-font-weight, regular),
116 | line-height: unitless(20px, 12px),
117 | opacity: 0.87
118 | )
119 | );
120 |
121 | //
122 | // @scss
123 | @mixin type($type, $color-contrast: false) {
124 | $type-props: map-get($type-styles, $type);
125 | @if not map-has-key($type-styles, $type) {
126 | @error "Invalid style specified! Choose one of #{map-keys($type-styles)}";
127 | }
128 | @if $type == blockquote {
129 | font-style: italic;
130 | }
131 | @if $type == button {
132 | text-transform: uppercase;
133 | }
134 | @if $type == blockquote {
135 | position: relative;
136 | }
137 | @if $color-contrast {
138 | opacity: map-get($type-props, opacity);
139 | }
140 | font-size: map-get($type-props, font-size);
141 | font-weight: #{map-get($type-props, font-weight)};
142 | line-height: map-get($type-props, line-height);
143 | letter-spacing: map-get($type-props, letter-spacing);
144 | }
145 |
--------------------------------------------------------------------------------
/tests/prosilver/scss/theme.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 1. Global Settings
78 | //-------------------------
79 | @import "../../all/scss/settings/settings";
80 |
81 |
82 | // 2. Tools
83 | //-------------------------
84 | @import "../../all/scss/tools/function/functions";
85 | @import "../../all/scss/tools/mixin/mixins";
86 |
87 |
88 | // 5. Objects
89 | //-------------------------
90 | @import "objects/action-bar";
91 |
92 | // 6. Components
93 | //-------------------------
94 | @import "../../all/scss/components/forum";
95 | @import "../../all/scss/components/list";
96 | @import "../../all/scss/components/menu";
97 | @import "../../all/scss/components/toolbar";
98 | @import "../../all/scss/components/paging";
99 | @import "../../all/scss/components/topic";
100 |
101 |
102 | // 7. Theme
103 | //-------------------------
104 |
--------------------------------------------------------------------------------
/tests/all/scss/generic/reset/_global.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Global
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | // A thin layer on top of normalize.css that provides a starting point more
7 | // suitable for web applications.
8 | //
9 | //------------------------------------------------------------------------------
10 |
11 | //
12 | // #scss
13 |
14 | //
15 | // 1. Force scrollbars to always be visible to prevent awkward ‘jumps’ when
16 | // navigating between pages that do/do not have enough content to produce
17 | // scrollbars naturally.
18 | // 2. Ensure the page always fills at least the entire height of the viewport.
19 | // 3. Fonts on OSX will look more consistent with other systems that do not
20 | // render text using sub-pixel anti-aliasing.
21 | // 4. Changes the default tap highlight to be completely transparent in iOS.
22 | // 5. Set touch-action to avoid touch delay on mobile IE
23 | // 6. Make html take up the entire screen
24 | //
25 | html {
26 | -webkit-font-smoothing: antialiased;
27 | -webkit-tap-highlight-color: rgba(0, 0, 0, 0); // [4]
28 | overflow-y: scroll; // [1]
29 | width: 100%; // [6]
30 | height: 100%; // [6]
31 | min-height: 100%; // [2]
32 | -ms-touch-action: manipulation; // [5]
33 | touch-action: manipulation;
34 | /* stylelint-disable order/declaration-block-properties-specified-order */
35 | -moz-osx-font-smoothing: grayscale; // [3]
36 | /* stylelint-enable order/declaration-block-properties-specified-order */
37 | -ms-overflow-style: -ms-autohiding-scrollbar; // [1] Edge 12+, IE 11
38 | }
39 |
40 | body {
41 | width: 100%;
42 | min-height: 100%;
43 | }
44 |
45 | //
46 | // Removes the default spacing and border for appropriate elements.
47 | //
48 | iframe {
49 | border: 0;
50 | }
51 |
52 | //
53 | // Remove the gap between audio, canvas, iframes,
54 | // images, videos and the bottom of their containers:
55 | // https://github.com/h5bp/html5-boilerplate/issues/440
56 | //
57 | audio,
58 | canvas,
59 | iframe,
60 | img,
61 | svg,
62 | video {
63 | vertical-align: middle;
64 | }
65 |
66 | //
67 | // Avoid 300ms click delay on touch devices that support the `touch-action`
68 | // CSS property.
69 | //
70 | // In particular, unlike most other browsers, IE11+Edge on Windows 10 on touch
71 | // devices and IE Mobile 10-11 DON'T remove the click delay when
72 | // `` is present.
73 | //
74 | // However, they DO support removing the click delay via
75 | // `touch-action: manipulation`.
76 | //
77 | // See:
78 | // * http://caniuse.com/#feat=css-touch-action
79 | // * http://patrickhlauke.github.io/touch/tests/results/#suppressing-300ms-delay
80 | //
81 | a,
82 | area,
83 | button,
84 | [role="button"],
85 | input,
86 | label,
87 | select,
88 | summary,
89 | textarea,
90 | [tabindex] {
91 | touch-action: manipulation;
92 | }
93 |
94 | //
95 | // Remove text-shadow in selection highlight:
96 | // https://twitter.com/miketaylr/status/12228805301
97 | //
98 | // These selection rule sets have to be separate.
99 | // Customize the background color to match your design.
100 | //
101 | ::-moz-selection {
102 | background: $blue-200;
103 | text-shadow: none;
104 | }
105 |
106 | ::selection {
107 | background: $blue-200;
108 | text-shadow: none;
109 | color: $white;
110 | }
111 |
112 | //
113 | // use current current as the default fill of svg elements
114 | //
115 | svg {
116 | fill: currentColor;
117 | }
118 |
119 | //
120 | // specify the progress cursor of updating elements
121 | //
122 | [aria-busy="true"] {
123 | cursor: progress;
124 | }
125 |
126 | //
127 | // specify the pointer cursor of trigger elements
128 | //
129 | [aria-controls] {
130 | cursor: pointer;
131 | }
132 |
133 | //
134 | // specify the unstyled cursor of disabled, not-editable, or otherwise
135 | // inoperable elements
136 | //
137 | [aria-disabled] {
138 | cursor: default;
139 | }
140 |
141 | //
142 | // specify the style of visually hidden yet accessible elements
143 | //
144 | [hidden][aria-hidden="false"] {
145 | position: absolute;
146 | display: inherit;
147 | clip: rect(0 0 0 0);
148 |
149 | &:focus {
150 | clip: auto;
151 | }
152 | }
153 |
154 | //
155 | // from bootstrap grid...not sure if we need this
156 | //
157 | /* stylelint-disable at-rule-no-vendor-prefix */
158 | @-ms-viewport {
159 | width: device-width;
160 | }
161 | /* stylelint-enable at-rule-no-vendor-prefix */
162 |
--------------------------------------------------------------------------------
/tests/all/scss/core.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @render: Base-L
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // @hanakin -- @midaym
7 | //
8 | // Base-L is a true core css framework.
9 | //
10 | // It follows the ITCSS structure coined by Harry Roberts of csswizardry.com
11 | //
12 | // Providing a strong foundation to add components and objects to. It provides
13 | // true scalability and extendability while keeping maintainability and
14 | // specificity in check.
15 | //
16 | // It provides a strict structure and guidlines for how your css is to be written
17 | // to keep your projects in check as they grow and evolve.
18 | //
19 | // The frmework was designed and developed along side the popular forum software
20 | // PHPBB as its core template library. By providing the most comon foundations
21 | // in a higher layer we allow for better control and flexability in component
22 | // design and themeing while still balancing maintainability and specificity.
23 | //
24 | //
25 | // The MIT License (MIT)
26 | //
27 | // Copyright (c) 2015 Michael Miday
28 | //
29 | // Permission is hereby granted, free of charge, to any person obtaining a copy
30 | // of this software and associated documentation files (the "Software"), to
31 | // deal in the Software without restriction, including without limitation the
32 | // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
33 | // sell copies of the Software, and to permit persons to whom the Software is
34 | // furnished to do so, subject to the following conditions:
35 | //
36 | // The above copyright notice and this permission notice shall be included in
37 | // all copies or substantial portions of the Software.
38 | //
39 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
40 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
41 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
42 | // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
43 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
44 | // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
45 | // SOFTWARE.
46 | //
47 |
48 | //
49 | // CONTENTS
50 | //
51 | // 1. Settings.....................The global settings only no object or
52 | // component settings. Those belong in the
53 | // individual partial files
54 | //
55 | // 2. Tools........................These are the mixins & functions used.
56 | //
57 | // 3. Generic......................This is for normalizing and reseting the css.
58 | //
59 | // 4. Base.........................This contains only the default html entitiy
60 | // styles, no classes or ids here.
61 | //
62 | // 5. Objects......................This contains all objects or partials to
63 | // build components.
64 | //
65 | // 6. Components...................Her is where you can build the component
66 | // library for your project.
67 | //
68 | // 7. Theme........................Here you can specifiy and theme ulterations
69 | // to use with your objects & components.
70 | //
71 | // 8. Utilities....................This is where all your trumps or utility
72 | // classes go those that usually contain the
73 | // highest specificity.
74 | //
75 |
76 |
77 | // 1. Global Settings
78 | //-------------------------
79 | @import "settings/settings";
80 |
81 |
82 | // 2. Tools
83 | //-------------------------
84 | @import "tools/function/functions";
85 | @import "tools/mixin/mixins";
86 |
87 |
88 | // 3. Generic
89 | //-------------------------
90 | /* stylelint-disable no-duplicate-selectors */
91 | @import "generic/normalize";
92 | @import "generic/box-sizing";
93 |
94 | // Resets
95 | @import "generic/reset/global";
96 | @import "generic/reset/type";
97 | @import "generic/reset/groupings";
98 | @import "generic/reset/other";
99 | @import "generic/reset/tables";
100 | @import "generic/reset/forms";
101 |
102 |
103 | // 4. Base
104 | //-------------------------
105 | @import "base/global";
106 | @import "base/links";
107 | @import "base/type";
108 | @import "base/forms";
109 | @import "base/table";
110 | @import "base/code";
111 | /* stylelint-enable no-duplicate-selectors */
112 |
113 | // 5. Ojbjects
114 | //-------------------------
115 | @import "objects/button";
116 | @import "objects/icon";
117 | @import "objects/grid";
118 | @import "objects/col";
119 | @import "objects/tag";
120 |
--------------------------------------------------------------------------------
/.postcss-sorting.json:
--------------------------------------------------------------------------------
1 | {
2 | "order": [
3 | "custom-properties",
4 | "dollar-variables",
5 | {
6 | "type": "at-rule",
7 | "name": "include"
8 | },
9 | "declarations",
10 | "rules",
11 | {
12 | "type": "at-rule",
13 | "name": "media"
14 | }
15 | ],
16 | "properties-order": [
17 | {
18 | "emptyLineBefore": false,
19 | "properties": [
20 | "font",
21 | "font-family",
22 | "font-size",
23 | "font-weight",
24 | "font-style",
25 | "font-variant",
26 | "font-size-adjust",
27 | "font-stretch",
28 | "font-effect",
29 | "font-emphasize",
30 | "font-emphasize-position",
31 | "font-emphasize-style",
32 | "font-smooth",
33 | "font-smoothing",
34 | "line-height",
35 | "text-align",
36 | "text-align-last",
37 | "vertical-align",
38 | "white-space",
39 | "text-decoration",
40 | "text-emphasis",
41 | "text-emphasis-color",
42 | "text-emphasis-style",
43 | "text-emphasis-position",
44 | "text-indent",
45 | "text-justify",
46 | "letter-spacing",
47 | "word-spacing",
48 | "writing-mode",
49 | "text-outline",
50 | "text-transform",
51 | "text-size-adjust",
52 | "text-wrap",
53 | "text-overflow",
54 | "text-overflow-ellipsis",
55 | "text-overflow-mode",
56 | "word-wrap",
57 | "word-break",
58 | "tab-size",
59 | "hyphens"
60 | ]
61 | },
62 | {
63 | "emptyLineBefore": false,
64 | "properties": [
65 | "background",
66 | "background-color",
67 | "background-image",
68 | "background-repeat",
69 | "background-attachment",
70 | "background-position",
71 | "background-position-x",
72 | "background-position-y",
73 | "background-clip",
74 | "background-origin",
75 | "background-size",
76 | "interpolation-mode",
77 | "filter",
78 | "border",
79 | "border-width",
80 | "border-style",
81 | "border-color",
82 | "border-top",
83 | "border-top-width",
84 | "border-top-style",
85 | "border-top-color",
86 | "border-right",
87 | "border-right-width",
88 | "border-right-style",
89 | "border-right-color",
90 | "border-bottom",
91 | "border-bottom-width",
92 | "border-bottom-style",
93 | "border-bottom-color",
94 | "border-left",
95 | "border-left-width",
96 | "border-left-style",
97 | "border-left-color",
98 | "border-radius",
99 | "border-top-left-radius",
100 | "border-top-right-radius",
101 | "border-bottom-right-radius",
102 | "border-bottom-left-radius",
103 | "border-image",
104 | "border-image-source",
105 | "border-image-slice",
106 | "border-image-width",
107 | "border-image-outset",
108 | "border-image-repeat",
109 | "outline",
110 | "outline-width",
111 | "outline-style",
112 | "outline-color",
113 | "outline-offset",
114 | "tap-highlight-color"
115 | ]
116 | },
117 | {
118 | "emptyLineBefore": false,
119 | "properties": [
120 | "box-decoration-break",
121 | "box-shadow",
122 | "text-shadow"
123 | ]
124 | },
125 | {
126 | "emptyLineBefore": false,
127 | "properties": [
128 | "color",
129 | "opacity"
130 | ]
131 | },
132 | {
133 | "emptyLineBefore": false,
134 | "properties": [
135 | "position",
136 | "z-index",
137 | "top",
138 | "right",
139 | "bottom",
140 | "left"
141 | ]
142 | },
143 | {
144 | "emptyLineBefore": false,
145 | "properties": [
146 | "display",
147 | "visibility",
148 | "float",
149 | "clear",
150 | "overflow",
151 | "overflow-x",
152 | "overflow-y",
153 | "overflow-scrolling",
154 | "clip",
155 | "zoom",
156 | "flex",
157 | "flex-direction",
158 | "flex-order",
159 | "flex-pack",
160 | "flex-align",
161 | "flex-basis",
162 | "flex-grow",
163 | "flex-shrink",
164 | "flex-wrap",
165 | "justify-content",
166 | "align-items",
167 | "align-self"
168 | ]
169 | },
170 | {
171 | "emptyLineBefore": false,
172 | "properties": [
173 | "box-sizing",
174 | "width",
175 | "min-width",
176 | "max-width",
177 | "height",
178 | "min-height",
179 | "max-height",
180 | "margin",
181 | "margin-top",
182 | "margin-right",
183 | "margin-bottom",
184 | "margin-left",
185 | "padding",
186 | "padding-top",
187 | "padding-right",
188 | "padding-bottom",
189 | "padding-left"
190 | ]
191 | },
192 | {
193 | "emptyLineBefore": false,
194 | "properties": [
195 | "table-layout",
196 | "empty-cells",
197 | "caption-side",
198 | "border-spacing",
199 | "border-collapse",
200 | "list-style",
201 | "list-style-position",
202 | "list-style-type",
203 | "list-style-image"
204 | ]
205 | },
206 | {
207 | "emptyLineBefore": false,
208 | "properties": [
209 | "content",
210 | "quotes",
211 | "counter-reset",
212 | "counter-increment",
213 | "resize",
214 | "cursor",
215 | "touch-callout",
216 | "touch-action",
217 | "user-select",
218 | "nav-index",
219 | "nav-up",
220 | "nav-right",
221 | "nav-down",
222 | "nav-left",
223 | "transition",
224 | "transition-delay",
225 | "transition-timing-function",
226 | "transition-duration",
227 | "transition-property",
228 | "transform",
229 | "transform-origin",
230 | "animation",
231 | "animation-name",
232 | "animation-duration",
233 | "animation-play-state",
234 | "animation-timing-function",
235 | "animation-delay",
236 | "animation-iteration-count",
237 | "animation-direction",
238 | "pointer-events"
239 | ]
240 | }
241 | ],
242 | "unspecified-properties-position": "bottomAlphabetical"
243 | }
--------------------------------------------------------------------------------
/tests/all/scss/generic/reset/_forms.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // #generic: Forms
3 | //------------------------------------------------------------------------------
4 | // #description:
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // #settings
10 | // Layout Variables
11 | $base-form-spacing: ($default-line-height / 3);
12 | $base-double-spacing: ($base-form-spacing * 2);
13 | $base-half-spacing: ($base-form-spacing / 2);
14 | $base-quarter-spacing: ($base-half-spacing / 2);
15 |
16 | //
17 | // #scss
18 |
19 | form {
20 | @include vertical-rhythm();
21 | padding: 0;
22 | }
23 |
24 | //
25 | // Organizational elements
26 | //------------------------------------------------------------------------------
27 | //
28 | // 1. Allow labels to use `margin` for spacing.
29 | // 2. Chrome and Firefox set a `min-width: min-content;` on fieldsets,
30 | // so we reset that to ensure it behaves more like a standard block element.
31 | // See https://github.com/twbs/bootstrap/issues/12359.
32 | //
33 | label {
34 | display: inline-block;
35 | margin: 0 $base-form-spacing $base-double-spacing; // [1]
36 | }
37 |
38 | fieldset { // [2]
39 | @include vertical-rhythm();
40 | border: 0;
41 | min-width: 0;
42 | padding: 0;
43 | }
44 |
45 | legend {
46 | @include type(headline);
47 | display: block;
48 | width: 100%;
49 | margin: 0 0 $base-double-spacing;
50 | }
51 |
52 | //
53 | // Control elements
54 | //------------------------------------------------------------------------------
55 | //
56 | // 1. Normalize includes `font: inherit;`, so `font-family`. `font-size`, etc
57 | // are properly inherited. However, `line-height` isn't addressed there.
58 | // Using this ensures we don't need to unnecessarily redeclare the global
59 | // font stack.
60 | // 2. iOS adds rounded borders by default
61 | // 3. Ensure all elements have same inital alignment
62 | //
63 | input,
64 | button,
65 | select,
66 | optgroup,
67 | textarea {
68 | line-height: inherit; // [1]
69 | vertical-align: middle; // [3]
70 | background-color: transparent;
71 | background-image: none; // [2]
72 | background-clip: padding-box;
73 | -webkit-border-radius: 0; // [2] iOS 8+
74 | border-radius: 0; // [2]
75 | color: inherit;
76 | }
77 |
78 | //
79 | // Buttons
80 | //------------------------------------------------------------------------------
81 | //
82 | // 1. Work around a Firefox/IE bug where the transparent `button` background
83 | // results in a loss of the default `button` focus styles.
84 | // 2. iOS 'clickable elements' fix for role="button" Fixes 'clickability' issue
85 | // (and more generally, the firing of events such as focus as well) for
86 | // traditionally non-focusable elements with role="button"
87 | // see: https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile
88 | //
89 | button {
90 | background: transparent;
91 | border: $default-border-size solid $default-gray;
92 | padding: ($base-double-spacing / 2) $base-quarter-spacing;
93 | cursor: pointer;
94 |
95 | &:focus {
96 | outline: 1px dotted; // [1]
97 | outline: 4px auto -webkit-focus-ring-color; // [1]
98 | }
99 | }
100 |
101 | // [2]
102 | [role="button"] {
103 | cursor: pointer;
104 | }
105 |
106 | //
107 | // Inputs
108 | //------------------------------------------------------------------------------
109 | //
110 | // 1. Radios & Checkboxes require slight spacing on the right to account for
111 | // labels.
112 | // 2. Apply a disabled cursor for radios and checkboxes.
113 | // 3. Remove the default appearance of temporal inputs to avoid a Mobile Safari
114 | // bug where setting a custom line-height prevents text from being vertically
115 | // centered within the input. Bug report: https://github.com/twbs/bootstrap/issues/11266
116 | // 4. This overrides the extra rounded corners on search inputs in iOS so that
117 | // our `.form-control` class can properly style them. Note that this cannot
118 | // simply be added to `.form-control` as it's not specific enough.
119 | // For details, see: https://github.com/twbs/bootstrap/issues/11586.
120 | // 5. specify the minimum height of form controls.
121 | //
122 | // Note: Neither radios nor checkboxes can be readonly.
123 | //
124 | input[type="radio"],
125 | input[type="checkbox"] {
126 | margin-right: $base-form-spacing; // [1]
127 |
128 | &:disabled {
129 | cursor: not-allowed; // [2]
130 | }
131 | }
132 |
133 | // [3]
134 | input[type="date"],
135 | input[type="time"],
136 | input[type="datetime-local"],
137 | input[type="month"] {
138 | -webkit-appearance: listbox;
139 | }
140 |
141 | [type="number"]::-webkit-inner-spin-button,
142 | [type="number"]::-webkit-outer-spin-button {
143 | height: auto;
144 | }
145 |
146 | [type="date"]::-webkit-inner-spin-button {
147 | display: none;
148 | -webkit-appearance: none;
149 | }
150 |
151 | // [4]
152 | input[type="search"] {
153 | -webkit-appearance: none;
154 | }
155 |
156 | // todo: needed?
157 | output {
158 | display: inline-block;
159 | }
160 |
161 | // [5]
162 | button,
163 | [type="button"],
164 | [type="date"],
165 | [type="datetime"],
166 | [type="datetime-local"],
167 | [type="email"],
168 | [type="month"],
169 | [type="number"],
170 | [type="password"],
171 | [type="reset"],
172 | [type="search"],
173 | [type="submit"],
174 | [type="tel"],
175 | [type="text"],
176 | [type="time"],
177 | [type="url"],
178 | [type="week"],
179 | [type="color"],
180 | select,
181 | textarea {
182 | min-height: $default-line-height;
183 | }
184 |
185 | input[type="color"] {
186 | vertical-align: middle; // [1]
187 | padding: $base-quarter-spacing;
188 | }
189 |
190 | //
191 | // Selects & Textareas
192 | //------------------------------------------------------------------------------
193 | //
194 | // 1. Align when inline to top for better conssistant alignments.
195 | // 2. Allow only vertical resizing of textareas.
196 | // 3. Specify the standard appearance of selects
197 | //
198 | select[multiple="multiple"],
199 | textarea {
200 | vertical-align: top; // [1]
201 | }
202 |
203 | select[multiple="multiple"] {
204 | height: auto;
205 | }
206 |
207 | textarea {
208 | resize: vertical; // [2]
209 | }
210 |
211 | // [3]
212 | select {
213 | -moz-appearance: none; // Firefox 40+
214 | -webkit-appearance: none; // Chrome 45+
215 |
216 | &::-ms-expand {
217 | background-color: transparent; // IE 10+
218 | border: 0; // IE 10+
219 | display: none; // Edge 12+, IE 11-
220 | }
221 |
222 | &::-ms-value {
223 | color: currentColor; // Edge 12+, IE 11-
224 | }
225 | }
226 |
--------------------------------------------------------------------------------
/tests/all/scss/components/_list.scss:
--------------------------------------------------------------------------------
1 |
2 | // @component: List
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $list-spacing: 16px !default;
13 | $list-border-radius: $default-border-radius !default;
14 | $list-height: 72px !default;
15 | $list-icon-size: 40px !default;
16 | $list-margin-bottom: 24px !default;
17 | $list-heading-margin-bottom: -32px !default;
18 | $list-title-line-height: 20px !default;
19 | $list-subheader-line-height: 18px !default;
20 | $list-data-spacing: 16px !default;
21 | $list-data-icon-size: 18px !default;
22 | $list-data-icon-margin: ($list-data-icon-size / 2) !default;
23 | $list-action-icon-margin-left: 8px !default;
24 | $list-action-img-size: 34px !default;
25 | $list-action-img-margin-bottom: 8px !default;
26 | $list-border-style: solid !default;
27 |
28 | // Theme Variables
29 | $list-icon-color: $default-secondary-color !default;
30 | $list-icon-color-read: $default-primary-color !default;
31 | $list-hover-color: $gray-50 !default;
32 | $list-action-hover-color: $default-action-bg-hover !default;
33 | $list-action-icon-color: $default-action-color !default;
34 | $list-action-hover-icon-color: $default-action-color-hover !default;
35 | $list-header-color: $default-action-bg !default;
36 | $list-border-color: rgba(0, 0, 0, 0.125) !default;
37 |
38 |
39 | //
40 | // @scss
41 | .c-list {
42 | @include shadow(2);
43 | border-radius: $list-border-radius;
44 | margin: 0;
45 | margin-bottom: $list-margin-bottom;
46 | padding: 0;
47 | list-style: none;
48 |
49 | &-header {
50 | background-color: $list-header-color;
51 | display: flex;
52 | flex-direction: row;
53 | flex-wrap: nowrap;
54 |
55 | &-title {
56 | @include type(title);
57 | line-height: unitless($list-title-line-height, map-get(map-get($type-styles, title), font-size));
58 | float: left;
59 | flex: 1;
60 | margin-bottom: 0;
61 | padding: $list-spacing;
62 | }
63 |
64 | &-actions {
65 | margin: 0;
66 | padding: 0;
67 | list-style: none;
68 | }
69 |
70 | &-action {
71 | display: flex;
72 | float: right;
73 |
74 | &-item {
75 | position: relative;
76 | }
77 |
78 | &-link {
79 | color: $list-action-icon-color;
80 | display: inline-block;
81 | padding: $list-spacing;
82 |
83 | &:hover,
84 | &:focus {
85 | background-color: $list-action-hover-color;
86 | color: $list-action-hover-icon-color;
87 | }
88 |
89 | &-icon {
90 | margin-right: 0;
91 | }
92 |
93 | &-icon:hover {
94 | text-decoration: none;
95 | }
96 | }
97 | }
98 | }
99 |
100 | &-item {
101 | @include type(subhead2);
102 | border-top: 1px solid $list-border-color;
103 | display: flex;
104 | flex-direction: row;
105 | flex-wrap: nowrap;
106 | min-height: $list-height;
107 | padding: $list-spacing;
108 |
109 | &:hover {
110 | background-color: $list-hover-color;
111 | }
112 | }
113 |
114 | &-type {
115 | padding-right: $list-spacing;
116 |
117 | &-icon {
118 | color: $list-icon-color;
119 | width: $list-icon-size;
120 | height: $list-icon-size;
121 | margin-right: 0;
122 |
123 | &-read {
124 | color: $list-icon-color-read;
125 | }
126 | }
127 | }
128 |
129 | &-primary {
130 | display: flex;
131 | flex-direction: column;
132 | flex-wrap: nowrap;
133 | width: 100%;
134 | }
135 |
136 | &-heading {
137 | display: flex;
138 | flex: 1;
139 | flex-direction: row;
140 | flex-wrap: nowrap;
141 | @media (min-width: $bp-md) {
142 | margin-bottom: $list-heading-margin-bottom;
143 | }
144 | }
145 |
146 | &-title {
147 | @include type(subhead2);
148 | line-height: unitless($list-title-line-height, map-get(map-get($type-styles, subhead2), font-size));
149 | flex: 1;
150 | margin-bottom: 0;
151 | }
152 |
153 | &-link:hover {
154 | text-decoration: underline;
155 | }
156 |
157 | &-action {
158 | display: inline-flex;
159 | margin-left: $list-action-icon-margin-left;
160 |
161 | &-body {
162 | @media (min-width: $bp-md) {
163 | margin-right: $list-spacing;
164 | }
165 | }
166 |
167 | &-img {
168 | border-radius: 50%;
169 | display: none;
170 | width: $list-action-img-size;
171 | height: $list-action-img-size;
172 | margin-bottom: $list-action-img-margin-bottom;
173 | @media (min-width: $bp-lg) {
174 | display: inline;
175 | }
176 | }
177 |
178 | &-list {
179 | text-align: right;
180 | margin: 0;
181 | padding: 0;
182 | list-style: none;
183 | }
184 |
185 | &-link:hover {
186 | text-decoration: underline;
187 | }
188 |
189 | &-user {
190 | display: none;
191 | @media (min-width: $bp-md) {
192 | display: inline-block;
193 | }
194 | }
195 |
196 | &-time {
197 | @include type(caption);
198 | @media (min-width: $bp-md) {
199 | @include type(body1);
200 | }
201 | }
202 | }
203 |
204 | &-subheader {
205 | @include type(body1);
206 | line-height: unitless($list-subheader-line-height, map-get(map-get($type-styles, body1), font-size));
207 | margin-top: ($list-data-spacing / 2);
208 | margin-bottom: 0;
209 | }
210 |
211 | &-data {
212 | display: inline-block;
213 | padding-right: $list-data-spacing;
214 |
215 | &-time {
216 | display: none;
217 | @media (min-width: $bp-lg) {
218 | display: inline-block;
219 | }
220 | }
221 |
222 | &-views {
223 | display: none;
224 | @media (min-width: $bp-md) {
225 | display: inline-block;
226 | }
227 | }
228 |
229 | // &-user {
230 | // display: none;
231 | // }
232 |
233 | &-icon {
234 | width: $list-data-icon-size;
235 | height: $list-data-icon-size;
236 | margin-right: $list-data-icon-margin;
237 | }
238 |
239 | &-link:hover {
240 | text-decoration: underline;
241 | }
242 | }
243 | }
244 |
245 | .paging {
246 | display: inline-flex;
247 | margin: 0;
248 | padding: 0;
249 | list-style: none;
250 | align-content: center;
251 |
252 | &-icon {
253 | margin-right: 8px;
254 | }
255 |
256 | &-item {
257 | margin: 0 2px;
258 | }
259 |
260 | &-link {
261 | @include type(caption);
262 | background: $gray-200;
263 | border-radius: 2px;
264 | margin: 0;
265 | padding: 2px 4px;
266 |
267 | &:hover {
268 | text-decoration: none;
269 | background: $gray-400;
270 | }
271 |
272 | &-icon {
273 | width: 18px;
274 | height: 18px;
275 | margin: 0;
276 | }
277 | }
278 | @media (min-width: $bp-md) {
279 | margin-left: 8px;
280 | }
281 | }
282 |
--------------------------------------------------------------------------------
/tests/all/scss/components/_topic.scss:
--------------------------------------------------------------------------------
1 |
2 | // @component: Topic
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | //------------------------------------------------------------------------------
7 |
8 | //
9 | // @settings
10 |
11 | // Layout Variables
12 | $topic-spacing: 16px !default;
13 | $topic-border-radius: $default-border-radius !default;
14 | $topic-height: 72px !default;
15 | $topic-icon-size: 40px !default;
16 | $topic-margin-bottom: 24px !default;
17 | $topic-heading-margin-bottom: -32px !default;
18 | $topic-title-line-height: 20px !default;
19 | $topic-subheader-line-height: 18px !default;
20 | $topic-data-spacing: 16px !default;
21 | $topic-data-icon-size: 18px !default;
22 | $topic-data-icon-margin: ($topic-data-icon-size / 2) !default;
23 | $topic-action-icon-margin-left: 8px !default;
24 | $topic-action-img-size: 34px !default;
25 | $topic-action-img-margin-bottom: 8px !default;
26 | $topic-border-style: solid !default;
27 |
28 | // Theme Variables
29 | $topic-icon-color: $default-secondary-color !default;
30 | $topic-icon-color-read: $default-primary-color !default;
31 | $topic-hover-color: $gray-50 !default;
32 | $topic-action-hover-color: $default-action-bg-hover !default;
33 | $topic-action-icon-color: $default-action-color !default;
34 | $topic-action-hover-icon-color: $default-action-color-hover !default;
35 | $topic-header-color: $default-action-bg !default;
36 | $topic-border-color: rgba(0, 0, 0, 0.125) !default;
37 |
38 |
39 | //
40 | // @scss
41 | .c-topic {
42 | @include shadow(2);
43 | border-radius: $topic-border-radius;
44 | margin: 0;
45 | margin-bottom: $topic-margin-bottom;
46 | padding: 0;
47 | list-style: none;
48 |
49 | &-header {
50 | background-color: $topic-header-color;
51 | display: flex;
52 | flex-direction: row;
53 | flex-wrap: nowrap;
54 |
55 | &-title {
56 | @include type(title);
57 | line-height: unitless($topic-title-line-height, map-get(map-get($type-styles, title), font-size));
58 | float: left;
59 | flex: 1;
60 | margin-bottom: 0;
61 | padding: $topic-spacing;
62 | }
63 |
64 | &-actions {
65 | margin: 0;
66 | padding: 0;
67 | list-style: none;
68 | }
69 |
70 | &-action {
71 | display: flex;
72 | float: right;
73 |
74 | &-item {
75 | position: relative;
76 | }
77 |
78 | &-link {
79 | color: $topic-action-icon-color;
80 | display: inline-block;
81 | padding: $topic-spacing;
82 |
83 | &:hover,
84 | &:focus {
85 | background-color: $topic-action-hover-color;
86 | color: $topic-action-hover-icon-color;
87 | }
88 |
89 | &-icon {
90 | margin-right: 0;
91 | }
92 |
93 | &-icon:hover {
94 | text-decoration: none;
95 | }
96 | }
97 | }
98 | }
99 |
100 | &-item {
101 | @include type(subhead2);
102 | border-top: 1px solid $topic-border-color;
103 | display: flex;
104 | flex-direction: row;
105 | flex-wrap: nowrap;
106 | min-height: $topic-height;
107 | padding: $topic-spacing;
108 |
109 | &:hover {
110 | background-color: $topic-hover-color;
111 | }
112 | }
113 |
114 | &-type {
115 | padding-right: $topic-spacing;
116 |
117 | &-icon {
118 | color: $topic-icon-color;
119 | width: $topic-icon-size;
120 | height: $topic-icon-size;
121 | margin-right: 0;
122 |
123 | &-read {
124 | color: $topic-icon-color-read;
125 | }
126 | }
127 | }
128 |
129 | &-primary {
130 | display: flex;
131 | flex-direction: column;
132 | flex-wrap: nowrap;
133 | width: 100%;
134 | }
135 |
136 | &-heading {
137 | display: flex;
138 | flex: 1;
139 | flex-direction: row;
140 | flex-wrap: nowrap;
141 | @media (min-width: $bp-md) {
142 | margin-bottom: $topic-heading-margin-bottom;
143 | }
144 | }
145 |
146 | &-title {
147 | @include type(subhead2);
148 | line-height: unitless($topic-title-line-height, map-get(map-get($type-styles, subhead2), font-size));
149 | flex: 1;
150 | margin-bottom: 0;
151 | }
152 |
153 | &-link:hover {
154 | text-decoration: underline;
155 | }
156 |
157 | &-action {
158 | display: inline-flex;
159 | margin-left: $topic-action-icon-margin-left;
160 |
161 | &-body {
162 | @media (min-width: $bp-md) {
163 | margin-right: $topic-spacing;
164 | }
165 | }
166 |
167 | &-img {
168 | border-radius: 50%;
169 | display: none;
170 | width: $topic-action-img-size;
171 | height: $topic-action-img-size;
172 | margin-bottom: $topic-action-img-margin-bottom;
173 | @media (min-width: $bp-lg) {
174 | display: inline;
175 | }
176 | }
177 |
178 | &-topic {
179 | text-align: right;
180 | margin: 0;
181 | padding: 0;
182 | list-style: none;
183 | }
184 |
185 | &-link:hover {
186 | text-decoration: underline;
187 | }
188 |
189 | &-user {
190 | display: none;
191 | @media (min-width: $bp-md) {
192 | display: inline-block;
193 | }
194 | }
195 |
196 | &-time {
197 | @include type(caption);
198 | @media (min-width: $bp-md) {
199 | @include type(body1);
200 | }
201 | }
202 | }
203 |
204 | &-subheader {
205 | @include type(body1);
206 | line-height: unitless($topic-subheader-line-height, map-get(map-get($type-styles, body1), font-size));
207 | margin-top: ($topic-data-spacing / 2);
208 | margin-bottom: 0;
209 | }
210 |
211 | &-data {
212 | display: inline-block;
213 | padding-right: $topic-data-spacing;
214 |
215 | &-time {
216 | display: none;
217 | @media (min-width: $bp-lg) {
218 | display: inline-block;
219 | }
220 | }
221 |
222 | &-views {
223 | display: none;
224 | @media (min-width: $bp-md) {
225 | display: inline-block;
226 | }
227 | }
228 |
229 | // &-user {
230 | // display: none;
231 | // }
232 |
233 | &-icon {
234 | width: $topic-data-icon-size;
235 | height: $topic-data-icon-size;
236 | margin-right: $topic-data-icon-margin;
237 | }
238 |
239 | &-link:hover {
240 | text-decoration: underline;
241 | }
242 | }
243 | }
244 |
245 | .paging {
246 | display: inline-flex;
247 | margin: 0;
248 | padding: 0;
249 | list-style: none;
250 | align-content: center;
251 |
252 | &-icon {
253 | margin-right: 8px;
254 | }
255 |
256 | &-item {
257 | margin: 0 2px;
258 | }
259 |
260 | &-link {
261 | @include type(caption);
262 | background: $gray-200;
263 | border-radius: 2px;
264 | margin: 0;
265 | padding: 2px 4px;
266 |
267 | &:hover {
268 | text-decoration: none;
269 | background: $gray-400;
270 | }
271 |
272 | &-icon {
273 | width: 18px;
274 | height: 18px;
275 | margin: 0;
276 | }
277 | }
278 | @media (min-width: $bp-md) {
279 | margin-left: 8px;
280 | }
281 | }
282 |
--------------------------------------------------------------------------------
/src/scss/tools/mixin/_shadows.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Shadows
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Mixin for generating Google Material Design shadows
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @settings
12 | $shadow-key-umbra-opacity: 0.2 !default;
13 | $shadow-key-penumbra-opacity: 0.14 !default;
14 | $shadow-ambient-shadow-opacity: 0.12 !default;
15 |
16 | $shadows: (
17 | 0: (
18 | umbra: none
19 | ),
20 | 1: (
21 | penumbra: 0 1px 1px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
22 | umbra: 0 2px 1px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
23 | ambient: 0 1px 3px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
24 | ),
25 | 2: (
26 | penumbra: 0 2px 2px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
27 | umbra: 0 3px 1px -2px rgba(0, 0, 0, $shadow-key-umbra-opacity),
28 | ambient: 0 1px 5px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
29 | ),
30 | 3: (
31 | penumbra: 0 3px 4px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
32 | umbra: 0 3px 3px -2px rgba(0, 0, 0, $shadow-key-umbra-opacity),
33 | ambient: 0 1px 8px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
34 | ),
35 | 4: (
36 | penumbra: 0 4px 5px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
37 | umbra: 0 2px 4px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
38 | ambient: 0 1px 10px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
39 | ),
40 | 5: (
41 | penumbra: 0 5px 8px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
42 | umbra: 0 3px 5px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
43 | ambient: 0 1px 14px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
44 | ),
45 | 6: (
46 | penumbra: 0 6px 10px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
47 | umbra: 0 3px 5px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
48 | ambient: 0 1px 18px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
49 | ),
50 | 7: (
51 | penumbra: 0 7px 10px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
52 | umbra: 0 4px 5px -2px rgba(0, 0, 0, $shadow-key-umbra-opacity),
53 | ambient: 0 2px 16px 1px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
54 | ),
55 | 8: (
56 | penumbra: 0 8px 10px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
57 | umbra: 0 5px 5px -3px rgba(0, 0, 0, $shadow-key-umbra-opacity),
58 | ambient: 0 3px 14px 2px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
59 | ),
60 | 9: (
61 | penumbra: 0 9px 12px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
62 | umbra: 0 5px 6px -3px rgba(0, 0, 0, $shadow-key-umbra-opacity),
63 | ambient: 0 3px 16px 2px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
64 | ),
65 | 10: (
66 | penumbra: 0 10px 14px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
67 | umbra: 0 6px 6px -3px rgba(0, 0, 0, $shadow-key-umbra-opacity),
68 | ambient: 0 4px 18px 3px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
69 | ),
70 | 11: (
71 | penumbra: 0 11px 15px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
72 | umbra: 0 6px 7px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
73 | ambient: 0 4px 20px 3px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
74 | ),
75 | 12: (
76 | penumbra: 0 12px 17px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
77 | umbra: 0 7px 8px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
78 | ambient: 0 5px 22px 4px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
79 | ),
80 | 13: (
81 | penumbra: 0 13px 19px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
82 | umbra: 0 7px 8px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
83 | ambient: 0 5px 24px 4px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
84 | ),
85 | 14: (
86 | penumbra: 0 14px 21px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
87 | umbra: 0 7px 9px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
88 | ambient: 0 5px 26px 4px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
89 | ),
90 | 15: (
91 | penumbra: 0 15px 22px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
92 | umbra: 0 8px 9px -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
93 | ambient: 0 6px 28px 5px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
94 | ),
95 | 16: (
96 | penumbra: 0 16px 24px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
97 | umbra: 0 8px 10 -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
98 | ambient: 0 6px 30px 5px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
99 | ),
100 | 17: (
101 | penumbra: 0 17px 26px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
102 | umbra: 0 8px 11px -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
103 | ambient: 0 6px 32px 5px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
104 | ),
105 | 18: (
106 | penumbra: 0 18px 28px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
107 | umbra: 0 9px 11px -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
108 | ambient: 0 7px 34px 6px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
109 | ),
110 | 19: (
111 | penumbra: 0 19px 29px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
112 | umbra: 0 9px 12px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
113 | ambient: 0 7px 36px 6px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
114 | ),
115 | 20: (
116 | penumbra: 0 20px 31px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
117 | umbra: 0 10px 13px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
118 | ambient: 0 8px 38px 7px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
119 | ),
120 | 21: (
121 | penumbra: 0 21px 33px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
122 | umbra: 0 10 13px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
123 | ambient: 0 8px 40px 7px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
124 | ),
125 | 22: (
126 | penumbra: 0 22px 35px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
127 | umbra: 0 10px 14px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
128 | ambient: 0 8px 42px 7px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
129 | ),
130 | 23: (
131 | penumbra: 0 23px 36px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
132 | umbra: 0 11px 14px -7px rgba(0, 0, 0, $shadow-key-umbra-opacity),
133 | ambient: 0 9px 44px 8px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
134 | ),
135 | 24: (
136 | penumbra: 0 24px 38px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
137 | umbra: 0 11px 15px -7px rgba(0, 0, 0, $shadow-key-umbra-opacity),
138 | ambient: 0 9px 46px 8px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
139 | )
140 | );
141 |
142 |
143 | //
144 | // @scss
145 | @mixin shadow($depth) {
146 | $shadow: map-get($shadows, $depth);
147 | // Focus Shadow
148 | @if not map-has-key($shadows, $depth) {
149 | box-shadow: 0 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.36);
150 | } @else {
151 | box-shadow:
152 | map-get($shadow, penumbra),
153 | map-get($shadow, umbra),
154 | map-get($shadow, ambient);
155 | }
156 | }
157 |
--------------------------------------------------------------------------------
/tests/all/scss/tools/mixin/_shadows.scss:
--------------------------------------------------------------------------------
1 | //------------------------------------------------------------------------------
2 | // @tool: Shadows
3 | //------------------------------------------------------------------------------
4 | // @description
5 | //
6 | // Mixin for generating Google Material Design shadows
7 | //
8 | //------------------------------------------------------------------------------
9 |
10 | //
11 | // @settings
12 | $shadow-key-umbra-opacity: 0.2 !default;
13 | $shadow-key-penumbra-opacity: 0.14 !default;
14 | $shadow-ambient-shadow-opacity: 0.12 !default;
15 |
16 | $shadows: (
17 | 0: (
18 | umbra: none
19 | ),
20 | 1: (
21 | penumbra: 0 1px 1px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
22 | umbra: 0 2px 1px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
23 | ambient: 0 1px 3px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
24 | ),
25 | 2: (
26 | penumbra: 0 2px 2px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
27 | umbra: 0 3px 1px -2px rgba(0, 0, 0, $shadow-key-umbra-opacity),
28 | ambient: 0 1px 5px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
29 | ),
30 | 3: (
31 | penumbra: 0 3px 4px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
32 | umbra: 0 3px 3px -2px rgba(0, 0, 0, $shadow-key-umbra-opacity),
33 | ambient: 0 1px 8px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
34 | ),
35 | 4: (
36 | penumbra: 0 4px 5px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
37 | umbra: 0 2px 4px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
38 | ambient: 0 1px 10px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
39 | ),
40 | 5: (
41 | penumbra: 0 5px 8px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
42 | umbra: 0 3px 5px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
43 | ambient: 0 1px 14px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
44 | ),
45 | 6: (
46 | penumbra: 0 6px 10px 0 rgba(0, 0, 0, $shadow-key-penumbra-opacity),
47 | umbra: 0 3px 5px -1px rgba(0, 0, 0, $shadow-key-umbra-opacity),
48 | ambient: 0 1px 18px 0 rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
49 | ),
50 | 7: (
51 | penumbra: 0 7px 10px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
52 | umbra: 0 4px 5px -2px rgba(0, 0, 0, $shadow-key-umbra-opacity),
53 | ambient: 0 2px 16px 1px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
54 | ),
55 | 8: (
56 | penumbra: 0 8px 10px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
57 | umbra: 0 5px 5px -3px rgba(0, 0, 0, $shadow-key-umbra-opacity),
58 | ambient: 0 3px 14px 2px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
59 | ),
60 | 9: (
61 | penumbra: 0 9px 12px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
62 | umbra: 0 5px 6px -3px rgba(0, 0, 0, $shadow-key-umbra-opacity),
63 | ambient: 0 3px 16px 2px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
64 | ),
65 | 10: (
66 | penumbra: 0 10px 14px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
67 | umbra: 0 6px 6px -3px rgba(0, 0, 0, $shadow-key-umbra-opacity),
68 | ambient: 0 4px 18px 3px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
69 | ),
70 | 11: (
71 | penumbra: 0 11px 15px 1px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
72 | umbra: 0 6px 7px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
73 | ambient: 0 4px 20px 3px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
74 | ),
75 | 12: (
76 | penumbra: 0 12px 17px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
77 | umbra: 0 7px 8px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
78 | ambient: 0 5px 22px 4px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
79 | ),
80 | 13: (
81 | penumbra: 0 13px 19px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
82 | umbra: 0 7px 8px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
83 | ambient: 0 5px 24px 4px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
84 | ),
85 | 14: (
86 | penumbra: 0 14px 21px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
87 | umbra: 0 7px 9px -4px rgba(0, 0, 0, $shadow-key-umbra-opacity),
88 | ambient: 0 5px 26px 4px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
89 | ),
90 | 15: (
91 | penumbra: 0 15px 22px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
92 | umbra: 0 8px 9px -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
93 | ambient: 0 6px 28px 5px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
94 | ),
95 | 16: (
96 | penumbra: 0 16px 24px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
97 | umbra: 0 8px 10 -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
98 | ambient: 0 6px 30px 5px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
99 | ),
100 | 17: (
101 | penumbra: 0 17px 26px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
102 | umbra: 0 8px 11px -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
103 | ambient: 0 6px 32px 5px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
104 | ),
105 | 18: (
106 | penumbra: 0 18px 28px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
107 | umbra: 0 9px 11px -5px rgba(0, 0, 0, $shadow-key-umbra-opacity),
108 | ambient: 0 7px 34px 6px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
109 | ),
110 | 19: (
111 | penumbra: 0 19px 29px 2px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
112 | umbra: 0 9px 12px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
113 | ambient: 0 7px 36px 6px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
114 | ),
115 | 20: (
116 | penumbra: 0 20px 31px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
117 | umbra: 0 10px 13px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
118 | ambient: 0 8px 38px 7px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
119 | ),
120 | 21: (
121 | penumbra: 0 21px 33px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
122 | umbra: 0 10 13px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
123 | ambient: 0 8px 40px 7px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
124 | ),
125 | 22: (
126 | penumbra: 0 22px 35px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
127 | umbra: 0 10px 14px -6px rgba(0, 0, 0, $shadow-key-umbra-opacity),
128 | ambient: 0 8px 42px 7px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
129 | ),
130 | 23: (
131 | penumbra: 0 23px 36px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
132 | umbra: 0 11px 14px -7px rgba(0, 0, 0, $shadow-key-umbra-opacity),
133 | ambient: 0 9px 44px 8px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
134 | ),
135 | 24: (
136 | penumbra: 0 24px 38px 3px rgba(0, 0, 0, $shadow-key-penumbra-opacity),
137 | umbra: 0 11px 15px -7px rgba(0, 0, 0, $shadow-key-umbra-opacity),
138 | ambient: 0 9px 46px 8px rgba(0, 0, 0, $shadow-ambient-shadow-opacity)
139 | )
140 | );
141 |
142 |
143 | //
144 | // @scss
145 | @mixin shadow($depth) {
146 | $shadow: map-get($shadows, $depth);
147 | // Focus Shadow
148 | @if not map-has-key($shadows, $depth) {
149 | box-shadow: 0 0 4px rgba(0, 0, 0, 0.18), 0 4px 8px rgba(0, 0, 0, 0.36);
150 | } @else {
151 | box-shadow:
152 | map-get($shadow, penumbra),
153 | map-get($shadow, umbra),
154 | map-get($shadow, ambient);
155 | }
156 | }
157 |
--------------------------------------------------------------------------------