reustyle 2.0.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.drone.yml +17 -0
- data/.gitignore +25 -0
- data/.nvmrc +1 -0
- data/.rbenv-gemsets +1 -0
- data/.ruby-version +1 -0
- data/CONTRIBUTING.md +68 -0
- data/Gemfile +4 -0
- data/Gruntfile.js +234 -0
- data/LICENSE.txt +13 -0
- data/README.md +196 -0
- data/Rakefile +6 -0
- data/bower.json +54 -0
- data/config/autoprefixer.yml +6 -0
- data/config/scss-lint.yml +55 -0
- data/dist/icons.svg +1 -0
- data/dist/ustyle-content.css +1 -0
- data/dist/ustyle-latest.css +1 -0
- data/dist/ustyle.js +567 -0
- data/dist/ustyle.json +1 -0
- data/dist/ustyle.min.js +1 -0
- data/grunt/modules/dss-helper.js +115 -0
- data/grunt/modules/file.js +24 -0
- data/grunt/modules/html-parser.js +22 -0
- data/grunt/modules/templates.js +57 -0
- data/grunt/tasks/browser-sync.js +23 -0
- data/grunt/tasks/builder.js +67 -0
- data/grunt/tasks/styleguide.js +299 -0
- data/index.js +37 -0
- data/lib/ustyle/deploy.rb +41 -0
- data/lib/ustyle/engine.rb +32 -0
- data/lib/ustyle/hash.rb +44 -0
- data/lib/ustyle/helpers/icon_helper.rb +15 -0
- data/lib/ustyle/icons.rb +13 -0
- data/lib/ustyle/middleware/icon_middleware.rb +27 -0
- data/lib/ustyle/sass_functions.rb +65 -0
- data/lib/ustyle/sinatra.rb +34 -0
- data/lib/ustyle/sprockets.rb +6 -0
- data/lib/ustyle/utils.rb +42 -0
- data/lib/ustyle/version.rb +4 -0
- data/lib/ustyle.rb +58 -0
- data/package-lock.json +9303 -0
- data/package.json +89 -0
- data/styleguide/CNAME +1 -0
- data/styleguide/assets/images/CTAs.png +0 -0
- data/styleguide/assets/images/badge-label-usp.png +0 -0
- data/styleguide/assets/images/bower-logo.png +0 -0
- data/styleguide/assets/images/caveat.png +0 -0
- data/styleguide/assets/images/cloudfront-logo.png +0 -0
- data/styleguide/assets/images/design-conventions.png +0 -0
- data/styleguide/assets/images/error-texts.png +0 -0
- data/styleguide/assets/images/external-requirements.png +0 -0
- data/styleguide/assets/images/favicon/android-chrome-192x192.png +0 -0
- data/styleguide/assets/images/favicon/android-chrome-512x512.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-114x114.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-120x120.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-144x144.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-152x152.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-180x180.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-57x57.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-60x60.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-72x72.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon-76x76.png +0 -0
- data/styleguide/assets/images/favicon/apple-touch-icon.png +0 -0
- data/styleguide/assets/images/favicon/browserconfig.xml +9 -0
- data/styleguide/assets/images/favicon/favicon-16x16.png +0 -0
- data/styleguide/assets/images/favicon/favicon-32x32.png +0 -0
- data/styleguide/assets/images/favicon/favicon.ico +0 -0
- data/styleguide/assets/images/favicon/manifest.json +18 -0
- data/styleguide/assets/images/favicon/mstile-144x144.png +0 -0
- data/styleguide/assets/images/favicon/mstile-150x150.png +0 -0
- data/styleguide/assets/images/favicon/mstile-310x150.png +0 -0
- data/styleguide/assets/images/favicon/mstile-310x310.png +0 -0
- data/styleguide/assets/images/favicon/mstile-70x70.png +0 -0
- data/styleguide/assets/images/favicon/safari-pinned-tab.svg +46 -0
- data/styleguide/assets/images/icons.svg +1 -0
- data/styleguide/assets/images/infographic-01.png +0 -0
- data/styleguide/assets/images/infographic-02.png +0 -0
- data/styleguide/assets/images/npm-logo.png +0 -0
- data/styleguide/assets/images/placeholder-text.png +0 -0
- data/styleguide/assets/images/ruby-logo.png +0 -0
- data/styleguide/assets/images/site-consistency01.png +0 -0
- data/styleguide/assets/images/site-consistency02.png +0 -0
- data/styleguide/assets/images/site-consistency03.png +0 -0
- data/styleguide/assets/images/styleguide-examples/accurate-housing.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/altered.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/bad-subject.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/centered.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/cliche.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/cold.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/good-subject.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/illustrations_1.png +0 -0
- data/styleguide/assets/images/styleguide-examples/illustrations_2.png +0 -0
- data/styleguide/assets/images/styleguide-examples/illustrations_3.png +0 -0
- data/styleguide/assets/images/styleguide-examples/illustrations_4.png +0 -0
- data/styleguide/assets/images/styleguide-examples/illustrations_5.png +0 -0
- data/styleguide/assets/images/styleguide-examples/illustrations_6.png +0 -0
- data/styleguide/assets/images/styleguide-examples/innaccurate-housing.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/natural-1.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/natural-2.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/natural-3.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/not-centered.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/realistic.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/unaltered.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/unnatural-1.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/unnatural-2.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/unnatural-3.jpg +0 -0
- data/styleguide/assets/images/styleguide-examples/warm.jpg +0 -0
- data/styleguide/assets/images/tone-framework.png +0 -0
- data/styleguide/assets/images/tone.png +0 -0
- data/styleguide/assets/images/tooltip.png +0 -0
- data/styleguide/assets/images/tsandcs.png +0 -0
- data/styleguide/assets/images/ustyle.svg +73 -0
- data/styleguide/assets/images/ux-conventions-consistency.png +0 -0
- data/styleguide/assets/images/ux-conventions-error.png +0 -0
- data/styleguide/assets/images/ux-conventions-errors.png +0 -0
- data/styleguide/assets/images/ux-conventions-flexibility.png +0 -0
- data/styleguide/assets/images/ux-conventions-freedom.png +0 -0
- data/styleguide/assets/images/ux-conventions-minimalist.png +0 -0
- data/styleguide/assets/images/ux-conventions-real-world.png +0 -0
- data/styleguide/assets/images/ux-conventions-recognition.png +0 -0
- data/styleguide/assets/images/ux-conventions-visibility.png +0 -0
- data/styleguide/assets/javascripts/app.js +115 -0
- data/styleguide/assets/javascripts/modules/stats.js +50 -0
- data/styleguide/assets/javascripts/vendor/highlight.js +1 -0
- data/styleguide/assets/javascripts/vendor/svg4everybody.js +1 -0
- data/styleguide/assets/sass/main.scss +42 -0
- data/styleguide/assets/sass/modules/_code.scss +8 -0
- data/styleguide/assets/sass/modules/_colours.scss +26 -0
- data/styleguide/assets/sass/modules/_copyright.scss +4 -0
- data/styleguide/assets/sass/modules/_grid.scss +12 -0
- data/styleguide/assets/sass/modules/_home.scss +5 -0
- data/styleguide/assets/sass/modules/_images.scss +24 -0
- data/styleguide/assets/sass/modules/_links.scss +3 -0
- data/styleguide/assets/sass/modules/_logo.scss +182 -0
- data/styleguide/assets/sass/modules/_made-at.scss +6 -0
- data/styleguide/assets/sass/modules/_markdown.scss +7 -0
- data/styleguide/assets/sass/modules/_nav-mobile.scss +72 -0
- data/styleguide/assets/sass/modules/_nav.scss +32 -0
- data/styleguide/assets/sass/modules/_sidebar.scss +94 -0
- data/styleguide/assets/sass/modules/_states.scss +4 -0
- data/styleguide/assets/sass/modules/_styleguide.scss +138 -0
- data/styleguide/assets/sass/modules/_table.scss +3 -0
- data/styleguide/assets/sass/modules/_tooltip.scss +9 -0
- data/styleguide/assets/sass/modules/_typography.scss +14 -0
- data/styleguide/assets/sass/modules/_version.scss +11 -0
- data/styleguide/assets/sass/structure/_base.scss +18 -0
- data/styleguide/assets/sass/structure/_header.scss +12 -0
- data/styleguide/assets/sass/vendor/_highlight.scss +139 -0
- data/styleguide/assets/sass/vendor/_pure-table.scss +75 -0
- data/styleguide/content/brand/index.md +47 -0
- data/styleguide/content/brand/logo.tpl +279 -0
- data/styleguide/content/design/accessibility-testing.md +82 -0
- data/styleguide/content/design/index.tpl +367 -0
- data/styleguide/content/design/typography.md +68 -0
- data/styleguide/content/design/validating-designs.tpl +304 -0
- data/styleguide/content/index.tpl +51 -0
- data/styleguide/content/language/grammar.md +220 -0
- data/styleguide/content/language/microcopy.md +170 -0
- data/styleguide/content/language/tone.md +135 -0
- data/styleguide/content/pattern-library/grid.tpl +64 -0
- data/styleguide/content/pattern-library/index.tpl +88 -0
- data/styleguide/partials/_footer.tpl +8 -0
- data/styleguide/partials/_head.tpl +26 -0
- data/styleguide/partials/_header.tpl +37 -0
- data/styleguide/partials/_sidebar.tpl +27 -0
- data/styleguide/partials/colour.tpl +24 -0
- data/styleguide/partials/icons.tpl +28 -0
- data/styleguide/partials/style_block.tpl +44 -0
- data/styleguide/templates/simple.tpl +25 -0
- data/styleguide/templates/stats.tpl +50 -0
- data/styleguide/templates/styleguide.tpl +36 -0
- data/tasks/publish.rake +67 -0
- data/ustyle.gemspec +32 -0
- data/vendor/assets/images/forms/checkbox-rebrand.svg +1 -0
- data/vendor/assets/images/forms/checkbox.svg +1 -0
- data/vendor/assets/images/icons/alarm.svg +1 -0
- data/vendor/assets/images/icons/android.svg +1 -0
- data/vendor/assets/images/icons/arrow-circle.svg +1 -0
- data/vendor/assets/images/icons/arrow-down.svg +1 -0
- data/vendor/assets/images/icons/arrow-up.svg +1 -0
- data/vendor/assets/images/icons/book.svg +1 -0
- data/vendor/assets/images/icons/bookmark.svg +1 -0
- data/vendor/assets/images/icons/breadcrumb.svg +1 -0
- data/vendor/assets/images/icons/calculator.svg +1 -0
- data/vendor/assets/images/icons/calendar.svg +1 -0
- data/vendor/assets/images/icons/car.svg +1 -0
- data/vendor/assets/images/icons/checkbox-tick.svg +1 -0
- data/vendor/assets/images/icons/chevron-left.svg +1 -0
- data/vendor/assets/images/icons/chevron-right.svg +1 -0
- data/vendor/assets/images/icons/clock.svg +1 -0
- data/vendor/assets/images/icons/close.svg +1 -0
- data/vendor/assets/images/icons/cog.svg +1 -0
- data/vendor/assets/images/icons/controller.svg +1 -0
- data/vendor/assets/images/icons/credit-card.svg +1 -0
- data/vendor/assets/images/icons/cross.svg +1 -0
- data/vendor/assets/images/icons/dashcam.svg +1 -0
- data/vendor/assets/images/icons/dual-fuel.svg +1 -0
- data/vendor/assets/images/icons/electric-light.svg +1 -0
- data/vendor/assets/images/icons/envelope.svg +1 -0
- data/vendor/assets/images/icons/exit-noexit.svg +1 -0
- data/vendor/assets/images/icons/facebook-brand.svg +1 -0
- data/vendor/assets/images/icons/facebook.svg +1 -0
- data/vendor/assets/images/icons/filter.svg +1 -0
- data/vendor/assets/images/icons/fixed-variable.svg +1 -0
- data/vendor/assets/images/icons/gas.svg +1 -0
- data/vendor/assets/images/icons/gauge.svg +1 -0
- data/vendor/assets/images/icons/github.svg +1 -0
- data/vendor/assets/images/icons/google-brand.svg +1 -0
- data/vendor/assets/images/icons/google.svg +1 -0
- data/vendor/assets/images/icons/graph-up.svg +1 -0
- data/vendor/assets/images/icons/home.svg +1 -0
- data/vendor/assets/images/icons/hot.svg +1 -0
- data/vendor/assets/images/icons/info.svg +1 -0
- data/vendor/assets/images/icons/kettle.svg +1 -0
- data/vendor/assets/images/icons/key.svg +1 -0
- data/vendor/assets/images/icons/lock.svg +1 -0
- data/vendor/assets/images/icons/magnify-in.svg +1 -0
- data/vendor/assets/images/icons/magnify.svg +1 -0
- data/vendor/assets/images/icons/menu.svg +1 -0
- data/vendor/assets/images/icons/message.svg +1 -0
- data/vendor/assets/images/icons/mobile.svg +1 -0
- data/vendor/assets/images/icons/monthly-dd.svg +1 -0
- data/vendor/assets/images/icons/network.svg +1 -0
- data/vendor/assets/images/icons/no-exit.svg +1 -0
- data/vendor/assets/images/icons/pdf.svg +1 -0
- data/vendor/assets/images/icons/pencil.svg +1 -0
- data/vendor/assets/images/icons/person-add.svg +1 -0
- data/vendor/assets/images/icons/person.svg +1 -0
- data/vendor/assets/images/icons/phone.svg +1 -0
- data/vendor/assets/images/icons/piggy-bank.svg +1 -0
- data/vendor/assets/images/icons/pin.svg +1 -0
- data/vendor/assets/images/icons/play.svg +1 -0
- data/vendor/assets/images/icons/pound-circle.svg +1 -0
- data/vendor/assets/images/icons/pound-note.svg +1 -0
- data/vendor/assets/images/icons/present.svg +1 -0
- data/vendor/assets/images/icons/print.svg +1 -0
- data/vendor/assets/images/icons/quarterly-dd.svg +1 -0
- data/vendor/assets/images/icons/question-circle.svg +1 -0
- data/vendor/assets/images/icons/quote.svg +1 -0
- data/vendor/assets/images/icons/recycle.svg +1 -0
- data/vendor/assets/images/icons/remove.svg +1 -0
- data/vendor/assets/images/icons/renewable.svg +1 -0
- data/vendor/assets/images/icons/results.svg +1 -0
- data/vendor/assets/images/icons/save.svg +1 -0
- data/vendor/assets/images/icons/share.svg +1 -0
- data/vendor/assets/images/icons/shield.svg +1 -0
- data/vendor/assets/images/icons/sim.svg +1 -0
- data/vendor/assets/images/icons/smiley.svg +1 -0
- data/vendor/assets/images/icons/sort.svg +1 -0
- data/vendor/assets/images/icons/speech-circle.svg +1 -0
- data/vendor/assets/images/icons/speech.svg +1 -0
- data/vendor/assets/images/icons/spinner-rebrand.svg +1 -0
- data/vendor/assets/images/icons/spinner.svg +1 -0
- data/vendor/assets/images/icons/star-half.svg +1 -0
- data/vendor/assets/images/icons/star.svg +1 -0
- data/vendor/assets/images/icons/starline-half.svg +1 -0
- data/vendor/assets/images/icons/starline.svg +1 -0
- data/vendor/assets/images/icons/talk.svg +1 -0
- data/vendor/assets/images/icons/tick-circle.svg +1 -0
- data/vendor/assets/images/icons/tick.svg +1 -0
- data/vendor/assets/images/icons/tv.svg +1 -0
- data/vendor/assets/images/icons/twitter-brand.svg +1 -0
- data/vendor/assets/images/icons/twitter.svg +1 -0
- data/vendor/assets/images/icons/ustyle.svg +1 -0
- data/vendor/assets/images/icons/uswitch.svg +1 -0
- data/vendor/assets/images/icons/variable.svg +1 -0
- data/vendor/assets/images/icons/warning-circle.svg +1 -0
- data/vendor/assets/images/icons/warning.svg +1 -0
- data/vendor/assets/images/icons/wifi.svg +1 -0
- data/vendor/assets/images/icons/wiki.svg +1 -0
- data/vendor/assets/images/icons/xml.svg +1 -0
- data/vendor/assets/images/icons.svg +1 -0
- data/vendor/assets/javascripts/ustyle/backdrop.js +56 -0
- data/vendor/assets/javascripts/ustyle/classtoggler.js +76 -0
- data/vendor/assets/javascripts/ustyle/overlay.js +152 -0
- data/vendor/assets/javascripts/ustyle/tabs.js +166 -0
- data/vendor/assets/javascripts/ustyle/utils.js +113 -0
- data/vendor/assets/javascripts/ustyle.js +4 -0
- data/vendor/assets/stylesheets/rebrand-content.scss +1 -0
- data/vendor/assets/stylesheets/rebrand.scss +1 -0
- data/vendor/assets/stylesheets/ustyle/_all.scss +55 -0
- data/vendor/assets/stylesheets/ustyle/_content.scss +5 -0
- data/vendor/assets/stylesheets/ustyle/_global.scss +20 -0
- data/vendor/assets/stylesheets/ustyle/articles/_base.scss +100 -0
- data/vendor/assets/stylesheets/ustyle/articles/_guide.scss +57 -0
- data/vendor/assets/stylesheets/ustyle/articles/_more.scss +31 -0
- data/vendor/assets/stylesheets/ustyle/articles/_news.scss +213 -0
- data/vendor/assets/stylesheets/ustyle/articles/_related.scss +76 -0
- data/vendor/assets/stylesheets/ustyle/basics/_extends.scss +73 -0
- data/vendor/assets/stylesheets/ustyle/basics/_fonts.scss +27 -0
- data/vendor/assets/stylesheets/ustyle/basics/_functions.scss +78 -0
- data/vendor/assets/stylesheets/ustyle/basics/_grid.scss +86 -0
- data/vendor/assets/stylesheets/ustyle/basics/_typography.scss +123 -0
- data/vendor/assets/stylesheets/ustyle/basics/_variables.scss +166 -0
- data/vendor/assets/stylesheets/ustyle/basics/variables/_colors.scss +94 -0
- data/vendor/assets/stylesheets/ustyle/basics/variables/_forms.scss +98 -0
- data/vendor/assets/stylesheets/ustyle/basics/variables/_icons.scss +43 -0
- data/vendor/assets/stylesheets/ustyle/components/_backdrop.scss +23 -0
- data/vendor/assets/stylesheets/ustyle/components/_breadcrumbs.scss +66 -0
- data/vendor/assets/stylesheets/ustyle/components/_button.scss +187 -0
- data/vendor/assets/stylesheets/ustyle/components/_calculator.scss +41 -0
- data/vendor/assets/stylesheets/ustyle/components/_comp-table-row.scss +341 -0
- data/vendor/assets/stylesheets/ustyle/components/_compliance-banner.scss +38 -0
- data/vendor/assets/stylesheets/ustyle/components/_content-group.scss +33 -0
- data/vendor/assets/stylesheets/ustyle/components/_cta.scss +66 -0
- data/vendor/assets/stylesheets/ustyle/components/_grid-classes.scss +52 -0
- data/vendor/assets/stylesheets/ustyle/components/_hero.scss +115 -0
- data/vendor/assets/stylesheets/ustyle/components/_links.scss +26 -0
- data/vendor/assets/stylesheets/ustyle/components/_lists-li.scss +92 -0
- data/vendor/assets/stylesheets/ustyle/components/_lists.scss +39 -0
- data/vendor/assets/stylesheets/ustyle/components/_loader.scss +139 -0
- data/vendor/assets/stylesheets/ustyle/components/_overlay.scss +183 -0
- data/vendor/assets/stylesheets/ustyle/components/_progress.scss +138 -0
- data/vendor/assets/stylesheets/ustyle/components/_promo-banner.scss +131 -0
- data/vendor/assets/stylesheets/ustyle/components/_reminder.scss +87 -0
- data/vendor/assets/stylesheets/ustyle/components/_tab-navigation.scss +114 -0
- data/vendor/assets/stylesheets/ustyle/components/_table-toolbar.scss +91 -0
- data/vendor/assets/stylesheets/ustyle/components/_tabs.scss +300 -0
- data/vendor/assets/stylesheets/ustyle/components/_tooltip.scss +243 -0
- data/vendor/assets/stylesheets/ustyle/components/_usp.scss +88 -0
- data/vendor/assets/stylesheets/ustyle/content/_base.scss +227 -0
- data/vendor/assets/stylesheets/ustyle/content/_c-header.scss +27 -0
- data/vendor/assets/stylesheets/ustyle/content/_c-social.scss +9 -0
- data/vendor/assets/stylesheets/ustyle/content/_c-tabs.scss +30 -0
- data/vendor/assets/stylesheets/ustyle/forms/_base.scss +9 -0
- data/vendor/assets/stylesheets/ustyle/forms/_fields.scss +78 -0
- data/vendor/assets/stylesheets/ustyle/forms/_input-group.scss +154 -0
- data/vendor/assets/stylesheets/ustyle/forms/_input.scss +61 -0
- data/vendor/assets/stylesheets/ustyle/forms/_radio-checkbox.scss +144 -0
- data/vendor/assets/stylesheets/ustyle/forms/_reset.scss +21 -0
- data/vendor/assets/stylesheets/ustyle/forms/_select.scss +154 -0
- data/vendor/assets/stylesheets/ustyle/forms/_textarea.scss +33 -0
- data/vendor/assets/stylesheets/ustyle/forms/_toggle.scss +114 -0
- data/vendor/assets/stylesheets/ustyle/forms/_validation.scss +104 -0
- data/vendor/assets/stylesheets/ustyle/icons/_base.scss +241 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_arrow.scss +51 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_base.scss +7 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_baseline.scss +43 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_forms.scss +84 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_general.scss +24 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_link-colors.scss +44 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_media-query.scss +121 -0
- data/vendor/assets/stylesheets/ustyle/mixins/_typography.scss +98 -0
- data/vendor/assets/stylesheets/ustyle/tables/_base.scss +4 -0
- data/vendor/assets/stylesheets/ustyle/tables/_tables-basic.scss +72 -0
- data/vendor/assets/stylesheets/ustyle/tables/_tables-sortable.scss +72 -0
- data/vendor/assets/stylesheets/ustyle/tables/_tables-with-key-cells.scss +18 -0
- data/vendor/assets/stylesheets/ustyle/tables/_variables.scss +15 -0
- data/vendor/assets/stylesheets/ustyle/utilities/_general.scss +116 -0
- data/vendor/assets/stylesheets/ustyle/utilities/_grid.scss +13 -0
- data/vendor/assets/stylesheets/ustyle/utilities/_images.scss +34 -0
- data/vendor/assets/stylesheets/ustyle/utilities/_responsive.scss +101 -0
- data/vendor/assets/stylesheets/ustyle/utilities/_spacing.scss +73 -0
- data/vendor/assets/stylesheets/ustyle/vendor/normalize.scss +427 -0
- data/vendor/assets/stylesheets/ustyle-content.scss +2 -0
- data/vendor/assets/stylesheets/ustyle.scss +1 -0
- metadata +517 -0
@@ -0,0 +1,166 @@
|
|
1
|
+
window.Tabs = (function(Utils) {
|
2
|
+
|
3
|
+
var addClass = Utils.addClass;
|
4
|
+
var hasClass = Utils.hasClass;
|
5
|
+
var removeClass = Utils.removeClass;
|
6
|
+
var setOptions = Utils.setOptions;
|
7
|
+
var forEach = Utils.forEach;
|
8
|
+
|
9
|
+
Tabs.prototype.defaults = {
|
10
|
+
tabContainer: ".us-tabs",
|
11
|
+
tabLinks: ".us-tabs-nav-mainlink",
|
12
|
+
tabNav: ".us-tabs-nav",
|
13
|
+
changeUrls: true,
|
14
|
+
activeClass: "active",
|
15
|
+
collapsible: false,
|
16
|
+
autoScroll: true
|
17
|
+
};
|
18
|
+
|
19
|
+
function Tabs(options) {
|
20
|
+
var ref = this.options = setOptions(options, this.defaults);
|
21
|
+
var tabContainer = ref.tabContainer;
|
22
|
+
var tabLinks = ref.tabLinks;
|
23
|
+
|
24
|
+
this.activeTabEvent = new CustomEvent('ustyle.tab.active');
|
25
|
+
this.tabs = document.querySelectorAll(tabContainer + ' ' + tabLinks);
|
26
|
+
if(!this.tabs.length) return;
|
27
|
+
this.filter = this.tabs.item(0).getAttribute("data-target") ? "data-target" : "href";
|
28
|
+
this.init();
|
29
|
+
|
30
|
+
var handleClick = (function (_this) {
|
31
|
+
return function (e) {
|
32
|
+
var target = e.currentTarget;
|
33
|
+
if (_this.isAccordion() && _this.options.collapsible && _this.isActive(target)) {
|
34
|
+
_this.collapse(target);
|
35
|
+
_this.hashClear();
|
36
|
+
} else {
|
37
|
+
_this.navigateTo(target);
|
38
|
+
_this.scrollToTab(target);
|
39
|
+
_this.hashChange(target);
|
40
|
+
}
|
41
|
+
|
42
|
+
return e.preventDefault();
|
43
|
+
}
|
44
|
+
})(this);
|
45
|
+
|
46
|
+
forEach(this.tabs, function (index, tab) {
|
47
|
+
tab.addEventListener('click', handleClick);
|
48
|
+
});
|
49
|
+
}
|
50
|
+
|
51
|
+
Tabs.prototype.init = function() {
|
52
|
+
var activeTab = this.activeTab();
|
53
|
+
var initialHash = this.tabFromHash();
|
54
|
+
|
55
|
+
if (initialHash) {
|
56
|
+
return this.navigateTo(initialHash);
|
57
|
+
} else if (activeTab) {
|
58
|
+
return this.navigateTo(activeTab);
|
59
|
+
} else if (!this.options.collapsible || !this.isAccordion()) {
|
60
|
+
return this.navigateTo(this.tabs.item(0));
|
61
|
+
}
|
62
|
+
};
|
63
|
+
|
64
|
+
Tabs.prototype.hashChange = function(target) {
|
65
|
+
if (!this.options.changeUrls) return;
|
66
|
+
|
67
|
+
return window.location.replace("#!" + (getSelector(target).replace(/#/, "")));
|
68
|
+
};
|
69
|
+
|
70
|
+
Tabs.prototype.hashClear = function() {
|
71
|
+
if (!this.options.changeUrls) return;
|
72
|
+
|
73
|
+
var url = window.location.pathname + window.location.search;
|
74
|
+
return typeof history.replaceState === "function" ? history.replaceState("", document.title, url) : void 0;
|
75
|
+
};
|
76
|
+
|
77
|
+
Tabs.prototype.navigateTo = function(target) {
|
78
|
+
var selector = getSelector(target);
|
79
|
+
var selected = document.querySelector(selector);
|
80
|
+
var activeClass = this.options.activeClass;
|
81
|
+
var filter = this.filter;
|
82
|
+
|
83
|
+
forEach(this.tabs, function (index, tab) {
|
84
|
+
removeClass(tab, activeClass);
|
85
|
+
});
|
86
|
+
|
87
|
+
forEach(this.tabs, function (index, tab) {
|
88
|
+
if (tab.getAttribute(filter) === selector) {
|
89
|
+
return addClass(tab, activeClass);
|
90
|
+
}
|
91
|
+
});
|
92
|
+
|
93
|
+
forEach(selected.parentNode.children, function (index, child) {
|
94
|
+
if (child !== selected) {
|
95
|
+
removeClass(child, activeClass);
|
96
|
+
}
|
97
|
+
});
|
98
|
+
|
99
|
+
addClass(selected, activeClass);
|
100
|
+
return selected.dispatchEvent(this.activeTabEvent);
|
101
|
+
};
|
102
|
+
|
103
|
+
Tabs.prototype.collapse = function(target) {
|
104
|
+
var selected = document.querySelector(getSelector(target));
|
105
|
+
var activeClass = this.options.activeClass;
|
106
|
+
|
107
|
+
forEach(this.tabs, function (index, tab) {
|
108
|
+
removeClass(tab, activeClass);
|
109
|
+
});
|
110
|
+
|
111
|
+
return removeClass(selected, activeClass);
|
112
|
+
};
|
113
|
+
|
114
|
+
Tabs.prototype.scrollToTab = function(target) {
|
115
|
+
if (!(this.isAccordion() && this.options.autoScroll)) {
|
116
|
+
return;
|
117
|
+
}
|
118
|
+
|
119
|
+
var selected = document.querySelector(getSelector(target));
|
120
|
+
return selected.scrollIntoView();
|
121
|
+
};
|
122
|
+
|
123
|
+
Tabs.prototype.activeTab = function() {
|
124
|
+
var activeTab = null;
|
125
|
+
var activeClass = this.options.activeClass;
|
126
|
+
var matchingTab = null;
|
127
|
+
|
128
|
+
forEach(this.tabs, function (index, tab) {
|
129
|
+
if (hasClass(tab, activeClass)) {
|
130
|
+
return matchingTab = tab;
|
131
|
+
}
|
132
|
+
});
|
133
|
+
|
134
|
+
return matchingTab;
|
135
|
+
};
|
136
|
+
|
137
|
+
Tabs.prototype.tabFromHash = function() {
|
138
|
+
var tabId = window.location.hash.replace("!", "");
|
139
|
+
var filter = this.filter;
|
140
|
+
var matchingTab = null;
|
141
|
+
|
142
|
+
forEach(this.tabs, function (index, tab) {
|
143
|
+
if (tab.getAttribute(filter) === tabId) {
|
144
|
+
return matchingTab = tab;
|
145
|
+
}
|
146
|
+
});
|
147
|
+
|
148
|
+
return matchingTab;
|
149
|
+
};
|
150
|
+
|
151
|
+
Tabs.prototype.isActive = function(target) {
|
152
|
+
return getSelector(target) === getSelector(this.activeTab());
|
153
|
+
};
|
154
|
+
|
155
|
+
Tabs.prototype.isAccordion = function() {
|
156
|
+
var tabNav = document.querySelector(this.options.tabNav);
|
157
|
+
|
158
|
+
return !(tabNav.offsetWidth > 0 || tabNav.offsetHeight > 0);
|
159
|
+
};
|
160
|
+
|
161
|
+
var getSelector = function(clicked) {
|
162
|
+
if(clicked) return clicked.getAttribute("data-target") || clicked.getAttribute("href");
|
163
|
+
};
|
164
|
+
|
165
|
+
return Tabs;
|
166
|
+
})(this.Utils);
|
@@ -0,0 +1,113 @@
|
|
1
|
+
var slice = [].slice;
|
2
|
+
var hasProp = {}.hasOwnProperty;
|
3
|
+
|
4
|
+
if (this.Utils == null) {
|
5
|
+
this.Utils = {
|
6
|
+
modules: []
|
7
|
+
};
|
8
|
+
}
|
9
|
+
|
10
|
+
var addClass = function(element, name) {
|
11
|
+
removeClass(element, name);
|
12
|
+
return element.className += " " + name + " ";
|
13
|
+
};
|
14
|
+
|
15
|
+
var removeClass = function(element, name) {
|
16
|
+
var regExp = new RegExp("(\\s|^)" + name + "(\\s|$)", "gi");
|
17
|
+
return element.className = element.className.replace(regExp, "");
|
18
|
+
};
|
19
|
+
|
20
|
+
var hasClass = function(element, name) {
|
21
|
+
return new RegExp("(^| )" + name + "( |$)", "gi").test(element.className);
|
22
|
+
};
|
23
|
+
|
24
|
+
var merge = function() {
|
25
|
+
var extension;
|
26
|
+
var i;
|
27
|
+
var len;
|
28
|
+
var property;
|
29
|
+
var target = arguments[0];
|
30
|
+
var extensions = 2 <= arguments.length ? slice.call(arguments, 1) : [];
|
31
|
+
|
32
|
+
for (i = 0, len = extensions.length; i < len; i++) {
|
33
|
+
extension = extensions[i];
|
34
|
+
for (property in extension) {
|
35
|
+
if (!hasProp.call(extension, property)) continue;
|
36
|
+
target[property] = extension[property];
|
37
|
+
}
|
38
|
+
}
|
39
|
+
|
40
|
+
return target;
|
41
|
+
};
|
42
|
+
|
43
|
+
var setOptions = function(options, defaults) {
|
44
|
+
return merge({}, defaults, options);
|
45
|
+
};
|
46
|
+
|
47
|
+
var deleteUndefined = function(obj) {
|
48
|
+
var key;
|
49
|
+
var value;
|
50
|
+
var results = [];
|
51
|
+
for (key in obj) {
|
52
|
+
value = obj[key];
|
53
|
+
if (value === null || value === void 0) {
|
54
|
+
results.push(delete obj[key]);
|
55
|
+
} else {
|
56
|
+
results.push(void 0);
|
57
|
+
}
|
58
|
+
}
|
59
|
+
|
60
|
+
return results;
|
61
|
+
};
|
62
|
+
|
63
|
+
var transformKey = (function() {
|
64
|
+
var i;
|
65
|
+
var key;
|
66
|
+
var len;
|
67
|
+
var el = document.createElement("div");
|
68
|
+
var transforms = ["transform", "webkitTransform", "OTransform", "MozTransform", "msTransform"];
|
69
|
+
for (i = 0, len = transforms.length; i < len; i++) {
|
70
|
+
key = transforms[i];
|
71
|
+
if (el.style[key] !== void 0) {
|
72
|
+
return key;
|
73
|
+
}
|
74
|
+
}
|
75
|
+
})();
|
76
|
+
|
77
|
+
var requestAnimationFrame = (function(window) {
|
78
|
+
var i;
|
79
|
+
var len;
|
80
|
+
var vendor;
|
81
|
+
var ref = ["ms", "moz", "webkit", "o"];
|
82
|
+
|
83
|
+
for (i = 0, len = ref.length; i < len; i++) {
|
84
|
+
vendor = ref[i];
|
85
|
+
if (window.requestAnimationFrame) {
|
86
|
+
break;
|
87
|
+
}
|
88
|
+
|
89
|
+
window.requestAnimationFrame = window[vendor + "RequestAnimationFrame"];
|
90
|
+
}
|
91
|
+
|
92
|
+
return window.requestAnimationFrame || (window.requestAnimationFrame = function(callback) {
|
93
|
+
return setTimeout(callback, 1000 / 60);
|
94
|
+
});
|
95
|
+
})(window);
|
96
|
+
|
97
|
+
var forEach = function (array, callback, scope) {
|
98
|
+
for (var i = array.length - 1; i >= 0; i--) {
|
99
|
+
callback.call(scope, i, array[i]);
|
100
|
+
}
|
101
|
+
};
|
102
|
+
|
103
|
+
this.Utils = {
|
104
|
+
addClass: addClass,
|
105
|
+
removeClass: removeClass,
|
106
|
+
hasClass: hasClass,
|
107
|
+
merge: merge,
|
108
|
+
setOptions: setOptions,
|
109
|
+
deleteUndefined: deleteUndefined,
|
110
|
+
transformKey: transformKey,
|
111
|
+
requestAnimationFrame: requestAnimationFrame,
|
112
|
+
forEach: forEach
|
113
|
+
};
|
@@ -0,0 +1 @@
|
|
1
|
+
@import "ustyle/content";
|
@@ -0,0 +1 @@
|
|
1
|
+
@import "ustyle/all";
|
@@ -0,0 +1,55 @@
|
|
1
|
+
// Global import
|
2
|
+
@import "ustyle/global";
|
3
|
+
|
4
|
+
// Basics
|
5
|
+
@import "ustyle/basics/typography";
|
6
|
+
|
7
|
+
// uSwitch grid
|
8
|
+
@import "ustyle/basics/grid";
|
9
|
+
|
10
|
+
// Forms
|
11
|
+
@import "ustyle/forms/base";
|
12
|
+
|
13
|
+
// Tables
|
14
|
+
@import "ustyle/tables/base";
|
15
|
+
|
16
|
+
// Icons
|
17
|
+
@import "ustyle/icons/base";
|
18
|
+
|
19
|
+
// Components
|
20
|
+
@import "ustyle/components/links";
|
21
|
+
@import "ustyle/components/lists";
|
22
|
+
@import "ustyle/components/lists-li";
|
23
|
+
@import "ustyle/components/button";
|
24
|
+
@import "ustyle/components/hero";
|
25
|
+
@import "ustyle/components/content-group";
|
26
|
+
@import "ustyle/components/tabs";
|
27
|
+
@import "ustyle/components/loader";
|
28
|
+
@import "ustyle/components/breadcrumbs";
|
29
|
+
@import "ustyle/components/cta";
|
30
|
+
@import "ustyle/components/overlay";
|
31
|
+
@import "ustyle/components/tooltip";
|
32
|
+
@import "ustyle/components/usp";
|
33
|
+
@import "ustyle/components/progress";
|
34
|
+
@import "ustyle/components/backdrop";
|
35
|
+
@import "ustyle/components/reminder";
|
36
|
+
@import "ustyle/components/tab-navigation";
|
37
|
+
@import "ustyle/components/table-toolbar";
|
38
|
+
@import "ustyle/components/compliance-banner";
|
39
|
+
@import "ustyle/components/promo-banner";
|
40
|
+
@import "ustyle/components/comp-table-row";
|
41
|
+
@import "ustyle/components/calculator";
|
42
|
+
|
43
|
+
// Articles
|
44
|
+
@import "ustyle/articles/base";
|
45
|
+
@import "ustyle/articles/news";
|
46
|
+
@import "ustyle/articles/guide";
|
47
|
+
@import "ustyle/articles/more";
|
48
|
+
@import "ustyle/articles/related";
|
49
|
+
|
50
|
+
// Utilities
|
51
|
+
@import "ustyle/utilities/general";
|
52
|
+
@import "ustyle/utilities/spacing";
|
53
|
+
@import "ustyle/utilities/images";
|
54
|
+
@import "ustyle/utilities/grid";
|
55
|
+
@import "ustyle/utilities/responsive";
|
@@ -0,0 +1,20 @@
|
|
1
|
+
// scss-lint:disable Comment
|
2
|
+
/*! uStyle version #{ustyle-version()}. Copyright uSwitch limited, all rights reserved. */
|
3
|
+
|
4
|
+
//
|
5
|
+
// This is the shared global file that includes uStyle's core helpers
|
6
|
+
//
|
7
|
+
|
8
|
+
// Reset
|
9
|
+
@import "ustyle/vendor/normalize";
|
10
|
+
|
11
|
+
// Basics
|
12
|
+
@import "ustyle/basics/functions";
|
13
|
+
@import "ustyle/basics/variables";
|
14
|
+
|
15
|
+
// All mixins
|
16
|
+
@import "ustyle/mixins/base";
|
17
|
+
|
18
|
+
// Basic extends
|
19
|
+
@import "ustyle/basics/fonts";
|
20
|
+
@import "ustyle/basics/extends";
|
@@ -0,0 +1,100 @@
|
|
1
|
+
// @page Pattern Library/Articles
|
2
|
+
// @name Base article
|
3
|
+
//
|
4
|
+
// @description
|
5
|
+
// Article listings for news are important on the landing pages.
|
6
|
+
//
|
7
|
+
// @markup
|
8
|
+
// <article class='us-article'>
|
9
|
+
// <a class='us-article__link' href="#">
|
10
|
+
// <div class='us-grid-row'>
|
11
|
+
// <div class='us-col-md-8'>
|
12
|
+
// <h3 class='us-article__title'>Car insurance guides</h3>
|
13
|
+
// <p class='us-article__description'>
|
14
|
+
// A quarter of 18-34 year olds believe that tech companies could offer better financial services than banks
|
15
|
+
// </p>
|
16
|
+
// <div class="us-article__meta">
|
17
|
+
// <span class="date">2 months ago</span>
|
18
|
+
// in
|
19
|
+
// <span class="category">Banking</span>
|
20
|
+
// </div>
|
21
|
+
// </div>
|
22
|
+
// <div class='us-col-md-4 us-tablet--block'>
|
23
|
+
// <img class='us-img--full us-article__image' src='https://assets0.uswitch.com/s3/uswitch-wp-cms-assets/money/guides/wp-content/uploads/2014/11/DB2011AU01018_SMALL.jpg' />
|
24
|
+
// </div>
|
25
|
+
// </a>
|
26
|
+
// </div>
|
27
|
+
// </article>
|
28
|
+
|
29
|
+
$article-border-color: $c-grey !default;
|
30
|
+
$article-padding: $gutter-width !default;
|
31
|
+
$article-description-color: $c-dark-grey !default;
|
32
|
+
|
33
|
+
.us-article {
|
34
|
+
position: relative;
|
35
|
+
padding: $article-padding*.75;
|
36
|
+
border: 1px solid $article-border-color;
|
37
|
+
|
38
|
+
@include respond-to(desktop, true) {
|
39
|
+
padding: $article-padding/2 $article-padding;
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
.us-article__link {
|
44
|
+
display: block;
|
45
|
+
-webkit-tap-highlight-color: rgba(0,0,0,0);
|
46
|
+
text-decoration: none;
|
47
|
+
|
48
|
+
&:hover {
|
49
|
+
.us-article__title {
|
50
|
+
text-decoration: underline;
|
51
|
+
}
|
52
|
+
}
|
53
|
+
}
|
54
|
+
|
55
|
+
.us-article__link,
|
56
|
+
.us-article__link:hover,
|
57
|
+
.us-article__link:visited {
|
58
|
+
color: inherit;
|
59
|
+
}
|
60
|
+
|
61
|
+
.us-article__title {
|
62
|
+
@include heading(4);
|
63
|
+
|
64
|
+
@include respond-to(tablet, true) {
|
65
|
+
@include heading(3, $extend: false);
|
66
|
+
}
|
67
|
+
|
68
|
+
@include respond-to(desktop, true) {
|
69
|
+
padding-top: $article-padding*.25;
|
70
|
+
}
|
71
|
+
}
|
72
|
+
|
73
|
+
.us-article__meta {
|
74
|
+
color: $c-uswitch-navy;
|
75
|
+
font-size: .875em;
|
76
|
+
position: absolute;
|
77
|
+
bottom: $article-padding*.75;
|
78
|
+
|
79
|
+
@include respond-to(desktop, true) {
|
80
|
+
bottom: $article-padding;
|
81
|
+
}
|
82
|
+
}
|
83
|
+
|
84
|
+
.us-article__description {
|
85
|
+
color: $article-description-color;
|
86
|
+
margin-bottom: 1em;
|
87
|
+
padding-bottom: 2em;
|
88
|
+
|
89
|
+
@include respond-to(tablet, true) {
|
90
|
+
font-size: 1.125em;
|
91
|
+
}
|
92
|
+
}
|
93
|
+
|
94
|
+
.us-article__image {
|
95
|
+
display: none;
|
96
|
+
|
97
|
+
@include respond-to(desktop, true) {
|
98
|
+
display: block;
|
99
|
+
}
|
100
|
+
}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
// @page Pattern Library/Articles
|
2
|
+
// @name Guide article
|
3
|
+
//
|
4
|
+
// @description
|
5
|
+
// Our guide and news articles are used across the site to communicate news/guide snippets. The layout is decided by our grid, by default they have 100% width.
|
6
|
+
//
|
7
|
+
// @markup
|
8
|
+
// <div class='us-article-group'>
|
9
|
+
// <div class='us-guide-item us-col-md-4'>
|
10
|
+
// <a class='us-guide-item-link' href='#'>
|
11
|
+
// <div class='us-guide-item-image-container'>
|
12
|
+
// <div class='us-guide-item-image background' style='background-image: url(https://assets0.uswitch.com/s3/uswitch-wp-cms-assets/money/guides/wp-content/uploads/2014/11/DB2011AU01018_SMALL.jpg)'></div>
|
13
|
+
// </div>
|
14
|
+
// <div class='us-guide-item-content'>
|
15
|
+
// <h4 class='us-guide-item-title'>Car insurance guides</h4>
|
16
|
+
// <p class='us-guide-item-description'>Read our car insurance advice guides for the facts on why you need car insurance, the types of cover available, and tips on how to make a claim.</p>
|
17
|
+
// </div>
|
18
|
+
// <div class='us-guide-item-readmore'>
|
19
|
+
// <span class='us-news-item-readmorelink'>Read more</span>
|
20
|
+
// </div>
|
21
|
+
// </a>
|
22
|
+
// </div>
|
23
|
+
// </div>
|
24
|
+
|
25
|
+
$guide-item-image-size: 128px !default;
|
26
|
+
|
27
|
+
.us-guide-item {
|
28
|
+
@extend %base-item;
|
29
|
+
}
|
30
|
+
|
31
|
+
.us-guide-item-link {
|
32
|
+
@extend %base-item-link;
|
33
|
+
}
|
34
|
+
|
35
|
+
.us-guide-item-title {
|
36
|
+
@extend %base-item-title;
|
37
|
+
}
|
38
|
+
|
39
|
+
.us-guide-item-description {
|
40
|
+
@extend %base-item-description;
|
41
|
+
}
|
42
|
+
|
43
|
+
.us-guide-item-image-container {
|
44
|
+
@extend %base-item-image-container;
|
45
|
+
}
|
46
|
+
|
47
|
+
.us-guide-item-image {
|
48
|
+
@extend %base-item-image;
|
49
|
+
}
|
50
|
+
|
51
|
+
.us-guide-item-readmore {
|
52
|
+
@extend %readmore;
|
53
|
+
}
|
54
|
+
|
55
|
+
.us-guide-item-readmorelink {
|
56
|
+
@extend %readmore-link;
|
57
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
// @page Pattern Library/Articles
|
2
|
+
// @name More article
|
3
|
+
//
|
4
|
+
// @description
|
5
|
+
// If the article listing has more in a category, we use this to let a user navigate to that category.
|
6
|
+
//
|
7
|
+
// @markup
|
8
|
+
// <div class='us-more-item us-col-md-4'>
|
9
|
+
// <a class='us-more-item-link' href='#'>
|
10
|
+
// <span class='us-more-item-title'>See more banking news</span>
|
11
|
+
// </a>
|
12
|
+
// </div>
|
13
|
+
|
14
|
+
.us-more-item {
|
15
|
+
@extend %base-item;
|
16
|
+
}
|
17
|
+
|
18
|
+
.us-more-item-link {
|
19
|
+
@extend %base-item-link;
|
20
|
+
}
|
21
|
+
|
22
|
+
.us-more-item-title {
|
23
|
+
@extend %heading-1;
|
24
|
+
display: block;
|
25
|
+
padding: $item-padding;
|
26
|
+
color: $c-typecyan;
|
27
|
+
|
28
|
+
&.small {
|
29
|
+
@extend %heading-3;
|
30
|
+
}
|
31
|
+
}
|