diff --git a/.codeclimate.yml b/.codeclimate.yml index e6635d929..536654819 100644 --- a/.codeclimate.yml +++ b/.codeclimate.yml @@ -80,7 +80,9 @@ exclude_patterns: - "node_modules" - "styleguide" - "kss/**/*" -- "core/scss/core/_normalize.scss" +- "core/dist/**/*" +- "core/src/scss/core/_normalize.scss" - "Gruntfile.js" - "composer.json" - "package.json" +- "webpack.config.js" diff --git a/.csslintrc b/.csslintrc deleted file mode 100644 index 1133ef2a9..000000000 --- a/.csslintrc +++ /dev/null @@ -1,37 +0,0 @@ -{ - "important": true, - "adjoining-classes": false, - "known-properties": true, - "box-sizing": false, - "box-model": true, - "overqualified-elements": true, - "display-property-grouping": true, - "bulletproof-font-face": false, - "compatible-vendor-prefixes": false, - "regex-selectors": false, - "errors": false, - "duplicate-background-images": true, - "duplicate-properties": true, - "empty-rules": true, - "selector-max-approaching": false, - "gradients": false, - "fallback-colors": false, - "font-sizes": false, - "font-faces": false, - "floats": false, - "star-property-hack": true, - "outline-none": true, - "import": true, - "ids": true, - "underscore-property-hack": true, - "rules-count": false, - "qualified-headings": true, - "selector-max": false, - "shorthand": true, - "text-indent": true, - "unique-headings": true, - "universal-selector": false, - "unqualified-attributes": true, - "vendor-prefix": true, - "zero-units": true -} diff --git a/.eslintrc b/.eslintrc index 6739fb255..66b1c7f1a 100644 --- a/.eslintrc +++ b/.eslintrc @@ -1,108 +1,111 @@ { - "extends": "eslint:recommended", - "env": { - "browser": true, - "es6": true + extends: "eslint:recommended", + env: { + browser: true, + es6: true }, - "globals": { - "domready": true + globals: { + domready: true }, - "ecmaFeatures": { - "arrowFunctions": true, - "blockBindings": true, - "classes": true, - "defaultParameters": true, - "destructuring": true, - "forOf": true, - "generators": true, - "modules": true, - "objectLiteralComputedProperties": true, - "objectLiteralDuplicateProperties": true, - "objectLiteralShorthandMethods": true, - "objectLiteralShorthandProperties": true, - "regexUFlag": true, - "regexYFlag": true, - "restParams": true, - "spread": true, - "superInFunctions": true, - "templateStrings": true, - "unicodeCodePointEscapes": true, - "globalReturn": true + parserOptions: { + ecmaVersion: 6, + sourceType: "module", + ecmaFeatures: { + arrowFunctions: true, + blockBindings: true, + classes: true, + defaultParameters: true, + destructuring: true, + forOf: true, + generators: true, + objectLiteralComputedProperties: true, + objectLiteralDuplicateProperties: true, + objectLiteralShorthandMethods: true, + objectLiteralShorthandProperties: true, + regexUFlag: true, + regexYFlag: true, + restParams: true, + spread: true, + superInFunctions: true, + templateStrings: true, + unicodeCodePointEscapes: true, + globalReturn: true + } }, - "rules": { - "max-len": [2, 80, 2, {"ignoreUrls": true}], - "array-bracket-spacing": [2, "never"], - "block-scoped-var": 2, - "brace-style": [2, "stroustrup", {"allowSingleLine": true}], - "comma-dangle": [2, "never"], - "comma-spacing": 2, - "comma-style": [2, "last"], - "computed-property-spacing": [2, "never"], - "curly": [2, "all"], - "eol-last": 2, - "eqeqeq": [2, "smart"], - "guard-for-in": 2, - "indent": [2, 2, {"SwitchCase": 1}], - "key-spacing": [2, {"beforeColon": false, "afterColon": true}], - "keyword-spacing": [2, {"before": true, "after": true}], - "linebreak-style": [2, "unix"], - "lines-around-comment": [2, {"beforeBlockComment": true, "afterBlockComment": false}], - "new-parens": 2, - "no-array-constructor": 2, - "no-caller": 2, - "no-catch-shadow": 2, - "no-eval": 2, - "no-extend-native": 2, - "no-extra-bind": 2, - "no-extra-parens": [2, "functions"], - "no-implied-eval": 2, - "no-iterator": 2, - "no-label-var": 2, - "no-labels": 2, - "no-lone-blocks": 2, - "no-loop-func": 2, - "no-multi-spaces": 2, - "no-multi-str": 2, - "no-native-reassign": 2, - "no-nested-ternary": 2, - "no-new-func": 2, - "no-new-object": 2, - "no-new-wrappers": 2, - "no-octal-escape": 2, - "no-process-exit": 2, - "no-proto": 2, - "no-return-assign": 2, - "no-script-url": 2, - "no-sequences": 2, - "no-shadow-restricted-names": 2, - "no-spaced-func": 2, - "no-trailing-spaces": 2, - "no-undef-init": 2, - "no-undefined": 2, - "no-unused-expressions": 2, - "no-unused-vars": [2, {"vars": "all", "args": "none"}], - "no-with": 2, - "object-curly-spacing": [2, "never"], - "one-var": [2, "never"], - "quote-props": [2, "consistent-as-needed"], - "quotes": [2, "single", "avoid-escape"], - "semi": [2, "always"], - "semi-spacing": [2, {"before": false, "after": true}], - "space-before-blocks": [2, "always"], - "space-before-function-paren": [2, {"anonymous": "always", "named": "never"}], - "space-in-parens": [2, "never"], - "space-infix-ops": 2, - "space-unary-ops": [2, { "words": true, "nonwords": false }], - "spaced-comment": [2, "always"], - "strict": [2, "function"], - "yoda": [2, "never"], - "max-nested-callbacks": [1, 3], - "valid-jsdoc": [1, { - "prefer": { - "returns": "return", - "property": "prop" + rules: { + max-len: [2, 80, 2, {"ignoreUrls": true}], + array-bracket-spacing: [2, "never"], + block-scoped-var: 2, + brace-style: [2, "stroustrup", {"allowSingleLine": true}], + comma-dangle: [2, "never"], + comma-spacing: 2, + comma-style: [2, "last"], + computed-property-spacing: [2, "never"], + curly: [2, "all"], + eol-last: 2, + eqeqeq: [2, "smart"], + guard-for-in: 2, + indent: [2, 2, {"SwitchCase": 1}], + key-spacing: [2, {"beforeColon": false, "afterColon": true}], + keyword-spacing: [2, {"before": true, "after": true}], + linebreak-style: [2, "unix"], + lines-around-comment: [2, {"beforeBlockComment": true, "afterBlockComment": false}], + new-parens: 2, + no-array-constructor: 2, + no-caller: 2, + no-catch-shadow: 2, + no-eval: 2, + no-extend-native: 2, + no-extra-bind: 2, + no-extra-parens: [2, "functions"], + no-implied-eval: 2, + no-iterator: 2, + no-label-var: 2, + no-labels: 2, + no-lone-blocks: 2, + no-loop-func: 2, + no-multi-spaces: 2, + no-multi-str: 2, + no-native-reassign: 2, + no-nested-ternary: 2, + no-new-func: 2, + no-new-object: 2, + no-new-wrappers: 2, + no-octal-escape: 2, + no-process-exit: 2, + no-proto: 2, + no-return-assign: 2, + no-script-url: 2, + no-sequences: 2, + no-shadow-restricted-names: 2, + no-spaced-func: 2, + no-trailing-spaces: 2, + no-undef-init: 2, + no-undefined: 2, + no-unused-expressions: 2, + no-unused-vars: [2, {"vars": "all", "args": "none"}], + no-with: 2, + object-curly-spacing: [2, "never"], + one-var: [2, "never"], + quote-props: [2, "consistent-as-needed"], + quotes: [2, "single", "avoid-escape"], + semi: [2, "always"], + semi-spacing: [2, {"before": false, "after": true}], + space-before-blocks: [2, "always"], + space-before-function-paren: [2, {"anonymous": "always", "named": "never"}], + space-in-parens: [2, "never"], + space-infix-ops: 2, + space-unary-ops: [2, { "words": true, "nonwords": false }], + spaced-comment: [2, "always"], + strict: [2, "function"], + yoda: [2, "never"], + max-nested-callbacks: [1, 3], + valid-jsdoc: [1, { + prefer: { + returns: "return", + property: "prop" }, - "requireReturn": false + requireReturn: false }] } } diff --git a/.gitignore b/.gitignore index c30f015f6..76f861931 100644 --- a/.gitignore +++ b/.gitignore @@ -32,6 +32,7 @@ config.rb cgi-bin node_modules styleguide +kss/builder/decanter/kss-assets/dist # Ignore as they are customized on the user end. .lando.yml diff --git a/.nvmrc b/.nvmrc index 97d6bcaa1..1047f6968 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -9.10.1 +10.15.1 diff --git a/Gruntfile.js b/Gruntfile.js index 09b7e4610..817e5b272 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -4,78 +4,12 @@ */ module.exports = function(grunt) { - /** - * [sass description] - * @type {[type]} - */ - const sass = require('node-sass'); - /** * [pkg description] * @type {[type]} */ grunt.initConfig({ pkg: grunt.file.readJSON('package.json'), - sass: { - options: { - implementation: sass, - includePaths: [ - "node_modules/bourbon/core", - "node_modules/bourbon-neat/app/assets/stylesheets", - "node_modules/neat-omega/core", - "node_modules", - "core/scss" - ], - lineNumbers: true, - sourceMap: true, - outputStyle: 'nested', - precision: 10 - }, - dist: { - files: { - 'core/css/decanter.css': 'core/scss/decanter.scss', - 'core/css/decanter-no-markup.css': 'core/scss/decanter-no-markup.scss', - 'core/css/decanter-grid.css': 'core/scss/decanter-grid.scss', - 'kss/builder/decanter/kss-assets/css/kss.css': 'kss/builder/decanter/scss/kss.scss', - } - } - }, - sasslint: { - options: { - configFile: '.sass-lint.yml' - }, - target: ['core/scss/\*\*/\*.scss'] - }, - postcss: { - options: { - map: true, // inline sourcemaps - processors: [ - require('autoprefixer')({ grid: true, browsers: ['last 2 versions', 'ie 11']}) // add vendor prefixes - ] - }, - dist: { - src: [ - 'core/css/*.css', - 'kss/builder/decanter/kss-assets/css/*.css' - ] - } - }, - watch: { - css: { - files: ['**/*.scss'], - tasks: ['styleguide'], - options: { - livereload: true - } - }, - jsmin: { - files: ['core/**/*.js'] - }, - twig: { - files: ['**/*.twig', '**/*.json'], - tasks: ['styleguide'] - } - }, browserSync: { dev: { bsFiles: { @@ -91,11 +25,6 @@ module.exports = function(grunt) { } }, clean: { - styleguide: { - src: [ - 'styleguide' - ] - }, postdeploy: { src: [ '.styleguide_site' @@ -103,10 +32,21 @@ module.exports = function(grunt) { } }, run: { + options: { + wait: 0 + }, + webpack: { + "cmd": "npm", + 'args': ['run-script', 'build'] + }, styleguide: { - "cmd": "./node_modules/.bin/kss", - "args": ['--config=kss/kss-config.json'] - } + "cmd": "npm", + "args": ['run-script', 'styleguide'] + }, + watch: { + "cmd": "npm", + "args": ['run-script', 'watch'] + }, }, deploy_site: { styleguide: { @@ -119,33 +59,38 @@ module.exports = function(grunt) { remote_url: 'git@github.com:SU-SWS/decanter.github.io' } }, - copy: { - styleguide: { - files: [ - // includes files within path - {expand: true, cwd: 'core/css', src: ['**'], dest: 'styleguide/css/'}, - {expand: true, cwd: 'core/fonts', src: ['**'], dest: 'styleguide/fonts/'}, - {expand: true, cwd: 'core/js', src: ['**'], dest: 'styleguide/js/'}, - {expand: true, cwd: 'core/img', src: ['**'], dest: 'styleguide/img/'}, - ], - }, - }, + deprecated_notice: { + styleguide: "This function has been deprecated in favor of `npm run-script styleguide` and will be removed in future versions. Executing now.", + compile: "This function has been deprecated in favor of `npm run-script build` and will be removed in future versions. Executing now.", + sasslint: "This function has been deprecated in favor of `npm run-script lint` and will be removed in future versions.", + sass: "This function has been deprecated in favor of `npm run-script build` and will be removed in future versions.", + watch: "This function has been deprecated in favor of `npm run-script watch` and will be removed in future versions." + } }); + // Create a Deprecated notice task. + grunt.task.registerTask('deprecated_notice', 'Logs a deprecated message.', function(arg1) { + grunt.log.write(grunt.config.data.deprecated_notice[arg1]); + }); + + // Load up tasks. grunt.loadNpmTasks('grunt-run'); grunt.loadNpmTasks('grunt-browser-sync'); grunt.loadNpmTasks('grunt-contrib-clean'); - grunt.loadNpmTasks('grunt-sass'); - grunt.loadNpmTasks('grunt-sass-lint'); grunt.loadNpmTasks('grunt-contrib-watch'); - grunt.loadNpmTasks('grunt-postcss'); grunt.loadNpmTasks('grunt-deploy-site'); - grunt.loadNpmTasks('grunt-contrib-copy'); + // Register some new ones. grunt.registerTask('deploy', ['styleguide', 'deploy_site:styleguide', 'clean:postdeploy']); - grunt.registerTask('styleguide', ['compile', 'clean:styleguide', 'run:styleguide', 'copy:styleguide']); - grunt.registerTask('compile', ['sass:dist', 'postcss:dist']); - grunt.registerTask('dev', ['styleguide', 'browserSync', 'watch']); + grunt.registerTask('webpack', ['run:webpack']); + grunt.registerTask('dev', ['styleguide', 'browserSync', 'run:watch']); grunt.registerTask('default', ['dev']); + // Deprecated tasks. + grunt.registerTask('styleguide', ['run:webpack', 'run:styleguide', 'deprecated_notice:styleguide']); + grunt.registerTask('compile', ['deprecated_notice:compile', 'run:webpack']); + grunt.registerTask('sass', ['deprecated_notice:sass']); + grunt.registerTask('sasslint', ['deprecated_notice:sasslint']); + grunt.registerTask('watch', ['deprecated_notice:watch']); + } diff --git a/core/css/decanter-no-markup.css b/core/css/decanter-no-markup.css deleted file mode 100644 index 8b9a04750..000000000 --- a/core/css/decanter-no-markup.css +++ /dev/null @@ -1,2 +0,0 @@ - -/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJkZWNhbnRlci1uby1tYXJrdXAuY3NzIn0= */ \ No newline at end of file diff --git a/core/css/decanter-grid.css b/core/dist/css/decanter-grid.css similarity index 99% rename from core/css/decanter-grid.css rename to core/dist/css/decanter-grid.css index d5dbfbed4..7eea97700 100644 --- a/core/css/decanter-grid.css +++ b/core/dist/css/decanter-grid.css @@ -1177,4 +1177,6 @@ body { -ms-flex: 0 0 calc(100% - 0px); flex: 0 0 calc(100% - 0px); max-width: calc(100% - 0px); } } -/*# sourceMappingURL=decanter-grid.css.map */ \ No newline at end of file + + +/*# sourceMappingURL=decanter-grid.css.map*/ \ No newline at end of file diff --git a/core/dist/css/decanter-no-markup.css b/core/dist/css/decanter-no-markup.css new file mode 100644 index 000000000..f82f613df --- /dev/null +++ b/core/dist/css/decanter-no-markup.css @@ -0,0 +1,3 @@ + + +/*# sourceMappingURL=decanter-no-markup.css.map*/ \ No newline at end of file diff --git a/core/css/decanter.css b/core/dist/css/decanter.css similarity index 84% rename from core/css/decanter.css rename to core/dist/css/decanter.css index 892fb1326..81a23284d 100644 --- a/core/css/decanter.css +++ b/core/dist/css/decanter.css @@ -1,3 +1,8 @@ +@import url(https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i); +@import url(https://fonts.googleapis.com/css?family=Source+Serif+Pro:400,600,700); +@import url(https://fonts.googleapis.com/css?family=Roboto+Slab:300,400,700); +@import url(https://fonts.googleapis.com/css?family=Kalam:300,400,700); +@import url(https://fonts.googleapis.com/css?family=Noto+Sans:400,400i,700,700i&subset=devanagari); @charset "UTF-8"; /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */ /* Document @@ -6,11 +11,6 @@ * 1. Correct the line height in all browsers. * 2. Prevent adjustments of font size after orientation changes in iOS. */ -@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i"); -@import url("https://fonts.googleapis.com/css?family=Source+Serif+Pro:400,600,700"); -@import url("https://fonts.googleapis.com/css?family=Roboto+Slab:300,400,700"); -@import url("https://fonts.googleapis.com/css?family=Kalam:300,400,700"); -@import url("https://fonts.googleapis.com/css?family=Noto+Sans:400,400i,700,700i&subset=devanagari"); html { line-height: 1.15; /* 1 */ @@ -1824,8 +1824,8 @@ select { -webkit-appearance: none; appearance: none; background-color: #ffffff; - background: url("../img/arrow-down.png"); - background-image: url("../img/arrow-down.svg"); + background: url(); + background-image: url(); background-position: right 1.3rem center; background-repeat: no-repeat; background-size: 1.3rem; } @@ -1905,8 +1905,8 @@ fieldset { [type=checkbox]:checked + label::before, [type=checkbox]:checked:disabled + label::before { - background: url("../img/check.png"); - background-image: url("../img/check.svg"); + background: url(); + background-image: url(); background-position: 50%; background-repeat: no-repeat; } @@ -3192,11 +3192,9 @@ dfn { .layout-blastila > div { margin: 0 auto; - -ms-grid-columns: 1fr 1fr 1fr; - grid-template-columns: 1fr 1fr 1fr; - -ms-grid-rows: auto; - grid-template-rows: auto; - grid-template-areas: "sidebar head head" "sidebar A B"; } + grid-template-columns: 1fr 1fr 1fr; + grid-template-rows: auto; + grid-template-areas: "sidebar head head" "sidebar A B"; } @media only screen and (min-width: 0) { .layout-blastila > div { max-width: calc(100% - 40px); @@ -3334,26 +3332,16 @@ dfn { display: grid; display: -ms-grid; } } .layout-blastila > div > aside { - -ms-grid-row: 1; - -ms-grid-row-span: 2; - -ms-grid-column: 3; grid-area: sidebar; } .layout-blastila > div > section { - -ms-grid-row: 1; - -ms-grid-column: 1; - -ms-grid-column-span: 2; grid-area: head; } .layout-blastila > div :nth-child(3) { - -ms-grid-row: 2; - -ms-grid-column: 1; grid-area: A; } .layout-blastila > div :nth-child(4) { - -ms-grid-row: 2; - -ms-grid-column: 2; grid-area: B; } .layout-blastila--right > div { - grid-template-areas: "head head sidebar" "A B sidebar"; } + grid-template-areas: "head head sidebar" "A B sidebar"; } .layout-chess > header, .layout-chess > footer { @@ -3823,40 +3811,16 @@ dfn { -ms-grid-column: 2; grid-column: 2 / span 2; -ms-grid-column-span: 2; - -ms-grid-columns: 1fr 1fr; - grid-template-columns: 1fr 1fr; - -ms-grid-rows: auto; - grid-template-rows: auto; - grid-template-areas: "head head" "A B" "foot foot"; } } + grid-template-columns: 1fr 1fr; + grid-template-rows: auto; + grid-template-areas: "head head" "A B" "foot foot"; } } .layout-cuttoner > div > section > header { - -ms-grid-row: 1; - -ms-grid-column: 1; - -ms-grid-column-span: 2; grid-area: head; } - @media only screen and (min-width: 576px) { - .layout-blastila > div > section { - -ms-grid-row: 1; - -ms-grid-column: 1; - -ms-grid-column-span: 2; } - .layout-blastila > div :nth-child(3) { - -ms-grid-row: 2; - -ms-grid-column: 1; } - .layout-blastila > div :nth-child(4) { - -ms-grid-row: 2; - -ms-grid-column: 2; } - .layout-cuttoner > div > section > header { - -ms-grid-row: 1; - -ms-grid-column: 1; - -ms-grid-column-span: 2; } } .layout-cuttoner > div > section > footer { grid-area: foot; } .layout-cuttoner > div > section :nth-child(2) { - -ms-grid-row: 2; - -ms-grid-column: 1; grid-area: A; } .layout-cuttoner > div > section :nth-child(3) { - -ms-grid-row: 2; - -ms-grid-column: 2; grid-area: B; } .layout-cuttoner > div > aside { -ms-grid-row: 1; @@ -6664,8 +6628,8 @@ dfn { .su-alert--error { background-color: #b1040e; - background-image: url("../img/alert-error.png"); - background-image: url("../img/alert-error.svg"); + background-image: url(); + background-image: url(); color: #ffffff; } .su-alert--error a { color: #ffffff; } @@ -6674,8 +6638,8 @@ dfn { .su-alert--info { background-color: #00548f; - background-image: url("../img/alert-info.png"); - background-image: url("../img/alert-info.svg"); + background-image: url(); + background-image: url(); color: #ffffff; } .su-alert--info a { color: #ffffff; } @@ -6684,8 +6648,8 @@ dfn { .su-alert--success { background-color: #175e54; - background-image: url("../img/alert-success.png"); - background-image: url("../img/alert-success.svg"); + background-image: url(); + background-image: url(); color: #ffffff; } .su-alert--success a { color: #ffffff; } @@ -6694,8 +6658,8 @@ dfn { .su-alert--warning { background-color: #eaab00; - background-image: url("../img/alert-warning.png"); - background-image: url("../img/alert-warning.svg"); } + background-image: url(); + background-image: url(); } .su-alert--warning a { color: #8c1515; } .su-alert--warning a:hover { @@ -7251,8 +7215,8 @@ a { .su-link--external::after { margin-bottom: -1px; margin-left: 4px; - background: url("../img/external-link.png") no-repeat 0 0; - background: url("../img/external-link.svg") no-repeat 0 0; + background: url() no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; content: ''; display: inline-block; @@ -7260,8 +7224,8 @@ a { width: .65em; } .su-link--external:hover::after { - background-image: url("../img/external-link-hover.png"); - background-image: url("../img/external-link-hover.svg"); } + background-image: url(); + background-image: url(); } .su-link--more::after { color: #b1040e; @@ -8209,7 +8173,7 @@ a { .su-main-nav li.su-main-nav__item--current > a:hover::before, .su-main-nav li.su-main-nav__item--current > a:focus::before { left: 6px; } .su-main-nav li.su-main-nav__item--parent > a::after { - background: url("../img/plus-white.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; content: ""; display: inline-block; @@ -8222,7 +8186,7 @@ a { .su-main-nav li.su-main-nav__item--parent > a::after { margin-bottom: 1px; margin-left: 6px; - background: url("../img/caret-down-black.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; position: relative; right: 0; @@ -8234,11 +8198,11 @@ a { transition: transform .3s ease-out; transition: transform .3s ease-out, -webkit-transform .3s ease-out; } } .su-main-nav li.su-main-nav__item--parent.su-main-nav__item--expanded > a::after { - background: url("../img/minus-white.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; } @media only screen and (min-width: 992px) { .su-main-nav li.su-main-nav__item--parent.su-main-nav__item--expanded > a::after { - background: url("../img/caret-down-black.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; -webkit-transform: rotate(180deg); transform: rotate(180deg); } } @@ -8399,7 +8363,7 @@ a { display: inline-block; width: 30px; height: 26px; - background: url("../img/hamburger-black.svg") no-repeat 3px 0; + background: url() no-repeat 3px 0; content: ""; } .su-main-nav__toggle[aria-expanded="true"]::before { visibility: visible; @@ -8408,7 +8372,7 @@ a { background-color: #2e2d29; } .su-main-nav__toggle[aria-expanded="true"]::after { width: 22px; - background: url("../img/close-black.svg") no-repeat 3px 0; + background: url() no-repeat 3px 0; background-size: 16px 16px; } .su-main-nav__toggle[aria-expanded="true"]:hover::before { background-color: #820000; } @@ -8517,11 +8481,11 @@ a { .su-main-nav.su-main-nav--dark .su-main-nav__toggle:active::before { background-color: #ec0513; } .su-main-nav.su-main-nav--dark .su-main-nav__toggle::after { - background: url("../img/hamburger-white.svg") no-repeat 3px 0; } + background: url() no-repeat 3px 0; } .su-main-nav.su-main-nav--dark .su-main-nav__toggle[aria-expanded="true"]::before { background-color: #ffffff; } .su-main-nav.su-main-nav--dark .su-main-nav__toggle[aria-expanded="true"]::after { - background: url("../img/close-white.svg") no-repeat 3px 0; + background: url() no-repeat 3px 0; background-size: 16px 16px; } .su-main-nav.su-main-nav--dark .su-main-nav__toggle[aria-expanded="true"]:hover::before { background-color: #ec0513; } } @@ -8546,7 +8510,7 @@ a { .su-main-nav.su-main-nav--dark > ul > li > a[aria-expanded="true"]:hover::before { background-color: #ec0513; } .su-main-nav.su-main-nav--dark > ul > li.su-main-nav__item--parent > a::after { - background: url("../img/caret-down-white.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; } .su-main-nav.su-main-nav--dark > ul > li.su-main-nav__item--current > a { color: #ffffff; } @@ -8594,10 +8558,10 @@ a { @media (max-width: 991px) { .su-main-nav.su-main-nav--light li.su-main-nav__item--parent > a::after { - background: url("../img/plus-black.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; } .su-main-nav.su-main-nav--light li.su-main-nav__item--parent.su-main-nav__item--expanded > a ::after { - background: url("../img/minus-black.svg") no-repeat 0 0; + background: url() no-repeat 0 0; background-size: 100%; } .su-main-nav.su-main-nav--light li.su-main-nav__item--parent.su-main-nav__item--expanded > a:focus::before { background-color: transparent; } @@ -8719,6 +8683,9 @@ a { .su-site-search__input::-webkit-input-placeholder { color: #2e2d29; opacity: 1; } + .su-site-search__input:-ms-input-placeholder { + color: #2e2d29; + opacity: 1; } .su-site-search__input::-ms-input-placeholder { color: #2e2d29; opacity: 1; } @@ -8743,7 +8710,7 @@ a { margin-top: 0; margin-right: 0; margin-bottom: 0; - background: url("../img/icon-search.svg") no-repeat 0 0; + background: url() no-repeat 0 0; opacity: .6; position: absolute; top: 1.1rem; @@ -8797,4 +8764,6 @@ a { top: .8em; width: auto; z-index: 11222; } -/*# sourceMappingURL=decanter.css.map */ \ No newline at end of file + + +/*# sourceMappingURL=decanter.css.map*/ \ No newline at end of file diff --git a/core/dist/js/assets.json b/core/dist/js/assets.json new file mode 100644 index 000000000..213f944a8 --- /dev/null +++ b/core/dist/js/assets.json @@ -0,0 +1,14 @@ +{ + "decanter-grid.css": "../css/decanter-grid.css", + "decanter-grid.css.map": "../css/decanter-grid.css.map", + "decanter-grid.js": "decanter-grid.js", + "decanter-grid.js.map": "decanter-grid.js.map", + "decanter-no-markup.css": "../css/decanter-no-markup.css", + "decanter-no-markup.css.map": "../css/decanter-no-markup.css.map", + "decanter-no-markup.js": "decanter-no-markup.js", + "decanter-no-markup.js.map": "decanter-no-markup.js.map", + "decanter.css": "../css/decanter.css", + "decanter.css.map": "../css/decanter.css.map", + "decanter.js": "decanter.js", + "decanter.js.map": "decanter.js.map" +} \ No newline at end of file diff --git a/core/dist/js/decanter-grid.js b/core/dist/js/decanter-grid.js new file mode 100644 index 000000000..1ad7a9be3 --- /dev/null +++ b/core/dist/js/decanter-grid.js @@ -0,0 +1,116 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./core/src/js/decanter-grid.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./core/src/js/decanter-grid.js": +/*!**************************************!*\ + !*** ./core/src/js/decanter-grid.js ***! + \**************************************/ +/*! no exports provided */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _scss_decanter_grid_scss__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../scss/decanter-grid.scss */ "./core/src/scss/decanter-grid.scss"); +/* harmony import */ var _scss_decanter_grid_scss__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_scss_decanter_grid_scss__WEBPACK_IMPORTED_MODULE_0__); + + +/***/ }), + +/***/ "./core/src/scss/decanter-grid.scss": +/*!******************************************!*\ + !*** ./core/src/scss/decanter-grid.scss ***! + \******************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +// extracted by mini-css-extract-plugin + +/***/ }) + +/******/ }); +//# sourceMappingURL=decanter-grid.js.map \ No newline at end of file diff --git a/core/dist/js/decanter-no-markup.js b/core/dist/js/decanter-no-markup.js new file mode 100644 index 000000000..caee0779f --- /dev/null +++ b/core/dist/js/decanter-no-markup.js @@ -0,0 +1,116 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./core/src/js/decanter-no-markup.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./core/src/js/decanter-no-markup.js": +/*!*******************************************!*\ + !*** ./core/src/js/decanter-no-markup.js ***! + \*******************************************/ +/*! no exports provided */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _scss_decanter_no_markup_scss__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../scss/decanter-no-markup.scss */ "./core/src/scss/decanter-no-markup.scss"); +/* harmony import */ var _scss_decanter_no_markup_scss__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_scss_decanter_no_markup_scss__WEBPACK_IMPORTED_MODULE_0__); + + +/***/ }), + +/***/ "./core/src/scss/decanter-no-markup.scss": +/*!***********************************************!*\ + !*** ./core/src/scss/decanter-no-markup.scss ***! + \***********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +// extracted by mini-css-extract-plugin + +/***/ }) + +/******/ }); +//# sourceMappingURL=decanter-no-markup.js.map \ No newline at end of file diff --git a/core/dist/js/decanter.js b/core/dist/js/decanter.js new file mode 100644 index 000000000..06ee1f934 --- /dev/null +++ b/core/dist/js/decanter.js @@ -0,0 +1,1096 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = "./core/src/js/decanter.js"); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./core/src/js/components/components.js": +/*!**********************************************!*\ + !*** ./core/src/js/components/components.js ***! + \**********************************************/ +/*! no exports provided */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _main_nav_main_nav_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./main-nav/main-nav.js */ "./core/src/js/components/main-nav/main-nav.js"); + + +/***/ }), + +/***/ "./core/src/js/components/main-nav/Nav.js": +/*!************************************************!*\ + !*** ./core/src/js/components/main-nav/Nav.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return Nav; }); +/* harmony import */ var _globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./globals */ "./core/src/js/components/main-nav/globals.js"); +/* harmony import */ var _utilities_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../utilities/keyboard */ "./core/src/js/utilities/keyboard.js"); +/* harmony import */ var _NavItem__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./NavItem */ "./core/src/js/components/main-nav/NavItem.js"); +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } + +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } + + + + +/** + * Represent a navigation menu. May be the top nav or a subnav. + * + * @prop {HTMLElement|NavItem} elem - The element that is the nav. May + * be a main nav (