diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 28f2bed580..bf3233da3b 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -4,11 +4,11 @@ on: [push, pull_request] jobs: build_latest_browserstack: - name: Node 14 with browserstack + name: Node Latest with browserstack runs-on: ubuntu-latest strategy: matrix: - node: ['14'] # latest (16+) not functional + node: ['20'] steps: - uses: actions/checkout@v1 - name: install system dependencies @@ -24,11 +24,11 @@ jobs: run: yarn test:javascript:browserstack build_latest: - name: Node 14 + name: Node Latest runs-on: ubuntu-latest strategy: matrix: - node: ['14'] # latest (16+) not functional + node: ['20'] # latest (16+) not functional steps: - uses: actions/checkout@v1 - name: install system dependencies @@ -44,7 +44,7 @@ jobs: strategy: matrix: platform: [ubuntu-latest, macos-latest, windows-latest] - node: [ '12', '14' ] + node: [ '16', '18' ] name: Node ${{ matrix.node }} (${{ matrix.platform }}) runs-on: ${{ matrix.platform }} steps: diff --git a/.husky/commit-msg b/.husky/commit-msg new file mode 100755 index 0000000000..89259dd91c --- /dev/null +++ b/.husky/commit-msg @@ -0,0 +1,4 @@ +#!/usr/bin/env sh +. "$(dirname -- "$0")/_/husky.sh" + +# node .husky/husky-commit-lint.js --color -e $1 diff --git a/script/husky-commit-lint.js b/.husky/husky-commit-lint.js similarity index 100% rename from script/husky-commit-lint.js rename to .husky/husky-commit-lint.js diff --git a/script/husky-commit-test.js b/.husky/husky-commit-test.js similarity index 100% rename from script/husky-commit-test.js rename to .husky/husky-commit-test.js diff --git a/script/husky-push-test.js b/.husky/husky-push-test.js similarity index 100% rename from script/husky-push-test.js rename to .husky/husky-push-test.js diff --git a/.husky/pre-push b/.husky/pre-push new file mode 100755 index 0000000000..12ae636a01 --- /dev/null +++ b/.husky/pre-push @@ -0,0 +1,6 @@ +#!/usr/bin/env sh +. "$(dirname -- "$0")/_/husky.sh" + +# node "$(dirname -- "$0")/husky-push-test.js --color + +yarn test \ No newline at end of file diff --git a/.huskyrc.yml b/.huskyrc.yml deleted file mode 100644 index cf0a820c16..0000000000 --- a/.huskyrc.yml +++ /dev/null @@ -1,5 +0,0 @@ -hooks: - commit-msg: > - node ./script/husky-commit-lint.js --color -e $GIT_PARAMS - pre-push: - node ./script/husky-push-test.js --color diff --git a/bower.json b/bower.json index 74309eceb2..165b7bbb9b 100644 --- a/bower.json +++ b/bower.json @@ -1,6 +1,6 @@ { "name": "foundation-sites", - "version": "6.7.5", + "version": "6.8.0", "description": "The most advanced responsive front-end framework in the world.", "homepage": "https://get.foundation/sites", "license": "MIT", diff --git a/dist/css/foundation-float.css b/dist/css/foundation-float.css index 6073316863..0c783ab5eb 100644 --- a/dist/css/foundation-float.css +++ b/dist/css/foundation-float.css @@ -1,74 +1,89 @@ @charset "UTF-8"; /** * Foundation for Sites - * Version 6.7.5 + * Version 6.8.0 * https://get.foundation * Licensed under MIT Open Source */ @media print, screen and (min-width: 40em) { - .reveal, .reveal.tiny, .reveal.small, .reveal.large { + .reveal.large, .reveal.small, .reveal.tiny, .reveal { right: auto; left: auto; - margin: 0 auto; } } - + margin: 0 auto; + } +} /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */ html { line-height: 1.15; - -webkit-text-size-adjust: 100%; } + -webkit-text-size-adjust: 100%; +} body { - margin: 0; } + margin: 0; +} h1 { font-size: 2em; - margin: 0.67em 0; } + margin: 0.67em 0; +} hr { -webkit-box-sizing: content-box; box-sizing: content-box; height: 0; - overflow: visible; } + overflow: visible; +} pre { font-family: monospace, monospace; - font-size: 1em; } + font-size: 1em; +} a { - background-color: transparent; } + background-color: transparent; +} abbr[title] { border-bottom: 0; -webkit-text-decoration: underline dotted; - text-decoration: underline dotted; } + text-decoration: underline dotted; +} b, strong { - font-weight: bolder; } + font-weight: bolder; +} code, kbd, samp { font-family: monospace, monospace; - font-size: 1em; } + font-size: 1em; +} small { - font-size: 80%; } + font-size: 80%; +} sub, sup { font-size: 75%; line-height: 0; position: relative; - vertical-align: baseline; } + vertical-align: baseline; +} sub { - bottom: -0.25em; } + bottom: -0.25em; +} sup { - top: -0.5em; } + top: -0.5em; +} img { - border-style: none; } + border-style: none; +} button, input, @@ -78,37 +93,44 @@ textarea { font-family: inherit; font-size: 100%; line-height: 1.15; - margin: 0; } + margin: 0; +} button, input { - overflow: visible; } + overflow: visible; +} button, select { - text-transform: none; } + text-transform: none; +} button, -[type="button"], -[type="reset"], -[type="submit"] { - -webkit-appearance: button; } +[type=button], +[type=reset], +[type=submit] { + -webkit-appearance: button; +} button::-moz-focus-inner, -[type="button"]::-moz-focus-inner, -[type="reset"]::-moz-focus-inner, -[type="submit"]::-moz-focus-inner { +[type=button]::-moz-focus-inner, +[type=reset]::-moz-focus-inner, +[type=submit]::-moz-focus-inner { border-style: none; - padding: 0; } + padding: 0; +} button:-moz-focusring, -[type="button"]:-moz-focusring, -[type="reset"]:-moz-focusring, -[type="submit"]:-moz-focusring { - outline: 1px dotted ButtonText; } +[type=button]:-moz-focusring, +[type=reset]:-moz-focusring, +[type=submit]:-moz-focusring { + outline: 1px dotted ButtonText; +} fieldset { - padding: 0.35em 0.75em 0.625em; } + padding: 0.35em 0.75em 0.625em; +} legend { -webkit-box-sizing: border-box; @@ -117,73 +139,90 @@ legend { display: table; max-width: 100%; padding: 0; - white-space: normal; } + white-space: normal; +} progress { - vertical-align: baseline; } + vertical-align: baseline; +} textarea { - overflow: auto; } + overflow: auto; +} -[type="checkbox"], -[type="radio"] { +[type=checkbox], +[type=radio] { -webkit-box-sizing: border-box; box-sizing: border-box; - padding: 0; } + padding: 0; +} -[type="number"]::-webkit-inner-spin-button, -[type="number"]::-webkit-outer-spin-button { - height: auto; } +[type=number]::-webkit-inner-spin-button, +[type=number]::-webkit-outer-spin-button { + height: auto; +} -[type="search"] { +[type=search] { -webkit-appearance: textfield; - outline-offset: -2px; } + outline-offset: -2px; +} -[type="search"]::-webkit-search-decoration { - -webkit-appearance: none; } +[type=search]::-webkit-search-decoration { + -webkit-appearance: none; +} ::-webkit-file-upload-button { -webkit-appearance: button; - font: inherit; } + font: inherit; +} details { - display: block; } + display: block; +} summary { - display: list-item; } + display: list-item; +} template { - display: none; } + display: none; +} [hidden] { - display: none; } - -[data-whatintent="mouse"] *, [data-whatintent="mouse"] *:focus, -[data-whatintent="touch"] *, -[data-whatintent="touch"] *:focus, -[data-whatinput="mouse"] *, -[data-whatinput="mouse"] *:focus, -[data-whatinput="touch"] *, -[data-whatinput="touch"] *:focus { - outline: none; } + display: none; +} + +[data-whatintent=mouse] *, [data-whatintent=mouse] *:focus, +[data-whatintent=touch] *, +[data-whatintent=touch] *:focus, +[data-whatinput=mouse] *, +[data-whatinput=mouse] *:focus, +[data-whatinput=touch] *, +[data-whatinput=touch] *:focus { + outline: none; +} [draggable=false] { -webkit-touch-callout: none; - -webkit-user-select: none; } + -webkit-user-select: none; +} .foundation-mq { - font-family: "small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"; } + font-family: "small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"; +} html { -webkit-box-sizing: border-box; box-sizing: border-box; - font-size: 100%; } + font-size: 100%; +} *, *::before, *::after { -webkit-box-sizing: inherit; - box-sizing: inherit; } + box-sizing: inherit; +} body { margin: 0; @@ -194,25 +233,29 @@ body { line-height: 1.5; color: #0a0a0a; -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; } + -moz-osx-font-smoothing: grayscale; +} img { display: inline-block; vertical-align: middle; max-width: 100%; height: auto; - -ms-interpolation-mode: bicubic; } + -ms-interpolation-mode: bicubic; +} textarea { height: auto; min-height: 50px; - border-radius: 0; } + border-radius: 0; +} select { -webkit-box-sizing: border-box; box-sizing: border-box; width: 100%; - border-radius: 0; } + border-radius: 0; +} .map_canvas img, .map_canvas embed, @@ -220,7 +263,8 @@ select { .mqa-display img, .mqa-display embed, .mqa-display object { - max-width: none !important; } + max-width: none !important; +} button { padding: 0; @@ -231,28 +275,34 @@ button { border-radius: 0; background: transparent; line-height: 1; - cursor: auto; } - [data-whatinput='mouse'] button { - outline: 0; } + cursor: auto; +} +[data-whatinput=mouse] button { + outline: 0; +} pre { overflow: auto; - -webkit-overflow-scrolling: touch; } + -webkit-overflow-scrolling: touch; +} button, input, optgroup, select, textarea { - font-family: inherit; } + font-family: inherit; +} .is-visible { - display: block !important; } + display: block !important; +} .is-hidden { - display: none !important; } + display: none !important; +} -[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'], +[type=text], [type=password], [type=date], [type=datetime], [type=datetime-local], [type=month], [type=week], [type=email], [type=number], [type=search], [type=tel], [type=time], [type=url], [type=color], textarea { display: block; -webkit-box-sizing: border-box; @@ -277,78 +327,95 @@ textarea { transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; -webkit-appearance: none; -moz-appearance: none; - appearance: none; } - [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus, - textarea:focus { - outline: none; - border: 1px solid #8a8a8a; - background-color: #fefefe; - -webkit-box-shadow: 0 0 5px #cacaca; - box-shadow: 0 0 5px #cacaca; - -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; - transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; - transition: box-shadow 0.5s, border-color 0.25s ease-in-out; - transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; } + appearance: none; +} +[type=text]:focus, [type=password]:focus, [type=date]:focus, [type=datetime]:focus, [type=datetime-local]:focus, [type=month]:focus, [type=week]:focus, [type=email]:focus, [type=number]:focus, [type=search]:focus, [type=tel]:focus, [type=time]:focus, [type=url]:focus, [type=color]:focus, +textarea:focus { + outline: none; + border: 1px solid #8a8a8a; + background-color: #fefefe; + -webkit-box-shadow: 0 0 5px #cacaca; + box-shadow: 0 0 5px #cacaca; + -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; +} textarea { - max-width: 100%; } - textarea[rows] { - height: auto; } + max-width: 100%; +} +textarea[rows] { + height: auto; +} input:disabled, input[readonly], textarea:disabled, textarea[readonly] { background-color: #e6e6e6; - cursor: not-allowed; } + cursor: not-allowed; +} -[type='submit'], -[type='button'] { +[type=submit], +[type=button] { -webkit-appearance: none; -moz-appearance: none; appearance: none; - border-radius: 0; } + border-radius: 0; +} -input[type='search'] { +input[type=search] { -webkit-box-sizing: border-box; - box-sizing: border-box; } + box-sizing: border-box; +} ::-webkit-input-placeholder { - color: #cacaca; } + color: #cacaca; +} ::-moz-placeholder { - color: #cacaca; } + color: #cacaca; +} :-ms-input-placeholder { - color: #cacaca; } + color: #cacaca; +} ::-ms-input-placeholder { - color: #cacaca; } + color: #cacaca; +} ::placeholder { - color: #cacaca; } + color: #cacaca; +} -[type='file'], -[type='checkbox'], -[type='radio'] { - margin: 0 0 1rem; } +[type=file], +[type=checkbox], +[type=radio] { + margin: 0 0 1rem; +} -[type='checkbox'] + label, -[type='radio'] + label { +[type=checkbox] + label, +[type=radio] + label { display: inline-block; vertical-align: baseline; margin-left: 0.5rem; margin-right: 1rem; - margin-bottom: 0; } - [type='checkbox'] + label[for], - [type='radio'] + label[for] { - cursor: pointer; } + margin-bottom: 0; +} +[type=checkbox] + label[for], +[type=radio] + label[for] { + cursor: pointer; +} -label > [type='checkbox'], -label > [type='radio'] { - margin-right: 0.5rem; } +label > [type=checkbox], +label > [type=radio] { + margin-right: 0.5rem; +} -[type='file'] { - width: 100%; } +[type=file] { + width: 100%; +} label { display: block; @@ -356,35 +423,42 @@ label { font-size: 0.875rem; font-weight: normal; line-height: 1.8; - color: #0a0a0a; } - label.middle { - margin: 0 0 1rem; - line-height: 1.5; - padding: 0.5625rem 0; } + color: #0a0a0a; +} +label.middle { + margin: 0 0 1rem; + line-height: 1.5; + padding: 0.5625rem 0; +} .help-text { margin-top: -0.5rem; font-size: 0.8125rem; font-style: italic; - color: #0a0a0a; } + color: #0a0a0a; +} .input-group { display: table; width: 100%; - margin-bottom: 1rem; } - .input-group > :first-child, .input-group > :first-child.input-group-button > * { - border-radius: 0 0 0 0; } - .input-group > :last-child, .input-group > :last-child.input-group-button > * { - border-radius: 0 0 0 0; } - -.input-group-label, .input-group-field, .input-group-button, .input-group-button a, + margin-bottom: 1rem; +} +.input-group > :first-child, .input-group > :first-child.input-group-button > * { + border-radius: 0 0 0 0; +} +.input-group > :last-child, .input-group > :last-child.input-group-button > * { + border-radius: 0 0 0 0; +} + +.input-group-button a, .input-group-button input, .input-group-button button, -.input-group-button label { +.input-group-button label, .input-group-button, .input-group-field, .input-group-label { margin: 0; white-space: nowrap; display: table-cell; - vertical-align: middle; } + vertical-align: middle; +} .input-group-label { padding: 0 1rem; @@ -394,50 +468,61 @@ label { text-align: center; white-space: nowrap; width: 1%; - height: 100%; } - .input-group-label:first-child { - border-right: 0; } - .input-group-label:last-child { - border-left: 0; } + height: 100%; +} +.input-group-label:first-child { + border-right: 0; +} +.input-group-label:last-child { + border-left: 0; +} .input-group-field { - border-radius: 0; } + border-radius: 0; +} .input-group-button { padding-top: 0; padding-bottom: 0; text-align: center; width: 1%; - height: 100%; } - .input-group-button a, - .input-group-button input, - .input-group-button button, - .input-group-button label { - height: 2.4375rem; - padding-top: 0; - padding-bottom: 0; - font-size: 1rem; } + height: 100%; +} +.input-group-button a, +.input-group-button input, +.input-group-button button, +.input-group-button label { + height: 2.4375rem; + padding-top: 0; + padding-bottom: 0; + font-size: 1rem; +} .input-group .input-group-button { - display: table-cell; } + display: table-cell; +} fieldset { margin: 0; padding: 0; - border: 0; } + border: 0; +} legend { max-width: 100%; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} .fieldset { margin: 1.125rem 0; padding: 1.25rem; - border: 1px solid #cacaca; } - .fieldset legend { - margin: 0; - margin-left: -0.1875rem; - padding: 0 0.1875rem; } + border: 1px solid #cacaca; +} +.fieldset legend { + margin: 0; + margin-left: -0.1875rem; + padding: 0 0.1875rem; +} select { height: 2.4375rem; @@ -463,48 +548,63 @@ select { -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; transition: box-shadow 0.5s, border-color 0.25s ease-in-out; - transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; } - @media screen and (min-width: 0\0) { - select { - background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } } - select:focus { - outline: none; - border: 1px solid #8a8a8a; - background-color: #fefefe; - -webkit-box-shadow: 0 0 5px #cacaca; - box-shadow: 0 0 5px #cacaca; - -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; - transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; - transition: box-shadow 0.5s, border-color 0.25s ease-in-out; - transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; } - select:disabled { - background-color: #e6e6e6; - cursor: not-allowed; } - select::-ms-expand { - display: none; } - select[multiple] { - height: auto; - background-image: none; } - select:not([multiple]) { - padding-top: 0; - padding-bottom: 0; } + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; +} +@media screen and (min-width: 0\0 ) { + select { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); + } +} +select:focus { + outline: none; + border: 1px solid #8a8a8a; + background-color: #fefefe; + -webkit-box-shadow: 0 0 5px #cacaca; + box-shadow: 0 0 5px #cacaca; + -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; +} +select:disabled { + background-color: #e6e6e6; + cursor: not-allowed; +} +select::-ms-expand { + display: none; +} +select[multiple] { + height: auto; + background-image: none; +} +select:not([multiple]) { + padding-top: 0; + padding-bottom: 0; +} .is-invalid-input:not(:focus) { border-color: #cc4b37; - background-color: #f9ecea; } - .is-invalid-input:not(:focus)::-webkit-input-placeholder { - color: #cc4b37; } - .is-invalid-input:not(:focus)::-moz-placeholder { - color: #cc4b37; } - .is-invalid-input:not(:focus):-ms-input-placeholder { - color: #cc4b37; } - .is-invalid-input:not(:focus)::-ms-input-placeholder { - color: #cc4b37; } - .is-invalid-input:not(:focus)::placeholder { - color: #cc4b37; } + background-color: #f9ecea; +} +.is-invalid-input:not(:focus)::-webkit-input-placeholder { + color: #cc4b37; +} +.is-invalid-input:not(:focus)::-moz-placeholder { + color: #cc4b37; +} +.is-invalid-input:not(:focus):-ms-input-placeholder { + color: #cc4b37; +} +.is-invalid-input:not(:focus)::-ms-input-placeholder { + color: #cc4b37; +} +.is-invalid-input:not(:focus)::placeholder { + color: #cc4b37; +} .is-invalid-label { - color: #cc4b37; } + color: #cc4b37; +} .form-error { display: none; @@ -512,9 +612,11 @@ select { margin-bottom: 1rem; font-size: 0.75rem; font-weight: bold; - color: #cc4b37; } - .form-error.is-visible { - display: block; } + color: #cc4b37; +} +.form-error.is-visible { + display: block; +} div, dl, @@ -536,27 +638,32 @@ blockquote, th, td { margin: 0; - padding: 0; } + padding: 0; +} p { margin-bottom: 1rem; font-size: inherit; line-height: 1.6; - text-rendering: optimizeLegibility; } + text-rendering: optimizeLegibility; +} em, i { font-style: italic; - line-height: inherit; } + line-height: inherit; +} strong, b { font-weight: bold; - line-height: inherit; } + line-height: inherit; +} small { font-size: 80%; - line-height: inherit; } + line-height: inherit; +} h1, .h1, h2, .h2, @@ -568,75 +675,92 @@ h6, .h6 { font-style: normal; font-weight: normal; color: inherit; - text-rendering: optimizeLegibility; } - h1 small, .h1 small, - h2 small, .h2 small, - h3 small, .h3 small, - h4 small, .h4 small, - h5 small, .h5 small, - h6 small, .h6 small { - line-height: 0; - color: #cacaca; } + text-rendering: optimizeLegibility; +} +h1 small, .h1 small, +h2 small, .h2 small, +h3 small, .h3 small, +h4 small, .h4 small, +h5 small, .h5 small, +h6 small, .h6 small { + line-height: 0; + color: #cacaca; +} h1, .h1 { font-size: 1.5rem; line-height: 1.4; margin-top: 0; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} h2, .h2 { font-size: 1.25rem; line-height: 1.4; margin-top: 0; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} h3, .h3 { font-size: 1.1875rem; line-height: 1.4; margin-top: 0; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} h4, .h4 { font-size: 1.125rem; line-height: 1.4; margin-top: 0; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} h5, .h5 { font-size: 1.0625rem; line-height: 1.4; margin-top: 0; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} h6, .h6 { font-size: 1rem; line-height: 1.4; margin-top: 0; - margin-bottom: 0.5rem; } + margin-bottom: 0.5rem; +} @media print, screen and (min-width: 40em) { h1, .h1 { - font-size: 3rem; } + font-size: 3rem; + } h2, .h2 { - font-size: 2.5rem; } + font-size: 2.5rem; + } h3, .h3 { - font-size: 1.9375rem; } + font-size: 1.9375rem; + } h4, .h4 { - font-size: 1.5625rem; } + font-size: 1.5625rem; + } h5, .h5 { - font-size: 1.25rem; } + font-size: 1.25rem; + } h6, .h6 { - font-size: 1rem; } } - + font-size: 1rem; + } +} a { line-height: inherit; color: #1779ba; text-decoration: none; - cursor: pointer; } - a:hover, a:focus { - color: #1468a0; } - a img { - border: 0; } + cursor: pointer; +} +a:hover, a:focus { + color: #1468a0; +} +a img { + border: 0; +} hr { clear: both; @@ -646,87 +770,107 @@ hr { border-top: 0; border-right: 0; border-bottom: 1px solid #cacaca; - border-left: 0; } + border-left: 0; +} ul, ol, dl { margin-bottom: 1rem; list-style-position: outside; - line-height: 1.6; } + line-height: 1.6; +} li { - font-size: inherit; } + font-size: inherit; +} ul { margin-left: 1.25rem; - list-style-type: disc; } + list-style-type: disc; +} ol { - margin-left: 1.25rem; } + margin-left: 1.25rem; +} -ul ul, ol ul, ul ol, ol ol { +ul ul, ul ol, ol ul, ol ol { margin-left: 1.25rem; - margin-bottom: 0; } + margin-bottom: 0; +} dl { - margin-bottom: 1rem; } - dl dt { - margin-bottom: 0.3rem; - font-weight: bold; } + margin-bottom: 1rem; +} +dl dt { + margin-bottom: 0.3rem; + font-weight: bold; +} blockquote { margin: 0 0 1rem; padding: 0.5625rem 1.25rem 0 1.1875rem; - border-left: 1px solid #cacaca; } - blockquote, blockquote p { - line-height: 1.6; - color: #8a8a8a; } + border-left: 1px solid #cacaca; +} +blockquote, blockquote p { + line-height: 1.6; + color: #8a8a8a; +} abbr, abbr[title] { border-bottom: 1px dotted #0a0a0a; cursor: help; - text-decoration: none; } + text-decoration: none; +} figure { - margin: 0; } + margin: 0; +} kbd { margin: 0; padding: 0.125rem 0.25rem 0; background-color: #e6e6e6; font-family: Consolas, "Liberation Mono", Courier, monospace; - color: #0a0a0a; } + color: #0a0a0a; +} .subheader { margin-top: 0.2rem; margin-bottom: 0.5rem; font-weight: normal; line-height: 1.4; - color: #8a8a8a; } + color: #8a8a8a; +} .lead { font-size: 125%; - line-height: 1.6; } + line-height: 1.6; +} .stat { font-size: 2.5rem; - line-height: 1; } - p + .stat { - margin-top: -1rem; } + line-height: 1; +} +p + .stat { + margin-top: -1rem; +} ul.no-bullet, ol.no-bullet { margin-left: 0; - list-style: none; } + list-style: none; +} -cite, .cite-block { +.cite-block, cite { display: block; color: #8a8a8a; - font-size: 0.8125rem; } - cite:before, .cite-block:before { - content: "— "; } + font-size: 0.8125rem; +} +.cite-block:before, cite:before { + content: "— "; +} -code, .code-inline { +.code-inline, code { border: 1px solid #cacaca; background-color: #e6e6e6; font-family: Consolas, "Liberation Mono", Courier, monospace; @@ -735,7 +879,8 @@ code, .code-inline { display: inline; max-width: 100%; word-wrap: break-word; - padding: 0.125rem 0.3125rem 0.0625rem; } + padding: 0.125rem 0.3125rem 0.0625rem; +} .code-block { border: 1px solid #cacaca; @@ -747,880 +892,1204 @@ code, .code-inline { overflow: auto; white-space: pre; padding: 1rem; - margin-bottom: 1.5rem; } + margin-bottom: 1.5rem; +} .text-left { - text-align: left; } + text-align: left; +} .text-right { - text-align: right; } + text-align: right; +} .text-center { - text-align: center; } + text-align: center; +} .text-justify { - text-align: justify; } + text-align: justify; +} @media print, screen and (min-width: 40em) { .medium-text-left { - text-align: left; } + text-align: left; + } .medium-text-right { - text-align: right; } + text-align: right; + } .medium-text-center { - text-align: center; } + text-align: center; + } .medium-text-justify { - text-align: justify; } } - + text-align: justify; + } +} @media print, screen and (min-width: 64em) { .large-text-left { - text-align: left; } + text-align: left; + } .large-text-right { - text-align: right; } + text-align: right; + } .large-text-center { - text-align: center; } + text-align: center; + } .large-text-justify { - text-align: justify; } } - + text-align: justify; + } +} .show-for-print { - display: none !important; } + display: none !important; +} @media print { * { background: transparent !important; color: black !important; - print-color-adjust: economy; + -webkit-print-color-adjust: economy; + print-color-adjust: economy; -webkit-box-shadow: none !important; box-shadow: none !important; - text-shadow: none !important; } + text-shadow: none !important; + } .show-for-print { - display: block !important; } + display: block !important; + } .hide-for-print { - display: none !important; } + display: none !important; + } table.show-for-print { - display: table !important; } + display: table !important; + } thead.show-for-print { - display: table-header-group !important; } + display: table-header-group !important; + } tbody.show-for-print { - display: table-row-group !important; } + display: table-row-group !important; + } tr.show-for-print { - display: table-row !important; } + display: table-row !important; + } td.show-for-print { - display: table-cell !important; } + display: table-cell !important; + } th.show-for-print { - display: table-cell !important; } + display: table-cell !important; + } a, a:visited { - text-decoration: underline; } + text-decoration: underline; + } a[href]:after { - content: " (" attr(href) ")"; } + content: " (" attr(href) ")"; + } .ir a:after, - a[href^='javascript:']:after, - a[href^='#']:after { - content: ''; } + a[href^="javascript:"]:after, + a[href^="#"]:after { + content: ""; + } abbr[title]:after { - content: " (" attr(title) ")"; } + content: " (" attr(title) ")"; + } pre, blockquote { border: 1px solid #8a8a8a; - page-break-inside: avoid; } + page-break-inside: avoid; + } thead { - display: table-header-group; } + display: table-header-group; + } tr, img { - page-break-inside: avoid; } + page-break-inside: avoid; + } img { - max-width: 100% !important; } + max-width: 100% !important; + } @page { - margin: 0.5cm; } + margin: 0.5cm; + } p, h2, h3 { orphans: 3; - widows: 3; } + widows: 3; + } h2, h3 { - page-break-after: avoid; } + page-break-after: avoid; + } .print-break-inside { - page-break-inside: auto; } } - + page-break-inside: auto; + } +} .row { max-width: 75rem; margin-right: auto; - margin-left: auto; } - .row::before, .row::after { - display: table; - content: ' '; } - .row::after { - clear: both; } - .row.collapse > .column, .row.collapse > .columns { - padding-right: 0; - padding-left: 0; } + margin-left: auto; +} +.row::before, .row::after { + display: table; + content: " "; +} +.row::after { + clear: both; +} +.row.collapse > .column, .row.collapse > .columns { + padding-right: 0; + padding-left: 0; +} +.row .row { + margin-right: -0.625rem; + margin-left: -0.625rem; +} +@media print, screen and (min-width: 40em) { .row .row { - margin-right: -0.625rem; - margin-left: -0.625rem; } - @media print, screen and (min-width: 40em) { - .row .row { - margin-right: -0.9375rem; - margin-left: -0.9375rem; } } - @media print, screen and (min-width: 64em) { - .row .row { - margin-right: -0.9375rem; - margin-left: -0.9375rem; } } - .row .row.collapse { - margin-right: 0; - margin-left: 0; } - .row.expanded { - max-width: none; } - .row.expanded .row { - margin-right: auto; - margin-left: auto; } - .row:not(.expanded) .row { - max-width: none; } - .row.gutter-small > .column, .row.gutter-small > .columns { - padding-right: 0.625rem; - padding-left: 0.625rem; } - .row.gutter-medium > .column, .row.gutter-medium > .columns { - padding-right: 0.9375rem; - padding-left: 0.9375rem; } + margin-right: -0.9375rem; + margin-left: -0.9375rem; + } +} +@media print, screen and (min-width: 64em) { + .row .row { + margin-right: -0.9375rem; + margin-left: -0.9375rem; + } +} +.row .row.collapse { + margin-right: 0; + margin-left: 0; +} +.row.expanded { + max-width: none; +} +.row.expanded .row { + margin-right: auto; + margin-left: auto; +} +.row:not(.expanded) .row { + max-width: none; +} +.row.gutter-small > .column, .row.gutter-small > .columns { + padding-right: 0.625rem; + padding-left: 0.625rem; +} +.row.gutter-medium > .column, .row.gutter-medium > .columns { + padding-right: 0.9375rem; + padding-left: 0.9375rem; +} .column, .columns { padding-right: 0.625rem; padding-left: 0.625rem; width: 100%; - float: left; } - @media print, screen and (min-width: 40em) { - .column, .columns { - padding-right: 0.9375rem; - padding-left: 0.9375rem; } } - .column, .columns, .column:last-child:not(:first-child), .columns:last-child:not(:first-child) { - float: left; - clear: none; } - .column:last-child:not(:first-child), .columns:last-child:not(:first-child) { - float: right; } - .column.end:last-child:last-child, .end.columns:last-child:last-child { - float: left; } + float: left; +} +@media print, screen and (min-width: 40em) { + .column, .columns { + padding-right: 0.9375rem; + padding-left: 0.9375rem; + } +} +.column, .columns, .column:last-child:not(:first-child) { + float: left; + clear: none; +} +.column:last-child:not(:first-child), .columns:last-child:not(:first-child) { + float: right; +} +.column.end:last-child:last-child, .end.columns:last-child:last-child { + float: left; +} .column.row.row, .row.row.columns { - float: none; } + float: none; +} .row .column.row.row, .row .row.row.columns { margin-right: 0; margin-left: 0; padding-right: 0; - padding-left: 0; } + padding-left: 0; +} .small-1 { - width: 8.33333%; } + width: 8.3333333333%; +} .small-push-1 { position: relative; - left: 8.33333%; } + left: 8.3333333333%; +} .small-pull-1 { position: relative; - left: -8.33333%; } + left: -8.3333333333%; +} .small-offset-0 { - margin-left: 0%; } + margin-left: 0%; +} .small-2 { - width: 16.66667%; } + width: 16.6666666667%; +} .small-push-2 { position: relative; - left: 16.66667%; } + left: 16.6666666667%; +} .small-pull-2 { position: relative; - left: -16.66667%; } + left: -16.6666666667%; +} .small-offset-1 { - margin-left: 8.33333%; } + margin-left: 8.3333333333%; +} .small-3 { - width: 25%; } + width: 25%; +} .small-push-3 { position: relative; - left: 25%; } + left: 25%; +} .small-pull-3 { position: relative; - left: -25%; } + left: -25%; +} .small-offset-2 { - margin-left: 16.66667%; } + margin-left: 16.6666666667%; +} .small-4 { - width: 33.33333%; } + width: 33.3333333333%; +} .small-push-4 { position: relative; - left: 33.33333%; } + left: 33.3333333333%; +} .small-pull-4 { position: relative; - left: -33.33333%; } + left: -33.3333333333%; +} .small-offset-3 { - margin-left: 25%; } + margin-left: 25%; +} .small-5 { - width: 41.66667%; } + width: 41.6666666667%; +} .small-push-5 { position: relative; - left: 41.66667%; } + left: 41.6666666667%; +} .small-pull-5 { position: relative; - left: -41.66667%; } + left: -41.6666666667%; +} .small-offset-4 { - margin-left: 33.33333%; } + margin-left: 33.3333333333%; +} .small-6 { - width: 50%; } + width: 50%; +} .small-push-6 { position: relative; - left: 50%; } + left: 50%; +} .small-pull-6 { position: relative; - left: -50%; } + left: -50%; +} .small-offset-5 { - margin-left: 41.66667%; } + margin-left: 41.6666666667%; +} .small-7 { - width: 58.33333%; } + width: 58.3333333333%; +} .small-push-7 { position: relative; - left: 58.33333%; } + left: 58.3333333333%; +} .small-pull-7 { position: relative; - left: -58.33333%; } + left: -58.3333333333%; +} .small-offset-6 { - margin-left: 50%; } + margin-left: 50%; +} .small-8 { - width: 66.66667%; } + width: 66.6666666667%; +} .small-push-8 { position: relative; - left: 66.66667%; } + left: 66.6666666667%; +} .small-pull-8 { position: relative; - left: -66.66667%; } + left: -66.6666666667%; +} .small-offset-7 { - margin-left: 58.33333%; } + margin-left: 58.3333333333%; +} .small-9 { - width: 75%; } + width: 75%; +} .small-push-9 { position: relative; - left: 75%; } + left: 75%; +} .small-pull-9 { position: relative; - left: -75%; } + left: -75%; +} .small-offset-8 { - margin-left: 66.66667%; } + margin-left: 66.6666666667%; +} .small-10 { - width: 83.33333%; } + width: 83.3333333333%; +} .small-push-10 { position: relative; - left: 83.33333%; } + left: 83.3333333333%; +} .small-pull-10 { position: relative; - left: -83.33333%; } + left: -83.3333333333%; +} .small-offset-9 { - margin-left: 75%; } + margin-left: 75%; +} .small-11 { - width: 91.66667%; } + width: 91.6666666667%; +} .small-push-11 { position: relative; - left: 91.66667%; } + left: 91.6666666667%; +} .small-pull-11 { position: relative; - left: -91.66667%; } + left: -91.6666666667%; +} .small-offset-10 { - margin-left: 83.33333%; } + margin-left: 83.3333333333%; +} .small-12 { - width: 100%; } + width: 100%; +} .small-offset-11 { - margin-left: 91.66667%; } + margin-left: 91.6666666667%; +} .small-up-1 > .column, .small-up-1 > .columns { float: left; - width: 100%; } - .small-up-1 > .column:nth-of-type(1n), .small-up-1 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-1 > .column:nth-of-type(1n+1), .small-up-1 > .columns:nth-of-type(1n+1) { - clear: both; } - .small-up-1 > .column:last-child, .small-up-1 > .columns:last-child { - float: left; } + width: 100%; +} +.small-up-1 > .column:nth-of-type(1n), .small-up-1 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-1 > .column:nth-of-type(1n+1), .small-up-1 > .columns:nth-of-type(1n+1) { + clear: both; +} +.small-up-1 > .column:last-child, .small-up-1 > .columns:last-child { + float: left; +} .small-up-2 > .column, .small-up-2 > .columns { float: left; - width: 50%; } - .small-up-2 > .column:nth-of-type(1n), .small-up-2 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-2 > .column:nth-of-type(2n+1), .small-up-2 > .columns:nth-of-type(2n+1) { - clear: both; } - .small-up-2 > .column:last-child, .small-up-2 > .columns:last-child { - float: left; } + width: 50%; +} +.small-up-2 > .column:nth-of-type(1n), .small-up-2 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-2 > .column:nth-of-type(2n+1), .small-up-2 > .columns:nth-of-type(2n+1) { + clear: both; +} +.small-up-2 > .column:last-child, .small-up-2 > .columns:last-child { + float: left; +} .small-up-3 > .column, .small-up-3 > .columns { float: left; - width: 33.33333%; } - .small-up-3 > .column:nth-of-type(1n), .small-up-3 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-3 > .column:nth-of-type(3n+1), .small-up-3 > .columns:nth-of-type(3n+1) { - clear: both; } - .small-up-3 > .column:last-child, .small-up-3 > .columns:last-child { - float: left; } + width: 33.3333333333%; +} +.small-up-3 > .column:nth-of-type(1n), .small-up-3 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-3 > .column:nth-of-type(3n+1), .small-up-3 > .columns:nth-of-type(3n+1) { + clear: both; +} +.small-up-3 > .column:last-child, .small-up-3 > .columns:last-child { + float: left; +} .small-up-4 > .column, .small-up-4 > .columns { float: left; - width: 25%; } - .small-up-4 > .column:nth-of-type(1n), .small-up-4 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-4 > .column:nth-of-type(4n+1), .small-up-4 > .columns:nth-of-type(4n+1) { - clear: both; } - .small-up-4 > .column:last-child, .small-up-4 > .columns:last-child { - float: left; } + width: 25%; +} +.small-up-4 > .column:nth-of-type(1n), .small-up-4 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-4 > .column:nth-of-type(4n+1), .small-up-4 > .columns:nth-of-type(4n+1) { + clear: both; +} +.small-up-4 > .column:last-child, .small-up-4 > .columns:last-child { + float: left; +} .small-up-5 > .column, .small-up-5 > .columns { float: left; - width: 20%; } - .small-up-5 > .column:nth-of-type(1n), .small-up-5 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-5 > .column:nth-of-type(5n+1), .small-up-5 > .columns:nth-of-type(5n+1) { - clear: both; } - .small-up-5 > .column:last-child, .small-up-5 > .columns:last-child { - float: left; } + width: 20%; +} +.small-up-5 > .column:nth-of-type(1n), .small-up-5 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-5 > .column:nth-of-type(5n+1), .small-up-5 > .columns:nth-of-type(5n+1) { + clear: both; +} +.small-up-5 > .column:last-child, .small-up-5 > .columns:last-child { + float: left; +} .small-up-6 > .column, .small-up-6 > .columns { float: left; - width: 16.66667%; } - .small-up-6 > .column:nth-of-type(1n), .small-up-6 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-6 > .column:nth-of-type(6n+1), .small-up-6 > .columns:nth-of-type(6n+1) { - clear: both; } - .small-up-6 > .column:last-child, .small-up-6 > .columns:last-child { - float: left; } + width: 16.6666666667%; +} +.small-up-6 > .column:nth-of-type(1n), .small-up-6 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-6 > .column:nth-of-type(6n+1), .small-up-6 > .columns:nth-of-type(6n+1) { + clear: both; +} +.small-up-6 > .column:last-child, .small-up-6 > .columns:last-child { + float: left; +} .small-up-7 > .column, .small-up-7 > .columns { float: left; - width: 14.28571%; } - .small-up-7 > .column:nth-of-type(1n), .small-up-7 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-7 > .column:nth-of-type(7n+1), .small-up-7 > .columns:nth-of-type(7n+1) { - clear: both; } - .small-up-7 > .column:last-child, .small-up-7 > .columns:last-child { - float: left; } + width: 14.2857142857%; +} +.small-up-7 > .column:nth-of-type(1n), .small-up-7 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-7 > .column:nth-of-type(7n+1), .small-up-7 > .columns:nth-of-type(7n+1) { + clear: both; +} +.small-up-7 > .column:last-child, .small-up-7 > .columns:last-child { + float: left; +} .small-up-8 > .column, .small-up-8 > .columns { float: left; - width: 12.5%; } - .small-up-8 > .column:nth-of-type(1n), .small-up-8 > .columns:nth-of-type(1n) { - clear: none; } - .small-up-8 > .column:nth-of-type(8n+1), .small-up-8 > .columns:nth-of-type(8n+1) { - clear: both; } - .small-up-8 > .column:last-child, .small-up-8 > .columns:last-child { - float: left; } + width: 12.5%; +} +.small-up-8 > .column:nth-of-type(1n), .small-up-8 > .columns:nth-of-type(1n) { + clear: none; +} +.small-up-8 > .column:nth-of-type(8n+1), .small-up-8 > .columns:nth-of-type(8n+1) { + clear: both; +} +.small-up-8 > .column:last-child, .small-up-8 > .columns:last-child { + float: left; +} .small-collapse > .column, .small-collapse > .columns { padding-right: 0; - padding-left: 0; } - + padding-left: 0; +} .small-collapse .row { margin-right: 0; - margin-left: 0; } + margin-left: 0; +} .expanded.row .small-collapse.row { margin-right: 0; - margin-left: 0; } + margin-left: 0; +} .small-uncollapse > .column, .small-uncollapse > .columns { padding-right: 0.625rem; - padding-left: 0.625rem; } + padding-left: 0.625rem; +} .small-centered { margin-right: auto; - margin-left: auto; } - .small-centered, .small-centered:last-child:not(:first-child) { - float: none; - clear: both; } + margin-left: auto; +} +.small-centered, .small-centered:last-child:not(:first-child) { + float: none; + clear: both; +} .small-uncentered, .small-push-0, .small-pull-0 { position: static; margin-right: 0; - margin-left: 0; } - .small-uncentered, .small-uncentered:last-child:not(:first-child), .small-push-0, .small-push-0:last-child:not(:first-child), .small-pull-0, .small-pull-0:last-child:not(:first-child) { - float: left; - clear: none; } - .small-uncentered:last-child:not(:first-child), .small-push-0:last-child:not(:first-child), .small-pull-0:last-child:not(:first-child) { - float: right; } + margin-left: 0; +} +.small-uncentered, .small-uncentered:last-child:not(:first-child), .small-push-0, .small-push-0:last-child:not(:first-child), .small-pull-0, .small-pull-0:last-child:not(:first-child) { + float: left; + clear: none; +} +.small-uncentered:last-child:not(:first-child), .small-push-0:last-child:not(:first-child), .small-pull-0:last-child:not(:first-child) { + float: right; +} @media print, screen and (min-width: 40em) { .medium-1 { - width: 8.33333%; } + width: 8.3333333333%; + } .medium-push-1 { position: relative; - left: 8.33333%; } + left: 8.3333333333%; + } .medium-pull-1 { position: relative; - left: -8.33333%; } + left: -8.3333333333%; + } .medium-offset-0 { - margin-left: 0%; } + margin-left: 0%; + } .medium-2 { - width: 16.66667%; } + width: 16.6666666667%; + } .medium-push-2 { position: relative; - left: 16.66667%; } + left: 16.6666666667%; + } .medium-pull-2 { position: relative; - left: -16.66667%; } + left: -16.6666666667%; + } .medium-offset-1 { - margin-left: 8.33333%; } + margin-left: 8.3333333333%; + } .medium-3 { - width: 25%; } + width: 25%; + } .medium-push-3 { position: relative; - left: 25%; } + left: 25%; + } .medium-pull-3 { position: relative; - left: -25%; } + left: -25%; + } .medium-offset-2 { - margin-left: 16.66667%; } + margin-left: 16.6666666667%; + } .medium-4 { - width: 33.33333%; } + width: 33.3333333333%; + } .medium-push-4 { position: relative; - left: 33.33333%; } + left: 33.3333333333%; + } .medium-pull-4 { position: relative; - left: -33.33333%; } + left: -33.3333333333%; + } .medium-offset-3 { - margin-left: 25%; } + margin-left: 25%; + } .medium-5 { - width: 41.66667%; } + width: 41.6666666667%; + } .medium-push-5 { position: relative; - left: 41.66667%; } + left: 41.6666666667%; + } .medium-pull-5 { position: relative; - left: -41.66667%; } + left: -41.6666666667%; + } .medium-offset-4 { - margin-left: 33.33333%; } + margin-left: 33.3333333333%; + } .medium-6 { - width: 50%; } + width: 50%; + } .medium-push-6 { position: relative; - left: 50%; } + left: 50%; + } .medium-pull-6 { position: relative; - left: -50%; } + left: -50%; + } .medium-offset-5 { - margin-left: 41.66667%; } + margin-left: 41.6666666667%; + } .medium-7 { - width: 58.33333%; } + width: 58.3333333333%; + } .medium-push-7 { position: relative; - left: 58.33333%; } + left: 58.3333333333%; + } .medium-pull-7 { position: relative; - left: -58.33333%; } + left: -58.3333333333%; + } .medium-offset-6 { - margin-left: 50%; } + margin-left: 50%; + } .medium-8 { - width: 66.66667%; } + width: 66.6666666667%; + } .medium-push-8 { position: relative; - left: 66.66667%; } + left: 66.6666666667%; + } .medium-pull-8 { position: relative; - left: -66.66667%; } + left: -66.6666666667%; + } .medium-offset-7 { - margin-left: 58.33333%; } + margin-left: 58.3333333333%; + } .medium-9 { - width: 75%; } + width: 75%; + } .medium-push-9 { position: relative; - left: 75%; } + left: 75%; + } .medium-pull-9 { position: relative; - left: -75%; } + left: -75%; + } .medium-offset-8 { - margin-left: 66.66667%; } + margin-left: 66.6666666667%; + } .medium-10 { - width: 83.33333%; } + width: 83.3333333333%; + } .medium-push-10 { position: relative; - left: 83.33333%; } + left: 83.3333333333%; + } .medium-pull-10 { position: relative; - left: -83.33333%; } + left: -83.3333333333%; + } .medium-offset-9 { - margin-left: 75%; } + margin-left: 75%; + } .medium-11 { - width: 91.66667%; } + width: 91.6666666667%; + } .medium-push-11 { position: relative; - left: 91.66667%; } + left: 91.6666666667%; + } .medium-pull-11 { position: relative; - left: -91.66667%; } + left: -91.6666666667%; + } .medium-offset-10 { - margin-left: 83.33333%; } + margin-left: 83.3333333333%; + } .medium-12 { - width: 100%; } + width: 100%; + } .medium-offset-11 { - margin-left: 91.66667%; } + margin-left: 91.6666666667%; + } .medium-up-1 > .column, .medium-up-1 > .columns { float: left; - width: 100%; } - .medium-up-1 > .column:nth-of-type(1n), .medium-up-1 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-1 > .column:nth-of-type(1n+1), .medium-up-1 > .columns:nth-of-type(1n+1) { - clear: both; } - .medium-up-1 > .column:last-child, .medium-up-1 > .columns:last-child { - float: left; } + width: 100%; + } + .medium-up-1 > .column:nth-of-type(1n), .medium-up-1 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-1 > .column:nth-of-type(1n+1), .medium-up-1 > .columns:nth-of-type(1n+1) { + clear: both; + } + .medium-up-1 > .column:last-child, .medium-up-1 > .columns:last-child { + float: left; + } .medium-up-2 > .column, .medium-up-2 > .columns { float: left; - width: 50%; } - .medium-up-2 > .column:nth-of-type(1n), .medium-up-2 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-2 > .column:nth-of-type(2n+1), .medium-up-2 > .columns:nth-of-type(2n+1) { - clear: both; } - .medium-up-2 > .column:last-child, .medium-up-2 > .columns:last-child { - float: left; } + width: 50%; + } + .medium-up-2 > .column:nth-of-type(1n), .medium-up-2 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-2 > .column:nth-of-type(2n+1), .medium-up-2 > .columns:nth-of-type(2n+1) { + clear: both; + } + .medium-up-2 > .column:last-child, .medium-up-2 > .columns:last-child { + float: left; + } .medium-up-3 > .column, .medium-up-3 > .columns { float: left; - width: 33.33333%; } - .medium-up-3 > .column:nth-of-type(1n), .medium-up-3 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-3 > .column:nth-of-type(3n+1), .medium-up-3 > .columns:nth-of-type(3n+1) { - clear: both; } - .medium-up-3 > .column:last-child, .medium-up-3 > .columns:last-child { - float: left; } + width: 33.3333333333%; + } + .medium-up-3 > .column:nth-of-type(1n), .medium-up-3 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-3 > .column:nth-of-type(3n+1), .medium-up-3 > .columns:nth-of-type(3n+1) { + clear: both; + } + .medium-up-3 > .column:last-child, .medium-up-3 > .columns:last-child { + float: left; + } .medium-up-4 > .column, .medium-up-4 > .columns { float: left; - width: 25%; } - .medium-up-4 > .column:nth-of-type(1n), .medium-up-4 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-4 > .column:nth-of-type(4n+1), .medium-up-4 > .columns:nth-of-type(4n+1) { - clear: both; } - .medium-up-4 > .column:last-child, .medium-up-4 > .columns:last-child { - float: left; } + width: 25%; + } + .medium-up-4 > .column:nth-of-type(1n), .medium-up-4 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-4 > .column:nth-of-type(4n+1), .medium-up-4 > .columns:nth-of-type(4n+1) { + clear: both; + } + .medium-up-4 > .column:last-child, .medium-up-4 > .columns:last-child { + float: left; + } .medium-up-5 > .column, .medium-up-5 > .columns { float: left; - width: 20%; } - .medium-up-5 > .column:nth-of-type(1n), .medium-up-5 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-5 > .column:nth-of-type(5n+1), .medium-up-5 > .columns:nth-of-type(5n+1) { - clear: both; } - .medium-up-5 > .column:last-child, .medium-up-5 > .columns:last-child { - float: left; } + width: 20%; + } + .medium-up-5 > .column:nth-of-type(1n), .medium-up-5 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-5 > .column:nth-of-type(5n+1), .medium-up-5 > .columns:nth-of-type(5n+1) { + clear: both; + } + .medium-up-5 > .column:last-child, .medium-up-5 > .columns:last-child { + float: left; + } .medium-up-6 > .column, .medium-up-6 > .columns { float: left; - width: 16.66667%; } - .medium-up-6 > .column:nth-of-type(1n), .medium-up-6 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-6 > .column:nth-of-type(6n+1), .medium-up-6 > .columns:nth-of-type(6n+1) { - clear: both; } - .medium-up-6 > .column:last-child, .medium-up-6 > .columns:last-child { - float: left; } + width: 16.6666666667%; + } + .medium-up-6 > .column:nth-of-type(1n), .medium-up-6 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-6 > .column:nth-of-type(6n+1), .medium-up-6 > .columns:nth-of-type(6n+1) { + clear: both; + } + .medium-up-6 > .column:last-child, .medium-up-6 > .columns:last-child { + float: left; + } .medium-up-7 > .column, .medium-up-7 > .columns { float: left; - width: 14.28571%; } - .medium-up-7 > .column:nth-of-type(1n), .medium-up-7 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-7 > .column:nth-of-type(7n+1), .medium-up-7 > .columns:nth-of-type(7n+1) { - clear: both; } - .medium-up-7 > .column:last-child, .medium-up-7 > .columns:last-child { - float: left; } + width: 14.2857142857%; + } + .medium-up-7 > .column:nth-of-type(1n), .medium-up-7 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-7 > .column:nth-of-type(7n+1), .medium-up-7 > .columns:nth-of-type(7n+1) { + clear: both; + } + .medium-up-7 > .column:last-child, .medium-up-7 > .columns:last-child { + float: left; + } .medium-up-8 > .column, .medium-up-8 > .columns { float: left; - width: 12.5%; } - .medium-up-8 > .column:nth-of-type(1n), .medium-up-8 > .columns:nth-of-type(1n) { - clear: none; } - .medium-up-8 > .column:nth-of-type(8n+1), .medium-up-8 > .columns:nth-of-type(8n+1) { - clear: both; } - .medium-up-8 > .column:last-child, .medium-up-8 > .columns:last-child { - float: left; } + width: 12.5%; + } + .medium-up-8 > .column:nth-of-type(1n), .medium-up-8 > .columns:nth-of-type(1n) { + clear: none; + } + .medium-up-8 > .column:nth-of-type(8n+1), .medium-up-8 > .columns:nth-of-type(8n+1) { + clear: both; + } + .medium-up-8 > .column:last-child, .medium-up-8 > .columns:last-child { + float: left; + } .medium-collapse > .column, .medium-collapse > .columns { padding-right: 0; - padding-left: 0; } + padding-left: 0; + } .medium-collapse .row { margin-right: 0; - margin-left: 0; } + margin-left: 0; + } .expanded.row .medium-collapse.row { margin-right: 0; - margin-left: 0; } + margin-left: 0; + } .medium-uncollapse > .column, .medium-uncollapse > .columns { padding-right: 0.9375rem; - padding-left: 0.9375rem; } + padding-left: 0.9375rem; + } .medium-centered { margin-right: auto; - margin-left: auto; } - .medium-centered, .medium-centered:last-child:not(:first-child) { - float: none; - clear: both; } + margin-left: auto; + } + .medium-centered, .medium-centered:last-child:not(:first-child) { + float: none; + clear: both; + } .medium-uncentered, .medium-push-0, .medium-pull-0 { position: static; margin-right: 0; - margin-left: 0; } - .medium-uncentered, .medium-uncentered:last-child:not(:first-child), .medium-push-0, .medium-push-0:last-child:not(:first-child), .medium-pull-0, .medium-pull-0:last-child:not(:first-child) { - float: left; - clear: none; } - .medium-uncentered:last-child:not(:first-child), .medium-push-0:last-child:not(:first-child), .medium-pull-0:last-child:not(:first-child) { - float: right; } } - + margin-left: 0; + } + .medium-uncentered, .medium-uncentered:last-child:not(:first-child), .medium-push-0, .medium-push-0:last-child:not(:first-child), .medium-pull-0, .medium-pull-0:last-child:not(:first-child) { + float: left; + clear: none; + } + .medium-uncentered:last-child:not(:first-child), .medium-push-0:last-child:not(:first-child), .medium-pull-0:last-child:not(:first-child) { + float: right; + } +} @media print, screen and (min-width: 64em) { .large-1 { - width: 8.33333%; } + width: 8.3333333333%; + } .large-push-1 { position: relative; - left: 8.33333%; } + left: 8.3333333333%; + } .large-pull-1 { position: relative; - left: -8.33333%; } + left: -8.3333333333%; + } .large-offset-0 { - margin-left: 0%; } + margin-left: 0%; + } .large-2 { - width: 16.66667%; } + width: 16.6666666667%; + } .large-push-2 { position: relative; - left: 16.66667%; } + left: 16.6666666667%; + } .large-pull-2 { position: relative; - left: -16.66667%; } + left: -16.6666666667%; + } .large-offset-1 { - margin-left: 8.33333%; } + margin-left: 8.3333333333%; + } .large-3 { - width: 25%; } + width: 25%; + } .large-push-3 { position: relative; - left: 25%; } + left: 25%; + } .large-pull-3 { position: relative; - left: -25%; } + left: -25%; + } .large-offset-2 { - margin-left: 16.66667%; } + margin-left: 16.6666666667%; + } .large-4 { - width: 33.33333%; } + width: 33.3333333333%; + } .large-push-4 { position: relative; - left: 33.33333%; } + left: 33.3333333333%; + } .large-pull-4 { position: relative; - left: -33.33333%; } + left: -33.3333333333%; + } .large-offset-3 { - margin-left: 25%; } + margin-left: 25%; + } .large-5 { - width: 41.66667%; } + width: 41.6666666667%; + } .large-push-5 { position: relative; - left: 41.66667%; } + left: 41.6666666667%; + } .large-pull-5 { position: relative; - left: -41.66667%; } + left: -41.6666666667%; + } .large-offset-4 { - margin-left: 33.33333%; } + margin-left: 33.3333333333%; + } .large-6 { - width: 50%; } + width: 50%; + } .large-push-6 { position: relative; - left: 50%; } + left: 50%; + } .large-pull-6 { position: relative; - left: -50%; } + left: -50%; + } .large-offset-5 { - margin-left: 41.66667%; } + margin-left: 41.6666666667%; + } .large-7 { - width: 58.33333%; } + width: 58.3333333333%; + } .large-push-7 { position: relative; - left: 58.33333%; } + left: 58.3333333333%; + } .large-pull-7 { position: relative; - left: -58.33333%; } + left: -58.3333333333%; + } .large-offset-6 { - margin-left: 50%; } + margin-left: 50%; + } .large-8 { - width: 66.66667%; } + width: 66.6666666667%; + } .large-push-8 { position: relative; - left: 66.66667%; } + left: 66.6666666667%; + } .large-pull-8 { position: relative; - left: -66.66667%; } + left: -66.6666666667%; + } .large-offset-7 { - margin-left: 58.33333%; } + margin-left: 58.3333333333%; + } .large-9 { - width: 75%; } + width: 75%; + } .large-push-9 { position: relative; - left: 75%; } + left: 75%; + } .large-pull-9 { position: relative; - left: -75%; } + left: -75%; + } .large-offset-8 { - margin-left: 66.66667%; } + margin-left: 66.6666666667%; + } .large-10 { - width: 83.33333%; } + width: 83.3333333333%; + } .large-push-10 { position: relative; - left: 83.33333%; } + left: 83.3333333333%; + } .large-pull-10 { position: relative; - left: -83.33333%; } + left: -83.3333333333%; + } .large-offset-9 { - margin-left: 75%; } + margin-left: 75%; + } .large-11 { - width: 91.66667%; } + width: 91.6666666667%; + } .large-push-11 { position: relative; - left: 91.66667%; } + left: 91.6666666667%; + } .large-pull-11 { position: relative; - left: -91.66667%; } + left: -91.6666666667%; + } .large-offset-10 { - margin-left: 83.33333%; } + margin-left: 83.3333333333%; + } .large-12 { - width: 100%; } + width: 100%; + } .large-offset-11 { - margin-left: 91.66667%; } + margin-left: 91.6666666667%; + } .large-up-1 > .column, .large-up-1 > .columns { float: left; - width: 100%; } - .large-up-1 > .column:nth-of-type(1n), .large-up-1 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-1 > .column:nth-of-type(1n+1), .large-up-1 > .columns:nth-of-type(1n+1) { - clear: both; } - .large-up-1 > .column:last-child, .large-up-1 > .columns:last-child { - float: left; } + width: 100%; + } + .large-up-1 > .column:nth-of-type(1n), .large-up-1 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-1 > .column:nth-of-type(1n+1), .large-up-1 > .columns:nth-of-type(1n+1) { + clear: both; + } + .large-up-1 > .column:last-child, .large-up-1 > .columns:last-child { + float: left; + } .large-up-2 > .column, .large-up-2 > .columns { float: left; - width: 50%; } - .large-up-2 > .column:nth-of-type(1n), .large-up-2 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-2 > .column:nth-of-type(2n+1), .large-up-2 > .columns:nth-of-type(2n+1) { - clear: both; } - .large-up-2 > .column:last-child, .large-up-2 > .columns:last-child { - float: left; } + width: 50%; + } + .large-up-2 > .column:nth-of-type(1n), .large-up-2 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-2 > .column:nth-of-type(2n+1), .large-up-2 > .columns:nth-of-type(2n+1) { + clear: both; + } + .large-up-2 > .column:last-child, .large-up-2 > .columns:last-child { + float: left; + } .large-up-3 > .column, .large-up-3 > .columns { float: left; - width: 33.33333%; } - .large-up-3 > .column:nth-of-type(1n), .large-up-3 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-3 > .column:nth-of-type(3n+1), .large-up-3 > .columns:nth-of-type(3n+1) { - clear: both; } - .large-up-3 > .column:last-child, .large-up-3 > .columns:last-child { - float: left; } + width: 33.3333333333%; + } + .large-up-3 > .column:nth-of-type(1n), .large-up-3 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-3 > .column:nth-of-type(3n+1), .large-up-3 > .columns:nth-of-type(3n+1) { + clear: both; + } + .large-up-3 > .column:last-child, .large-up-3 > .columns:last-child { + float: left; + } .large-up-4 > .column, .large-up-4 > .columns { float: left; - width: 25%; } - .large-up-4 > .column:nth-of-type(1n), .large-up-4 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-4 > .column:nth-of-type(4n+1), .large-up-4 > .columns:nth-of-type(4n+1) { - clear: both; } - .large-up-4 > .column:last-child, .large-up-4 > .columns:last-child { - float: left; } + width: 25%; + } + .large-up-4 > .column:nth-of-type(1n), .large-up-4 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-4 > .column:nth-of-type(4n+1), .large-up-4 > .columns:nth-of-type(4n+1) { + clear: both; + } + .large-up-4 > .column:last-child, .large-up-4 > .columns:last-child { + float: left; + } .large-up-5 > .column, .large-up-5 > .columns { float: left; - width: 20%; } - .large-up-5 > .column:nth-of-type(1n), .large-up-5 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-5 > .column:nth-of-type(5n+1), .large-up-5 > .columns:nth-of-type(5n+1) { - clear: both; } - .large-up-5 > .column:last-child, .large-up-5 > .columns:last-child { - float: left; } + width: 20%; + } + .large-up-5 > .column:nth-of-type(1n), .large-up-5 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-5 > .column:nth-of-type(5n+1), .large-up-5 > .columns:nth-of-type(5n+1) { + clear: both; + } + .large-up-5 > .column:last-child, .large-up-5 > .columns:last-child { + float: left; + } .large-up-6 > .column, .large-up-6 > .columns { float: left; - width: 16.66667%; } - .large-up-6 > .column:nth-of-type(1n), .large-up-6 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-6 > .column:nth-of-type(6n+1), .large-up-6 > .columns:nth-of-type(6n+1) { - clear: both; } - .large-up-6 > .column:last-child, .large-up-6 > .columns:last-child { - float: left; } + width: 16.6666666667%; + } + .large-up-6 > .column:nth-of-type(1n), .large-up-6 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-6 > .column:nth-of-type(6n+1), .large-up-6 > .columns:nth-of-type(6n+1) { + clear: both; + } + .large-up-6 > .column:last-child, .large-up-6 > .columns:last-child { + float: left; + } .large-up-7 > .column, .large-up-7 > .columns { float: left; - width: 14.28571%; } - .large-up-7 > .column:nth-of-type(1n), .large-up-7 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-7 > .column:nth-of-type(7n+1), .large-up-7 > .columns:nth-of-type(7n+1) { - clear: both; } - .large-up-7 > .column:last-child, .large-up-7 > .columns:last-child { - float: left; } + width: 14.2857142857%; + } + .large-up-7 > .column:nth-of-type(1n), .large-up-7 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-7 > .column:nth-of-type(7n+1), .large-up-7 > .columns:nth-of-type(7n+1) { + clear: both; + } + .large-up-7 > .column:last-child, .large-up-7 > .columns:last-child { + float: left; + } .large-up-8 > .column, .large-up-8 > .columns { float: left; - width: 12.5%; } - .large-up-8 > .column:nth-of-type(1n), .large-up-8 > .columns:nth-of-type(1n) { - clear: none; } - .large-up-8 > .column:nth-of-type(8n+1), .large-up-8 > .columns:nth-of-type(8n+1) { - clear: both; } - .large-up-8 > .column:last-child, .large-up-8 > .columns:last-child { - float: left; } + width: 12.5%; + } + .large-up-8 > .column:nth-of-type(1n), .large-up-8 > .columns:nth-of-type(1n) { + clear: none; + } + .large-up-8 > .column:nth-of-type(8n+1), .large-up-8 > .columns:nth-of-type(8n+1) { + clear: both; + } + .large-up-8 > .column:last-child, .large-up-8 > .columns:last-child { + float: left; + } .large-collapse > .column, .large-collapse > .columns { padding-right: 0; - padding-left: 0; } + padding-left: 0; + } .large-collapse .row { margin-right: 0; - margin-left: 0; } + margin-left: 0; + } .expanded.row .large-collapse.row { margin-right: 0; - margin-left: 0; } + margin-left: 0; + } .large-uncollapse > .column, .large-uncollapse > .columns { padding-right: 0.9375rem; - padding-left: 0.9375rem; } + padding-left: 0.9375rem; + } .large-centered { margin-right: auto; - margin-left: auto; } - .large-centered, .large-centered:last-child:not(:first-child) { - float: none; - clear: both; } + margin-left: auto; + } + .large-centered, .large-centered:last-child:not(:first-child) { + float: none; + clear: both; + } .large-uncentered, .large-push-0, .large-pull-0 { position: static; margin-right: 0; - margin-left: 0; } - .large-uncentered, .large-uncentered:last-child:not(:first-child), .large-push-0, .large-push-0:last-child:not(:first-child), .large-pull-0, .large-pull-0:last-child:not(:first-child) { - float: left; - clear: none; } - .large-uncentered:last-child:not(:first-child), .large-push-0:last-child:not(:first-child), .large-pull-0:last-child:not(:first-child) { - float: right; } } - + margin-left: 0; + } + .large-uncentered, .large-uncentered:last-child:not(:first-child), .large-push-0, .large-push-0:last-child:not(:first-child), .large-pull-0, .large-pull-0:last-child:not(:first-child) { + float: left; + clear: none; + } + .large-uncentered:last-child:not(:first-child), .large-push-0:last-child:not(:first-child), .large-pull-0:last-child:not(:first-child) { + float: right; + } +} .column-block { - margin-bottom: 1.25rem; } + margin-bottom: 1.25rem; +} +.column-block > :last-child { + margin-bottom: 0; +} +@media print, screen and (min-width: 40em) { + .column-block { + margin-bottom: 1.875rem; + } .column-block > :last-child { - margin-bottom: 0; } - @media print, screen and (min-width: 40em) { - .column-block { - margin-bottom: 1.875rem; } - .column-block > :last-child { - margin-bottom: 0; } } + margin-bottom: 0; + } +} .button { display: inline-block; @@ -1636,394 +2105,538 @@ code, .code-inline { -webkit-appearance: none; line-height: 1; text-align: center; - cursor: pointer; } - [data-whatinput='mouse'] .button { - outline: 0; } - .button.tiny { - font-size: 0.6rem; } - .button.small { - font-size: 0.75rem; } - .button.large { - font-size: 1.25rem; } - .button.expanded { - display: block; - width: 100%; - margin-right: 0; - margin-left: 0; } - .button, .button.disabled, .button[disabled], .button.disabled:hover, .button[disabled]:hover, .button.disabled:focus, .button[disabled]:focus { - background-color: #1779ba; - color: #fefefe; } - .button:hover, .button:focus { - background-color: #14679e; - color: #fefefe; } - .button.primary, .button.primary.disabled, .button.primary[disabled], .button.primary.disabled:hover, .button.primary[disabled]:hover, .button.primary.disabled:focus, .button.primary[disabled]:focus { - background-color: #1779ba; - color: #fefefe; } - .button.primary:hover, .button.primary:focus { - background-color: #126195; - color: #fefefe; } - .button.secondary, .button.secondary.disabled, .button.secondary[disabled], .button.secondary.disabled:hover, .button.secondary[disabled]:hover, .button.secondary.disabled:focus, .button.secondary[disabled]:focus { - background-color: #767676; - color: #fefefe; } - .button.secondary:hover, .button.secondary:focus { - background-color: #5e5e5e; - color: #fefefe; } - .button.success, .button.success.disabled, .button.success[disabled], .button.success.disabled:hover, .button.success[disabled]:hover, .button.success.disabled:focus, .button.success[disabled]:focus { - background-color: #3adb76; - color: #0a0a0a; } - .button.success:hover, .button.success:focus { - background-color: #22bb5b; - color: #0a0a0a; } - .button.warning, .button.warning.disabled, .button.warning[disabled], .button.warning.disabled:hover, .button.warning[disabled]:hover, .button.warning.disabled:focus, .button.warning[disabled]:focus { - background-color: #ffae00; - color: #0a0a0a; } - .button.warning:hover, .button.warning:focus { - background-color: #cc8b00; - color: #0a0a0a; } - .button.alert, .button.alert.disabled, .button.alert[disabled], .button.alert.disabled:hover, .button.alert[disabled]:hover, .button.alert.disabled:focus, .button.alert[disabled]:focus { - background-color: #cc4b37; - color: #fefefe; } - .button.alert:hover, .button.alert:focus { - background-color: #a53b2a; - color: #fefefe; } - .button.hollow, .button.hollow:hover, .button.hollow:focus, .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus { - background-color: transparent; } - .button.hollow, .button.hollow.disabled, .button.hollow[disabled], .button.hollow.disabled:hover, .button.hollow[disabled]:hover, .button.hollow.disabled:focus, .button.hollow[disabled]:focus { - border: 1px solid #1779ba; - color: #1779ba; } - .button.hollow:hover, .button.hollow:focus { - border-color: #0c3d5d; - color: #0c3d5d; } - .button.hollow.primary, .button.hollow.primary.disabled, .button.hollow.primary[disabled], .button.hollow.primary.disabled:hover, .button.hollow.primary[disabled]:hover, .button.hollow.primary.disabled:focus, .button.hollow.primary[disabled]:focus { - border: 1px solid #1779ba; - color: #1779ba; } - .button.hollow.primary:hover, .button.hollow.primary:focus { - border-color: #0c3d5d; - color: #0c3d5d; } - .button.hollow.secondary, .button.hollow.secondary.disabled, .button.hollow.secondary[disabled], .button.hollow.secondary.disabled:hover, .button.hollow.secondary[disabled]:hover, .button.hollow.secondary.disabled:focus, .button.hollow.secondary[disabled]:focus { - border: 1px solid #767676; - color: #767676; } - .button.hollow.secondary:hover, .button.hollow.secondary:focus { - border-color: #3b3b3b; - color: #3b3b3b; } - .button.hollow.success, .button.hollow.success.disabled, .button.hollow.success[disabled], .button.hollow.success.disabled:hover, .button.hollow.success[disabled]:hover, .button.hollow.success.disabled:focus, .button.hollow.success[disabled]:focus { - border: 1px solid #3adb76; - color: #3adb76; } - .button.hollow.success:hover, .button.hollow.success:focus { - border-color: #157539; - color: #157539; } - .button.hollow.warning, .button.hollow.warning.disabled, .button.hollow.warning[disabled], .button.hollow.warning.disabled:hover, .button.hollow.warning[disabled]:hover, .button.hollow.warning.disabled:focus, .button.hollow.warning[disabled]:focus { - border: 1px solid #ffae00; - color: #ffae00; } - .button.hollow.warning:hover, .button.hollow.warning:focus { - border-color: #805700; - color: #805700; } - .button.hollow.alert, .button.hollow.alert.disabled, .button.hollow.alert[disabled], .button.hollow.alert.disabled:hover, .button.hollow.alert[disabled]:hover, .button.hollow.alert.disabled:focus, .button.hollow.alert[disabled]:focus { - border: 1px solid #cc4b37; - color: #cc4b37; } - .button.hollow.alert:hover, .button.hollow.alert:focus { - border-color: #67251a; - color: #67251a; } - .button.clear, .button.clear:hover, .button.clear:focus, .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus { - border-color: transparent; - background-color: transparent; } - .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear.disabled:hover, .button.clear[disabled]:hover, .button.clear.disabled:focus, .button.clear[disabled]:focus { - color: #1779ba; } - .button.clear:hover, .button.clear:focus { - color: #0c3d5d; } - .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary.disabled:hover, .button.clear.primary[disabled]:hover, .button.clear.primary.disabled:focus, .button.clear.primary[disabled]:focus { - color: #1779ba; } - .button.clear.primary:hover, .button.clear.primary:focus { - color: #0c3d5d; } - .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary.disabled:hover, .button.clear.secondary[disabled]:hover, .button.clear.secondary.disabled:focus, .button.clear.secondary[disabled]:focus { - color: #767676; } - .button.clear.secondary:hover, .button.clear.secondary:focus { - color: #3b3b3b; } - .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success.disabled:hover, .button.clear.success[disabled]:hover, .button.clear.success.disabled:focus, .button.clear.success[disabled]:focus { - color: #3adb76; } - .button.clear.success:hover, .button.clear.success:focus { - color: #157539; } - .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning.disabled:hover, .button.clear.warning[disabled]:hover, .button.clear.warning.disabled:focus, .button.clear.warning[disabled]:focus { - color: #ffae00; } - .button.clear.warning:hover, .button.clear.warning:focus { - color: #805700; } - .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert.disabled:hover, .button.clear.alert[disabled]:hover, .button.clear.alert.disabled:focus, .button.clear.alert[disabled]:focus { - color: #cc4b37; } - .button.clear.alert:hover, .button.clear.alert:focus { - color: #67251a; } - .button.disabled, .button[disabled] { - opacity: 0.25; - cursor: not-allowed; } - .button.dropdown::after { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 0.4em; - content: ''; - border-bottom-width: 0; - border-color: #fefefe transparent transparent; - position: relative; - top: 0.4em; - display: inline-block; - float: right; - margin-left: 1em; } - .button.dropdown.hollow::after, .button.dropdown.clear::after { - border-top-color: #1779ba; } - .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after { - border-top-color: #1779ba; } - .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after { - border-top-color: #767676; } - .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after { - border-top-color: #3adb76; } - .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after { - border-top-color: #ffae00; } - .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after { - border-top-color: #cc4b37; } - .button.arrow-only::after { - top: -0.1em; - float: none; - margin-left: 0; } + cursor: pointer; +} +[data-whatinput=mouse] .button { + outline: 0; +} +.button.tiny { + font-size: 0.6rem; +} +.button.small { + font-size: 0.75rem; +} +.button.large { + font-size: 1.25rem; +} +.button.expanded { + display: block; + width: 100%; + margin-right: 0; + margin-left: 0; +} +.button, .button.disabled, .button[disabled], .button.disabled:hover, .button[disabled]:hover, .button.disabled:focus, .button[disabled]:focus { + background-color: #1779ba; + color: #fefefe; +} +.button:hover, .button:focus { + background-color: #14679e; + color: #fefefe; +} +.button.primary, .button.primary.disabled, .button.primary[disabled], .button.primary.disabled:hover, .button.primary[disabled]:hover, .button.primary.disabled:focus, .button.primary[disabled]:focus { + background-color: #1779ba; + color: #fefefe; +} +.button.primary:hover, .button.primary:focus { + background-color: #126195; + color: #fefefe; +} +.button.secondary, .button.secondary.disabled, .button.secondary[disabled], .button.secondary.disabled:hover, .button.secondary[disabled]:hover, .button.secondary.disabled:focus, .button.secondary[disabled]:focus { + background-color: #767676; + color: #fefefe; +} +.button.secondary:hover, .button.secondary:focus { + background-color: #5e5e5e; + color: #fefefe; +} +.button.success, .button.success.disabled, .button.success[disabled], .button.success.disabled:hover, .button.success[disabled]:hover, .button.success.disabled:focus, .button.success[disabled]:focus { + background-color: #3adb76; + color: #0a0a0a; +} +.button.success:hover, .button.success:focus { + background-color: #22bb5b; + color: #0a0a0a; +} +.button.warning, .button.warning.disabled, .button.warning[disabled], .button.warning.disabled:hover, .button.warning[disabled]:hover, .button.warning.disabled:focus, .button.warning[disabled]:focus { + background-color: #ffae00; + color: #0a0a0a; +} +.button.warning:hover, .button.warning:focus { + background-color: #cc8b00; + color: #0a0a0a; +} +.button.alert, .button.alert.disabled, .button.alert[disabled], .button.alert.disabled:hover, .button.alert[disabled]:hover, .button.alert.disabled:focus, .button.alert[disabled]:focus { + background-color: #cc4b37; + color: #fefefe; +} +.button.alert:hover, .button.alert:focus { + background-color: #a53b2a; + color: #fefefe; +} +.button.hollow, .button.hollow:hover, .button.hollow:focus, .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus { + background-color: transparent; +} +.button.hollow, .button.hollow.disabled, .button.hollow[disabled], .button.hollow.disabled:hover, .button.hollow[disabled]:hover, .button.hollow.disabled:focus, .button.hollow[disabled]:focus { + border: 1px solid #1779ba; + color: #1779ba; +} +.button.hollow:hover, .button.hollow:focus { + border-color: #0c3d5d; + color: #0c3d5d; +} +.button.hollow.primary, .button.hollow.primary.disabled, .button.hollow.primary[disabled], .button.hollow.primary.disabled:hover, .button.hollow.primary[disabled]:hover, .button.hollow.primary.disabled:focus, .button.hollow.primary[disabled]:focus { + border: 1px solid #1779ba; + color: #1779ba; +} +.button.hollow.primary:hover, .button.hollow.primary:focus { + border-color: #0c3d5d; + color: #0c3d5d; +} +.button.hollow.secondary, .button.hollow.secondary.disabled, .button.hollow.secondary[disabled], .button.hollow.secondary.disabled:hover, .button.hollow.secondary[disabled]:hover, .button.hollow.secondary.disabled:focus, .button.hollow.secondary[disabled]:focus { + border: 1px solid #767676; + color: #767676; +} +.button.hollow.secondary:hover, .button.hollow.secondary:focus { + border-color: #3b3b3b; + color: #3b3b3b; +} +.button.hollow.success, .button.hollow.success.disabled, .button.hollow.success[disabled], .button.hollow.success.disabled:hover, .button.hollow.success[disabled]:hover, .button.hollow.success.disabled:focus, .button.hollow.success[disabled]:focus { + border: 1px solid #3adb76; + color: #3adb76; +} +.button.hollow.success:hover, .button.hollow.success:focus { + border-color: #157539; + color: #157539; +} +.button.hollow.warning, .button.hollow.warning.disabled, .button.hollow.warning[disabled], .button.hollow.warning.disabled:hover, .button.hollow.warning[disabled]:hover, .button.hollow.warning.disabled:focus, .button.hollow.warning[disabled]:focus { + border: 1px solid #ffae00; + color: #ffae00; +} +.button.hollow.warning:hover, .button.hollow.warning:focus { + border-color: #805700; + color: #805700; +} +.button.hollow.alert, .button.hollow.alert.disabled, .button.hollow.alert[disabled], .button.hollow.alert.disabled:hover, .button.hollow.alert[disabled]:hover, .button.hollow.alert.disabled:focus, .button.hollow.alert[disabled]:focus { + border: 1px solid #cc4b37; + color: #cc4b37; +} +.button.hollow.alert:hover, .button.hollow.alert:focus { + border-color: #67251a; + color: #67251a; +} +.button.clear, .button.clear:hover, .button.clear:focus, .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus { + border-color: transparent; + background-color: transparent; +} +.button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear.disabled:hover, .button.clear[disabled]:hover, .button.clear.disabled:focus, .button.clear[disabled]:focus { + color: #1779ba; +} +.button.clear:hover, .button.clear:focus { + color: #0c3d5d; +} +.button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary.disabled:hover, .button.clear.primary[disabled]:hover, .button.clear.primary.disabled:focus, .button.clear.primary[disabled]:focus { + color: #1779ba; +} +.button.clear.primary:hover, .button.clear.primary:focus { + color: #0c3d5d; +} +.button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary.disabled:hover, .button.clear.secondary[disabled]:hover, .button.clear.secondary.disabled:focus, .button.clear.secondary[disabled]:focus { + color: #767676; +} +.button.clear.secondary:hover, .button.clear.secondary:focus { + color: #3b3b3b; +} +.button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success.disabled:hover, .button.clear.success[disabled]:hover, .button.clear.success.disabled:focus, .button.clear.success[disabled]:focus { + color: #3adb76; +} +.button.clear.success:hover, .button.clear.success:focus { + color: #157539; +} +.button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning.disabled:hover, .button.clear.warning[disabled]:hover, .button.clear.warning.disabled:focus, .button.clear.warning[disabled]:focus { + color: #ffae00; +} +.button.clear.warning:hover, .button.clear.warning:focus { + color: #805700; +} +.button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert.disabled:hover, .button.clear.alert[disabled]:hover, .button.clear.alert.disabled:focus, .button.clear.alert[disabled]:focus { + color: #cc4b37; +} +.button.clear.alert:hover, .button.clear.alert:focus { + color: #67251a; +} +.button.disabled, .button[disabled] { + opacity: 0.25; + cursor: not-allowed; +} +.button.dropdown::after { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 0.4em; + content: ""; + border-bottom-width: 0; + border-color: #fefefe transparent transparent; + position: relative; + top: 0.4em; + display: inline-block; + float: right; + margin-left: 1em; +} +.button.dropdown.hollow::after, .button.dropdown.clear::after { + border-top-color: #1779ba; +} +.button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after { + border-top-color: #1779ba; +} +.button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after { + border-top-color: #767676; +} +.button.dropdown.hollow.success::after, .button.dropdown.clear.success::after { + border-top-color: #3adb76; +} +.button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after { + border-top-color: #ffae00; +} +.button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after { + border-top-color: #cc4b37; +} +.button.arrow-only::after { + top: -0.1em; + float: none; + margin-left: 0; +} a.button:hover, a.button:focus { - text-decoration: none; } + text-decoration: none; +} .button-group { margin-bottom: 1rem; - font-size: 0; } - .button-group::before, .button-group::after { - display: table; - content: ' '; } - .button-group::after { - clear: both; } - .button-group .button { - margin: 0; - margin-right: 1px; - margin-bottom: 1px; - font-size: 0.9rem; } - .button-group .button:last-child { - margin-right: 0; } - .button-group.tiny .button { - font-size: 0.6rem; } - .button-group.small .button { - font-size: 0.75rem; } - .button-group.large .button { - font-size: 1.25rem; } - .button-group.expanded { - margin-right: -1px; } - .button-group.expanded::before, .button-group.expanded::after { - display: none; } - .button-group.expanded .button:first-child:last-child { - width: calc(100% - 1px); } - .button-group.expanded .button:first-child:nth-last-child(2), .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button { - display: inline-block; - width: calc(50% - 1px); - margin-right: 1px; } - .button-group.expanded .button:first-child:nth-last-child(2):last-child, .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child { - margin-right: -6px; } - .button-group.expanded .button:first-child:nth-last-child(3), .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button { - display: inline-block; - width: calc(33.33333% - 1px); - margin-right: 1px; } - .button-group.expanded .button:first-child:nth-last-child(3):last-child, .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child { - margin-right: -6px; } - .button-group.expanded .button:first-child:nth-last-child(4), .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button { - display: inline-block; - width: calc(25% - 1px); - margin-right: 1px; } - .button-group.expanded .button:first-child:nth-last-child(4):last-child, .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child { - margin-right: -6px; } - .button-group.expanded .button:first-child:nth-last-child(5), .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button { - display: inline-block; - width: calc(20% - 1px); - margin-right: 1px; } - .button-group.expanded .button:first-child:nth-last-child(5):last-child, .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child { - margin-right: -6px; } - .button-group.expanded .button:first-child:nth-last-child(6), .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button { - display: inline-block; - width: calc(16.66667% - 1px); - margin-right: 1px; } - .button-group.expanded .button:first-child:nth-last-child(6):last-child, .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child { - margin-right: -6px; } - .button-group.primary .button, .button-group.primary .button.disabled, .button-group.primary .button[disabled], .button-group.primary .button.disabled:hover, .button-group.primary .button[disabled]:hover, .button-group.primary .button.disabled:focus, .button-group.primary .button[disabled]:focus { - background-color: #1779ba; - color: #fefefe; } - .button-group.primary .button:hover, .button-group.primary .button:focus { - background-color: #126195; - color: #fefefe; } - .button-group.secondary .button, .button-group.secondary .button.disabled, .button-group.secondary .button[disabled], .button-group.secondary .button.disabled:hover, .button-group.secondary .button[disabled]:hover, .button-group.secondary .button.disabled:focus, .button-group.secondary .button[disabled]:focus { - background-color: #767676; - color: #fefefe; } - .button-group.secondary .button:hover, .button-group.secondary .button:focus { - background-color: #5e5e5e; - color: #fefefe; } - .button-group.success .button, .button-group.success .button.disabled, .button-group.success .button[disabled], .button-group.success .button.disabled:hover, .button-group.success .button[disabled]:hover, .button-group.success .button.disabled:focus, .button-group.success .button[disabled]:focus { - background-color: #3adb76; - color: #0a0a0a; } - .button-group.success .button:hover, .button-group.success .button:focus { - background-color: #22bb5b; - color: #0a0a0a; } - .button-group.warning .button, .button-group.warning .button.disabled, .button-group.warning .button[disabled], .button-group.warning .button.disabled:hover, .button-group.warning .button[disabled]:hover, .button-group.warning .button.disabled:focus, .button-group.warning .button[disabled]:focus { - background-color: #ffae00; - color: #0a0a0a; } - .button-group.warning .button:hover, .button-group.warning .button:focus { - background-color: #cc8b00; - color: #0a0a0a; } - .button-group.alert .button, .button-group.alert .button.disabled, .button-group.alert .button[disabled], .button-group.alert .button.disabled:hover, .button-group.alert .button[disabled]:hover, .button-group.alert .button.disabled:focus, .button-group.alert .button[disabled]:focus { - background-color: #cc4b37; - color: #fefefe; } - .button-group.alert .button:hover, .button-group.alert .button:focus { - background-color: #a53b2a; - color: #fefefe; } - .button-group.hollow .button, .button-group.hollow .button:hover, .button-group.hollow .button:focus, .button-group.hollow .button.disabled, .button-group.hollow .button.disabled:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled], .button-group.hollow .button[disabled]:hover, .button-group.hollow .button[disabled]:focus { - background-color: transparent; } - .button-group.hollow .button, .button-group.hollow .button.disabled, .button-group.hollow .button[disabled], .button-group.hollow .button.disabled:hover, .button-group.hollow .button[disabled]:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled]:focus { - border: 1px solid #1779ba; - color: #1779ba; } - .button-group.hollow .button:hover, .button-group.hollow .button:focus { - border-color: #0c3d5d; - color: #0c3d5d; } - .button-group.hollow.primary .button, .button-group.hollow.primary .button.disabled, .button-group.hollow.primary .button[disabled], .button-group.hollow.primary .button.disabled:hover, .button-group.hollow.primary .button[disabled]:hover, .button-group.hollow.primary .button.disabled:focus, .button-group.hollow.primary .button[disabled]:focus, .button-group.hollow .button.primary, .button-group.hollow .button.primary.disabled, .button-group.hollow .button.primary[disabled], .button-group.hollow .button.primary.disabled:hover, .button-group.hollow .button.primary[disabled]:hover, .button-group.hollow .button.primary.disabled:focus, .button-group.hollow .button.primary[disabled]:focus { - border: 1px solid #1779ba; - color: #1779ba; } - .button-group.hollow.primary .button:hover, .button-group.hollow.primary .button:focus, .button-group.hollow .button.primary:hover, .button-group.hollow .button.primary:focus { - border-color: #0c3d5d; - color: #0c3d5d; } - .button-group.hollow.secondary .button, .button-group.hollow.secondary .button.disabled, .button-group.hollow.secondary .button[disabled], .button-group.hollow.secondary .button.disabled:hover, .button-group.hollow.secondary .button[disabled]:hover, .button-group.hollow.secondary .button.disabled:focus, .button-group.hollow.secondary .button[disabled]:focus, .button-group.hollow .button.secondary, .button-group.hollow .button.secondary.disabled, .button-group.hollow .button.secondary[disabled], .button-group.hollow .button.secondary.disabled:hover, .button-group.hollow .button.secondary[disabled]:hover, .button-group.hollow .button.secondary.disabled:focus, .button-group.hollow .button.secondary[disabled]:focus { - border: 1px solid #767676; - color: #767676; } - .button-group.hollow.secondary .button:hover, .button-group.hollow.secondary .button:focus, .button-group.hollow .button.secondary:hover, .button-group.hollow .button.secondary:focus { - border-color: #3b3b3b; - color: #3b3b3b; } - .button-group.hollow.success .button, .button-group.hollow.success .button.disabled, .button-group.hollow.success .button[disabled], .button-group.hollow.success .button.disabled:hover, .button-group.hollow.success .button[disabled]:hover, .button-group.hollow.success .button.disabled:focus, .button-group.hollow.success .button[disabled]:focus, .button-group.hollow .button.success, .button-group.hollow .button.success.disabled, .button-group.hollow .button.success[disabled], .button-group.hollow .button.success.disabled:hover, .button-group.hollow .button.success[disabled]:hover, .button-group.hollow .button.success.disabled:focus, .button-group.hollow .button.success[disabled]:focus { - border: 1px solid #3adb76; - color: #3adb76; } - .button-group.hollow.success .button:hover, .button-group.hollow.success .button:focus, .button-group.hollow .button.success:hover, .button-group.hollow .button.success:focus { - border-color: #157539; - color: #157539; } - .button-group.hollow.warning .button, .button-group.hollow.warning .button.disabled, .button-group.hollow.warning .button[disabled], .button-group.hollow.warning .button.disabled:hover, .button-group.hollow.warning .button[disabled]:hover, .button-group.hollow.warning .button.disabled:focus, .button-group.hollow.warning .button[disabled]:focus, .button-group.hollow .button.warning, .button-group.hollow .button.warning.disabled, .button-group.hollow .button.warning[disabled], .button-group.hollow .button.warning.disabled:hover, .button-group.hollow .button.warning[disabled]:hover, .button-group.hollow .button.warning.disabled:focus, .button-group.hollow .button.warning[disabled]:focus { - border: 1px solid #ffae00; - color: #ffae00; } - .button-group.hollow.warning .button:hover, .button-group.hollow.warning .button:focus, .button-group.hollow .button.warning:hover, .button-group.hollow .button.warning:focus { - border-color: #805700; - color: #805700; } - .button-group.hollow.alert .button, .button-group.hollow.alert .button.disabled, .button-group.hollow.alert .button[disabled], .button-group.hollow.alert .button.disabled:hover, .button-group.hollow.alert .button[disabled]:hover, .button-group.hollow.alert .button.disabled:focus, .button-group.hollow.alert .button[disabled]:focus, .button-group.hollow .button.alert, .button-group.hollow .button.alert.disabled, .button-group.hollow .button.alert[disabled], .button-group.hollow .button.alert.disabled:hover, .button-group.hollow .button.alert[disabled]:hover, .button-group.hollow .button.alert.disabled:focus, .button-group.hollow .button.alert[disabled]:focus { - border: 1px solid #cc4b37; - color: #cc4b37; } - .button-group.hollow.alert .button:hover, .button-group.hollow.alert .button:focus, .button-group.hollow .button.alert:hover, .button-group.hollow .button.alert:focus { - border-color: #67251a; - color: #67251a; } - .button-group.clear .button, .button-group.clear .button:hover, .button-group.clear .button:focus, .button-group.clear .button.disabled, .button-group.clear .button.disabled:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled], .button-group.clear .button[disabled]:hover, .button-group.clear .button[disabled]:focus { - border-color: transparent; - background-color: transparent; } - .button-group.clear .button, .button-group.clear .button.disabled, .button-group.clear .button[disabled], .button-group.clear .button.disabled:hover, .button-group.clear .button[disabled]:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled]:focus { - color: #1779ba; } - .button-group.clear .button:hover, .button-group.clear .button:focus { - color: #0c3d5d; } - .button-group.clear.primary .button, .button-group.clear.primary .button.disabled, .button-group.clear.primary .button[disabled], .button-group.clear.primary .button.disabled:hover, .button-group.clear.primary .button[disabled]:hover, .button-group.clear.primary .button.disabled:focus, .button-group.clear.primary .button[disabled]:focus, .button-group.clear .button.primary, .button-group.clear .button.primary.disabled, .button-group.clear .button.primary[disabled], .button-group.clear .button.primary.disabled:hover, .button-group.clear .button.primary[disabled]:hover, .button-group.clear .button.primary.disabled:focus, .button-group.clear .button.primary[disabled]:focus { - color: #1779ba; } - .button-group.clear.primary .button:hover, .button-group.clear.primary .button:focus, .button-group.clear .button.primary:hover, .button-group.clear .button.primary:focus { - color: #0c3d5d; } - .button-group.clear.secondary .button, .button-group.clear.secondary .button.disabled, .button-group.clear.secondary .button[disabled], .button-group.clear.secondary .button.disabled:hover, .button-group.clear.secondary .button[disabled]:hover, .button-group.clear.secondary .button.disabled:focus, .button-group.clear.secondary .button[disabled]:focus, .button-group.clear .button.secondary, .button-group.clear .button.secondary.disabled, .button-group.clear .button.secondary[disabled], .button-group.clear .button.secondary.disabled:hover, .button-group.clear .button.secondary[disabled]:hover, .button-group.clear .button.secondary.disabled:focus, .button-group.clear .button.secondary[disabled]:focus { - color: #767676; } - .button-group.clear.secondary .button:hover, .button-group.clear.secondary .button:focus, .button-group.clear .button.secondary:hover, .button-group.clear .button.secondary:focus { - color: #3b3b3b; } - .button-group.clear.success .button, .button-group.clear.success .button.disabled, .button-group.clear.success .button[disabled], .button-group.clear.success .button.disabled:hover, .button-group.clear.success .button[disabled]:hover, .button-group.clear.success .button.disabled:focus, .button-group.clear.success .button[disabled]:focus, .button-group.clear .button.success, .button-group.clear .button.success.disabled, .button-group.clear .button.success[disabled], .button-group.clear .button.success.disabled:hover, .button-group.clear .button.success[disabled]:hover, .button-group.clear .button.success.disabled:focus, .button-group.clear .button.success[disabled]:focus { - color: #3adb76; } - .button-group.clear.success .button:hover, .button-group.clear.success .button:focus, .button-group.clear .button.success:hover, .button-group.clear .button.success:focus { - color: #157539; } - .button-group.clear.warning .button, .button-group.clear.warning .button.disabled, .button-group.clear.warning .button[disabled], .button-group.clear.warning .button.disabled:hover, .button-group.clear.warning .button[disabled]:hover, .button-group.clear.warning .button.disabled:focus, .button-group.clear.warning .button[disabled]:focus, .button-group.clear .button.warning, .button-group.clear .button.warning.disabled, .button-group.clear .button.warning[disabled], .button-group.clear .button.warning.disabled:hover, .button-group.clear .button.warning[disabled]:hover, .button-group.clear .button.warning.disabled:focus, .button-group.clear .button.warning[disabled]:focus { - color: #ffae00; } - .button-group.clear.warning .button:hover, .button-group.clear.warning .button:focus, .button-group.clear .button.warning:hover, .button-group.clear .button.warning:focus { - color: #805700; } - .button-group.clear.alert .button, .button-group.clear.alert .button.disabled, .button-group.clear.alert .button[disabled], .button-group.clear.alert .button.disabled:hover, .button-group.clear.alert .button[disabled]:hover, .button-group.clear.alert .button.disabled:focus, .button-group.clear.alert .button[disabled]:focus, .button-group.clear .button.alert, .button-group.clear .button.alert.disabled, .button-group.clear .button.alert[disabled], .button-group.clear .button.alert.disabled:hover, .button-group.clear .button.alert[disabled]:hover, .button-group.clear .button.alert.disabled:focus, .button-group.clear .button.alert[disabled]:focus { - color: #cc4b37; } - .button-group.clear.alert .button:hover, .button-group.clear.alert .button:focus, .button-group.clear .button.alert:hover, .button-group.clear .button.alert:focus { - color: #67251a; } - .button-group.no-gaps .button { - margin-right: -0.0625rem; } - .button-group.no-gaps .button + .button { - border-left-color: transparent; } - .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button { - width: 100%; } - .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child { - margin-bottom: 0; } - .button-group.stacked.expanded, .button-group.stacked-for-small.expanded, .button-group.stacked-for-medium.expanded { - margin-right: -1px; } - .button-group.stacked.expanded::before, .button-group.stacked.expanded::after, .button-group.stacked-for-small.expanded::before, .button-group.stacked-for-small.expanded::after, .button-group.stacked-for-medium.expanded::before, .button-group.stacked-for-medium.expanded::after { - display: none; } - .button-group.stacked.expanded .button:first-child:last-child, .button-group.stacked-for-small.expanded .button:first-child:last-child, .button-group.stacked-for-medium.expanded .button:first-child:last-child { - width: calc(100% - 1px); } - .button-group.stacked.expanded .button:first-child:nth-last-child(2), .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button { - display: inline-block; - width: calc(50% - 1px); - margin-right: 1px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child { - margin-right: -6px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(3), .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button { - display: inline-block; - width: calc(33.33333% - 1px); - margin-right: 1px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child { - margin-right: -6px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(4), .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button { - display: inline-block; - width: calc(25% - 1px); - margin-right: 1px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child { - margin-right: -6px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(5), .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button { - display: inline-block; - width: calc(20% - 1px); - margin-right: 1px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child { - margin-right: -6px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(6), .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button { - display: inline-block; - width: calc(16.66667% - 1px); - margin-right: 1px; } - .button-group.stacked.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child { - margin-right: -6px; } - @media print, screen and (min-width: 40em) { - .button-group.stacked-for-small .button { - width: auto; - margin-bottom: 0; } } - @media print, screen and (min-width: 64em) { - .button-group.stacked-for-medium .button { - width: auto; - margin-bottom: 0; } } - @media print, screen and (max-width: 39.99875em) { - .button-group.stacked-for-small.expanded { - display: block; } - .button-group.stacked-for-small.expanded .button { - display: block; - margin-right: 0; } } - @media print, screen and (max-width: 63.99875em) { - .button-group.stacked-for-medium.expanded { - display: block; } - .button-group.stacked-for-medium.expanded .button { - display: block; - margin-right: 0; } } + font-size: 0; +} +.button-group::before, .button-group::after { + display: table; + content: " "; +} +.button-group::after { + clear: both; +} +.button-group .button { + margin: 0; + margin-right: 1px; + margin-bottom: 1px; + font-size: 0.9rem; +} +.button-group .button:last-child { + margin-right: 0; +} +.button-group.tiny .button { + font-size: 0.6rem; +} +.button-group.small .button { + font-size: 0.75rem; +} +.button-group.large .button { + font-size: 1.25rem; +} +.button-group.expanded { + margin-right: -1px; +} +.button-group.expanded::before, .button-group.expanded::after { + display: none; +} +.button-group.expanded .button:first-child:last-child { + width: calc(100% - 1px); +} +.button-group.expanded .button:first-child:nth-last-child(2), .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button { + display: inline-block; + width: calc(50% - 1px); + margin-right: 1px; +} +.button-group.expanded .button:first-child:nth-last-child(2):last-child, .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child { + margin-right: -6px; +} +.button-group.expanded .button:first-child:nth-last-child(3), .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button { + display: inline-block; + width: calc(33.3333333333% - 1px); + margin-right: 1px; +} +.button-group.expanded .button:first-child:nth-last-child(3):last-child, .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child { + margin-right: -6px; +} +.button-group.expanded .button:first-child:nth-last-child(4), .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button { + display: inline-block; + width: calc(25% - 1px); + margin-right: 1px; +} +.button-group.expanded .button:first-child:nth-last-child(4):last-child, .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child { + margin-right: -6px; +} +.button-group.expanded .button:first-child:nth-last-child(5), .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button { + display: inline-block; + width: calc(20% - 1px); + margin-right: 1px; +} +.button-group.expanded .button:first-child:nth-last-child(5):last-child, .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child { + margin-right: -6px; +} +.button-group.expanded .button:first-child:nth-last-child(6), .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button { + display: inline-block; + width: calc(16.6666666667% - 1px); + margin-right: 1px; +} +.button-group.expanded .button:first-child:nth-last-child(6):last-child, .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child { + margin-right: -6px; +} +.button-group.primary .button, .button-group.primary .button.disabled, .button-group.primary .button[disabled], .button-group.primary .button.disabled:hover, .button-group.primary .button[disabled]:hover, .button-group.primary .button.disabled:focus, .button-group.primary .button[disabled]:focus { + background-color: #1779ba; + color: #fefefe; +} +.button-group.primary .button:hover, .button-group.primary .button:focus { + background-color: #126195; + color: #fefefe; +} +.button-group.secondary .button, .button-group.secondary .button.disabled, .button-group.secondary .button[disabled], .button-group.secondary .button.disabled:hover, .button-group.secondary .button[disabled]:hover, .button-group.secondary .button.disabled:focus, .button-group.secondary .button[disabled]:focus { + background-color: #767676; + color: #fefefe; +} +.button-group.secondary .button:hover, .button-group.secondary .button:focus { + background-color: #5e5e5e; + color: #fefefe; +} +.button-group.success .button, .button-group.success .button.disabled, .button-group.success .button[disabled], .button-group.success .button.disabled:hover, .button-group.success .button[disabled]:hover, .button-group.success .button.disabled:focus, .button-group.success .button[disabled]:focus { + background-color: #3adb76; + color: #0a0a0a; +} +.button-group.success .button:hover, .button-group.success .button:focus { + background-color: #22bb5b; + color: #0a0a0a; +} +.button-group.warning .button, .button-group.warning .button.disabled, .button-group.warning .button[disabled], .button-group.warning .button.disabled:hover, .button-group.warning .button[disabled]:hover, .button-group.warning .button.disabled:focus, .button-group.warning .button[disabled]:focus { + background-color: #ffae00; + color: #0a0a0a; +} +.button-group.warning .button:hover, .button-group.warning .button:focus { + background-color: #cc8b00; + color: #0a0a0a; +} +.button-group.alert .button, .button-group.alert .button.disabled, .button-group.alert .button[disabled], .button-group.alert .button.disabled:hover, .button-group.alert .button[disabled]:hover, .button-group.alert .button.disabled:focus, .button-group.alert .button[disabled]:focus { + background-color: #cc4b37; + color: #fefefe; +} +.button-group.alert .button:hover, .button-group.alert .button:focus { + background-color: #a53b2a; + color: #fefefe; +} +.button-group.hollow .button, .button-group.hollow .button:hover, .button-group.hollow .button:focus, .button-group.hollow .button.disabled, .button-group.hollow .button.disabled:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled], .button-group.hollow .button[disabled]:hover, .button-group.hollow .button[disabled]:focus { + background-color: transparent; +} +.button-group.hollow .button, .button-group.hollow .button.disabled, .button-group.hollow .button[disabled], .button-group.hollow .button.disabled:hover, .button-group.hollow .button[disabled]:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled]:focus { + border: 1px solid #1779ba; + color: #1779ba; +} +.button-group.hollow .button:hover, .button-group.hollow .button:focus { + border-color: #0c3d5d; + color: #0c3d5d; +} +.button-group.hollow.primary .button, .button-group.hollow.primary .button.disabled, .button-group.hollow.primary .button[disabled], .button-group.hollow.primary .button.disabled:hover, .button-group.hollow.primary .button[disabled]:hover, .button-group.hollow.primary .button.disabled:focus, .button-group.hollow.primary .button[disabled]:focus, .button-group.hollow .button.primary, .button-group.hollow .button.primary.disabled, .button-group.hollow .button.primary[disabled], .button-group.hollow .button.primary.disabled:hover, .button-group.hollow .button.primary[disabled]:hover, .button-group.hollow .button.primary.disabled:focus, .button-group.hollow .button.primary[disabled]:focus { + border: 1px solid #1779ba; + color: #1779ba; +} +.button-group.hollow.primary .button:hover, .button-group.hollow.primary .button:focus, .button-group.hollow .button.primary:hover, .button-group.hollow .button.primary:focus { + border-color: #0c3d5d; + color: #0c3d5d; +} +.button-group.hollow.secondary .button, .button-group.hollow.secondary .button.disabled, .button-group.hollow.secondary .button[disabled], .button-group.hollow.secondary .button.disabled:hover, .button-group.hollow.secondary .button[disabled]:hover, .button-group.hollow.secondary .button.disabled:focus, .button-group.hollow.secondary .button[disabled]:focus, .button-group.hollow .button.secondary, .button-group.hollow .button.secondary.disabled, .button-group.hollow .button.secondary[disabled], .button-group.hollow .button.secondary.disabled:hover, .button-group.hollow .button.secondary[disabled]:hover, .button-group.hollow .button.secondary.disabled:focus, .button-group.hollow .button.secondary[disabled]:focus { + border: 1px solid #767676; + color: #767676; +} +.button-group.hollow.secondary .button:hover, .button-group.hollow.secondary .button:focus, .button-group.hollow .button.secondary:hover, .button-group.hollow .button.secondary:focus { + border-color: #3b3b3b; + color: #3b3b3b; +} +.button-group.hollow.success .button, .button-group.hollow.success .button.disabled, .button-group.hollow.success .button[disabled], .button-group.hollow.success .button.disabled:hover, .button-group.hollow.success .button[disabled]:hover, .button-group.hollow.success .button.disabled:focus, .button-group.hollow.success .button[disabled]:focus, .button-group.hollow .button.success, .button-group.hollow .button.success.disabled, .button-group.hollow .button.success[disabled], .button-group.hollow .button.success.disabled:hover, .button-group.hollow .button.success[disabled]:hover, .button-group.hollow .button.success.disabled:focus, .button-group.hollow .button.success[disabled]:focus { + border: 1px solid #3adb76; + color: #3adb76; +} +.button-group.hollow.success .button:hover, .button-group.hollow.success .button:focus, .button-group.hollow .button.success:hover, .button-group.hollow .button.success:focus { + border-color: #157539; + color: #157539; +} +.button-group.hollow.warning .button, .button-group.hollow.warning .button.disabled, .button-group.hollow.warning .button[disabled], .button-group.hollow.warning .button.disabled:hover, .button-group.hollow.warning .button[disabled]:hover, .button-group.hollow.warning .button.disabled:focus, .button-group.hollow.warning .button[disabled]:focus, .button-group.hollow .button.warning, .button-group.hollow .button.warning.disabled, .button-group.hollow .button.warning[disabled], .button-group.hollow .button.warning.disabled:hover, .button-group.hollow .button.warning[disabled]:hover, .button-group.hollow .button.warning.disabled:focus, .button-group.hollow .button.warning[disabled]:focus { + border: 1px solid #ffae00; + color: #ffae00; +} +.button-group.hollow.warning .button:hover, .button-group.hollow.warning .button:focus, .button-group.hollow .button.warning:hover, .button-group.hollow .button.warning:focus { + border-color: #805700; + color: #805700; +} +.button-group.hollow.alert .button, .button-group.hollow.alert .button.disabled, .button-group.hollow.alert .button[disabled], .button-group.hollow.alert .button.disabled:hover, .button-group.hollow.alert .button[disabled]:hover, .button-group.hollow.alert .button.disabled:focus, .button-group.hollow.alert .button[disabled]:focus, .button-group.hollow .button.alert, .button-group.hollow .button.alert.disabled, .button-group.hollow .button.alert[disabled], .button-group.hollow .button.alert.disabled:hover, .button-group.hollow .button.alert[disabled]:hover, .button-group.hollow .button.alert.disabled:focus, .button-group.hollow .button.alert[disabled]:focus { + border: 1px solid #cc4b37; + color: #cc4b37; +} +.button-group.hollow.alert .button:hover, .button-group.hollow.alert .button:focus, .button-group.hollow .button.alert:hover, .button-group.hollow .button.alert:focus { + border-color: #67251a; + color: #67251a; +} +.button-group.clear .button, .button-group.clear .button:hover, .button-group.clear .button:focus, .button-group.clear .button.disabled, .button-group.clear .button.disabled:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled], .button-group.clear .button[disabled]:hover, .button-group.clear .button[disabled]:focus { + border-color: transparent; + background-color: transparent; +} +.button-group.clear .button, .button-group.clear .button.disabled, .button-group.clear .button[disabled], .button-group.clear .button.disabled:hover, .button-group.clear .button[disabled]:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled]:focus { + color: #1779ba; +} +.button-group.clear .button:hover, .button-group.clear .button:focus { + color: #0c3d5d; +} +.button-group.clear.primary .button, .button-group.clear.primary .button.disabled, .button-group.clear.primary .button[disabled], .button-group.clear.primary .button.disabled:hover, .button-group.clear.primary .button[disabled]:hover, .button-group.clear.primary .button.disabled:focus, .button-group.clear.primary .button[disabled]:focus, .button-group.clear .button.primary, .button-group.clear .button.primary.disabled, .button-group.clear .button.primary[disabled], .button-group.clear .button.primary.disabled:hover, .button-group.clear .button.primary[disabled]:hover, .button-group.clear .button.primary.disabled:focus, .button-group.clear .button.primary[disabled]:focus { + color: #1779ba; +} +.button-group.clear.primary .button:hover, .button-group.clear.primary .button:focus, .button-group.clear .button.primary:hover, .button-group.clear .button.primary:focus { + color: #0c3d5d; +} +.button-group.clear.secondary .button, .button-group.clear.secondary .button.disabled, .button-group.clear.secondary .button[disabled], .button-group.clear.secondary .button.disabled:hover, .button-group.clear.secondary .button[disabled]:hover, .button-group.clear.secondary .button.disabled:focus, .button-group.clear.secondary .button[disabled]:focus, .button-group.clear .button.secondary, .button-group.clear .button.secondary.disabled, .button-group.clear .button.secondary[disabled], .button-group.clear .button.secondary.disabled:hover, .button-group.clear .button.secondary[disabled]:hover, .button-group.clear .button.secondary.disabled:focus, .button-group.clear .button.secondary[disabled]:focus { + color: #767676; +} +.button-group.clear.secondary .button:hover, .button-group.clear.secondary .button:focus, .button-group.clear .button.secondary:hover, .button-group.clear .button.secondary:focus { + color: #3b3b3b; +} +.button-group.clear.success .button, .button-group.clear.success .button.disabled, .button-group.clear.success .button[disabled], .button-group.clear.success .button.disabled:hover, .button-group.clear.success .button[disabled]:hover, .button-group.clear.success .button.disabled:focus, .button-group.clear.success .button[disabled]:focus, .button-group.clear .button.success, .button-group.clear .button.success.disabled, .button-group.clear .button.success[disabled], .button-group.clear .button.success.disabled:hover, .button-group.clear .button.success[disabled]:hover, .button-group.clear .button.success.disabled:focus, .button-group.clear .button.success[disabled]:focus { + color: #3adb76; +} +.button-group.clear.success .button:hover, .button-group.clear.success .button:focus, .button-group.clear .button.success:hover, .button-group.clear .button.success:focus { + color: #157539; +} +.button-group.clear.warning .button, .button-group.clear.warning .button.disabled, .button-group.clear.warning .button[disabled], .button-group.clear.warning .button.disabled:hover, .button-group.clear.warning .button[disabled]:hover, .button-group.clear.warning .button.disabled:focus, .button-group.clear.warning .button[disabled]:focus, .button-group.clear .button.warning, .button-group.clear .button.warning.disabled, .button-group.clear .button.warning[disabled], .button-group.clear .button.warning.disabled:hover, .button-group.clear .button.warning[disabled]:hover, .button-group.clear .button.warning.disabled:focus, .button-group.clear .button.warning[disabled]:focus { + color: #ffae00; +} +.button-group.clear.warning .button:hover, .button-group.clear.warning .button:focus, .button-group.clear .button.warning:hover, .button-group.clear .button.warning:focus { + color: #805700; +} +.button-group.clear.alert .button, .button-group.clear.alert .button.disabled, .button-group.clear.alert .button[disabled], .button-group.clear.alert .button.disabled:hover, .button-group.clear.alert .button[disabled]:hover, .button-group.clear.alert .button.disabled:focus, .button-group.clear.alert .button[disabled]:focus, .button-group.clear .button.alert, .button-group.clear .button.alert.disabled, .button-group.clear .button.alert[disabled], .button-group.clear .button.alert.disabled:hover, .button-group.clear .button.alert[disabled]:hover, .button-group.clear .button.alert.disabled:focus, .button-group.clear .button.alert[disabled]:focus { + color: #cc4b37; +} +.button-group.clear.alert .button:hover, .button-group.clear.alert .button:focus, .button-group.clear .button.alert:hover, .button-group.clear .button.alert:focus { + color: #67251a; +} +.button-group.no-gaps .button { + margin-right: -0.0625rem; +} +.button-group.no-gaps .button + .button { + border-left-color: transparent; +} +.button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button { + width: 100%; +} +.button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child { + margin-bottom: 0; +} +.button-group.stacked.expanded, .button-group.stacked-for-small.expanded, .button-group.stacked-for-medium.expanded { + margin-right: -1px; +} +.button-group.stacked.expanded::before, .button-group.stacked.expanded::after, .button-group.stacked-for-small.expanded::before, .button-group.stacked-for-small.expanded::after, .button-group.stacked-for-medium.expanded::before, .button-group.stacked-for-medium.expanded::after { + display: none; +} +.button-group.stacked.expanded .button:first-child:last-child, .button-group.stacked-for-small.expanded .button:first-child:last-child, .button-group.stacked-for-medium.expanded .button:first-child:last-child { + width: calc(100% - 1px); +} +.button-group.stacked.expanded .button:first-child:nth-last-child(2), .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button { + display: inline-block; + width: calc(50% - 1px); + margin-right: 1px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child { + margin-right: -6px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(3), .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button { + display: inline-block; + width: calc(33.3333333333% - 1px); + margin-right: 1px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child { + margin-right: -6px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(4), .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button { + display: inline-block; + width: calc(25% - 1px); + margin-right: 1px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child { + margin-right: -6px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(5), .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button { + display: inline-block; + width: calc(20% - 1px); + margin-right: 1px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child { + margin-right: -6px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(6), .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button { + display: inline-block; + width: calc(16.6666666667% - 1px); + margin-right: 1px; +} +.button-group.stacked.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child { + margin-right: -6px; +} +@media print, screen and (min-width: 40em) { + .button-group.stacked-for-small .button { + width: auto; + margin-bottom: 0; + } +} +@media print, screen and (min-width: 64em) { + .button-group.stacked-for-medium .button { + width: auto; + margin-bottom: 0; + } +} +@media print, screen and (max-width: 39.99875em) { + .button-group.stacked-for-small.expanded { + display: block; + } + .button-group.stacked-for-small.expanded .button { + display: block; + margin-right: 0; + } +} +@media print, screen and (max-width: 63.99875em) { + .button-group.stacked-for-medium.expanded { + display: block; + } + .button-group.stacked-for-medium.expanded .button { + display: block; + margin-right: 0; + } +} .close-button { position: absolute; z-index: 10; color: #8a8a8a; - cursor: pointer; } - [data-whatinput='mouse'] .close-button { - outline: 0; } - .close-button:hover, .close-button:focus { - color: #0a0a0a; } - .close-button.small { - right: 0.66rem; - top: 0.33em; - font-size: 1.5em; - line-height: 1; } - .close-button, .close-button.medium { - right: 1rem; - top: 0.5rem; - font-size: 2em; - line-height: 1; } + cursor: pointer; +} +[data-whatinput=mouse] .close-button { + outline: 0; +} +.close-button:hover, .close-button:focus { + color: #0a0a0a; +} +.close-button.small { + right: 0.66rem; + top: 0.33em; + font-size: 1.5em; + line-height: 1; +} + +.close-button.medium, .close-button { + right: 1rem; + top: 0.5rem; + font-size: 2em; + line-height: 1; +} .label { display: inline-block; @@ -2034,45 +2647,58 @@ a.button:hover, a.button:focus { white-space: nowrap; cursor: default; background: #1779ba; - color: #fefefe; } - .label.primary { - background: #1779ba; - color: #fefefe; } - .label.secondary { - background: #767676; - color: #fefefe; } - .label.success { - background: #3adb76; - color: #0a0a0a; } - .label.warning { - background: #ffae00; - color: #0a0a0a; } - .label.alert { - background: #cc4b37; - color: #fefefe; } + color: #fefefe; +} +.label.primary { + background: #1779ba; + color: #fefefe; +} +.label.secondary { + background: #767676; + color: #fefefe; +} +.label.success { + background: #3adb76; + color: #0a0a0a; +} +.label.warning { + background: #ffae00; + color: #0a0a0a; +} +.label.alert { + background: #cc4b37; + color: #fefefe; +} .progress { height: 1rem; margin-bottom: 1rem; border-radius: 0; - background-color: #cacaca; } - .progress.primary .progress-meter { - background-color: #1779ba; } - .progress.secondary .progress-meter { - background-color: #767676; } - .progress.success .progress-meter { - background-color: #3adb76; } - .progress.warning .progress-meter { - background-color: #ffae00; } - .progress.alert .progress-meter { - background-color: #cc4b37; } + background-color: #cacaca; +} +.progress.primary .progress-meter { + background-color: #1779ba; +} +.progress.secondary .progress-meter { + background-color: #767676; +} +.progress.success .progress-meter { + background-color: #3adb76; +} +.progress.warning .progress-meter { + background-color: #ffae00; +} +.progress.alert .progress-meter { + background-color: #cc4b37; +} .progress-meter { position: relative; display: block; width: 0%; height: 100%; - background-color: #1779ba; } + background-color: #1779ba; +} .progress-meter-text { position: absolute; @@ -2085,7 +2711,8 @@ a.button:hover, a.button:focus { font-size: 0.75rem; font-weight: bold; color: #fefefe; - white-space: nowrap; } + white-space: nowrap; +} .slider { position: relative; @@ -2099,7 +2726,8 @@ a.button:hover, a.button:focus { -ms-user-select: none; user-select: none; -ms-touch-action: none; - touch-action: none; } + touch-action: none; +} .slider-fill { position: absolute; @@ -2110,10 +2738,12 @@ a.button:hover, a.button:focus { height: 0.5rem; background-color: #cacaca; -webkit-transition: all 0.2s ease-in-out; - transition: all 0.2s ease-in-out; } - .slider-fill.is-dragging { - -webkit-transition: all 0s linear; - transition: all 0s linear; } + transition: all 0.2s ease-in-out; +} +.slider-fill.is-dragging { + -webkit-transition: all 0s linear; + transition: all 0s linear; +} .slider-handle { position: absolute; @@ -2133,21 +2763,26 @@ a.button:hover, a.button:focus { -webkit-transition: all 0.2s ease-in-out; transition: all 0.2s ease-in-out; -ms-touch-action: manipulation; - touch-action: manipulation; } - [data-whatinput='mouse'] .slider-handle { - outline: 0; } - .slider-handle:hover { - background-color: #14679e; } - .slider-handle.is-dragging { - -webkit-transition: all 0s linear; - transition: all 0s linear; - cursor: -webkit-grabbing; - cursor: grabbing; } + touch-action: manipulation; +} +[data-whatinput=mouse] .slider-handle { + outline: 0; +} +.slider-handle:hover { + background-color: #14679e; +} +.slider-handle.is-dragging { + -webkit-transition: all 0s linear; + transition: all 0s linear; + cursor: -webkit-grabbing; + cursor: grabbing; +} .slider.disabled, .slider[disabled] { opacity: 0.25; - cursor: not-allowed; } + cursor: not-allowed; +} .slider.vertical { display: inline-block; @@ -2156,20 +2791,23 @@ a.button:hover, a.button:focus { margin: 0 1.25rem; -webkit-transform: scale(1, -1); -ms-transform: scale(1, -1); - transform: scale(1, -1); } - .slider.vertical .slider-fill { - top: 0; - width: 0.5rem; - max-height: 100%; } - .slider.vertical .slider-handle { - position: absolute; - top: 0; - left: 50%; - width: 1.4rem; - height: 1.4rem; - -webkit-transform: translateX(-50%); - -ms-transform: translateX(-50%); - transform: translateX(-50%); } + transform: scale(1, -1); +} +.slider.vertical .slider-fill { + top: 0; + width: 0.5rem; + max-height: 100%; +} +.slider.vertical .slider-handle { + position: absolute; + top: 0; + left: 50%; + width: 1.4rem; + height: 1.4rem; + -webkit-transform: translateX(-50%); + -ms-transform: translateX(-50%); + transform: translateX(-50%); +} .switch { position: relative; @@ -2182,12 +2820,14 @@ a.button:hover, a.button:focus { -moz-user-select: none; -ms-user-select: none; user-select: none; - height: 2rem; } + height: 2rem; +} .switch-input { position: absolute; margin-bottom: 0; - opacity: 0; } + opacity: 0; +} .switch-paddle { position: relative; @@ -2200,165 +2840,215 @@ a.button:hover, a.button:focus { transition: all 0.25s ease-out; font-weight: inherit; color: inherit; - cursor: pointer; } - input + .switch-paddle { - margin: 0; } - .switch-paddle::after { - position: absolute; - top: 0.25rem; - left: 0.25rem; - display: block; - width: 1.5rem; - height: 1.5rem; - -webkit-transform: translate3d(0, 0, 0); - transform: translate3d(0, 0, 0); - border-radius: 0; - background: #fefefe; - -webkit-transition: all 0.25s ease-out; - transition: all 0.25s ease-out; - content: ''; } - input:checked ~ .switch-paddle { - background: #1779ba; } - input:checked ~ .switch-paddle::after { - left: 2.25rem; } - input:disabled ~ .switch-paddle { - cursor: not-allowed; - opacity: 0.5; } - [data-whatinput='mouse'] input:focus ~ .switch-paddle { - outline: 0; } - -.switch-active, .switch-inactive { + cursor: pointer; +} +input + .switch-paddle { + margin: 0; +} +.switch-paddle::after { + position: absolute; + top: 0.25rem; + left: 0.25rem; + display: block; + width: 1.5rem; + height: 1.5rem; + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + border-radius: 0; + background: #fefefe; + -webkit-transition: all 0.25s ease-out; + transition: all 0.25s ease-out; + content: ""; +} +input:checked ~ .switch-paddle { + background: #1779ba; +} +input:checked ~ .switch-paddle::after { + left: 2.25rem; +} +input:disabled ~ .switch-paddle { + cursor: not-allowed; + opacity: 0.5; +} +[data-whatinput=mouse] input:focus ~ .switch-paddle { + outline: 0; +} + +.switch-inactive, .switch-active { position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); - transform: translateY(-50%); } + transform: translateY(-50%); +} .switch-active { left: 8%; - display: none; } - input:checked + label > .switch-active { - display: block; } + display: none; +} +input:checked + label > .switch-active { + display: block; +} .switch-inactive { - right: 15%; } - input:checked + label > .switch-inactive { - display: none; } + right: 15%; +} +input:checked + label > .switch-inactive { + display: none; +} .switch.tiny { - height: 1.5rem; } - .switch.tiny .switch-paddle { - width: 3rem; - height: 1.5rem; - font-size: 0.625rem; } - .switch.tiny .switch-paddle::after { - top: 0.25rem; - left: 0.25rem; - width: 1rem; - height: 1rem; } - .switch.tiny input:checked ~ .switch-paddle::after { - left: 1.75rem; } + height: 1.5rem; +} +.switch.tiny .switch-paddle { + width: 3rem; + height: 1.5rem; + font-size: 0.625rem; +} +.switch.tiny .switch-paddle::after { + top: 0.25rem; + left: 0.25rem; + width: 1rem; + height: 1rem; +} +.switch.tiny input:checked ~ .switch-paddle::after { + left: 1.75rem; +} .switch.small { - height: 1.75rem; } - .switch.small .switch-paddle { - width: 3.5rem; - height: 1.75rem; - font-size: 0.75rem; } - .switch.small .switch-paddle::after { - top: 0.25rem; - left: 0.25rem; - width: 1.25rem; - height: 1.25rem; } - .switch.small input:checked ~ .switch-paddle::after { - left: 2rem; } + height: 1.75rem; +} +.switch.small .switch-paddle { + width: 3.5rem; + height: 1.75rem; + font-size: 0.75rem; +} +.switch.small .switch-paddle::after { + top: 0.25rem; + left: 0.25rem; + width: 1.25rem; + height: 1.25rem; +} +.switch.small input:checked ~ .switch-paddle::after { + left: 2rem; +} .switch.large { - height: 2.5rem; } - .switch.large .switch-paddle { - width: 5rem; - height: 2.5rem; - font-size: 1rem; } - .switch.large .switch-paddle::after { - top: 0.25rem; - left: 0.25rem; - width: 2rem; - height: 2rem; } - .switch.large input:checked ~ .switch-paddle::after { - left: 2.75rem; } + height: 2.5rem; +} +.switch.large .switch-paddle { + width: 5rem; + height: 2.5rem; + font-size: 1rem; +} +.switch.large .switch-paddle::after { + top: 0.25rem; + left: 0.25rem; + width: 2rem; + height: 2rem; +} +.switch.large input:checked ~ .switch-paddle::after { + left: 2.75rem; +} table { border-collapse: collapse; width: 100%; margin-bottom: 1rem; - border-radius: 0; } - thead, - tbody, - tfoot { - border: 1px solid #f1f1f1; - background-color: #fefefe; } - caption { - padding: 0.5rem 0.625rem 0.625rem; - font-weight: bold; } - thead { - background: #f8f8f8; - color: #0a0a0a; } - tfoot { - background: #f1f1f1; - color: #0a0a0a; } - thead tr, - tfoot tr { - background: transparent; } - thead th, - thead td, - tfoot th, - tfoot td { - padding: 0.5rem 0.625rem 0.625rem; - font-weight: bold; - text-align: left; } - tbody th, - tbody td { - padding: 0.5rem 0.625rem 0.625rem; } - tbody tr:nth-child(even) { - border-bottom: 0; - background-color: #f1f1f1; } - table.unstriped tbody { - background-color: #fefefe; } - table.unstriped tbody tr { - border-bottom: 1px solid #f1f1f1; - background-color: #fefefe; } + border-radius: 0; +} +thead, +tbody, +tfoot { + border: 1px solid #f1f1f1; + background-color: #fefefe; +} + +caption { + padding: 0.5rem 0.625rem 0.625rem; + font-weight: bold; +} + +thead { + background: #f8f8f8; + color: #0a0a0a; +} + +tfoot { + background: #f1f1f1; + color: #0a0a0a; +} + +thead tr, +tfoot tr { + background: transparent; +} +thead th, +thead td, +tfoot th, +tfoot td { + padding: 0.5rem 0.625rem 0.625rem; + font-weight: bold; + text-align: left; +} + +tbody th, +tbody td { + padding: 0.5rem 0.625rem 0.625rem; +} + +tbody tr:nth-child(even) { + border-bottom: 0; + background-color: #f1f1f1; +} + +table.unstriped tbody { + background-color: #fefefe; +} +table.unstriped tbody tr { + border-bottom: 1px solid #f1f1f1; + background-color: #fefefe; +} @media print, screen and (max-width: 63.99875em) { table.stack thead { - display: none; } + display: none; + } table.stack tfoot { - display: none; } + display: none; + } table.stack tr, table.stack th, table.stack td { - display: block; } + display: block; + } table.stack td { - border-top: 0; } } + border-top: 0; + } +} table.scroll { display: block; width: 100%; - overflow-x: auto; } + overflow-x: auto; +} table.hover thead tr:hover { - background-color: #f3f3f3; } - + background-color: #f3f3f3; +} table.hover tfoot tr:hover { - background-color: #ececec; } - + background-color: #ececec; +} table.hover tbody tr:hover { - background-color: #f9f9f9; } - + background-color: #f9f9f9; +} table.hover:not(.unstriped) tr:nth-of-type(even):hover { - background-color: #ececec; } + background-color: #ececec; +} .table-scroll { - overflow-x: auto; } + overflow-x: auto; +} .badge { display: inline-block; @@ -2368,50 +3058,64 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { font-size: 0.6rem; text-align: center; background: #1779ba; - color: #fefefe; } - .badge.primary { - background: #1779ba; - color: #fefefe; } - .badge.secondary { - background: #767676; - color: #fefefe; } - .badge.success { - background: #3adb76; - color: #0a0a0a; } - .badge.warning { - background: #ffae00; - color: #0a0a0a; } - .badge.alert { - background: #cc4b37; - color: #fefefe; } + color: #fefefe; +} +.badge.primary { + background: #1779ba; + color: #fefefe; +} +.badge.secondary { + background: #767676; + color: #fefefe; +} +.badge.success { + background: #3adb76; + color: #0a0a0a; +} +.badge.warning { + background: #ffae00; + color: #0a0a0a; +} +.badge.alert { + background: #cc4b37; + color: #fefefe; +} .breadcrumbs { margin: 0 0 1rem 0; - list-style: none; } - .breadcrumbs::before, .breadcrumbs::after { - display: table; - content: ' '; } - .breadcrumbs::after { - clear: both; } - .breadcrumbs li { - float: left; - font-size: 0.6875rem; - color: #0a0a0a; - cursor: default; - text-transform: uppercase; } - .breadcrumbs li:not(:last-child)::after { - position: relative; - margin: 0 0.75rem; - opacity: 1; - content: "/"; - color: #cacaca; } - .breadcrumbs a { - color: #1779ba; } - .breadcrumbs a:hover { - text-decoration: underline; } - .breadcrumbs .disabled { - color: #cacaca; - cursor: not-allowed; } + list-style: none; +} +.breadcrumbs::before, .breadcrumbs::after { + display: table; + content: " "; +} +.breadcrumbs::after { + clear: both; +} +.breadcrumbs li { + float: left; + font-size: 0.6875rem; + color: #0a0a0a; + cursor: default; + text-transform: uppercase; +} +.breadcrumbs li:not(:last-child)::after { + position: relative; + margin: 0 0.75rem; + opacity: 1; + content: "/"; + color: #cacaca; +} +.breadcrumbs a { + color: #1779ba; +} +.breadcrumbs a:hover { + text-decoration: underline; +} +.breadcrumbs .disabled { + color: #cacaca; + cursor: not-allowed; +} .callout { position: relative; @@ -2420,36 +3124,46 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { border: 1px solid rgba(10, 10, 10, 0.25); border-radius: 0; background-color: white; - color: #0a0a0a; } - .callout > :first-child { - margin-top: 0; } - .callout > :last-child { - margin-bottom: 0; } - .callout.primary { - background-color: #d7ecfa; - color: #0a0a0a; } - .callout.secondary { - background-color: #eaeaea; - color: #0a0a0a; } - .callout.success { - background-color: #e1faea; - color: #0a0a0a; } - .callout.warning { - background-color: #fff3d9; - color: #0a0a0a; } - .callout.alert { - background-color: #f7e4e1; - color: #0a0a0a; } - .callout.small { - padding-top: 0.5rem; - padding-right: 0.5rem; - padding-bottom: 0.5rem; - padding-left: 0.5rem; } - .callout.large { - padding-top: 3rem; - padding-right: 3rem; - padding-bottom: 3rem; - padding-left: 3rem; } + color: #0a0a0a; +} +.callout > :first-child { + margin-top: 0; +} +.callout > :last-child { + margin-bottom: 0; +} +.callout.primary { + background-color: #d7ecfa; + color: #0a0a0a; +} +.callout.secondary { + background-color: #eaeaea; + color: #0a0a0a; +} +.callout.success { + background-color: #e1faea; + color: #0a0a0a; +} +.callout.warning { + background-color: #fff3d9; + color: #0a0a0a; +} +.callout.alert { + background-color: #f7e4e1; + color: #0a0a0a; +} +.callout.small { + padding-top: 0.5rem; + padding-right: 0.5rem; + padding-bottom: 0.5rem; + padding-left: 0.5rem; +} +.callout.large { + padding-top: 3rem; + padding-right: 3rem; + padding-bottom: 3rem; + padding-left: 3rem; +} .card { margin-bottom: 1rem; @@ -2459,23 +3173,30 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { -webkit-box-shadow: none; box-shadow: none; overflow: hidden; - color: #0a0a0a; } - .card > :last-child { - margin-bottom: 0; } + color: #0a0a0a; +} +.card > :last-child { + margin-bottom: 0; +} .card-divider { padding: 1rem; - background: #e6e6e6; } - .card-divider > :last-child { - margin-bottom: 0; } + background: #e6e6e6; +} +.card-divider > :last-child { + margin-bottom: 0; +} .card-section { - padding: 1rem; } - .card-section > :last-child { - margin-bottom: 0; } + padding: 1rem; +} +.card-section > :last-child { + margin-bottom: 0; +} .card-image { - min-height: 1px; } + min-height: 1px; +} .dropdown-pane { position: absolute; @@ -2487,83 +3208,105 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { border: 1px solid #cacaca; border-radius: 0; background-color: #fefefe; - font-size: 1rem; } - .dropdown-pane.is-opening { - display: block; } - .dropdown-pane.is-open { - display: block; - visibility: visible; } + font-size: 1rem; +} +.dropdown-pane.is-opening { + display: block; +} +.dropdown-pane.is-open { + display: block; + visibility: visible; +} .dropdown-pane.tiny { - width: 100px; } + width: 100px; +} .dropdown-pane.small { - width: 200px; } + width: 200px; +} .dropdown-pane.large { - width: 400px; } + width: 400px; +} .pagination { margin-left: 0; - margin-bottom: 1rem; } - .pagination::before, .pagination::after { - display: table; - content: ' '; } - .pagination::after { - clear: both; } + margin-bottom: 1rem; +} +.pagination::before, .pagination::after { + display: table; + content: " "; +} +.pagination::after { + clear: both; +} +.pagination li { + margin-right: 0.0625rem; + border-radius: 0; + font-size: 0.875rem; + display: none; +} +.pagination li:last-child, .pagination li:first-child { + display: inline-block; +} +@media print, screen and (min-width: 40em) { .pagination li { - margin-right: 0.0625rem; - border-radius: 0; - font-size: 0.875rem; - display: none; } - .pagination li:last-child, .pagination li:first-child { - display: inline-block; } - @media print, screen and (min-width: 40em) { - .pagination li { - display: inline-block; } } - .pagination a, - .pagination button { - display: block; - padding: 0.1875rem 0.625rem; - border-radius: 0; - color: #0a0a0a; } - .pagination a:hover, - .pagination button:hover { - background: #e6e6e6; } - .pagination .current { - padding: 0.1875rem 0.625rem; - background: #1779ba; - color: #fefefe; - cursor: default; } - .pagination .disabled { - padding: 0.1875rem 0.625rem; - color: #cacaca; - cursor: not-allowed; } - .pagination .disabled:hover { - background: transparent; } - .pagination .ellipsis::after { - padding: 0.1875rem 0.625rem; - content: '\2026'; - color: #0a0a0a; } + display: inline-block; + } +} +.pagination a, +.pagination button { + display: block; + padding: 0.1875rem 0.625rem; + border-radius: 0; + color: #0a0a0a; +} +.pagination a:hover, +.pagination button:hover { + background: #e6e6e6; +} +.pagination .current { + padding: 0.1875rem 0.625rem; + background: #1779ba; + color: #fefefe; + cursor: default; +} +.pagination .disabled { + padding: 0.1875rem 0.625rem; + color: #cacaca; + cursor: not-allowed; +} +.pagination .disabled:hover { + background: transparent; +} +.pagination .ellipsis::after { + padding: 0.1875rem 0.625rem; + content: "…"; + color: #0a0a0a; +} .pagination-previous a::before, .pagination-previous.disabled::before { display: inline-block; margin-right: 0.5rem; - content: "«"; } + content: "«"; +} .pagination-next a::after, .pagination-next.disabled::after { display: inline-block; margin-left: 0.5rem; - content: "»"; } + content: "»"; +} .has-tip { position: relative; display: inline-block; border-bottom: dotted 1px #8a8a8a; font-weight: bold; - cursor: help; } + cursor: help; +} .tooltip { position: absolute; @@ -2574,98 +3317,115 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { border-radius: 0; background-color: #0a0a0a; font-size: 80%; - color: #fefefe; } - .tooltip::before { - position: absolute; } - .tooltip.bottom::before { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 0.75rem; - content: ''; - border-top-width: 0; - border-color: transparent transparent #0a0a0a; - bottom: 100%; } - .tooltip.bottom.align-center::before { - left: 50%; - -webkit-transform: translateX(-50%); - -ms-transform: translateX(-50%); - transform: translateX(-50%); } - .tooltip.top::before { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 0.75rem; - content: ''; - border-bottom-width: 0; - border-color: #0a0a0a transparent transparent; - top: 100%; - bottom: auto; } - .tooltip.top.align-center::before { - left: 50%; - -webkit-transform: translateX(-50%); - -ms-transform: translateX(-50%); - transform: translateX(-50%); } - .tooltip.left::before { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 0.75rem; - content: ''; - border-right-width: 0; - border-color: transparent transparent transparent #0a0a0a; - left: 100%; } - .tooltip.left.align-center::before { - bottom: auto; - top: 50%; - -webkit-transform: translateY(-50%); - -ms-transform: translateY(-50%); - transform: translateY(-50%); } - .tooltip.right::before { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 0.75rem; - content: ''; - border-left-width: 0; - border-color: transparent #0a0a0a transparent transparent; - right: 100%; - left: auto; } - .tooltip.right.align-center::before { - bottom: auto; - top: 50%; - -webkit-transform: translateY(-50%); - -ms-transform: translateY(-50%); - transform: translateY(-50%); } - .tooltip.align-top::before { - bottom: auto; - top: 10%; } - .tooltip.align-bottom::before { - bottom: 10%; - top: auto; } - .tooltip.align-left::before { - left: 10%; - right: auto; } - .tooltip.align-right::before { - left: auto; - right: 10%; } + color: #fefefe; +} +.tooltip::before { + position: absolute; +} +.tooltip.bottom::before { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 0.75rem; + content: ""; + border-top-width: 0; + border-color: transparent transparent #0a0a0a; + bottom: 100%; +} +.tooltip.bottom.align-center::before { + left: 50%; + -webkit-transform: translateX(-50%); + -ms-transform: translateX(-50%); + transform: translateX(-50%); +} +.tooltip.top::before { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 0.75rem; + content: ""; + border-bottom-width: 0; + border-color: #0a0a0a transparent transparent; + top: 100%; + bottom: auto; +} +.tooltip.top.align-center::before { + left: 50%; + -webkit-transform: translateX(-50%); + -ms-transform: translateX(-50%); + transform: translateX(-50%); +} +.tooltip.left::before { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 0.75rem; + content: ""; + border-right-width: 0; + border-color: transparent transparent transparent #0a0a0a; + left: 100%; +} +.tooltip.left.align-center::before { + bottom: auto; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); +} +.tooltip.right::before { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 0.75rem; + content: ""; + border-left-width: 0; + border-color: transparent #0a0a0a transparent transparent; + right: 100%; + left: auto; +} +.tooltip.right.align-center::before { + bottom: auto; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); +} +.tooltip.align-top::before { + bottom: auto; + top: 10%; +} +.tooltip.align-bottom::before { + bottom: 10%; + top: auto; +} +.tooltip.align-left::before { + left: 10%; + right: auto; +} +.tooltip.align-right::before { + left: auto; + right: 10%; +} .accordion { margin-left: 0; background: #fefefe; - list-style-type: none; } - .accordion[disabled] .accordion-title { - cursor: not-allowed; } + list-style-type: none; +} +.accordion[disabled] .accordion-title { + cursor: not-allowed; +} .accordion-item:first-child > :first-child { - border-radius: 0 0 0 0; } - + border-radius: 0 0 0 0; +} .accordion-item:last-child > :last-child { - border-radius: 0 0 0 0; } + border-radius: 0 0 0 0; +} .accordion-title { position: relative; @@ -2675,20 +3435,25 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { border-bottom: 0; font-size: 0.75rem; line-height: 1; - color: #1779ba; } - :last-child:not(.is-active) > .accordion-title { - border-bottom: 1px solid #e6e6e6; - border-radius: 0 0 0 0; } - .accordion-title:hover, .accordion-title:focus { - background-color: #e6e6e6; } - .accordion-title::before { - position: absolute; - top: 50%; - right: 1rem; - margin-top: -0.5rem; - content: "+"; } - .is-active > .accordion-title::before { - content: "–"; } + color: #1779ba; +} +:last-child:not(.is-active) > .accordion-title { + border-bottom: 1px solid #e6e6e6; + border-radius: 0 0 0 0; +} +.accordion-title:hover, .accordion-title:focus { + background-color: #e6e6e6; +} +.accordion-title::before { + position: absolute; + top: 50%; + right: 1rem; + margin-top: -0.5rem; + content: "+"; +} +.is-active > .accordion-title::before { + content: "–"; +} .accordion-content { display: none; @@ -2696,61 +3461,80 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { border: 1px solid #e6e6e6; border-bottom: 0; background-color: #fefefe; - color: #0a0a0a; } - :last-child > .accordion-content:last-child { - border-bottom: 1px solid #e6e6e6; } + color: #0a0a0a; +} +:last-child > .accordion-content:last-child { + border-bottom: 1px solid #e6e6e6; +} .media-object { display: block; - margin-bottom: 1rem; } - .media-object img { - max-width: none; } + margin-bottom: 1rem; +} +.media-object img { + max-width: none; +} .media-object-section { display: table-cell; - vertical-align: top; } - .media-object-section:first-child { - padding-right: 1rem; } - .media-object-section:last-child:not(:nth-child(2)) { - padding-left: 1rem; } - .media-object-section > :last-child { - margin-bottom: 0; } - @media print, screen and (max-width: 39.99875em) { - .stack-for-small .media-object-section { - padding: 0; - padding-bottom: 1rem; - display: block; } - .stack-for-small .media-object-section img { - width: 100%; } } - .media-object-section.middle { - vertical-align: middle; } - .media-object-section.bottom { - vertical-align: bottom; } + vertical-align: top; +} +.media-object-section:first-child { + padding-right: 1rem; +} +.media-object-section:last-child:not(:nth-child(2)) { + padding-left: 1rem; +} +.media-object-section > :last-child { + margin-bottom: 0; +} +@media print, screen and (max-width: 39.99875em) { + .stack-for-small .media-object-section { + padding: 0; + padding-bottom: 1rem; + display: block; + } + .stack-for-small .media-object-section img { + width: 100%; + } +} +.media-object-section.middle { + vertical-align: middle; +} +.media-object-section.bottom { + vertical-align: bottom; +} .orbit { - position: relative; } + position: relative; +} .orbit-container { position: relative; height: 0; margin: 0; list-style: none; - overflow: hidden; } + overflow: hidden; +} .orbit-slide { width: 100%; - position: absolute; } - .orbit-slide.no-motionui.is-active { - top: 0; - left: 0; } + position: absolute; +} +.orbit-slide.no-motionui.is-active { + top: 0; + left: 0; +} .orbit-figure { - margin: 0; } + margin: 0; +} .orbit-image { width: 100%; max-width: 100%; - margin: 0; } + margin: 0; +} .orbit-caption { position: absolute; @@ -2759,9 +3543,10 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { margin-bottom: 0; padding: 1rem; background-color: rgba(10, 10, 10, 0.5); - color: #fefefe; } + color: #fefefe; +} -.orbit-previous, .orbit-next { +.orbit-next, .orbit-previous { position: absolute; top: 50%; -webkit-transform: translateY(-50%); @@ -2769,36 +3554,46 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { transform: translateY(-50%); z-index: 10; padding: 1rem; - color: #fefefe; } - [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next { - outline: 0; } - .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus { - background-color: rgba(10, 10, 10, 0.5); } + color: #fefefe; +} +[data-whatinput=mouse] .orbit-next, [data-whatinput=mouse] .orbit-previous { + outline: 0; +} +.orbit-next:hover, .orbit-previous:hover, .orbit-next:active, .orbit-previous:active, .orbit-next:focus, .orbit-previous:focus { + background-color: rgba(10, 10, 10, 0.5); +} .orbit-previous { - left: 0; } + left: 0; +} .orbit-next { left: auto; - right: 0; } + right: 0; +} .orbit-bullets { position: relative; margin-top: 0.8rem; margin-bottom: 0.8rem; - text-align: center; } - [data-whatinput='mouse'] .orbit-bullets { - outline: 0; } - .orbit-bullets button { - width: 1.2rem; - height: 1.2rem; - margin: 0.1rem; - border-radius: 50%; - background-color: #cacaca; } - .orbit-bullets button:hover { - background-color: #8a8a8a; } - .orbit-bullets button.is-active { - background-color: #8a8a8a; } + text-align: center; +} +[data-whatinput=mouse] .orbit-bullets { + outline: 0; +} +.orbit-bullets button { + width: 1.2rem; + height: 1.2rem; + margin: 0.1rem; + border-radius: 50%; + background-color: #cacaca; +} +.orbit-bullets button:hover { + background-color: #8a8a8a; +} +.orbit-bullets button.is-active { + background-color: #8a8a8a; +} .responsive-embed, .flex-video { @@ -2806,68 +3601,85 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { height: 0; margin-bottom: 1rem; padding-bottom: 75%; - overflow: hidden; } - .responsive-embed iframe, - .responsive-embed object, - .responsive-embed embed, - .responsive-embed video, - .flex-video iframe, - .flex-video object, - .flex-video embed, - .flex-video video { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; } - .responsive-embed.widescreen, - .flex-video.widescreen { - padding-bottom: 56.25%; } + overflow: hidden; +} +.responsive-embed iframe, +.responsive-embed object, +.responsive-embed embed, +.responsive-embed video, +.flex-video iframe, +.flex-video object, +.flex-video embed, +.flex-video video { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; +} +.responsive-embed.widescreen, +.flex-video.widescreen { + padding-bottom: 56.25%; +} .tabs { margin: 0; border: 1px solid #e6e6e6; background: #fefefe; - list-style-type: none; } - .tabs::before, .tabs::after { - display: table; - content: ' '; } - .tabs::after { - clear: both; } + list-style-type: none; +} +.tabs::before, .tabs::after { + display: table; + content: " "; +} +.tabs::after { + clear: both; +} .tabs.vertical > li { display: block; float: none; - width: auto; } + width: auto; +} .tabs.simple > li > a { - padding: 0; } - .tabs.simple > li > a:hover { - background: transparent; } + padding: 0; +} +.tabs.simple > li > a:hover { + background: transparent; +} .tabs.primary { - background: #1779ba; } - .tabs.primary > li > a { - color: #fefefe; } - .tabs.primary > li > a:hover, .tabs.primary > li > a:focus { - background: #1673b1; } + background: #1779ba; +} +.tabs.primary > li > a { + color: #fefefe; +} +.tabs.primary > li > a:hover, .tabs.primary > li > a:focus { + background: #1673b1; +} .tabs-title { - float: left; } - .tabs-title > a { - display: block; - padding: 1.25rem 1.5rem; - font-size: 0.75rem; - line-height: 1; - color: #1779ba; } - [data-whatinput='mouse'] .tabs-title > a { - outline: 0; } - .tabs-title > a:hover { - background: #fefefe; - color: #1468a0; } - .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] { - background: #e6e6e6; - color: #1779ba; } + float: left; +} +.tabs-title > a { + display: block; + padding: 1.25rem 1.5rem; + font-size: 0.75rem; + line-height: 1; + color: #1779ba; +} +[data-whatinput=mouse] .tabs-title > a { + outline: 0; +} +.tabs-title > a:hover { + background: #fefefe; + color: #1468a0; +} +.tabs-title > a:focus, .tabs-title > a[aria-selected=true] { + background: #e6e6e6; + color: #1779ba; +} .tabs-content { border: 1px solid #e6e6e6; @@ -2875,17 +3687,21 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { background: #fefefe; color: #0a0a0a; -webkit-transition: all 0.5s ease; - transition: all 0.5s ease; } + transition: all 0.5s ease; +} .tabs-content.vertical { border: 1px solid #e6e6e6; - border-left: 0; } + border-left: 0; +} .tabs-panel { display: none; - padding: 1rem; } - .tabs-panel.is-active { - display: block; } + padding: 1rem; +} +.tabs-panel.is-active { + display: block; +} .thumbnail { display: inline-block; @@ -2895,185 +3711,238 @@ table.hover:not(.unstriped) tr:nth-of-type(even):hover { border-radius: 0; -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2); box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2); - line-height: 0; } + line-height: 0; +} a.thumbnail { -webkit-transition: -webkit-box-shadow 200ms ease-out; transition: -webkit-box-shadow 200ms ease-out; transition: box-shadow 200ms ease-out; - transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; } - a.thumbnail:hover, a.thumbnail:focus { - -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); - box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); } - a.thumbnail image { - -webkit-box-shadow: none; - box-shadow: none; } + transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; +} +a.thumbnail:hover, a.thumbnail:focus { + -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); + box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); +} +a.thumbnail image { + -webkit-box-shadow: none; + box-shadow: none; +} .menu { padding: 0; margin: 0; list-style: none; - position: relative; } - [data-whatinput='mouse'] .menu li { - outline: 0; } - .menu a, - .menu .button { - line-height: 1; - text-decoration: none; + position: relative; +} +[data-whatinput=mouse] .menu li { + outline: 0; +} +.menu a, +.menu .button { + line-height: 1; + text-decoration: none; + display: block; + padding: 0.7rem 1rem; +} +.menu input, +.menu select, +.menu a, +.menu button { + margin-bottom: 0; +} +.menu input { + display: inline-block; +} +.menu li, .menu.horizontal li { + display: inline-block; +} +.menu.vertical li { + display: block; +} +.menu.expanded { + display: table; + width: 100%; +} +.menu.expanded > li { + display: table-cell; + vertical-align: middle; +} +.menu.simple li + li { + margin-left: 1rem; +} +.menu.simple a { + padding: 0; +} +@media print, screen and (min-width: 40em) { + .menu.medium-horizontal li { + display: inline-block; + } + .menu.medium-vertical li { display: block; - padding: 0.7rem 1rem; } - .menu input, - .menu select, - .menu a, - .menu button { - margin-bottom: 0; } - .menu input { - display: inline-block; } - .menu li, .menu.horizontal li { - display: inline-block; } - .menu.vertical li { - display: block; } - .menu.expanded { + } + .menu.medium-expanded { display: table; - width: 100%; } - .menu.expanded > li { - display: table-cell; - vertical-align: middle; } - .menu.simple li + li { - margin-left: 1rem; } - .menu.simple a { - padding: 0; } - @media print, screen and (min-width: 40em) { - .menu.medium-horizontal li { - display: inline-block; } - .menu.medium-vertical li { - display: block; } - .menu.medium-expanded { - display: table; - width: 100%; } - .menu.medium-expanded > li { - display: table-cell; - vertical-align: middle; } - .menu.medium-simple { - display: table; - width: 100%; } - .menu.medium-simple > li { - display: table-cell; - vertical-align: middle; } } - @media print, screen and (min-width: 64em) { - .menu.large-horizontal li { - display: inline-block; } - .menu.large-vertical li { - display: block; } - .menu.large-expanded { - display: table; - width: 100%; } - .menu.large-expanded > li { - display: table-cell; - vertical-align: middle; } - .menu.large-simple { - display: table; - width: 100%; } - .menu.large-simple > li { - display: table-cell; - vertical-align: middle; } } - .menu.nested { - margin-right: 0; - margin-left: 1rem; } - .menu.icons img, - .menu.icons i, - .menu.icons svg { - vertical-align: middle; } - .menu.icons img + span, - .menu.icons i + span, - .menu.icons svg + span { - vertical-align: middle; } - .menu.icon-top img, - .menu.icon-top i, - .menu.icon-top svg, .menu.icon-right img, - .menu.icon-right i, - .menu.icon-right svg, .menu.icon-bottom img, - .menu.icon-bottom i, - .menu.icon-bottom svg, .menu.icon-left img, - .menu.icon-left i, - .menu.icon-left svg { - vertical-align: middle; } - .menu.icon-top img + span, - .menu.icon-top i + span, - .menu.icon-top svg + span, .menu.icon-right img + span, - .menu.icon-right i + span, - .menu.icon-right svg + span, .menu.icon-bottom img + span, - .menu.icon-bottom i + span, - .menu.icon-bottom svg + span, .menu.icon-left img + span, - .menu.icon-left i + span, - .menu.icon-left svg + span { - vertical-align: middle; } - .menu.icon-left li a img, - .menu.icon-left li a i, - .menu.icon-left li a svg, .menu.nested.icon-left li a img, - .menu.nested.icon-left li a i, - .menu.nested.icon-left li a svg { - margin-right: 0.25rem; - display: inline-block; } - .menu.icon-right li a img, - .menu.icon-right li a i, - .menu.icon-right li a svg, .menu.nested.icon-right li a img, - .menu.nested.icon-right li a i, - .menu.nested.icon-right li a svg { - margin-left: 0.25rem; - display: inline-block; } - .menu.icon-top li a, .menu.nested.icon-top li a { - text-align: center; } - .menu.icon-top li a img, - .menu.icon-top li a i, - .menu.icon-top li a svg, .menu.nested.icon-top li a img, - .menu.nested.icon-top li a i, - .menu.nested.icon-top li a svg { - display: block; - margin: 0 auto 0.25rem; } - .menu.icon-bottom li a, .menu.nested.icon-bottom li a { - text-align: center; } - .menu.icon-bottom li a img, - .menu.icon-bottom li a i, - .menu.icon-bottom li a svg, .menu.nested.icon-bottom li a img, - .menu.nested.icon-bottom li a i, - .menu.nested.icon-bottom li a svg { - display: block; - margin: 0.25rem auto 0; } - .menu .is-active > a { - background: #1779ba; - color: #fefefe; } - .menu .active > a { - background: #1779ba; - color: #fefefe; } - .menu.align-left { - text-align: left; } - .menu.align-right { - text-align: right; } - .menu.align-right .submenu li { - text-align: left; } - .menu.align-right.vertical .submenu li { - text-align: right; } - .menu.align-right .nested { - margin-right: 1rem; - margin-left: 0; } - .menu.align-center { - text-align: center; } - .menu.align-center .submenu li { - text-align: left; } - .menu .menu-text { - padding: 0.7rem 1rem; - font-weight: bold; - line-height: 1; - color: inherit; } + width: 100%; + } + .menu.medium-expanded > li { + display: table-cell; + vertical-align: middle; + } + .menu.medium-simple { + display: table; + width: 100%; + } + .menu.medium-simple > li { + display: table-cell; + vertical-align: middle; + } +} +@media print, screen and (min-width: 64em) { + .menu.large-horizontal li { + display: inline-block; + } + .menu.large-vertical li { + display: block; + } + .menu.large-expanded { + display: table; + width: 100%; + } + .menu.large-expanded > li { + display: table-cell; + vertical-align: middle; + } + .menu.large-simple { + display: table; + width: 100%; + } + .menu.large-simple > li { + display: table-cell; + vertical-align: middle; + } +} +.menu.nested { + margin-right: 0; + margin-left: 1rem; +} +.menu.icons img, +.menu.icons i, +.menu.icons svg { + vertical-align: middle; +} +.menu.icons img + span, +.menu.icons i + span, +.menu.icons svg + span { + vertical-align: middle; +} +.menu.icon-top img, +.menu.icon-top i, +.menu.icon-top svg, .menu.icon-right img, +.menu.icon-right i, +.menu.icon-right svg, .menu.icon-bottom img, +.menu.icon-bottom i, +.menu.icon-bottom svg, .menu.icon-left img, +.menu.icon-left i, +.menu.icon-left svg { + vertical-align: middle; +} +.menu.icon-top img + span, +.menu.icon-top i + span, +.menu.icon-top svg + span, .menu.icon-right img + span, +.menu.icon-right i + span, +.menu.icon-right svg + span, .menu.icon-bottom img + span, +.menu.icon-bottom i + span, +.menu.icon-bottom svg + span, .menu.icon-left img + span, +.menu.icon-left i + span, +.menu.icon-left svg + span { + vertical-align: middle; +} +.menu.icon-left li a img, +.menu.icon-left li a i, +.menu.icon-left li a svg, .menu.nested.icon-left li a img, +.menu.nested.icon-left li a i, +.menu.nested.icon-left li a svg { + margin-right: 0.25rem; + display: inline-block; +} +.menu.icon-right li a img, +.menu.icon-right li a i, +.menu.icon-right li a svg, .menu.nested.icon-right li a img, +.menu.nested.icon-right li a i, +.menu.nested.icon-right li a svg { + margin-left: 0.25rem; + display: inline-block; +} +.menu.icon-top li a, .menu.nested.icon-top li a { + text-align: center; +} +.menu.icon-top li a img, +.menu.icon-top li a i, +.menu.icon-top li a svg, .menu.nested.icon-top li a img, +.menu.nested.icon-top li a i, +.menu.nested.icon-top li a svg { + display: block; + margin: 0 auto 0.25rem; +} +.menu.icon-bottom li a, .menu.nested.icon-bottom li a { + text-align: center; +} +.menu.icon-bottom li a img, +.menu.icon-bottom li a i, +.menu.icon-bottom li a svg, .menu.nested.icon-bottom li a img, +.menu.nested.icon-bottom li a i, +.menu.nested.icon-bottom li a svg { + display: block; + margin: 0.25rem auto 0; +} +.menu .is-active > a { + background: #1779ba; + color: #fefefe; +} +.menu .active > a { + background: #1779ba; + color: #fefefe; +} +.menu.align-left { + text-align: left; +} +.menu.align-right { + text-align: right; +} +.menu.align-right .submenu li { + text-align: left; +} +.menu.align-right.vertical .submenu li { + text-align: right; +} +.menu.align-right .nested { + margin-right: 1rem; + margin-left: 0; +} +.menu.align-center { + text-align: center; +} +.menu.align-center .submenu li { + text-align: left; +} +.menu .menu-text { + padding: 0.7rem 1rem; + font-weight: bold; + line-height: 1; + color: inherit; +} .menu-centered > .menu { - text-align: center; } - .menu-centered > .menu .submenu li { - text-align: left; } + text-align: center; +} +.menu-centered > .menu .submenu li { + text-align: left; +} .no-js [data-responsive-menu] ul { - display: none; } + display: none; +} .menu-icon { position: relative; @@ -3081,22 +3950,25 @@ a.thumbnail { vertical-align: middle; width: 20px; height: 16px; - cursor: pointer; } - .menu-icon::after { - position: absolute; - top: 0; - left: 0; - display: block; - width: 100%; - height: 2px; - background: #fefefe; - -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; - box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; - content: ''; } - .menu-icon:hover::after { - background: #cacaca; - -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; - box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; } + cursor: pointer; +} +.menu-icon::after { + position: absolute; + top: 0; + left: 0; + display: block; + width: 100%; + height: 2px; + background: #fefefe; + -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + content: ""; +} +.menu-icon:hover::after { + background: #cacaca; + -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; + box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; +} .menu-icon.dark { position: relative; @@ -3104,77 +3976,84 @@ a.thumbnail { vertical-align: middle; width: 20px; height: 16px; - cursor: pointer; } - .menu-icon.dark::after { - position: absolute; - top: 0; - left: 0; - display: block; - width: 100%; - height: 2px; - background: #0a0a0a; - -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a; - box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a; - content: ''; } - .menu-icon.dark:hover::after { - background: #8a8a8a; - -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; - box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; } + cursor: pointer; +} +.menu-icon.dark::after { + position: absolute; + top: 0; + left: 0; + display: block; + width: 100%; + height: 2px; + background: #0a0a0a; + -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a; + box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a; + content: ""; +} +.menu-icon.dark:hover::after { + background: #8a8a8a; + -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; + box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; +} .accordion-menu li { - width: 100%; } - + width: 100%; +} .accordion-menu a { - padding: 0.7rem 1rem; } - + padding: 0.7rem 1rem; +} .accordion-menu .is-accordion-submenu a { - padding: 0.7rem 1rem; } - + padding: 0.7rem 1rem; +} .accordion-menu .nested.is-accordion-submenu { margin-right: 0; - margin-left: 1rem; } - + margin-left: 1rem; +} .accordion-menu.align-right .nested.is-accordion-submenu { margin-right: 1rem; - margin-left: 0; } - + margin-left: 0; +} .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a { - position: relative; } - .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 6px; - content: ''; - border-bottom-width: 0; - border-color: #1779ba transparent transparent; - position: absolute; - top: 50%; - margin-top: -3px; - right: 1rem; } - + position: relative; +} +.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 6px; + content: ""; + border-bottom-width: 0; + border-color: #1779ba transparent transparent; + position: absolute; + top: 50%; + margin-top: -3px; + right: 1rem; +} .accordion-menu.align-left .is-accordion-submenu-parent > a::after { right: 1rem; - left: auto; } - + left: auto; +} .accordion-menu.align-right .is-accordion-submenu-parent > a::after { right: auto; - left: 1rem; } - -.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after { + left: 1rem; +} +.accordion-menu .is-accordion-submenu-parent[aria-expanded=true] > a::after { -webkit-transform: rotate(180deg); -ms-transform: rotate(180deg); transform: rotate(180deg); -webkit-transform-origin: 50% 50%; -ms-transform-origin: 50% 50%; - transform-origin: 50% 50%; } + transform-origin: 50% 50%; +} .is-accordion-submenu-parent { - position: relative; } + position: relative; +} .has-submenu-toggle > a { - margin-right: 40px; } + margin-right: 40px; +} .submenu-toggle { position: absolute; @@ -3182,27 +4061,30 @@ a.thumbnail { right: 0; width: 40px; height: 40px; - cursor: pointer; } - .submenu-toggle::after { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 6px; - content: ''; - border-bottom-width: 0; - border-color: #1779ba transparent transparent; - top: 0; - bottom: 0; - margin: auto; } + cursor: pointer; +} +.submenu-toggle::after { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 6px; + content: ""; + border-bottom-width: 0; + border-color: #1779ba transparent transparent; + top: 0; + bottom: 0; + margin: auto; +} -.submenu-toggle[aria-expanded='true']::after { +.submenu-toggle[aria-expanded=true]::after { -webkit-transform: scaleY(-1); -ms-transform: scaleY(-1); transform: scaleY(-1); -webkit-transform-origin: 50% 50%; -ms-transform-origin: 50% 50%; - transform-origin: 50% 50%; } + transform-origin: 50% 50%; +} .submenu-toggle-text { position: absolute !important; @@ -3212,21 +4094,25 @@ a.thumbnail { overflow: hidden !important; clip: rect(0, 0, 0, 0) !important; white-space: nowrap !important; - border: 0 !important; } + border: 0 !important; +} .is-drilldown { position: relative; - overflow: hidden; } - .is-drilldown li { - display: block; } - .is-drilldown.animate-height { - -webkit-transition: height 0.5s; - transition: height 0.5s; } + overflow: hidden; +} +.is-drilldown li { + display: block; +} +.is-drilldown.animate-height { + -webkit-transition: height 0.5s; + transition: height 0.5s; +} .drilldown a { padding: 0.7rem 1rem; - background: #fefefe; } - + background: #fefefe; +} .drilldown .is-drilldown-submenu { position: absolute; top: 0; @@ -3237,300 +4123,333 @@ a.thumbnail { -webkit-transition: -webkit-transform 0.15s linear; transition: -webkit-transform 0.15s linear; transition: transform 0.15s linear; - transition: transform 0.15s linear, -webkit-transform 0.15s linear; } - .drilldown .is-drilldown-submenu.is-active { - z-index: 1; - display: block; - -webkit-transform: translateX(-100%); - -ms-transform: translateX(-100%); - transform: translateX(-100%); } - .drilldown .is-drilldown-submenu.is-closing { - -webkit-transform: translateX(100%); - -ms-transform: translateX(100%); - transform: translateX(100%); } - .drilldown .is-drilldown-submenu a { - padding: 0.7rem 1rem; } - + transition: transform 0.15s linear, -webkit-transform 0.15s linear; +} +.drilldown .is-drilldown-submenu.is-active { + z-index: 1; + display: block; + -webkit-transform: translateX(-100%); + -ms-transform: translateX(-100%); + transform: translateX(-100%); +} +.drilldown .is-drilldown-submenu.is-closing { + -webkit-transform: translateX(100%); + -ms-transform: translateX(100%); + transform: translateX(100%); +} +.drilldown .is-drilldown-submenu a { + padding: 0.7rem 1rem; +} .drilldown .nested.is-drilldown-submenu { margin-right: 0; - margin-left: 0; } - + margin-left: 0; +} .drilldown .drilldown-submenu-cover-previous { - min-height: 100%; } - + min-height: 100%; +} .drilldown .is-drilldown-submenu-parent > a { - position: relative; } - .drilldown .is-drilldown-submenu-parent > a::after { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 6px; - content: ''; - border-right-width: 0; - border-color: transparent transparent transparent #1779ba; - position: absolute; - top: 50%; - margin-top: -6px; - right: 1rem; } - + position: relative; +} +.drilldown .is-drilldown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 6px; + content: ""; + border-right-width: 0; + border-color: transparent transparent transparent #1779ba; + position: absolute; + top: 50%; + margin-top: -6px; + right: 1rem; +} .drilldown.align-left .is-drilldown-submenu-parent > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-right-width: 0; border-color: transparent transparent transparent #1779ba; right: 1rem; - left: auto; } - + left: auto; +} .drilldown.align-right .is-drilldown-submenu-parent > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-left-width: 0; border-color: transparent #1779ba transparent transparent; right: auto; - left: 1rem; } - + left: 1rem; +} .drilldown .js-drilldown-back > a::before { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-left-width: 0; border-color: transparent #1779ba transparent transparent; display: inline-block; vertical-align: middle; - margin-right: 0.75rem; } + margin-right: 0.75rem; +} .dropdown.menu > li.opens-left > .is-dropdown-submenu { top: 100%; right: 0; - left: auto; } - + left: auto; +} .dropdown.menu > li.opens-right > .is-dropdown-submenu { top: 100%; right: auto; - left: 0; } - + left: 0; +} .dropdown.menu > li.is-dropdown-submenu-parent > a { position: relative; - padding-right: 1.5rem; } - + padding-right: 1.5rem; +} .dropdown.menu > li.is-dropdown-submenu-parent > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-bottom-width: 0; border-color: #1779ba transparent transparent; right: 5px; left: auto; - margin-top: -3px; } - -[data-whatinput='mouse'] .dropdown.menu a { - outline: 0; } - + margin-top: -3px; +} +[data-whatinput=mouse] .dropdown.menu a { + outline: 0; +} .dropdown.menu > li > a { - padding: 0.7rem 1rem; } - + padding: 0.7rem 1rem; +} .dropdown.menu > li.is-active > a { background: transparent; - color: #1779ba; } - + color: #1779ba; +} .no-js .dropdown.menu ul { - display: none; } - + display: none; +} .dropdown.menu .nested.is-dropdown-submenu { margin-right: 0; - margin-left: 0; } - + margin-left: 0; +} .dropdown.menu.vertical > li .is-dropdown-submenu { - top: 0; } - + top: 0; +} .dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu { top: 0; right: 100%; - left: auto; } - + left: auto; +} .dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu { right: auto; - left: 100%; } - + left: 100%; +} .dropdown.menu.vertical > li > a::after { - right: 14px; } - + right: 14px; +} .dropdown.menu.vertical > li.opens-left > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-left-width: 0; border-color: transparent #1779ba transparent transparent; right: auto; - left: 5px; } - + left: 5px; +} .dropdown.menu.vertical > li.opens-right > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-right-width: 0; - border-color: transparent transparent transparent #1779ba; } - + border-color: transparent transparent transparent #1779ba; +} @media print, screen and (min-width: 40em) { .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu { top: 100%; right: 0; - left: auto; } + left: auto; + } .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu { top: 100%; right: auto; - left: 0; } + left: 0; + } .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a { position: relative; - padding-right: 1.5rem; } + padding-right: 1.5rem; + } .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-bottom-width: 0; border-color: #1779ba transparent transparent; right: 5px; left: auto; - margin-top: -3px; } + margin-top: -3px; + } .dropdown.menu.medium-vertical > li .is-dropdown-submenu { - top: 0; } + top: 0; + } .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu { top: 0; right: 100%; - left: auto; } + left: auto; + } .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu { right: auto; - left: 100%; } + left: 100%; + } .dropdown.menu.medium-vertical > li > a::after { - right: 14px; } + right: 14px; + } .dropdown.menu.medium-vertical > li.opens-left > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-left-width: 0; border-color: transparent #1779ba transparent transparent; right: auto; - left: 5px; } + left: 5px; + } .dropdown.menu.medium-vertical > li.opens-right > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-right-width: 0; - border-color: transparent transparent transparent #1779ba; } } - + border-color: transparent transparent transparent #1779ba; + } +} @media print, screen and (min-width: 64em) { .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu { top: 100%; right: 0; - left: auto; } + left: auto; + } .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu { top: 100%; right: auto; - left: 0; } + left: 0; + } .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a { position: relative; - padding-right: 1.5rem; } + padding-right: 1.5rem; + } .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-bottom-width: 0; border-color: #1779ba transparent transparent; right: 5px; left: auto; - margin-top: -3px; } + margin-top: -3px; + } .dropdown.menu.large-vertical > li .is-dropdown-submenu { - top: 0; } + top: 0; + } .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu { top: 0; right: 100%; - left: auto; } + left: auto; + } .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu { right: auto; - left: 100%; } + left: 100%; + } .dropdown.menu.large-vertical > li > a::after { - right: 14px; } + right: 14px; + } .dropdown.menu.large-vertical > li.opens-left > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-left-width: 0; border-color: transparent #1779ba transparent transparent; right: auto; - left: 5px; } + left: 5px; + } .dropdown.menu.large-vertical > li.opens-right > a::after { display: block; width: 0; height: 0; border-style: solid; border-width: 6px; - content: ''; + content: ""; border-right-width: 0; - border-color: transparent transparent transparent #1779ba; } } - + border-color: transparent transparent transparent #1779ba; + } +} .dropdown.menu.align-right .is-dropdown-submenu.first-sub { top: 100%; right: 0; - left: auto; } + left: auto; +} .is-dropdown-menu.vertical { - width: 100px; } - .is-dropdown-menu.vertical.align-right { - float: right; } + width: 100px; +} +.is-dropdown-menu.vertical.align-right { + float: right; +} .is-dropdown-submenu-parent { - position: relative; } - .is-dropdown-submenu-parent a::after { - position: absolute; - top: 50%; - right: 5px; - left: auto; - margin-top: -6px; } - .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu { - top: 100%; - left: auto; } - .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu { - right: 100%; - left: auto; } - .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu { - right: auto; - left: 100%; } + position: relative; +} +.is-dropdown-submenu-parent a::after { + position: absolute; + top: 50%; + right: 5px; + left: auto; + margin-top: -6px; +} +.is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu { + top: 100%; + left: auto; +} +.is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu { + right: 100%; + left: auto; +} +.is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu { + right: auto; + left: 100%; +} .is-dropdown-submenu { position: absolute; @@ -3540,40 +4459,49 @@ a.thumbnail { display: none; min-width: 200px; border: 1px solid #cacaca; - background: #fefefe; } - .dropdown .is-dropdown-submenu a { - padding: 0.7rem 1rem; } - .is-dropdown-submenu .is-dropdown-submenu-parent > a::after { - right: 14px; } - .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 6px; - content: ''; - border-left-width: 0; - border-color: transparent #1779ba transparent transparent; - right: auto; - left: 5px; } - .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after { - display: block; - width: 0; - height: 0; - border-style: solid; - border-width: 6px; - content: ''; - border-right-width: 0; - border-color: transparent transparent transparent #1779ba; } - .is-dropdown-submenu .is-dropdown-submenu { - margin-top: -1px; } - .is-dropdown-submenu > li { - width: 100%; } - .is-dropdown-submenu.js-dropdown-active { - display: block; } + background: #fefefe; +} +.dropdown .is-dropdown-submenu a { + padding: 0.7rem 1rem; +} +.is-dropdown-submenu .is-dropdown-submenu-parent > a::after { + right: 14px; +} +.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 6px; + content: ""; + border-left-width: 0; + border-color: transparent #1779ba transparent transparent; + right: auto; + left: 5px; +} +.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after { + display: block; + width: 0; + height: 0; + border-style: solid; + border-width: 6px; + content: ""; + border-right-width: 0; + border-color: transparent transparent transparent #1779ba; +} +.is-dropdown-submenu .is-dropdown-submenu { + margin-top: -1px; +} +.is-dropdown-submenu > li { + width: 100%; +} +.is-dropdown-submenu.js-dropdown-active { + display: block; +} .is-off-canvas-open { - overflow: hidden; } + overflow: hidden; +} .js-off-canvas-overlay { position: absolute; @@ -3587,20 +4515,26 @@ a.thumbnail { background: rgba(254, 254, 254, 0.25); opacity: 0; visibility: hidden; - overflow: hidden; } - .js-off-canvas-overlay.is-visible { - opacity: 1; - visibility: visible; } - .js-off-canvas-overlay.is-closable { - cursor: pointer; } - .js-off-canvas-overlay.is-overlay-absolute { - position: absolute; } - .js-off-canvas-overlay.is-overlay-fixed { - position: fixed; } + overflow: hidden; +} +.js-off-canvas-overlay.is-visible { + opacity: 1; + visibility: visible; +} +.js-off-canvas-overlay.is-closable { + cursor: pointer; +} +.js-off-canvas-overlay.is-overlay-absolute { + position: absolute; +} +.js-off-canvas-overlay.is-overlay-fixed { + position: fixed; +} .off-canvas-wrapper { position: relative; - overflow: hidden; } + overflow: hidden; +} .off-canvas { position: fixed; @@ -3611,22 +4545,29 @@ a.thumbnail { transition: transform 0.5s ease, -webkit-transform 0.5s ease; -webkit-backface-visibility: hidden; backface-visibility: hidden; - background: #e6e6e6; } - [data-whatinput='mouse'] .off-canvas { - outline: 0; } - .off-canvas.is-transition-push { - z-index: 12; } - .off-canvas.is-closed { - visibility: hidden; } - .off-canvas.is-transition-overlap { - z-index: 13; } - .off-canvas.is-transition-overlap.is-open { - -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); - box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); } - .off-canvas.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } + background: #e6e6e6; +} +[data-whatinput=mouse] .off-canvas { + outline: 0; +} +.off-canvas.is-transition-push { + z-index: 12; +} +.off-canvas.is-closed { + visibility: hidden; +} +.off-canvas.is-transition-overlap { + z-index: 13; +} +.off-canvas.is-transition-overlap.is-open { + -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); + box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); +} +.off-canvas.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} .off-canvas-absolute { position: absolute; @@ -3637,22 +4578,29 @@ a.thumbnail { transition: transform 0.5s ease, -webkit-transform 0.5s ease; -webkit-backface-visibility: hidden; backface-visibility: hidden; - background: #e6e6e6; } - [data-whatinput='mouse'] .off-canvas-absolute { - outline: 0; } - .off-canvas-absolute.is-transition-push { - z-index: 12; } - .off-canvas-absolute.is-closed { - visibility: hidden; } - .off-canvas-absolute.is-transition-overlap { - z-index: 13; } - .off-canvas-absolute.is-transition-overlap.is-open { - -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); - box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); } - .off-canvas-absolute.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } + background: #e6e6e6; +} +[data-whatinput=mouse] .off-canvas-absolute { + outline: 0; +} +.off-canvas-absolute.is-transition-push { + z-index: 12; +} +.off-canvas-absolute.is-closed { + visibility: hidden; +} +.off-canvas-absolute.is-transition-overlap { + z-index: 13; +} +.off-canvas-absolute.is-transition-overlap.is-open { + -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); + box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); +} +.off-canvas-absolute.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} .position-left { top: 0; @@ -3663,22 +4611,29 @@ a.thumbnail { width: 250px; -webkit-transform: translateX(-250px); -ms-transform: translateX(-250px); - transform: translateX(-250px); } - .off-canvas-content .off-canvas.position-left { - -webkit-transform: translateX(-250px); - -ms-transform: translateX(-250px); - transform: translateX(-250px); } - .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } - .off-canvas-content.is-open-left.has-transition-push { - -webkit-transform: translateX(250px); - -ms-transform: translateX(250px); - transform: translateX(250px); } - .position-left.is-transition-push { - -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); - box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); } + transform: translateX(-250px); +} +.off-canvas-content .off-canvas.position-left { + -webkit-transform: translateX(-250px); + -ms-transform: translateX(-250px); + transform: translateX(-250px); +} +.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} + +.off-canvas-content.is-open-left.has-transition-push { + -webkit-transform: translateX(250px); + -ms-transform: translateX(250px); + transform: translateX(250px); +} + +.position-left.is-transition-push { + -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); +} .position-right { top: 0; @@ -3689,22 +4644,29 @@ a.thumbnail { width: 250px; -webkit-transform: translateX(250px); -ms-transform: translateX(250px); - transform: translateX(250px); } - .off-canvas-content .off-canvas.position-right { - -webkit-transform: translateX(250px); - -ms-transform: translateX(250px); - transform: translateX(250px); } - .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } - .off-canvas-content.is-open-right.has-transition-push { - -webkit-transform: translateX(-250px); - -ms-transform: translateX(-250px); - transform: translateX(-250px); } - .position-right.is-transition-push { - -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); - box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); } + transform: translateX(250px); +} +.off-canvas-content .off-canvas.position-right { + -webkit-transform: translateX(250px); + -ms-transform: translateX(250px); + transform: translateX(250px); +} +.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} + +.off-canvas-content.is-open-right.has-transition-push { + -webkit-transform: translateX(-250px); + -ms-transform: translateX(-250px); + transform: translateX(-250px); +} + +.position-right.is-transition-push { + -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); +} .position-top { top: 0; @@ -3715,22 +4677,29 @@ a.thumbnail { height: 250px; -webkit-transform: translateY(-250px); -ms-transform: translateY(-250px); - transform: translateY(-250px); } - .off-canvas-content .off-canvas.position-top { - -webkit-transform: translateY(-250px); - -ms-transform: translateY(-250px); - transform: translateY(-250px); } - .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } - .off-canvas-content.is-open-top.has-transition-push { - -webkit-transform: translateY(250px); - -ms-transform: translateY(250px); - transform: translateY(250px); } - .position-top.is-transition-push { - -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); - box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); } + transform: translateY(-250px); +} +.off-canvas-content .off-canvas.position-top { + -webkit-transform: translateY(-250px); + -ms-transform: translateY(-250px); + transform: translateY(-250px); +} +.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} + +.off-canvas-content.is-open-top.has-transition-push { + -webkit-transform: translateY(250px); + -ms-transform: translateY(250px); + transform: translateY(250px); +} + +.position-top.is-transition-push { + -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); +} .position-bottom { bottom: 0; @@ -3741,42 +4710,53 @@ a.thumbnail { height: 250px; -webkit-transform: translateY(250px); -ms-transform: translateY(250px); - transform: translateY(250px); } - .off-canvas-content .off-canvas.position-bottom { - -webkit-transform: translateY(250px); - -ms-transform: translateY(250px); - transform: translateY(250px); } - .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } - .off-canvas-content.is-open-bottom.has-transition-push { - -webkit-transform: translateY(-250px); - -ms-transform: translateY(-250px); - transform: translateY(-250px); } - .position-bottom.is-transition-push { - -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); - box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); } + transform: translateY(250px); +} +.off-canvas-content .off-canvas.position-bottom { + -webkit-transform: translateY(250px); + -ms-transform: translateY(250px); + transform: translateY(250px); +} +.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} + +.off-canvas-content.is-open-bottom.has-transition-push { + -webkit-transform: translateY(-250px); + -ms-transform: translateY(-250px); + transform: translateY(-250px); +} + +.position-bottom.is-transition-push { + -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); +} .off-canvas-content { -webkit-transform: none; -ms-transform: none; transform: none; -webkit-backface-visibility: hidden; - backface-visibility: hidden; } - .off-canvas-content.has-transition-overlap, .off-canvas-content.has-transition-push { - -webkit-transition: -webkit-transform 0.5s ease; - transition: -webkit-transform 0.5s ease; - transition: transform 0.5s ease; - transition: transform 0.5s ease, -webkit-transform 0.5s ease; } - .off-canvas-content.has-transition-push { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } - .off-canvas-content .off-canvas.is-open { - -webkit-transform: translate(0, 0); - -ms-transform: translate(0, 0); - transform: translate(0, 0); } + backface-visibility: hidden; +} +.off-canvas-content.has-transition-overlap, .off-canvas-content.has-transition-push { + -webkit-transition: -webkit-transform 0.5s ease; + transition: -webkit-transform 0.5s ease; + transition: transform 0.5s ease; + transition: transform 0.5s ease, -webkit-transform 0.5s ease; +} +.off-canvas-content.has-transition-push { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} +.off-canvas-content .off-canvas.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); +} @media print, screen and (min-width: 40em) { .position-left.reveal-for-medium { @@ -3786,17 +4766,22 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-left.reveal-for-medium .close-button { - display: none; } - .off-canvas-content .position-left.reveal-for-medium { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-left { - margin-left: 250px; } - .position-left.reveal-for-medium ~ .off-canvas-content { - margin-left: 250px; } + visibility: visible; + } + .position-left.reveal-for-medium .close-button { + display: none; + } + .off-canvas-content .position-left.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-left { + margin-left: 250px; + } + .position-left.reveal-for-medium ~ .off-canvas-content { + margin-left: 250px; + } .position-right.reveal-for-medium { -webkit-transform: none; -ms-transform: none; @@ -3804,17 +4789,22 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-right.reveal-for-medium .close-button { - display: none; } - .off-canvas-content .position-right.reveal-for-medium { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-right { - margin-right: 250px; } - .position-right.reveal-for-medium ~ .off-canvas-content { - margin-right: 250px; } + visibility: visible; + } + .position-right.reveal-for-medium .close-button { + display: none; + } + .off-canvas-content .position-right.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-right { + margin-right: 250px; + } + .position-right.reveal-for-medium ~ .off-canvas-content { + margin-right: 250px; + } .position-top.reveal-for-medium { -webkit-transform: none; -ms-transform: none; @@ -3822,17 +4812,22 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-top.reveal-for-medium .close-button { - display: none; } - .off-canvas-content .position-top.reveal-for-medium { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-top { - margin-top: 250px; } - .position-top.reveal-for-medium ~ .off-canvas-content { - margin-top: 250px; } + visibility: visible; + } + .position-top.reveal-for-medium .close-button { + display: none; + } + .off-canvas-content .position-top.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-top { + margin-top: 250px; + } + .position-top.reveal-for-medium ~ .off-canvas-content { + margin-top: 250px; + } .position-bottom.reveal-for-medium { -webkit-transform: none; -ms-transform: none; @@ -3840,18 +4835,23 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-bottom.reveal-for-medium .close-button { - display: none; } - .off-canvas-content .position-bottom.reveal-for-medium { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-bottom { - margin-bottom: 250px; } - .position-bottom.reveal-for-medium ~ .off-canvas-content { - margin-bottom: 250px; } } - + visibility: visible; + } + .position-bottom.reveal-for-medium .close-button { + display: none; + } + .off-canvas-content .position-bottom.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-bottom { + margin-bottom: 250px; + } + .position-bottom.reveal-for-medium ~ .off-canvas-content { + margin-bottom: 250px; + } +} @media print, screen and (min-width: 64em) { .position-left.reveal-for-large { -webkit-transform: none; @@ -3860,17 +4860,22 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-left.reveal-for-large .close-button { - display: none; } - .off-canvas-content .position-left.reveal-for-large { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-left { - margin-left: 250px; } - .position-left.reveal-for-large ~ .off-canvas-content { - margin-left: 250px; } + visibility: visible; + } + .position-left.reveal-for-large .close-button { + display: none; + } + .off-canvas-content .position-left.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-left { + margin-left: 250px; + } + .position-left.reveal-for-large ~ .off-canvas-content { + margin-left: 250px; + } .position-right.reveal-for-large { -webkit-transform: none; -ms-transform: none; @@ -3878,17 +4883,22 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-right.reveal-for-large .close-button { - display: none; } - .off-canvas-content .position-right.reveal-for-large { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-right { - margin-right: 250px; } - .position-right.reveal-for-large ~ .off-canvas-content { - margin-right: 250px; } + visibility: visible; + } + .position-right.reveal-for-large .close-button { + display: none; + } + .off-canvas-content .position-right.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-right { + margin-right: 250px; + } + .position-right.reveal-for-large ~ .off-canvas-content { + margin-right: 250px; + } .position-top.reveal-for-large { -webkit-transform: none; -ms-transform: none; @@ -3896,17 +4906,22 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-top.reveal-for-large .close-button { - display: none; } - .off-canvas-content .position-top.reveal-for-large { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-top { - margin-top: 250px; } - .position-top.reveal-for-large ~ .off-canvas-content { - margin-top: 250px; } + visibility: visible; + } + .position-top.reveal-for-large .close-button { + display: none; + } + .off-canvas-content .position-top.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-top { + margin-top: 250px; + } + .position-top.reveal-for-large ~ .off-canvas-content { + margin-top: 250px; + } .position-bottom.reveal-for-large { -webkit-transform: none; -ms-transform: none; @@ -3914,18 +4929,23 @@ a.thumbnail { z-index: 12; -webkit-transition: none; transition: none; - visibility: visible; } - .position-bottom.reveal-for-large .close-button { - display: none; } - .off-canvas-content .position-bottom.reveal-for-large { - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas-content.has-reveal-bottom { - margin-bottom: 250px; } - .position-bottom.reveal-for-large ~ .off-canvas-content { - margin-bottom: 250px; } } - + visibility: visible; + } + .position-bottom.reveal-for-large .close-button { + display: none; + } + .off-canvas-content .position-bottom.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas-content.has-reveal-bottom { + margin-bottom: 250px; + } + .position-bottom.reveal-for-large ~ .off-canvas-content { + margin-bottom: 250px; + } +} @media print, screen and (min-width: 40em) { .off-canvas.in-canvas-for-medium { visibility: visible; @@ -3935,16 +4955,19 @@ a.thumbnail { width: auto; overflow: visible; -webkit-transition: none; - transition: none; } - .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom { - -webkit-box-shadow: none; - box-shadow: none; - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas.in-canvas-for-medium .close-button { - display: none; } } - + transition: none; + } + .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom { + -webkit-box-shadow: none; + box-shadow: none; + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas.in-canvas-for-medium .close-button { + display: none; + } +} @media print, screen and (min-width: 64em) { .off-canvas.in-canvas-for-large { visibility: visible; @@ -3954,25 +4977,31 @@ a.thumbnail { width: auto; overflow: visible; -webkit-transition: none; - transition: none; } - .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom { - -webkit-box-shadow: none; - box-shadow: none; - -webkit-transform: none; - -ms-transform: none; - transform: none; } - .off-canvas.in-canvas-for-large .close-button { - display: none; } } - + transition: none; + } + .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom { + -webkit-box-shadow: none; + box-shadow: none; + -webkit-transform: none; + -ms-transform: none; + transform: none; + } + .off-canvas.in-canvas-for-large .close-button { + display: none; + } +} html.is-reveal-open { position: fixed; width: 100%; - overflow-y: hidden; } - html.is-reveal-open.zf-has-scroll { - overflow-y: scroll; - -webkit-overflow-scrolling: touch; } - html.is-reveal-open body { - overflow-y: hidden; } + overflow-y: hidden; +} +html.is-reveal-open.zf-has-scroll { + overflow-y: scroll; + -webkit-overflow-scrolling: touch; +} +html.is-reveal-open body { + overflow-y: hidden; +} .reveal-overlay { position: fixed; @@ -3984,7 +5013,8 @@ html.is-reveal-open { display: none; background-color: rgba(10, 10, 10, 0.45); overflow-y: auto; - -webkit-overflow-scrolling: touch; } + -webkit-overflow-scrolling: touch; +} .reveal { z-index: 1006; @@ -4000,35 +5030,64 @@ html.is-reveal-open { margin-right: auto; margin-left: auto; overflow-y: auto; - -webkit-overflow-scrolling: touch; } - [data-whatinput='mouse'] .reveal { - outline: 0; } - @media print, screen and (min-width: 40em) { - .reveal { - min-height: 0; } } - .reveal .column, .reveal .columns { - min-width: 0; } - .reveal > :last-child { - margin-bottom: 0; } - @media print, screen and (min-width: 40em) { - .reveal { - width: 600px; - max-width: 75rem; } } - .reveal.collapse { - padding: 0; } - @media print, screen and (min-width: 40em) { - .reveal.tiny { - width: 30%; - max-width: 75rem; } } - @media print, screen and (min-width: 40em) { - .reveal.small { - width: 50%; - max-width: 75rem; } } - @media print, screen and (min-width: 40em) { - .reveal.large { - width: 90%; - max-width: 75rem; } } - .reveal.full { + -webkit-overflow-scrolling: touch; +} +[data-whatinput=mouse] .reveal { + outline: 0; +} +@media print, screen and (min-width: 40em) { + .reveal { + min-height: 0; + } +} +.reveal .column, .reveal .columns { + min-width: 0; +} +.reveal > :last-child { + margin-bottom: 0; +} +@media print, screen and (min-width: 40em) { + .reveal { + width: 600px; + max-width: 75rem; + } +} +.reveal.collapse { + padding: 0; +} +@media print, screen and (min-width: 40em) { + .reveal.tiny { + width: 30%; + max-width: 75rem; + } +} +@media print, screen and (min-width: 40em) { + .reveal.small { + width: 50%; + max-width: 75rem; + } +} +@media print, screen and (min-width: 40em) { + .reveal.large { + width: 90%; + max-width: 75rem; + } +} +.reveal.full { + top: 0; + right: 0; + bottom: 0; + left: 0; + width: 100%; + max-width: none; + height: 100%; + min-height: 100%; + margin-left: 0; + border: 0; + border-radius: 0; +} +@media print, screen and (max-width: 39.99875em) { + .reveal { top: 0; right: 0; bottom: 0; @@ -4039,186 +5098,235 @@ html.is-reveal-open { min-height: 100%; margin-left: 0; border: 0; - border-radius: 0; } - @media print, screen and (max-width: 39.99875em) { - .reveal { - top: 0; - right: 0; - bottom: 0; - left: 0; - width: 100%; - max-width: none; - height: 100%; - min-height: 100%; - margin-left: 0; - border: 0; - border-radius: 0; } } - .reveal.without-overlay { - position: fixed; } + border-radius: 0; + } +} +.reveal.without-overlay { + position: fixed; +} .sticky-container { - position: relative; } + position: relative; +} .sticky { position: relative; z-index: 0; -webkit-transform: translate3d(0, 0, 0); - transform: translate3d(0, 0, 0); } + transform: translate3d(0, 0, 0); +} .sticky.is-stuck { position: fixed; z-index: 5; - width: 100%; } - .sticky.is-stuck.is-at-top { - top: 0; } - .sticky.is-stuck.is-at-bottom { - bottom: 0; } + width: 100%; +} +.sticky.is-stuck.is-at-top { + top: 0; +} +.sticky.is-stuck.is-at-bottom { + bottom: 0; +} .sticky.is-anchored { position: relative; right: auto; - left: auto; } - .sticky.is-anchored.is-at-bottom { - bottom: 0; } + left: auto; +} +.sticky.is-anchored.is-at-bottom { + bottom: 0; +} .title-bar { padding: 0.5rem; background: #0a0a0a; - color: #fefefe; } - .title-bar::before, .title-bar::after { - display: table; - content: ' '; } - .title-bar::after { - clear: both; } - .title-bar .menu-icon { - margin-left: 0.25rem; - margin-right: 0.25rem; } + color: #fefefe; +} +.title-bar::before, .title-bar::after { + display: table; + content: " "; +} +.title-bar::after { + clear: both; +} +.title-bar .menu-icon { + margin-left: 0.25rem; + margin-right: 0.25rem; +} .title-bar-left { - float: left; } + float: left; +} .title-bar-right { float: right; - text-align: right; } + text-align: right; +} .title-bar-title { display: inline-block; vertical-align: middle; - font-weight: bold; } + font-weight: bold; +} .top-bar { - padding: 0.5rem; } - .top-bar::before, .top-bar::after { - display: table; - content: ' '; } - .top-bar::after { - clear: both; } - .top-bar, - .top-bar ul { - background-color: #e6e6e6; } - .top-bar input { - max-width: 200px; - margin-right: 1rem; } - .top-bar .input-group-field { - width: 100%; - margin-right: 0; } - .top-bar input.button { - width: auto; } + padding: 0.5rem; +} +.top-bar::before, .top-bar::after { + display: table; + content: " "; +} +.top-bar::after { + clear: both; +} +.top-bar, +.top-bar ul { + background-color: #e6e6e6; +} +.top-bar input { + max-width: 200px; + margin-right: 1rem; +} +.top-bar .input-group-field { + width: 100%; + margin-right: 0; +} +.top-bar input.button { + width: auto; +} +.top-bar .top-bar-left, +.top-bar .top-bar-right { + width: 100%; +} +@media print, screen and (min-width: 40em) { .top-bar .top-bar-left, .top-bar .top-bar-right { - width: 100%; } - @media print, screen and (min-width: 40em) { - .top-bar .top-bar-left, - .top-bar .top-bar-right { - width: auto; } } - @media print, screen and (max-width: 63.99875em) { - .top-bar.stacked-for-medium .top-bar-left, - .top-bar.stacked-for-medium .top-bar-right { - width: 100%; } } - @media print, screen and (max-width: 74.99875em) { - .top-bar.stacked-for-large .top-bar-left, - .top-bar.stacked-for-large .top-bar-right { - width: 100%; } } + width: auto; + } +} +@media print, screen and (max-width: 63.99875em) { + .top-bar.stacked-for-medium .top-bar-left, + .top-bar.stacked-for-medium .top-bar-right { + width: 100%; + } +} +@media print, screen and (max-width: 74.99875em) { + .top-bar.stacked-for-large .top-bar-left, + .top-bar.stacked-for-large .top-bar-right { + width: 100%; + } +} .top-bar-title { display: inline-block; float: left; - padding: 0.5rem 1rem 0.5rem 0; } - .top-bar-title .menu-icon { - bottom: 2px; } + padding: 0.5rem 1rem 0.5rem 0; +} +.top-bar-title .menu-icon { + bottom: 2px; +} .top-bar-left { - float: left; } + float: left; +} .top-bar-right { - float: right; } + float: right; +} .float-left { - float: left !important; } + float: left !important; +} .float-right { - float: right !important; } + float: right !important; +} .float-center { display: block; margin-right: auto; - margin-left: auto; } + margin-left: auto; +} .clearfix::before, .clearfix::after { display: table; - content: ' '; } - + content: " "; +} .clearfix::after { - clear: both; } + clear: both; +} .hide { - display: none !important; } + display: none !important; +} .invisible { - visibility: hidden; } + visibility: hidden; +} .visible { - visibility: visible; } + visibility: visible; +} @media print, screen and (max-width: 39.99875em) { .hide-for-small-only { - display: none !important; } } + display: none !important; + } +} @media screen and (max-width: 0em), screen and (min-width: 40em) { .show-for-small-only { - display: none !important; } } + display: none !important; + } +} @media print, screen and (min-width: 40em) { .hide-for-medium { - display: none !important; } } + display: none !important; + } +} @media screen and (max-width: 39.99875em) { .show-for-medium { - display: none !important; } } + display: none !important; + } +} @media print, screen and (min-width: 40em) and (max-width: 63.99875em) { .hide-for-medium-only { - display: none !important; } } + display: none !important; + } +} @media screen and (max-width: 39.99875em), screen and (min-width: 64em) { .show-for-medium-only { - display: none !important; } } + display: none !important; + } +} @media print, screen and (min-width: 64em) { .hide-for-large { - display: none !important; } } + display: none !important; + } +} @media screen and (max-width: 63.99875em) { .show-for-large { - display: none !important; } } + display: none !important; + } +} @media print, screen and (min-width: 64em) and (max-width: 74.99875em) { .hide-for-large-only { - display: none !important; } } + display: none !important; + } +} @media screen and (max-width: 63.99875em), screen and (min-width: 75em) { .show-for-large-only { - display: none !important; } } + display: none !important; + } +} .show-for-sr, .show-on-focus { @@ -4229,7 +5337,8 @@ html.is-reveal-open { overflow: hidden !important; clip: rect(0, 0, 0, 0) !important; white-space: nowrap !important; - border: 0 !important; } + border: 0 !important; +} .show-on-focus:active, .show-on-focus:focus { position: static !important; @@ -4237,60 +5346,80 @@ html.is-reveal-open { height: auto !important; overflow: visible !important; clip: auto !important; - white-space: normal !important; } + white-space: normal !important; +} .show-for-landscape, .hide-for-portrait { - display: block !important; } - @media screen and (orientation: landscape) { - .show-for-landscape, - .hide-for-portrait { - display: block !important; } } - @media screen and (orientation: portrait) { - .show-for-landscape, - .hide-for-portrait { - display: none !important; } } + display: block !important; +} +@media screen and (orientation: landscape) { + .show-for-landscape, + .hide-for-portrait { + display: block !important; + } +} +@media screen and (orientation: portrait) { + .show-for-landscape, + .hide-for-portrait { + display: none !important; + } +} .hide-for-landscape, .show-for-portrait { - display: none !important; } - @media screen and (orientation: landscape) { - .hide-for-landscape, - .show-for-portrait { - display: none !important; } } - @media screen and (orientation: portrait) { - .hide-for-landscape, - .show-for-portrait { - display: block !important; } } + display: none !important; +} +@media screen and (orientation: landscape) { + .hide-for-landscape, + .show-for-portrait { + display: none !important; + } +} +@media screen and (orientation: portrait) { + .hide-for-landscape, + .show-for-portrait { + display: block !important; + } +} .show-for-dark-mode { - display: none; } + display: none; +} .hide-for-dark-mode { - display: block; } + display: block; +} @media screen and (prefers-color-scheme: dark) { .show-for-dark-mode { - display: block !important; } + display: block !important; + } .hide-for-dark-mode { - display: none !important; } } - + display: none !important; + } +} .show-for-ie { - display: none; } + display: none; +} @media all and (-ms-high-contrast: none), (-ms-high-contrast: active) { .show-for-ie { - display: block !important; } + display: block !important; + } .hide-for-ie { - display: none !important; } } - + display: none !important; + } +} .show-for-sticky { - display: none; } + display: none; +} .is-stuck .show-for-sticky { - display: block; } + display: block; +} .is-stuck .hide-for-sticky { - display: none; } - + display: none; +} /*# sourceMappingURL=foundation-float.css.map */ diff --git a/dist/css/foundation-float.css.map b/dist/css/foundation-float.css.map index aad1368902..9756bdbf4b 100644 --- a/dist/css/foundation-float.css.map +++ b/dist/css/foundation-float.css.map @@ -1 +1 @@ -{"version":3,"sources":["foundation-float.css","../scss/foundation.scss","../scss/util/_breakpoint.scss","../scss/components/_reveal.scss","../scss/vendor/normalize.scss","../scss/_global.scss","../scss/util/_unit.scss","../scss/util/_mixins.scss","../scss/forms/_text.scss","../scss/forms/_checkbox.scss","../scss/forms/_label.scss","../scss/forms/_help-text.scss","../scss/forms/_input-group.scss","../scss/forms/_fieldset.scss","../scss/forms/_select.scss","../scss/forms/_error.scss","../scss/typography/_base.scss","../scss/typography/_helpers.scss","../scss/typography/_alignment.scss","../scss/typography/_print.scss","../scss/grid/_classes.scss","../scss/grid/_row.scss","../scss/grid/_gutter.scss","../scss/grid/_size.scss","../scss/util/_math.scss","../scss/grid/_column.scss","../scss/grid/_position.scss","../scss/grid/_layout.scss","../scss/components/_button.scss","../scss/components/_button-group.scss","../scss/components/_close-button.scss","../scss/components/_label.scss","../scss/components/_progress-bar.scss","../scss/forms/_progress.scss","../scss/components/_slider.scss","../scss/forms/_range.scss","../scss/components/_switch.scss","../scss/components/_table.scss","../scss/util/_color.scss","../scss/components/_badge.scss","../scss/components/_breadcrumbs.scss","../scss/components/_callout.scss","../scss/components/_card.scss","../scss/components/_dropdown.scss","../scss/components/_pagination.scss","../scss/components/_tooltip.scss","../scss/components/_accordion.scss","../scss/components/_media-object.scss","../scss/components/_orbit.scss","../scss/components/_responsive-embed.scss","../scss/components/_tabs.scss","../scss/components/_thumbnail.scss","../scss/components/_menu.scss","../scss/components/_menu-icon.scss","../scss/components/_accordion-menu.scss","../scss/components/_drilldown.scss","../scss/components/_dropdown-menu.scss","../scss/components/_off-canvas.scss","../scss/components/_sticky.scss","../scss/components/_title-bar.scss","../scss/components/_top-bar.scss","../scss/components/_float.scss","../scss/components/_visibility.scss"],"names":[],"mappings":"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D,EAAA;;AN2FtD;EM3DN,sBF+EkE,EAAA;;AJ3C9D;EGxFJ,UCmIkE,EAAA;;AJpC1D;EMzEN,kBAAkB;EAClB,SAH0D,EAAA;;ANiFpD;EM/EN,kBAAkB;EAClB,UAH0D,EAAA;;AN2FtD;EM3DN,sBF+EkE,EAAA;;AJ3C9D;EGxFJ,gBCmIkE,EAAA;;AJpC1D;EMzEN,kBAAkB;EAClB,eAH0D,EAAA;;ANiFpD;EM/EN,kBAAkB;EAClB,gBAH0D,EAAA;;AN2FtD;EM3DN,gBF+EkE,EAAA;;AJ3C9D;EGxFJ,gBCmIkE,EAAA;;AJpC1D;EMzEN,kBAAkB;EAClB,eAH0D,EAAA;;ANiFpD;EM/EN,kBAAkB;EAClB,gBAH0D,EAAA;;AN2FtD;EM3DN,sBF+EkE,EAAA;;AJ3C9D;EGxFJ,WCmIkE,EAAA;;AJpB5D;EM3DN,sBF+EkE,EAAA;;AJZ9D;EO/GF,WtBwGuD;EsBvGvD,WAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,UAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,gBAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,UAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,UAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,gBAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,gBAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeOrD;EO/GF,WtBwGuD;EsBvGvD,YAAgC,EAAA;EP8G9B;IOvFA,WAAW,EAAA;EPuFX;IOnFA,WAAW,EAAA;EPmFX;IO/EA,WtBwEqD,EAAA;;AeavD;EErHA,gBhB6ES;EgB5ET,ehB4ES,EAAA;;AcwCT;EAII,eAAe;EACf,cAAc,EAAA;;AAIlB;EACE,eAAe;EACf,cAAc,EAAA;;AAGhB;EEnIA,uBAFuC;EAGvC,sBAHuC,EAAA;;AF2IrC;EMjHF,kBAAkB;EAClB,iBAAiB,EAAA;EALjB;IACE,WAAW;IACX,WAAW,EAAA;;AN+HX;EMjHJ,gBAAgB;EAChB,eAAe;EACf,cAAc,EAAA;EAzCZ;IACE,WrB0GqD;IqBzGrD,WAAW,EAAA;EAKX;IACE,YrBoGoD,EAAA;;AHoDpD;EkB7EF;IGxFJ,eCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,cAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,eAH0D,EAAA;EN2FtD;IM3DN,eF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,qBF+EkE,EAAA;EJ3C9D;IGxFJ,UCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,SAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,UAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,gBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,UCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,SAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,UAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,gBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,UCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,SAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,UAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,gBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,WCmIkE,EAAA;EJpB5D;IM3DN,sBF+EkE,EAAA;EJZ9D;IO/GF,WtBwGuD;IsBvGvD,WAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,UAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,gBAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,UAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,UAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,gBAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,gBAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,YAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeavD;IErHA,gBhB6ES;IgB5ET,ehB4ES,EAAA;EcwCT;IAII,eAAe;IACf,cAAc,EAAA;EAIlB;IACE,eAAe;IACf,cAAc,EAAA;EAGhB;IEnIA,wBAFuC;IAGvC,uBAHuC,EAAA;EF2IrC;IMjHF,kBAAkB;IAClB,iBAAiB,EAAA;IALjB;MACE,WAAW;MACX,WAAW,EAAA;EN+HX;IMjHJ,gBAAgB;IAChB,eAAe;IACf,cAAc,EAAA;IAzCZ;MACE,WrB0GqD;MqBzGrD,WAAW,EAAA;IAKX;MACE,YrBoGoD,EAAA,EqBnGrD;;AxBuJC;EkB7EF;IGxFJ,eCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,cAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,eAH0D,EAAA;EN2FtD;IM3DN,eF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,qBF+EkE,EAAA;EJ3C9D;IGxFJ,UCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,SAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,UAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,gBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,UCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,SAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,UAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,gBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,UCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,SAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,UAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,gBF+EkE,EAAA;EJ3C9D;IGxFJ,gBCmIkE,EAAA;EJpC1D;IMzEN,kBAAkB;IAClB,eAH0D,EAAA;ENiFpD;IM/EN,kBAAkB;IAClB,gBAH0D,EAAA;EN2FtD;IM3DN,sBF+EkE,EAAA;EJ3C9D;IGxFJ,WCmIkE,EAAA;EJpB5D;IM3DN,sBF+EkE,EAAA;EJZ9D;IO/GF,WtBwGuD;IsBvGvD,WAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,WtBwGuD;IsBvGvD,UAAgC,EAAA;IP8G9B;MOvFA,WAAW,EAAA;IPuFX;MOnFA,WAAW,EAAA;IPmFX;MO/EA,WtBwEqD,EAAA;EeOrD;IO/GF,Wt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","file":"foundation-float.css","sourcesContent":["@charset \"UTF-8\";\n/**\n * Foundation for Sites\n * Version 6.7.5\n * https://get.foundation\n * Licensed under MIT Open Source\n */\n@media print, screen and (min-width: 40em) {\n .reveal, .reveal.tiny, .reveal.small, .reveal.large {\n right: auto;\n left: auto;\n margin: 0 auto; } }\n\n/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n line-height: 1.15;\n -webkit-text-size-adjust: 100%; }\n\nbody {\n margin: 0; }\n\nh1 {\n font-size: 2em;\n margin: 0.67em 0; }\n\nhr {\n box-sizing: content-box;\n height: 0;\n overflow: visible; }\n\npre {\n font-family: monospace, monospace;\n font-size: 1em; }\n\na {\n background-color: transparent; }\n\nabbr[title] {\n border-bottom: 0;\n text-decoration: underline dotted; }\n\nb,\nstrong {\n font-weight: bolder; }\n\ncode,\nkbd,\nsamp {\n font-family: monospace, monospace;\n font-size: 1em; }\n\nsmall {\n font-size: 80%; }\n\nsub,\nsup {\n font-size: 75%;\n line-height: 0;\n position: relative;\n vertical-align: baseline; }\n\nsub {\n bottom: -0.25em; }\n\nsup {\n top: -0.5em; }\n\nimg {\n border-style: none; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n font-family: inherit;\n font-size: 100%;\n line-height: 1.15;\n margin: 0; }\n\nbutton,\ninput {\n overflow: visible; }\n\nbutton,\nselect {\n text-transform: none; }\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n -webkit-appearance: button; }\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n border-style: none;\n padding: 0; }\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n outline: 1px dotted ButtonText; }\n\nfieldset {\n padding: 0.35em 0.75em 0.625em; }\n\nlegend {\n box-sizing: border-box;\n color: inherit;\n display: table;\n max-width: 100%;\n padding: 0;\n white-space: normal; }\n\nprogress {\n vertical-align: baseline; }\n\ntextarea {\n overflow: auto; }\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n box-sizing: border-box;\n padding: 0; }\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n height: auto; }\n\n[type=\"search\"] {\n -webkit-appearance: textfield;\n outline-offset: -2px; }\n\n[type=\"search\"]::-webkit-search-decoration {\n -webkit-appearance: none; }\n\n::-webkit-file-upload-button {\n -webkit-appearance: button;\n font: inherit; }\n\ndetails {\n display: block; }\n\nsummary {\n display: list-item; }\n\ntemplate {\n display: none; }\n\n[hidden] {\n display: none; }\n\n[data-whatintent=\"mouse\"] *, [data-whatintent=\"mouse\"] *:focus,\n[data-whatintent=\"touch\"] *,\n[data-whatintent=\"touch\"] *:focus,\n[data-whatinput=\"mouse\"] *,\n[data-whatinput=\"mouse\"] *:focus,\n[data-whatinput=\"touch\"] *,\n[data-whatinput=\"touch\"] *:focus {\n outline: none; }\n\n[draggable=false] {\n -webkit-touch-callout: none;\n -webkit-user-select: none; }\n\n.foundation-mq {\n font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\"; }\n\nhtml {\n box-sizing: border-box;\n font-size: 100%; }\n\n*,\n*::before,\n*::after {\n box-sizing: inherit; }\n\nbody {\n margin: 0;\n padding: 0;\n background: #fefefe;\n font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n font-weight: normal;\n line-height: 1.5;\n color: #0a0a0a;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\nimg {\n display: inline-block;\n vertical-align: middle;\n max-width: 100%;\n height: auto;\n -ms-interpolation-mode: bicubic; }\n\ntextarea {\n height: auto;\n min-height: 50px;\n border-radius: 0; }\n\nselect {\n box-sizing: border-box;\n width: 100%;\n border-radius: 0; }\n\n.map_canvas img,\n.map_canvas embed,\n.map_canvas object,\n.mqa-display img,\n.mqa-display embed,\n.mqa-display object {\n max-width: none !important; }\n\nbutton {\n padding: 0;\n appearance: none;\n border: 0;\n border-radius: 0;\n background: transparent;\n line-height: 1;\n cursor: auto; }\n [data-whatinput='mouse'] button {\n outline: 0; }\n\npre {\n overflow: auto;\n -webkit-overflow-scrolling: touch; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n font-family: inherit; }\n\n.is-visible {\n display: block !important; }\n\n.is-hidden {\n display: none !important; }\n\n[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],\ntextarea {\n display: block;\n box-sizing: border-box;\n width: 100%;\n height: 2.4375rem;\n margin: 0 0 1rem;\n padding: 0.5rem;\n border: 1px solid #cacaca;\n border-radius: 0;\n background-color: #fefefe;\n box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);\n font-family: inherit;\n font-size: 1rem;\n font-weight: normal;\n line-height: 1.5;\n color: #0a0a0a;\n transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n appearance: none; }\n [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,\n textarea:focus {\n outline: none;\n border: 1px solid #8a8a8a;\n background-color: #fefefe;\n box-shadow: 0 0 5px #cacaca;\n transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n\ntextarea {\n max-width: 100%; }\n textarea[rows] {\n height: auto; }\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n background-color: #e6e6e6;\n cursor: not-allowed; }\n\n[type='submit'],\n[type='button'] {\n appearance: none;\n border-radius: 0; }\n\ninput[type='search'] {\n box-sizing: border-box; }\n\n::placeholder {\n color: #cacaca; }\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n margin: 0 0 1rem; }\n\n[type='checkbox'] + label,\n[type='radio'] + label {\n display: inline-block;\n vertical-align: baseline;\n margin-left: 0.5rem;\n margin-right: 1rem;\n margin-bottom: 0; }\n [type='checkbox'] + label[for],\n [type='radio'] + label[for] {\n cursor: pointer; }\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n margin-right: 0.5rem; }\n\n[type='file'] {\n width: 100%; }\n\nlabel {\n display: block;\n margin: 0;\n font-size: 0.875rem;\n font-weight: normal;\n line-height: 1.8;\n color: #0a0a0a; }\n label.middle {\n margin: 0 0 1rem;\n line-height: 1.5;\n padding: 0.5625rem 0; }\n\n.help-text {\n margin-top: -0.5rem;\n font-size: 0.8125rem;\n font-style: italic;\n color: #0a0a0a; }\n\n.input-group {\n display: table;\n width: 100%;\n margin-bottom: 1rem; }\n .input-group > :first-child, .input-group > :first-child.input-group-button > * {\n border-radius: 0 0 0 0; }\n .input-group > :last-child, .input-group > :last-child.input-group-button > * {\n border-radius: 0 0 0 0; }\n\n.input-group-label, .input-group-field, .input-group-button, .input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n margin: 0;\n white-space: nowrap;\n display: table-cell;\n vertical-align: middle; }\n\n.input-group-label {\n padding: 0 1rem;\n border: 1px solid #cacaca;\n background: #e6e6e6;\n color: #0a0a0a;\n text-align: center;\n white-space: nowrap;\n width: 1%;\n height: 100%; }\n .input-group-label:first-child {\n border-right: 0; }\n .input-group-label:last-child {\n border-left: 0; }\n\n.input-group-field {\n border-radius: 0; }\n\n.input-group-button {\n padding-top: 0;\n padding-bottom: 0;\n text-align: center;\n width: 1%;\n height: 100%; }\n .input-group-button a,\n .input-group-button input,\n .input-group-button button,\n .input-group-button label {\n height: 2.4375rem;\n padding-top: 0;\n padding-bottom: 0;\n font-size: 1rem; }\n\n.input-group .input-group-button {\n display: table-cell; }\n\nfieldset {\n margin: 0;\n padding: 0;\n border: 0; }\n\nlegend {\n max-width: 100%;\n margin-bottom: 0.5rem; }\n\n.fieldset {\n margin: 1.125rem 0;\n padding: 1.25rem;\n border: 1px solid #cacaca; }\n .fieldset legend {\n margin: 0;\n margin-left: -0.1875rem;\n padding: 0 0.1875rem; }\n\nselect {\n height: 2.4375rem;\n margin: 0 0 1rem;\n padding: 0.5rem;\n appearance: none;\n border: 1px solid #cacaca;\n border-radius: 0;\n background-color: #fefefe;\n font-family: inherit;\n font-size: 1rem;\n font-weight: normal;\n line-height: 1.5;\n color: #0a0a0a;\n background-image: url('data:image/svg+xml;utf8,');\n background-origin: content-box;\n background-position: right -1rem center;\n background-repeat: no-repeat;\n background-size: 9px 6px;\n padding-right: 1.5rem;\n transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n @media screen and (min-width: 0\\0) {\n select {\n background-image: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==\"); } }\n select:focus {\n outline: none;\n border: 1px solid #8a8a8a;\n background-color: #fefefe;\n box-shadow: 0 0 5px #cacaca;\n transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n select:disabled {\n background-color: #e6e6e6;\n cursor: not-allowed; }\n select::-ms-expand {\n display: none; }\n select[multiple] {\n height: auto;\n background-image: none; }\n select:not([multiple]) {\n padding-top: 0;\n padding-bottom: 0; }\n\n.is-invalid-input:not(:focus) {\n border-color: #cc4b37;\n background-color: #f9ecea; }\n .is-invalid-input:not(:focus)::placeholder {\n color: #cc4b37; }\n\n.is-invalid-label {\n color: #cc4b37; }\n\n.form-error {\n display: none;\n margin-top: -0.5rem;\n margin-bottom: 1rem;\n font-size: 0.75rem;\n font-weight: bold;\n color: #cc4b37; }\n .form-error.is-visible {\n display: block; }\n\ndiv,\ndl,\ndt,\ndd,\nul,\nol,\nli,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\npre,\nform,\np,\nblockquote,\nth,\ntd {\n margin: 0;\n padding: 0; }\n\np {\n margin-bottom: 1rem;\n font-size: inherit;\n line-height: 1.6;\n text-rendering: optimizeLegibility; }\n\nem,\ni {\n font-style: italic;\n line-height: inherit; }\n\nstrong,\nb {\n font-weight: bold;\n line-height: inherit; }\n\nsmall {\n font-size: 80%;\n line-height: inherit; }\n\nh1, .h1,\nh2, .h2,\nh3, .h3,\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n font-style: normal;\n font-weight: normal;\n color: inherit;\n text-rendering: optimizeLegibility; }\n h1 small, .h1 small,\n h2 small, .h2 small,\n h3 small, .h3 small,\n h4 small, .h4 small,\n h5 small, .h5 small,\n h6 small, .h6 small {\n line-height: 0;\n color: #cacaca; }\n\nh1, .h1 {\n font-size: 1.5rem;\n line-height: 1.4;\n margin-top: 0;\n margin-bottom: 0.5rem; }\n\nh2, .h2 {\n font-size: 1.25rem;\n line-height: 1.4;\n margin-top: 0;\n margin-bottom: 0.5rem; }\n\nh3, .h3 {\n font-size: 1.1875rem;\n line-height: 1.4;\n margin-top: 0;\n margin-bottom: 0.5rem; }\n\nh4, .h4 {\n font-size: 1.125rem;\n line-height: 1.4;\n margin-top: 0;\n margin-bottom: 0.5rem; }\n\nh5, .h5 {\n font-size: 1.0625rem;\n line-height: 1.4;\n margin-top: 0;\n margin-bottom: 0.5rem; }\n\nh6, .h6 {\n font-size: 1rem;\n line-height: 1.4;\n margin-top: 0;\n margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n h1, .h1 {\n font-size: 3rem; }\n h2, .h2 {\n font-size: 2.5rem; }\n h3, .h3 {\n font-size: 1.9375rem; }\n h4, .h4 {\n font-size: 1.5625rem; }\n h5, .h5 {\n font-size: 1.25rem; }\n h6, .h6 {\n font-size: 1rem; } }\n\na {\n line-height: inherit;\n color: #1779ba;\n text-decoration: none;\n cursor: pointer; }\n a:hover, a:focus {\n color: #1468a0; }\n a img {\n border: 0; }\n\nhr {\n clear: both;\n max-width: 75rem;\n height: 0;\n margin: 1.25rem auto;\n border-top: 0;\n border-right: 0;\n border-bottom: 1px solid #cacaca;\n border-left: 0; }\n\nul,\nol,\ndl {\n margin-bottom: 1rem;\n list-style-position: outside;\n line-height: 1.6; }\n\nli {\n font-size: inherit; }\n\nul {\n margin-left: 1.25rem;\n list-style-type: disc; }\n\nol {\n margin-left: 1.25rem; }\n\nul ul, ol ul, ul ol, ol ol {\n margin-left: 1.25rem;\n margin-bottom: 0; }\n\ndl {\n margin-bottom: 1rem; }\n dl dt {\n margin-bottom: 0.3rem;\n font-weight: bold; }\n\nblockquote {\n margin: 0 0 1rem;\n padding: 0.5625rem 1.25rem 0 1.1875rem;\n border-left: 1px solid #cacaca; }\n blockquote, blockquote p {\n line-height: 1.6;\n color: #8a8a8a; }\n\nabbr, abbr[title] {\n border-bottom: 1px dotted #0a0a0a;\n cursor: help;\n text-decoration: none; }\n\nfigure {\n margin: 0; }\n\nkbd {\n margin: 0;\n padding: 0.125rem 0.25rem 0;\n background-color: #e6e6e6;\n font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n color: #0a0a0a; }\n\n.subheader {\n margin-top: 0.2rem;\n margin-bottom: 0.5rem;\n font-weight: normal;\n line-height: 1.4;\n color: #8a8a8a; }\n\n.lead {\n font-size: 125%;\n line-height: 1.6; }\n\n.stat {\n font-size: 2.5rem;\n line-height: 1; }\n p + .stat {\n margin-top: -1rem; }\n\nul.no-bullet, ol.no-bullet {\n margin-left: 0;\n list-style: none; }\n\ncite, .cite-block {\n display: block;\n color: #8a8a8a;\n font-size: 0.8125rem; }\n cite:before, .cite-block:before {\n content: \"— \"; }\n\ncode, .code-inline {\n border: 1px solid #cacaca;\n background-color: #e6e6e6;\n font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n font-weight: normal;\n color: #0a0a0a;\n display: inline;\n max-width: 100%;\n word-wrap: break-word;\n padding: 0.125rem 0.3125rem 0.0625rem; }\n\n.code-block {\n border: 1px solid #cacaca;\n background-color: #e6e6e6;\n font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n font-weight: normal;\n color: #0a0a0a;\n display: block;\n overflow: auto;\n white-space: pre;\n padding: 1rem;\n margin-bottom: 1.5rem; }\n\n.text-left {\n text-align: left; }\n\n.text-right {\n text-align: right; }\n\n.text-center {\n text-align: center; }\n\n.text-justify {\n text-align: justify; }\n\n@media print, screen and (min-width: 40em) {\n .medium-text-left {\n text-align: left; }\n .medium-text-right {\n text-align: right; }\n .medium-text-center {\n text-align: center; }\n .medium-text-justify {\n text-align: justify; } }\n\n@media print, screen and (min-width: 64em) {\n .large-text-left {\n text-align: left; }\n .large-text-right {\n text-align: right; }\n .large-text-center {\n text-align: center; }\n .large-text-justify {\n text-align: justify; } }\n\n.show-for-print {\n display: none !important; }\n\n@media print {\n * {\n background: transparent !important;\n color: black !important;\n print-color-adjust: economy;\n box-shadow: none !important;\n text-shadow: none !important; }\n .show-for-print {\n display: block !important; }\n .hide-for-print {\n display: none !important; }\n table.show-for-print {\n display: table !important; }\n thead.show-for-print {\n display: table-header-group !important; }\n tbody.show-for-print {\n display: table-row-group !important; }\n tr.show-for-print {\n display: table-row !important; }\n td.show-for-print {\n display: table-cell !important; }\n th.show-for-print {\n display: table-cell !important; }\n a,\n a:visited {\n text-decoration: underline; }\n a[href]:after {\n content: \" (\" attr(href) \")\"; }\n .ir a:after,\n a[href^='javascript:']:after,\n a[href^='#']:after {\n content: ''; }\n abbr[title]:after {\n content: \" (\" attr(title) \")\"; }\n pre,\n blockquote {\n border: 1px solid #8a8a8a;\n page-break-inside: avoid; }\n thead {\n display: table-header-group; }\n tr,\n img {\n page-break-inside: avoid; }\n img {\n max-width: 100% !important; }\n @page {\n margin: 0.5cm; }\n p,\n h2,\n h3 {\n orphans: 3;\n widows: 3; }\n h2,\n h3 {\n page-break-after: avoid; }\n .print-break-inside {\n page-break-inside: auto; } }\n\n.row {\n max-width: 75rem;\n margin-right: auto;\n margin-left: auto; }\n .row::before, .row::after {\n display: table;\n content: ' '; }\n .row::after {\n clear: both; }\n .row.collapse > .column, .row.collapse > .columns {\n padding-right: 0;\n padding-left: 0; }\n .row .row {\n margin-right: -0.625rem;\n margin-left: -0.625rem; }\n @media print, screen and (min-width: 40em) {\n .row .row {\n margin-right: -0.9375rem;\n margin-left: -0.9375rem; } }\n @media print, screen and (min-width: 64em) {\n .row .row {\n margin-right: -0.9375rem;\n margin-left: -0.9375rem; } }\n .row .row.collapse {\n margin-right: 0;\n margin-left: 0; }\n .row.expanded {\n max-width: none; }\n .row.expanded .row {\n margin-right: auto;\n margin-left: auto; }\n .row:not(.expanded) .row {\n max-width: none; }\n .row.gutter-small > .column, .row.gutter-small > .columns {\n padding-right: 0.625rem;\n padding-left: 0.625rem; }\n .row.gutter-medium > .column, .row.gutter-medium > .columns {\n padding-right: 0.9375rem;\n padding-left: 0.9375rem; }\n\n.column, .columns {\n padding-right: 0.625rem;\n padding-left: 0.625rem;\n width: 100%;\n float: left; }\n @media print, screen and (min-width: 40em) {\n .column, .columns {\n padding-right: 0.9375rem;\n padding-left: 0.9375rem; } }\n .column, .columns, .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {\n float: left;\n clear: none; }\n .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {\n float: right; }\n .column.end:last-child:last-child, .end.columns:last-child:last-child {\n float: left; }\n\n.column.row.row, .row.row.columns {\n float: none; }\n\n.row .column.row.row, .row .row.row.columns {\n margin-right: 0;\n margin-left: 0;\n padding-right: 0;\n padding-left: 0; }\n\n.small-1 {\n width: 8.33333%; }\n\n.small-push-1 {\n position: relative;\n left: 8.33333%; }\n\n.small-pull-1 {\n position: relative;\n left: -8.33333%; }\n\n.small-offset-0 {\n margin-left: 0%; }\n\n.small-2 {\n width: 16.66667%; }\n\n.small-push-2 {\n position: relative;\n left: 16.66667%; }\n\n.small-pull-2 {\n position: relative;\n left: -16.66667%; }\n\n.small-offset-1 {\n margin-left: 8.33333%; }\n\n.small-3 {\n width: 25%; }\n\n.small-push-3 {\n position: relative;\n left: 25%; }\n\n.small-pull-3 {\n position: relative;\n left: -25%; }\n\n.small-offset-2 {\n margin-left: 16.66667%; }\n\n.small-4 {\n width: 33.33333%; }\n\n.small-push-4 {\n position: relative;\n left: 33.33333%; }\n\n.small-pull-4 {\n position: relative;\n left: -33.33333%; }\n\n.small-offset-3 {\n margin-left: 25%; }\n\n.small-5 {\n width: 41.66667%; }\n\n.small-push-5 {\n position: relative;\n left: 41.66667%; }\n\n.small-pull-5 {\n position: relative;\n left: -41.66667%; }\n\n.small-offset-4 {\n margin-left: 33.33333%; }\n\n.small-6 {\n width: 50%; }\n\n.small-push-6 {\n position: relative;\n left: 50%; }\n\n.small-pull-6 {\n position: relative;\n left: -50%; }\n\n.small-offset-5 {\n margin-left: 41.66667%; }\n\n.small-7 {\n width: 58.33333%; }\n\n.small-push-7 {\n position: relative;\n left: 58.33333%; }\n\n.small-pull-7 {\n position: relative;\n left: -58.33333%; }\n\n.small-offset-6 {\n margin-left: 50%; }\n\n.small-8 {\n width: 66.66667%; }\n\n.small-push-8 {\n position: relative;\n left: 66.66667%; }\n\n.small-pull-8 {\n position: relative;\n left: -66.66667%; }\n\n.small-offset-7 {\n margin-left: 58.33333%; }\n\n.small-9 {\n width: 75%; }\n\n.small-push-9 {\n position: relative;\n left: 75%; }\n\n.small-pull-9 {\n position: relative;\n left: -75%; }\n\n.small-offset-8 {\n margin-left: 66.66667%; }\n\n.small-10 {\n width: 83.33333%; }\n\n.small-push-10 {\n position: relative;\n left: 83.33333%; }\n\n.small-pull-10 {\n position: relative;\n left: -83.33333%; }\n\n.small-offset-9 {\n margin-left: 75%; }\n\n.small-11 {\n width: 91.66667%; }\n\n.small-push-11 {\n position: relative;\n left: 91.66667%; }\n\n.small-pull-11 {\n position: relative;\n left: -91.66667%; }\n\n.small-offset-10 {\n margin-left: 83.33333%; }\n\n.small-12 {\n width: 100%; }\n\n.small-offset-11 {\n margin-left: 91.66667%; }\n\n.small-up-1 > .column, .small-up-1 > .columns {\n float: left;\n width: 100%; }\n .small-up-1 > .column:nth-of-type(1n), .small-up-1 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-1 > .column:nth-of-type(1n+1), .small-up-1 > .columns:nth-of-type(1n+1) {\n clear: both; }\n .small-up-1 > .column:last-child, .small-up-1 > .columns:last-child {\n float: left; }\n\n.small-up-2 > .column, .small-up-2 > .columns {\n float: left;\n width: 50%; }\n .small-up-2 > .column:nth-of-type(1n), .small-up-2 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-2 > .column:nth-of-type(2n+1), .small-up-2 > .columns:nth-of-type(2n+1) {\n clear: both; }\n .small-up-2 > .column:last-child, .small-up-2 > .columns:last-child {\n float: left; }\n\n.small-up-3 > .column, .small-up-3 > .columns {\n float: left;\n width: 33.33333%; }\n .small-up-3 > .column:nth-of-type(1n), .small-up-3 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-3 > .column:nth-of-type(3n+1), .small-up-3 > .columns:nth-of-type(3n+1) {\n clear: both; }\n .small-up-3 > .column:last-child, .small-up-3 > .columns:last-child {\n float: left; }\n\n.small-up-4 > .column, .small-up-4 > .columns {\n float: left;\n width: 25%; }\n .small-up-4 > .column:nth-of-type(1n), .small-up-4 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-4 > .column:nth-of-type(4n+1), .small-up-4 > .columns:nth-of-type(4n+1) {\n clear: both; }\n .small-up-4 > .column:last-child, .small-up-4 > .columns:last-child {\n float: left; }\n\n.small-up-5 > .column, .small-up-5 > .columns {\n float: left;\n width: 20%; }\n .small-up-5 > .column:nth-of-type(1n), .small-up-5 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-5 > .column:nth-of-type(5n+1), .small-up-5 > .columns:nth-of-type(5n+1) {\n clear: both; }\n .small-up-5 > .column:last-child, .small-up-5 > .columns:last-child {\n float: left; }\n\n.small-up-6 > .column, .small-up-6 > .columns {\n float: left;\n width: 16.66667%; }\n .small-up-6 > .column:nth-of-type(1n), .small-up-6 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-6 > .column:nth-of-type(6n+1), .small-up-6 > .columns:nth-of-type(6n+1) {\n clear: both; }\n .small-up-6 > .column:last-child, .small-up-6 > .columns:last-child {\n float: left; }\n\n.small-up-7 > .column, .small-up-7 > .columns {\n float: left;\n width: 14.28571%; }\n .small-up-7 > .column:nth-of-type(1n), .small-up-7 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-7 > .column:nth-of-type(7n+1), .small-up-7 > .columns:nth-of-type(7n+1) {\n clear: both; }\n .small-up-7 > .column:last-child, .small-up-7 > .columns:last-child {\n float: left; }\n\n.small-up-8 > .column, .small-up-8 > .columns {\n float: left;\n width: 12.5%; }\n .small-up-8 > .column:nth-of-type(1n), .small-up-8 > .columns:nth-of-type(1n) {\n clear: none; }\n .small-up-8 > .column:nth-of-type(8n+1), .small-up-8 > .columns:nth-of-type(8n+1) {\n clear: both; }\n .small-up-8 > .column:last-child, .small-up-8 > .columns:last-child {\n float: left; }\n\n.small-collapse > .column, .small-collapse > .columns {\n padding-right: 0;\n padding-left: 0; }\n\n.small-collapse .row {\n margin-right: 0;\n margin-left: 0; }\n\n.expanded.row .small-collapse.row {\n margin-right: 0;\n margin-left: 0; }\n\n.small-uncollapse > .column, .small-uncollapse > .columns {\n padding-right: 0.625rem;\n padding-left: 0.625rem; }\n\n.small-centered {\n margin-right: auto;\n margin-left: auto; }\n .small-centered, .small-centered:last-child:not(:first-child) {\n float: none;\n clear: both; }\n\n.small-uncentered, .small-push-0, .small-pull-0 {\n position: static;\n margin-right: 0;\n margin-left: 0; }\n .small-uncentered, .small-uncentered:last-child:not(:first-child), .small-push-0, .small-push-0:last-child:not(:first-child), .small-pull-0, .small-pull-0:last-child:not(:first-child) {\n float: left;\n clear: none; }\n .small-uncentered:last-child:not(:first-child), .small-push-0:last-child:not(:first-child), .small-pull-0:last-child:not(:first-child) {\n float: right; }\n\n@media print, screen and (min-width: 40em) {\n .medium-1 {\n width: 8.33333%; }\n .medium-push-1 {\n position: relative;\n left: 8.33333%; }\n .medium-pull-1 {\n position: relative;\n left: -8.33333%; }\n .medium-offset-0 {\n margin-left: 0%; }\n .medium-2 {\n width: 16.66667%; }\n .medium-push-2 {\n position: relative;\n left: 16.66667%; }\n .medium-pull-2 {\n position: relative;\n left: -16.66667%; }\n .medium-offset-1 {\n margin-left: 8.33333%; }\n .medium-3 {\n width: 25%; }\n .medium-push-3 {\n position: relative;\n left: 25%; }\n .medium-pull-3 {\n position: relative;\n left: -25%; }\n .medium-offset-2 {\n margin-left: 16.66667%; }\n .medium-4 {\n width: 33.33333%; }\n .medium-push-4 {\n position: relative;\n left: 33.33333%; }\n .medium-pull-4 {\n position: relative;\n left: -33.33333%; }\n .medium-offset-3 {\n margin-left: 25%; }\n .medium-5 {\n width: 41.66667%; }\n .medium-push-5 {\n position: relative;\n left: 41.66667%; }\n .medium-pull-5 {\n position: relative;\n left: -41.66667%; }\n .medium-offset-4 {\n margin-left: 33.33333%; }\n .medium-6 {\n width: 50%; }\n .medium-push-6 {\n position: relative;\n left: 50%; }\n .medium-pull-6 {\n position: relative;\n left: -50%; }\n .medium-offset-5 {\n margin-left: 41.66667%; }\n .medium-7 {\n width: 58.33333%; }\n .medium-push-7 {\n position: relative;\n left: 58.33333%; }\n .medium-pull-7 {\n position: relative;\n left: -58.33333%; }\n .medium-offset-6 {\n margin-left: 50%; }\n .medium-8 {\n width: 66.66667%; }\n .medium-push-8 {\n position: relative;\n left: 66.66667%; }\n .medium-pull-8 {\n position: relative;\n left: -66.66667%; }\n .medium-offset-7 {\n margin-left: 58.33333%; }\n .medium-9 {\n width: 75%; }\n .medium-push-9 {\n position: relative;\n left: 75%; }\n .medium-pull-9 {\n position: relative;\n left: -75%; }\n .medium-offset-8 {\n margin-left: 66.66667%; }\n .medium-10 {\n width: 83.33333%; }\n .medium-push-10 {\n position: relative;\n left: 83.33333%; }\n .medium-pull-10 {\n position: relative;\n left: -83.33333%; }\n .medium-offset-9 {\n margin-left: 75%; }\n .medium-11 {\n width: 91.66667%; }\n .medium-push-11 {\n position: relative;\n left: 91.66667%; }\n .medium-pull-11 {\n position: relative;\n left: -91.66667%; }\n .medium-offset-10 {\n margin-left: 83.33333%; }\n .medium-12 {\n width: 100%; }\n .medium-offset-11 {\n margin-left: 91.66667%; }\n .medium-up-1 > .column, .medium-up-1 > .columns {\n float: left;\n width: 100%; }\n .medium-up-1 > .column:nth-of-type(1n), .medium-up-1 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-1 > .column:nth-of-type(1n+1), .medium-up-1 > .columns:nth-of-type(1n+1) {\n clear: both; }\n .medium-up-1 > .column:last-child, .medium-up-1 > .columns:last-child {\n float: left; }\n .medium-up-2 > .column, .medium-up-2 > .columns {\n float: left;\n width: 50%; }\n .medium-up-2 > .column:nth-of-type(1n), .medium-up-2 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-2 > .column:nth-of-type(2n+1), .medium-up-2 > .columns:nth-of-type(2n+1) {\n clear: both; }\n .medium-up-2 > .column:last-child, .medium-up-2 > .columns:last-child {\n float: left; }\n .medium-up-3 > .column, .medium-up-3 > .columns {\n float: left;\n width: 33.33333%; }\n .medium-up-3 > .column:nth-of-type(1n), .medium-up-3 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-3 > .column:nth-of-type(3n+1), .medium-up-3 > .columns:nth-of-type(3n+1) {\n clear: both; }\n .medium-up-3 > .column:last-child, .medium-up-3 > .columns:last-child {\n float: left; }\n .medium-up-4 > .column, .medium-up-4 > .columns {\n float: left;\n width: 25%; }\n .medium-up-4 > .column:nth-of-type(1n), .medium-up-4 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-4 > .column:nth-of-type(4n+1), .medium-up-4 > .columns:nth-of-type(4n+1) {\n clear: both; }\n .medium-up-4 > .column:last-child, .medium-up-4 > .columns:last-child {\n float: left; }\n .medium-up-5 > .column, .medium-up-5 > .columns {\n float: left;\n width: 20%; }\n .medium-up-5 > .column:nth-of-type(1n), .medium-up-5 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-5 > .column:nth-of-type(5n+1), .medium-up-5 > .columns:nth-of-type(5n+1) {\n clear: both; }\n .medium-up-5 > .column:last-child, .medium-up-5 > .columns:last-child {\n float: left; }\n .medium-up-6 > .column, .medium-up-6 > .columns {\n float: left;\n width: 16.66667%; }\n .medium-up-6 > .column:nth-of-type(1n), .medium-up-6 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-6 > .column:nth-of-type(6n+1), .medium-up-6 > .columns:nth-of-type(6n+1) {\n clear: both; }\n .medium-up-6 > .column:last-child, .medium-up-6 > .columns:last-child {\n float: left; }\n .medium-up-7 > .column, .medium-up-7 > .columns {\n float: left;\n width: 14.28571%; }\n .medium-up-7 > .column:nth-of-type(1n), .medium-up-7 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-7 > .column:nth-of-type(7n+1), .medium-up-7 > .columns:nth-of-type(7n+1) {\n clear: both; }\n .medium-up-7 > .column:last-child, .medium-up-7 > .columns:last-child {\n float: left; }\n .medium-up-8 > .column, .medium-up-8 > .columns {\n float: left;\n width: 12.5%; }\n .medium-up-8 > .column:nth-of-type(1n), .medium-up-8 > .columns:nth-of-type(1n) {\n clear: none; }\n .medium-up-8 > .column:nth-of-type(8n+1), .medium-up-8 > .columns:nth-of-type(8n+1) {\n clear: both; }\n .medium-up-8 > .column:last-child, .medium-up-8 > .columns:last-child {\n float: left; }\n .medium-collapse > .column, .medium-collapse > .columns {\n padding-right: 0;\n padding-left: 0; }\n .medium-collapse .row {\n margin-right: 0;\n margin-left: 0; }\n .expanded.row .medium-collapse.row {\n margin-right: 0;\n margin-left: 0; }\n .medium-uncollapse > .column, .medium-uncollapse > .columns {\n padding-right: 0.9375rem;\n padding-left: 0.9375rem; }\n .medium-centered {\n margin-right: auto;\n margin-left: auto; }\n .medium-centered, .medium-centered:last-child:not(:first-child) {\n float: none;\n clear: both; }\n .medium-uncentered, .medium-push-0, .medium-pull-0 {\n position: static;\n margin-right: 0;\n margin-left: 0; }\n .medium-uncentered, .medium-uncentered:last-child:not(:first-child), .medium-push-0, .medium-push-0:last-child:not(:first-child), .medium-pull-0, .medium-pull-0:last-child:not(:first-child) {\n float: left;\n clear: none; }\n .medium-uncentered:last-child:not(:first-child), .medium-push-0:last-child:not(:first-child), .medium-pull-0:last-child:not(:first-child) {\n float: right; } }\n\n@media print, screen and (min-width: 64em) {\n .large-1 {\n width: 8.33333%; }\n .large-push-1 {\n position: relative;\n left: 8.33333%; }\n .large-pull-1 {\n position: relative;\n left: -8.33333%; }\n .large-offset-0 {\n margin-left: 0%; }\n .large-2 {\n width: 16.66667%; }\n .large-push-2 {\n position: relative;\n left: 16.66667%; }\n .large-pull-2 {\n position: relative;\n left: -16.66667%; }\n .large-offset-1 {\n margin-left: 8.33333%; }\n .large-3 {\n width: 25%; }\n .large-push-3 {\n position: relative;\n left: 25%; }\n .large-pull-3 {\n position: relative;\n left: -25%; }\n .large-offset-2 {\n margin-left: 16.66667%; }\n .large-4 {\n width: 33.33333%; }\n .large-push-4 {\n position: relative;\n left: 33.33333%; }\n .large-pull-4 {\n position: relative;\n left: -33.33333%; }\n .large-offset-3 {\n margin-left: 25%; }\n .large-5 {\n width: 41.66667%; }\n .large-push-5 {\n position: relative;\n left: 41.66667%; }\n .large-pull-5 {\n position: relative;\n left: -41.66667%; }\n .large-offset-4 {\n margin-left: 33.33333%; }\n .large-6 {\n width: 50%; }\n .large-push-6 {\n position: relative;\n left: 50%; }\n .large-pull-6 {\n position: relative;\n left: -50%; }\n .large-offset-5 {\n margin-left: 41.66667%; }\n .large-7 {\n width: 58.33333%; }\n .large-push-7 {\n position: relative;\n left: 58.33333%; }\n .large-pull-7 {\n position: relative;\n left: -58.33333%; }\n .large-offset-6 {\n margin-left: 50%; }\n .large-8 {\n width: 66.66667%; }\n .large-push-8 {\n position: relative;\n left: 66.66667%; }\n .large-pull-8 {\n position: relative;\n left: -66.66667%; }\n .large-offset-7 {\n margin-left: 58.33333%; }\n .large-9 {\n width: 75%; }\n .large-push-9 {\n position: relative;\n left: 75%; }\n .large-pull-9 {\n position: relative;\n left: -75%; }\n .large-offset-8 {\n margin-left: 66.66667%; }\n .large-10 {\n width: 83.33333%; }\n .large-push-10 {\n position: relative;\n left: 83.33333%; }\n .large-pull-10 {\n position: relative;\n left: -83.33333%; }\n .large-offset-9 {\n margin-left: 75%; }\n .large-11 {\n width: 91.66667%; }\n .large-push-11 {\n position: relative;\n left: 91.66667%; }\n .large-pull-11 {\n position: relative;\n left: -91.66667%; }\n .large-offset-10 {\n margin-left: 83.33333%; }\n .large-12 {\n width: 100%; }\n .large-offset-11 {\n margin-left: 91.66667%; }\n .large-up-1 > .column, .large-up-1 > .columns {\n float: left;\n width: 100%; }\n .large-up-1 > .column:nth-of-type(1n), .large-up-1 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-1 > .column:nth-of-type(1n+1), .large-up-1 > .columns:nth-of-type(1n+1) {\n clear: both; }\n .large-up-1 > .column:last-child, .large-up-1 > .columns:last-child {\n float: left; }\n .large-up-2 > .column, .large-up-2 > .columns {\n float: left;\n width: 50%; }\n .large-up-2 > .column:nth-of-type(1n), .large-up-2 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-2 > .column:nth-of-type(2n+1), .large-up-2 > .columns:nth-of-type(2n+1) {\n clear: both; }\n .large-up-2 > .column:last-child, .large-up-2 > .columns:last-child {\n float: left; }\n .large-up-3 > .column, .large-up-3 > .columns {\n float: left;\n width: 33.33333%; }\n .large-up-3 > .column:nth-of-type(1n), .large-up-3 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-3 > .column:nth-of-type(3n+1), .large-up-3 > .columns:nth-of-type(3n+1) {\n clear: both; }\n .large-up-3 > .column:last-child, .large-up-3 > .columns:last-child {\n float: left; }\n .large-up-4 > .column, .large-up-4 > .columns {\n float: left;\n width: 25%; }\n .large-up-4 > .column:nth-of-type(1n), .large-up-4 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-4 > .column:nth-of-type(4n+1), .large-up-4 > .columns:nth-of-type(4n+1) {\n clear: both; }\n .large-up-4 > .column:last-child, .large-up-4 > .columns:last-child {\n float: left; }\n .large-up-5 > .column, .large-up-5 > .columns {\n float: left;\n width: 20%; }\n .large-up-5 > .column:nth-of-type(1n), .large-up-5 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-5 > .column:nth-of-type(5n+1), .large-up-5 > .columns:nth-of-type(5n+1) {\n clear: both; }\n .large-up-5 > .column:last-child, .large-up-5 > .columns:last-child {\n float: left; }\n .large-up-6 > .column, .large-up-6 > .columns {\n float: left;\n width: 16.66667%; }\n .large-up-6 > .column:nth-of-type(1n), .large-up-6 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-6 > .column:nth-of-type(6n+1), .large-up-6 > .columns:nth-of-type(6n+1) {\n clear: both; }\n .large-up-6 > .column:last-child, .large-up-6 > .columns:last-child {\n float: left; }\n .large-up-7 > .column, .large-up-7 > .columns {\n float: left;\n width: 14.28571%; }\n .large-up-7 > .column:nth-of-type(1n), .large-up-7 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-7 > .column:nth-of-type(7n+1), .large-up-7 > .columns:nth-of-type(7n+1) {\n clear: both; }\n .large-up-7 > .column:last-child, .large-up-7 > .columns:last-child {\n float: left; }\n .large-up-8 > .column, .large-up-8 > .columns {\n float: left;\n width: 12.5%; }\n .large-up-8 > .column:nth-of-type(1n), .large-up-8 > .columns:nth-of-type(1n) {\n clear: none; }\n .large-up-8 > .column:nth-of-type(8n+1), .large-up-8 > .columns:nth-of-type(8n+1) {\n clear: both; }\n .large-up-8 > .column:last-child, .large-up-8 > .columns:last-child {\n float: left; }\n .large-collapse > .column, .large-collapse > .columns {\n padding-right: 0;\n padding-left: 0; }\n .large-collapse .row {\n margin-right: 0;\n margin-left: 0; }\n .expanded.row .large-collapse.row {\n margin-right: 0;\n margin-left: 0; }\n .large-uncollapse > .column, .large-uncollapse > .columns {\n padding-right: 0.9375rem;\n padding-left: 0.9375rem; }\n .large-centered {\n margin-right: auto;\n margin-left: auto; }\n .large-centered, .large-centered:last-child:not(:first-child) {\n float: none;\n clear: both; }\n .large-uncentered, .large-push-0, .large-pull-0 {\n position: static;\n margin-right: 0;\n margin-left: 0; }\n .large-uncentered, .large-uncentered:last-child:not(:first-child), .large-push-0, .large-push-0:last-child:not(:first-child), .large-pull-0, .large-pull-0:last-child:not(:first-child) {\n float: left;\n clear: none; }\n .large-uncentered:last-child:not(:first-child), .large-push-0:last-child:not(:first-child), .large-pull-0:last-child:not(:first-child) {\n float: right; } }\n\n.column-block {\n margin-bottom: 1.25rem; }\n .column-block > :last-child {\n margin-bottom: 0; }\n @media print, screen and (min-width: 40em) {\n .column-block {\n margin-bottom: 1.875rem; }\n .column-block > :last-child {\n margin-bottom: 0; } }\n\n.button {\n display: inline-block;\n vertical-align: middle;\n margin: 0 0 1rem 0;\n padding: 0.85em 1em;\n border: 1px solid transparent;\n border-radius: 0;\n transition: background-color 0.25s ease-out, color 0.25s ease-out;\n font-family: inherit;\n font-size: 0.9rem;\n -webkit-appearance: none;\n line-height: 1;\n text-align: center;\n cursor: pointer; }\n [data-whatinput='mouse'] .button {\n outline: 0; }\n .button.tiny {\n font-size: 0.6rem; }\n .button.small {\n font-size: 0.75rem; }\n .button.large {\n font-size: 1.25rem; }\n .button.expanded {\n display: block;\n width: 100%;\n margin-right: 0;\n margin-left: 0; }\n .button, .button.disabled, .button[disabled], .button.disabled:hover, .button[disabled]:hover, .button.disabled:focus, .button[disabled]:focus {\n background-color: #1779ba;\n color: #fefefe; }\n .button:hover, .button:focus {\n background-color: #14679e;\n color: #fefefe; }\n .button.primary, .button.primary.disabled, .button.primary[disabled], .button.primary.disabled:hover, .button.primary[disabled]:hover, .button.primary.disabled:focus, .button.primary[disabled]:focus {\n background-color: #1779ba;\n color: #fefefe; }\n .button.primary:hover, .button.primary:focus {\n background-color: #126195;\n color: #fefefe; }\n .button.secondary, .button.secondary.disabled, .button.secondary[disabled], .button.secondary.disabled:hover, .button.secondary[disabled]:hover, .button.secondary.disabled:focus, .button.secondary[disabled]:focus {\n background-color: #767676;\n color: #fefefe; }\n .button.secondary:hover, .button.secondary:focus {\n background-color: #5e5e5e;\n color: #fefefe; }\n .button.success, .button.success.disabled, .button.success[disabled], .button.success.disabled:hover, .button.success[disabled]:hover, .button.success.disabled:focus, .button.success[disabled]:focus {\n background-color: #3adb76;\n color: #0a0a0a; }\n .button.success:hover, .button.success:focus {\n background-color: #22bb5b;\n color: #0a0a0a; }\n .button.warning, .button.warning.disabled, .button.warning[disabled], .button.warning.disabled:hover, .button.warning[disabled]:hover, .button.warning.disabled:focus, .button.warning[disabled]:focus {\n background-color: #ffae00;\n color: #0a0a0a; }\n .button.warning:hover, .button.warning:focus {\n background-color: #cc8b00;\n color: #0a0a0a; }\n .button.alert, .button.alert.disabled, .button.alert[disabled], .button.alert.disabled:hover, .button.alert[disabled]:hover, .button.alert.disabled:focus, .button.alert[disabled]:focus {\n background-color: #cc4b37;\n color: #fefefe; }\n .button.alert:hover, .button.alert:focus {\n background-color: #a53b2a;\n color: #fefefe; }\n .button.hollow, .button.hollow:hover, .button.hollow:focus, .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {\n background-color: transparent; }\n .button.hollow, .button.hollow.disabled, .button.hollow[disabled], .button.hollow.disabled:hover, .button.hollow[disabled]:hover, .button.hollow.disabled:focus, .button.hollow[disabled]:focus {\n border: 1px solid #1779ba;\n color: #1779ba; }\n .button.hollow:hover, .button.hollow:focus {\n border-color: #0c3d5d;\n color: #0c3d5d; }\n .button.hollow.primary, .button.hollow.primary.disabled, .button.hollow.primary[disabled], .button.hollow.primary.disabled:hover, .button.hollow.primary[disabled]:hover, .button.hollow.primary.disabled:focus, .button.hollow.primary[disabled]:focus {\n border: 1px solid #1779ba;\n color: #1779ba; }\n .button.hollow.primary:hover, .button.hollow.primary:focus {\n border-color: #0c3d5d;\n color: #0c3d5d; }\n .button.hollow.secondary, .button.hollow.secondary.disabled, .button.hollow.secondary[disabled], .button.hollow.secondary.disabled:hover, .button.hollow.secondary[disabled]:hover, .button.hollow.secondary.disabled:focus, .button.hollow.secondary[disabled]:focus {\n border: 1px solid #767676;\n color: #767676; }\n .button.hollow.secondary:hover, .button.hollow.secondary:focus {\n border-color: #3b3b3b;\n color: #3b3b3b; }\n .button.hollow.success, .button.hollow.success.disabled, .button.hollow.success[disabled], .button.hollow.success.disabled:hover, .button.hollow.success[disabled]:hover, .button.hollow.success.disabled:focus, .button.hollow.success[disabled]:focus {\n border: 1px solid #3adb76;\n color: #3adb76; }\n .button.hollow.success:hover, .button.hollow.success:focus {\n border-color: #157539;\n color: #157539; }\n .button.hollow.warning, .button.hollow.warning.disabled, .button.hollow.warning[disabled], .button.hollow.warning.disabled:hover, .button.hollow.warning[disabled]:hover, .button.hollow.warning.disabled:focus, .button.hollow.warning[disabled]:focus {\n border: 1px solid #ffae00;\n color: #ffae00; }\n .button.hollow.warning:hover, .button.hollow.warning:focus {\n border-color: #805700;\n color: #805700; }\n .button.hollow.alert, .button.hollow.alert.disabled, .button.hollow.alert[disabled], .button.hollow.alert.disabled:hover, .button.hollow.alert[disabled]:hover, .button.hollow.alert.disabled:focus, .button.hollow.alert[disabled]:focus {\n border: 1px solid #cc4b37;\n color: #cc4b37; }\n .button.hollow.alert:hover, .button.hollow.alert:focus {\n border-color: #67251a;\n color: #67251a; }\n .button.clear, .button.clear:hover, .button.clear:focus, .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {\n border-color: transparent;\n background-color: transparent; }\n .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear.disabled:hover, .button.clear[disabled]:hover, .button.clear.disabled:focus, .button.clear[disabled]:focus {\n color: #1779ba; }\n .button.clear:hover, .button.clear:focus {\n color: #0c3d5d; }\n .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary.disabled:hover, .button.clear.primary[disabled]:hover, .button.clear.primary.disabled:focus, .button.clear.primary[disabled]:focus {\n color: #1779ba; }\n .button.clear.primary:hover, .button.clear.primary:focus {\n color: #0c3d5d; }\n .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary.disabled:hover, .button.clear.secondary[disabled]:hover, .button.clear.secondary.disabled:focus, .button.clear.secondary[disabled]:focus {\n color: #767676; }\n .button.clear.secondary:hover, .button.clear.secondary:focus {\n color: #3b3b3b; }\n .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success.disabled:hover, .button.clear.success[disabled]:hover, .button.clear.success.disabled:focus, .button.clear.success[disabled]:focus {\n color: #3adb76; }\n .button.clear.success:hover, .button.clear.success:focus {\n color: #157539; }\n .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning.disabled:hover, .button.clear.warning[disabled]:hover, .button.clear.warning.disabled:focus, .button.clear.warning[disabled]:focus {\n color: #ffae00; }\n .button.clear.warning:hover, .button.clear.warning:focus {\n color: #805700; }\n .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert.disabled:hover, .button.clear.alert[disabled]:hover, .button.clear.alert.disabled:focus, .button.clear.alert[disabled]:focus {\n color: #cc4b37; }\n .button.clear.alert:hover, .button.clear.alert:focus {\n color: #67251a; }\n .button.disabled, .button[disabled] {\n opacity: 0.25;\n cursor: not-allowed; }\n .button.dropdown::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 0.4em;\n content: '';\n border-bottom-width: 0;\n border-color: #fefefe transparent transparent;\n position: relative;\n top: 0.4em;\n display: inline-block;\n float: right;\n margin-left: 1em; }\n .button.dropdown.hollow::after, .button.dropdown.clear::after {\n border-top-color: #1779ba; }\n .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {\n border-top-color: #1779ba; }\n .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {\n border-top-color: #767676; }\n .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {\n border-top-color: #3adb76; }\n .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {\n border-top-color: #ffae00; }\n .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {\n border-top-color: #cc4b37; }\n .button.arrow-only::after {\n top: -0.1em;\n float: none;\n margin-left: 0; }\n\na.button:hover, a.button:focus {\n text-decoration: none; }\n\n.button-group {\n margin-bottom: 1rem;\n font-size: 0; }\n .button-group::before, .button-group::after {\n display: table;\n content: ' '; }\n .button-group::after {\n clear: both; }\n .button-group .button {\n margin: 0;\n margin-right: 1px;\n margin-bottom: 1px;\n font-size: 0.9rem; }\n .button-group .button:last-child {\n margin-right: 0; }\n .button-group.tiny .button {\n font-size: 0.6rem; }\n .button-group.small .button {\n font-size: 0.75rem; }\n .button-group.large .button {\n font-size: 1.25rem; }\n .button-group.expanded {\n margin-right: -1px; }\n .button-group.expanded::before, .button-group.expanded::after {\n display: none; }\n .button-group.expanded .button:first-child:last-child {\n width: calc(100% - 1px); }\n .button-group.expanded .button:first-child:nth-last-child(2), .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button {\n display: inline-block;\n width: calc(50% - 1px);\n margin-right: 1px; }\n .button-group.expanded .button:first-child:nth-last-child(2):last-child, .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.expanded .button:first-child:nth-last-child(3), .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button {\n display: inline-block;\n width: calc(33.33333% - 1px);\n margin-right: 1px; }\n .button-group.expanded .button:first-child:nth-last-child(3):last-child, .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.expanded .button:first-child:nth-last-child(4), .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button {\n display: inline-block;\n width: calc(25% - 1px);\n margin-right: 1px; }\n .button-group.expanded .button:first-child:nth-last-child(4):last-child, .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.expanded .button:first-child:nth-last-child(5), .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button {\n display: inline-block;\n width: calc(20% - 1px);\n margin-right: 1px; }\n .button-group.expanded .button:first-child:nth-last-child(5):last-child, .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.expanded .button:first-child:nth-last-child(6), .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button {\n display: inline-block;\n width: calc(16.66667% - 1px);\n margin-right: 1px; }\n .button-group.expanded .button:first-child:nth-last-child(6):last-child, .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.primary .button, .button-group.primary .button.disabled, .button-group.primary .button[disabled], .button-group.primary .button.disabled:hover, .button-group.primary .button[disabled]:hover, .button-group.primary .button.disabled:focus, .button-group.primary .button[disabled]:focus {\n background-color: #1779ba;\n color: #fefefe; }\n .button-group.primary .button:hover, .button-group.primary .button:focus {\n background-color: #126195;\n color: #fefefe; }\n .button-group.secondary .button, .button-group.secondary .button.disabled, .button-group.secondary .button[disabled], .button-group.secondary .button.disabled:hover, .button-group.secondary .button[disabled]:hover, .button-group.secondary .button.disabled:focus, .button-group.secondary .button[disabled]:focus {\n background-color: #767676;\n color: #fefefe; }\n .button-group.secondary .button:hover, .button-group.secondary .button:focus {\n background-color: #5e5e5e;\n color: #fefefe; }\n .button-group.success .button, .button-group.success .button.disabled, .button-group.success .button[disabled], .button-group.success .button.disabled:hover, .button-group.success .button[disabled]:hover, .button-group.success .button.disabled:focus, .button-group.success .button[disabled]:focus {\n background-color: #3adb76;\n color: #0a0a0a; }\n .button-group.success .button:hover, .button-group.success .button:focus {\n background-color: #22bb5b;\n color: #0a0a0a; }\n .button-group.warning .button, .button-group.warning .button.disabled, .button-group.warning .button[disabled], .button-group.warning .button.disabled:hover, .button-group.warning .button[disabled]:hover, .button-group.warning .button.disabled:focus, .button-group.warning .button[disabled]:focus {\n background-color: #ffae00;\n color: #0a0a0a; }\n .button-group.warning .button:hover, .button-group.warning .button:focus {\n background-color: #cc8b00;\n color: #0a0a0a; }\n .button-group.alert .button, .button-group.alert .button.disabled, .button-group.alert .button[disabled], .button-group.alert .button.disabled:hover, .button-group.alert .button[disabled]:hover, .button-group.alert .button.disabled:focus, .button-group.alert .button[disabled]:focus {\n background-color: #cc4b37;\n color: #fefefe; }\n .button-group.alert .button:hover, .button-group.alert .button:focus {\n background-color: #a53b2a;\n color: #fefefe; }\n .button-group.hollow .button, .button-group.hollow .button:hover, .button-group.hollow .button:focus, .button-group.hollow .button.disabled, .button-group.hollow .button.disabled:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled], .button-group.hollow .button[disabled]:hover, .button-group.hollow .button[disabled]:focus {\n background-color: transparent; }\n .button-group.hollow .button, .button-group.hollow .button.disabled, .button-group.hollow .button[disabled], .button-group.hollow .button.disabled:hover, .button-group.hollow .button[disabled]:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled]:focus {\n border: 1px solid #1779ba;\n color: #1779ba; }\n .button-group.hollow .button:hover, .button-group.hollow .button:focus {\n border-color: #0c3d5d;\n color: #0c3d5d; }\n .button-group.hollow.primary .button, .button-group.hollow.primary .button.disabled, .button-group.hollow.primary .button[disabled], .button-group.hollow.primary .button.disabled:hover, .button-group.hollow.primary .button[disabled]:hover, .button-group.hollow.primary .button.disabled:focus, .button-group.hollow.primary .button[disabled]:focus, .button-group.hollow .button.primary, .button-group.hollow .button.primary.disabled, .button-group.hollow .button.primary[disabled], .button-group.hollow .button.primary.disabled:hover, .button-group.hollow .button.primary[disabled]:hover, .button-group.hollow .button.primary.disabled:focus, .button-group.hollow .button.primary[disabled]:focus {\n border: 1px solid #1779ba;\n color: #1779ba; }\n .button-group.hollow.primary .button:hover, .button-group.hollow.primary .button:focus, .button-group.hollow .button.primary:hover, .button-group.hollow .button.primary:focus {\n border-color: #0c3d5d;\n color: #0c3d5d; }\n .button-group.hollow.secondary .button, .button-group.hollow.secondary .button.disabled, .button-group.hollow.secondary .button[disabled], .button-group.hollow.secondary .button.disabled:hover, .button-group.hollow.secondary .button[disabled]:hover, .button-group.hollow.secondary .button.disabled:focus, .button-group.hollow.secondary .button[disabled]:focus, .button-group.hollow .button.secondary, .button-group.hollow .button.secondary.disabled, .button-group.hollow .button.secondary[disabled], .button-group.hollow .button.secondary.disabled:hover, .button-group.hollow .button.secondary[disabled]:hover, .button-group.hollow .button.secondary.disabled:focus, .button-group.hollow .button.secondary[disabled]:focus {\n border: 1px solid #767676;\n color: #767676; }\n .button-group.hollow.secondary .button:hover, .button-group.hollow.secondary .button:focus, .button-group.hollow .button.secondary:hover, .button-group.hollow .button.secondary:focus {\n border-color: #3b3b3b;\n color: #3b3b3b; }\n .button-group.hollow.success .button, .button-group.hollow.success .button.disabled, .button-group.hollow.success .button[disabled], .button-group.hollow.success .button.disabled:hover, .button-group.hollow.success .button[disabled]:hover, .button-group.hollow.success .button.disabled:focus, .button-group.hollow.success .button[disabled]:focus, .button-group.hollow .button.success, .button-group.hollow .button.success.disabled, .button-group.hollow .button.success[disabled], .button-group.hollow .button.success.disabled:hover, .button-group.hollow .button.success[disabled]:hover, .button-group.hollow .button.success.disabled:focus, .button-group.hollow .button.success[disabled]:focus {\n border: 1px solid #3adb76;\n color: #3adb76; }\n .button-group.hollow.success .button:hover, .button-group.hollow.success .button:focus, .button-group.hollow .button.success:hover, .button-group.hollow .button.success:focus {\n border-color: #157539;\n color: #157539; }\n .button-group.hollow.warning .button, .button-group.hollow.warning .button.disabled, .button-group.hollow.warning .button[disabled], .button-group.hollow.warning .button.disabled:hover, .button-group.hollow.warning .button[disabled]:hover, .button-group.hollow.warning .button.disabled:focus, .button-group.hollow.warning .button[disabled]:focus, .button-group.hollow .button.warning, .button-group.hollow .button.warning.disabled, .button-group.hollow .button.warning[disabled], .button-group.hollow .button.warning.disabled:hover, .button-group.hollow .button.warning[disabled]:hover, .button-group.hollow .button.warning.disabled:focus, .button-group.hollow .button.warning[disabled]:focus {\n border: 1px solid #ffae00;\n color: #ffae00; }\n .button-group.hollow.warning .button:hover, .button-group.hollow.warning .button:focus, .button-group.hollow .button.warning:hover, .button-group.hollow .button.warning:focus {\n border-color: #805700;\n color: #805700; }\n .button-group.hollow.alert .button, .button-group.hollow.alert .button.disabled, .button-group.hollow.alert .button[disabled], .button-group.hollow.alert .button.disabled:hover, .button-group.hollow.alert .button[disabled]:hover, .button-group.hollow.alert .button.disabled:focus, .button-group.hollow.alert .button[disabled]:focus, .button-group.hollow .button.alert, .button-group.hollow .button.alert.disabled, .button-group.hollow .button.alert[disabled], .button-group.hollow .button.alert.disabled:hover, .button-group.hollow .button.alert[disabled]:hover, .button-group.hollow .button.alert.disabled:focus, .button-group.hollow .button.alert[disabled]:focus {\n border: 1px solid #cc4b37;\n color: #cc4b37; }\n .button-group.hollow.alert .button:hover, .button-group.hollow.alert .button:focus, .button-group.hollow .button.alert:hover, .button-group.hollow .button.alert:focus {\n border-color: #67251a;\n color: #67251a; }\n .button-group.clear .button, .button-group.clear .button:hover, .button-group.clear .button:focus, .button-group.clear .button.disabled, .button-group.clear .button.disabled:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled], .button-group.clear .button[disabled]:hover, .button-group.clear .button[disabled]:focus {\n border-color: transparent;\n background-color: transparent; }\n .button-group.clear .button, .button-group.clear .button.disabled, .button-group.clear .button[disabled], .button-group.clear .button.disabled:hover, .button-group.clear .button[disabled]:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled]:focus {\n color: #1779ba; }\n .button-group.clear .button:hover, .button-group.clear .button:focus {\n color: #0c3d5d; }\n .button-group.clear.primary .button, .button-group.clear.primary .button.disabled, .button-group.clear.primary .button[disabled], .button-group.clear.primary .button.disabled:hover, .button-group.clear.primary .button[disabled]:hover, .button-group.clear.primary .button.disabled:focus, .button-group.clear.primary .button[disabled]:focus, .button-group.clear .button.primary, .button-group.clear .button.primary.disabled, .button-group.clear .button.primary[disabled], .button-group.clear .button.primary.disabled:hover, .button-group.clear .button.primary[disabled]:hover, .button-group.clear .button.primary.disabled:focus, .button-group.clear .button.primary[disabled]:focus {\n color: #1779ba; }\n .button-group.clear.primary .button:hover, .button-group.clear.primary .button:focus, .button-group.clear .button.primary:hover, .button-group.clear .button.primary:focus {\n color: #0c3d5d; }\n .button-group.clear.secondary .button, .button-group.clear.secondary .button.disabled, .button-group.clear.secondary .button[disabled], .button-group.clear.secondary .button.disabled:hover, .button-group.clear.secondary .button[disabled]:hover, .button-group.clear.secondary .button.disabled:focus, .button-group.clear.secondary .button[disabled]:focus, .button-group.clear .button.secondary, .button-group.clear .button.secondary.disabled, .button-group.clear .button.secondary[disabled], .button-group.clear .button.secondary.disabled:hover, .button-group.clear .button.secondary[disabled]:hover, .button-group.clear .button.secondary.disabled:focus, .button-group.clear .button.secondary[disabled]:focus {\n color: #767676; }\n .button-group.clear.secondary .button:hover, .button-group.clear.secondary .button:focus, .button-group.clear .button.secondary:hover, .button-group.clear .button.secondary:focus {\n color: #3b3b3b; }\n .button-group.clear.success .button, .button-group.clear.success .button.disabled, .button-group.clear.success .button[disabled], .button-group.clear.success .button.disabled:hover, .button-group.clear.success .button[disabled]:hover, .button-group.clear.success .button.disabled:focus, .button-group.clear.success .button[disabled]:focus, .button-group.clear .button.success, .button-group.clear .button.success.disabled, .button-group.clear .button.success[disabled], .button-group.clear .button.success.disabled:hover, .button-group.clear .button.success[disabled]:hover, .button-group.clear .button.success.disabled:focus, .button-group.clear .button.success[disabled]:focus {\n color: #3adb76; }\n .button-group.clear.success .button:hover, .button-group.clear.success .button:focus, .button-group.clear .button.success:hover, .button-group.clear .button.success:focus {\n color: #157539; }\n .button-group.clear.warning .button, .button-group.clear.warning .button.disabled, .button-group.clear.warning .button[disabled], .button-group.clear.warning .button.disabled:hover, .button-group.clear.warning .button[disabled]:hover, .button-group.clear.warning .button.disabled:focus, .button-group.clear.warning .button[disabled]:focus, .button-group.clear .button.warning, .button-group.clear .button.warning.disabled, .button-group.clear .button.warning[disabled], .button-group.clear .button.warning.disabled:hover, .button-group.clear .button.warning[disabled]:hover, .button-group.clear .button.warning.disabled:focus, .button-group.clear .button.warning[disabled]:focus {\n color: #ffae00; }\n .button-group.clear.warning .button:hover, .button-group.clear.warning .button:focus, .button-group.clear .button.warning:hover, .button-group.clear .button.warning:focus {\n color: #805700; }\n .button-group.clear.alert .button, .button-group.clear.alert .button.disabled, .button-group.clear.alert .button[disabled], .button-group.clear.alert .button.disabled:hover, .button-group.clear.alert .button[disabled]:hover, .button-group.clear.alert .button.disabled:focus, .button-group.clear.alert .button[disabled]:focus, .button-group.clear .button.alert, .button-group.clear .button.alert.disabled, .button-group.clear .button.alert[disabled], .button-group.clear .button.alert.disabled:hover, .button-group.clear .button.alert[disabled]:hover, .button-group.clear .button.alert.disabled:focus, .button-group.clear .button.alert[disabled]:focus {\n color: #cc4b37; }\n .button-group.clear.alert .button:hover, .button-group.clear.alert .button:focus, .button-group.clear .button.alert:hover, .button-group.clear .button.alert:focus {\n color: #67251a; }\n .button-group.no-gaps .button {\n margin-right: -0.0625rem; }\n .button-group.no-gaps .button + .button {\n border-left-color: transparent; }\n .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n width: 100%; }\n .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {\n margin-bottom: 0; }\n .button-group.stacked.expanded, .button-group.stacked-for-small.expanded, .button-group.stacked-for-medium.expanded {\n margin-right: -1px; }\n .button-group.stacked.expanded::before, .button-group.stacked.expanded::after, .button-group.stacked-for-small.expanded::before, .button-group.stacked-for-small.expanded::after, .button-group.stacked-for-medium.expanded::before, .button-group.stacked-for-medium.expanded::after {\n display: none; }\n .button-group.stacked.expanded .button:first-child:last-child, .button-group.stacked-for-small.expanded .button:first-child:last-child, .button-group.stacked-for-medium.expanded .button:first-child:last-child {\n width: calc(100% - 1px); }\n .button-group.stacked.expanded .button:first-child:nth-last-child(2), .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button {\n display: inline-block;\n width: calc(50% - 1px);\n margin-right: 1px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(3), .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button {\n display: inline-block;\n width: calc(33.33333% - 1px);\n margin-right: 1px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(4), .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button {\n display: inline-block;\n width: calc(25% - 1px);\n margin-right: 1px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(5), .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button {\n display: inline-block;\n width: calc(20% - 1px);\n margin-right: 1px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child {\n margin-right: -6px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(6), .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button {\n display: inline-block;\n width: calc(16.66667% - 1px);\n margin-right: 1px; }\n .button-group.stacked.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child {\n margin-right: -6px; }\n @media print, screen and (min-width: 40em) {\n .button-group.stacked-for-small .button {\n width: auto;\n margin-bottom: 0; } }\n @media print, screen and (min-width: 64em) {\n .button-group.stacked-for-medium .button {\n width: auto;\n margin-bottom: 0; } }\n @media print, screen and (max-width: 39.99875em) {\n .button-group.stacked-for-small.expanded {\n display: block; }\n .button-group.stacked-for-small.expanded .button {\n display: block;\n margin-right: 0; } }\n @media print, screen and (max-width: 63.99875em) {\n .button-group.stacked-for-medium.expanded {\n display: block; }\n .button-group.stacked-for-medium.expanded .button {\n display: block;\n margin-right: 0; } }\n\n.close-button {\n position: absolute;\n z-index: 10;\n color: #8a8a8a;\n cursor: pointer; }\n [data-whatinput='mouse'] .close-button {\n outline: 0; }\n .close-button:hover, .close-button:focus {\n color: #0a0a0a; }\n .close-button.small {\n right: 0.66rem;\n top: 0.33em;\n font-size: 1.5em;\n line-height: 1; }\n .close-button, .close-button.medium {\n right: 1rem;\n top: 0.5rem;\n font-size: 2em;\n line-height: 1; }\n\n.label {\n display: inline-block;\n padding: 0.33333rem 0.5rem;\n border-radius: 0;\n font-size: 0.8rem;\n line-height: 1;\n white-space: nowrap;\n cursor: default;\n background: #1779ba;\n color: #fefefe; }\n .label.primary {\n background: #1779ba;\n color: #fefefe; }\n .label.secondary {\n background: #767676;\n color: #fefefe; }\n .label.success {\n background: #3adb76;\n color: #0a0a0a; }\n .label.warning {\n background: #ffae00;\n color: #0a0a0a; }\n .label.alert {\n background: #cc4b37;\n color: #fefefe; }\n\n.progress {\n height: 1rem;\n margin-bottom: 1rem;\n border-radius: 0;\n background-color: #cacaca; }\n .progress.primary .progress-meter {\n background-color: #1779ba; }\n .progress.secondary .progress-meter {\n background-color: #767676; }\n .progress.success .progress-meter {\n background-color: #3adb76; }\n .progress.warning .progress-meter {\n background-color: #ffae00; }\n .progress.alert .progress-meter {\n background-color: #cc4b37; }\n\n.progress-meter {\n position: relative;\n display: block;\n width: 0%;\n height: 100%;\n background-color: #1779ba; }\n\n.progress-meter-text {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n margin: 0;\n font-size: 0.75rem;\n font-weight: bold;\n color: #fefefe;\n white-space: nowrap; }\n\n.slider {\n position: relative;\n height: 0.5rem;\n margin-top: 1.25rem;\n margin-bottom: 2.25rem;\n background-color: #e6e6e6;\n cursor: pointer;\n user-select: none;\n touch-action: none; }\n\n.slider-fill {\n position: absolute;\n top: 0;\n left: 0;\n display: inline-block;\n max-width: 100%;\n height: 0.5rem;\n background-color: #cacaca;\n transition: all 0.2s ease-in-out; }\n .slider-fill.is-dragging {\n transition: all 0s linear; }\n\n.slider-handle {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n left: 0;\n z-index: 1;\n cursor: grab;\n display: inline-block;\n width: 1.4rem;\n height: 1.4rem;\n border-radius: 0;\n background-color: #1779ba;\n transition: all 0.2s ease-in-out;\n touch-action: manipulation; }\n [data-whatinput='mouse'] .slider-handle {\n outline: 0; }\n .slider-handle:hover {\n background-color: #14679e; }\n .slider-handle.is-dragging {\n transition: all 0s linear;\n cursor: grabbing; }\n\n.slider.disabled,\n.slider[disabled] {\n opacity: 0.25;\n cursor: not-allowed; }\n\n.slider.vertical {\n display: inline-block;\n width: 0.5rem;\n height: 12.5rem;\n margin: 0 1.25rem;\n transform: scale(1, -1); }\n .slider.vertical .slider-fill {\n top: 0;\n width: 0.5rem;\n max-height: 100%; }\n .slider.vertical .slider-handle {\n position: absolute;\n top: 0;\n left: 50%;\n width: 1.4rem;\n height: 1.4rem;\n transform: translateX(-50%); }\n\n.switch {\n position: relative;\n margin-bottom: 1rem;\n outline: 0;\n font-size: 0.875rem;\n font-weight: bold;\n color: #fefefe;\n user-select: none;\n height: 2rem; }\n\n.switch-input {\n position: absolute;\n margin-bottom: 0;\n opacity: 0; }\n\n.switch-paddle {\n position: relative;\n display: block;\n width: 4rem;\n height: 2rem;\n border-radius: 0;\n background: #cacaca;\n transition: all 0.25s ease-out;\n font-weight: inherit;\n color: inherit;\n cursor: pointer; }\n input + .switch-paddle {\n margin: 0; }\n .switch-paddle::after {\n position: absolute;\n top: 0.25rem;\n left: 0.25rem;\n display: block;\n width: 1.5rem;\n height: 1.5rem;\n transform: translate3d(0, 0, 0);\n border-radius: 0;\n background: #fefefe;\n transition: all 0.25s ease-out;\n content: ''; }\n input:checked ~ .switch-paddle {\n background: #1779ba; }\n input:checked ~ .switch-paddle::after {\n left: 2.25rem; }\n input:disabled ~ .switch-paddle {\n cursor: not-allowed;\n opacity: 0.5; }\n [data-whatinput='mouse'] input:focus ~ .switch-paddle {\n outline: 0; }\n\n.switch-active, .switch-inactive {\n position: absolute;\n top: 50%;\n transform: translateY(-50%); }\n\n.switch-active {\n left: 8%;\n display: none; }\n input:checked + label > .switch-active {\n display: block; }\n\n.switch-inactive {\n right: 15%; }\n input:checked + label > .switch-inactive {\n display: none; }\n\n.switch.tiny {\n height: 1.5rem; }\n .switch.tiny .switch-paddle {\n width: 3rem;\n height: 1.5rem;\n font-size: 0.625rem; }\n .switch.tiny .switch-paddle::after {\n top: 0.25rem;\n left: 0.25rem;\n width: 1rem;\n height: 1rem; }\n .switch.tiny input:checked ~ .switch-paddle::after {\n left: 1.75rem; }\n\n.switch.small {\n height: 1.75rem; }\n .switch.small .switch-paddle {\n width: 3.5rem;\n height: 1.75rem;\n font-size: 0.75rem; }\n .switch.small .switch-paddle::after {\n top: 0.25rem;\n left: 0.25rem;\n width: 1.25rem;\n height: 1.25rem; }\n .switch.small input:checked ~ .switch-paddle::after {\n left: 2rem; }\n\n.switch.large {\n height: 2.5rem; }\n .switch.large .switch-paddle {\n width: 5rem;\n height: 2.5rem;\n font-size: 1rem; }\n .switch.large .switch-paddle::after {\n top: 0.25rem;\n left: 0.25rem;\n width: 2rem;\n height: 2rem; }\n .switch.large input:checked ~ .switch-paddle::after {\n left: 2.75rem; }\n\ntable {\n border-collapse: collapse;\n width: 100%;\n margin-bottom: 1rem;\n border-radius: 0; }\n thead,\n tbody,\n tfoot {\n border: 1px solid #f1f1f1;\n background-color: #fefefe; }\n caption {\n padding: 0.5rem 0.625rem 0.625rem;\n font-weight: bold; }\n thead {\n background: #f8f8f8;\n color: #0a0a0a; }\n tfoot {\n background: #f1f1f1;\n color: #0a0a0a; }\n thead tr,\n tfoot tr {\n background: transparent; }\n thead th,\n thead td,\n tfoot th,\n tfoot td {\n padding: 0.5rem 0.625rem 0.625rem;\n font-weight: bold;\n text-align: left; }\n tbody th,\n tbody td {\n padding: 0.5rem 0.625rem 0.625rem; }\n tbody tr:nth-child(even) {\n border-bottom: 0;\n background-color: #f1f1f1; }\n table.unstriped tbody {\n background-color: #fefefe; }\n table.unstriped tbody tr {\n border-bottom: 1px solid #f1f1f1;\n background-color: #fefefe; }\n\n@media print, screen and (max-width: 63.99875em) {\n table.stack thead {\n display: none; }\n table.stack tfoot {\n display: none; }\n table.stack tr,\n table.stack th,\n table.stack td {\n display: block; }\n table.stack td {\n border-top: 0; } }\n\ntable.scroll {\n display: block;\n width: 100%;\n overflow-x: auto; }\n\ntable.hover thead tr:hover {\n background-color: #f3f3f3; }\n\ntable.hover tfoot tr:hover {\n background-color: #ececec; }\n\ntable.hover tbody tr:hover {\n background-color: #f9f9f9; }\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n background-color: #ececec; }\n\n.table-scroll {\n overflow-x: auto; }\n\n.badge {\n display: inline-block;\n min-width: 2.1em;\n padding: 0.3em;\n border-radius: 50%;\n font-size: 0.6rem;\n text-align: center;\n background: #1779ba;\n color: #fefefe; }\n .badge.primary {\n background: #1779ba;\n color: #fefefe; }\n .badge.secondary {\n background: #767676;\n color: #fefefe; }\n .badge.success {\n background: #3adb76;\n color: #0a0a0a; }\n .badge.warning {\n background: #ffae00;\n color: #0a0a0a; }\n .badge.alert {\n background: #cc4b37;\n color: #fefefe; }\n\n.breadcrumbs {\n margin: 0 0 1rem 0;\n list-style: none; }\n .breadcrumbs::before, .breadcrumbs::after {\n display: table;\n content: ' '; }\n .breadcrumbs::after {\n clear: both; }\n .breadcrumbs li {\n float: left;\n font-size: 0.6875rem;\n color: #0a0a0a;\n cursor: default;\n text-transform: uppercase; }\n .breadcrumbs li:not(:last-child)::after {\n position: relative;\n margin: 0 0.75rem;\n opacity: 1;\n content: \"/\";\n color: #cacaca; }\n .breadcrumbs a {\n color: #1779ba; }\n .breadcrumbs a:hover {\n text-decoration: underline; }\n .breadcrumbs .disabled {\n color: #cacaca;\n cursor: not-allowed; }\n\n.callout {\n position: relative;\n margin: 0 0 1rem 0;\n padding: 1rem;\n border: 1px solid rgba(10, 10, 10, 0.25);\n border-radius: 0;\n background-color: white;\n color: #0a0a0a; }\n .callout > :first-child {\n margin-top: 0; }\n .callout > :last-child {\n margin-bottom: 0; }\n .callout.primary {\n background-color: #d7ecfa;\n color: #0a0a0a; }\n .callout.secondary {\n background-color: #eaeaea;\n color: #0a0a0a; }\n .callout.success {\n background-color: #e1faea;\n color: #0a0a0a; }\n .callout.warning {\n background-color: #fff3d9;\n color: #0a0a0a; }\n .callout.alert {\n background-color: #f7e4e1;\n color: #0a0a0a; }\n .callout.small {\n padding-top: 0.5rem;\n padding-right: 0.5rem;\n padding-bottom: 0.5rem;\n padding-left: 0.5rem; }\n .callout.large {\n padding-top: 3rem;\n padding-right: 3rem;\n padding-bottom: 3rem;\n padding-left: 3rem; }\n\n.card {\n margin-bottom: 1rem;\n border: 1px solid #e6e6e6;\n border-radius: 0;\n background: #fefefe;\n box-shadow: none;\n overflow: hidden;\n color: #0a0a0a; }\n .card > :last-child {\n margin-bottom: 0; }\n\n.card-divider {\n padding: 1rem;\n background: #e6e6e6; }\n .card-divider > :last-child {\n margin-bottom: 0; }\n\n.card-section {\n padding: 1rem; }\n .card-section > :last-child {\n margin-bottom: 0; }\n\n.card-image {\n min-height: 1px; }\n\n.dropdown-pane {\n position: absolute;\n z-index: 10;\n display: none;\n width: 300px;\n padding: 1rem;\n visibility: hidden;\n border: 1px solid #cacaca;\n border-radius: 0;\n background-color: #fefefe;\n font-size: 1rem; }\n .dropdown-pane.is-opening {\n display: block; }\n .dropdown-pane.is-open {\n display: block;\n visibility: visible; }\n\n.dropdown-pane.tiny {\n width: 100px; }\n\n.dropdown-pane.small {\n width: 200px; }\n\n.dropdown-pane.large {\n width: 400px; }\n\n.pagination {\n margin-left: 0;\n margin-bottom: 1rem; }\n .pagination::before, .pagination::after {\n display: table;\n content: ' '; }\n .pagination::after {\n clear: both; }\n .pagination li {\n margin-right: 0.0625rem;\n border-radius: 0;\n font-size: 0.875rem;\n display: none; }\n .pagination li:last-child, .pagination li:first-child {\n display: inline-block; }\n @media print, screen and (min-width: 40em) {\n .pagination li {\n display: inline-block; } }\n .pagination a,\n .pagination button {\n display: block;\n padding: 0.1875rem 0.625rem;\n border-radius: 0;\n color: #0a0a0a; }\n .pagination a:hover,\n .pagination button:hover {\n background: #e6e6e6; }\n .pagination .current {\n padding: 0.1875rem 0.625rem;\n background: #1779ba;\n color: #fefefe;\n cursor: default; }\n .pagination .disabled {\n padding: 0.1875rem 0.625rem;\n color: #cacaca;\n cursor: not-allowed; }\n .pagination .disabled:hover {\n background: transparent; }\n .pagination .ellipsis::after {\n padding: 0.1875rem 0.625rem;\n content: '\\2026';\n color: #0a0a0a; }\n\n.pagination-previous a::before,\n.pagination-previous.disabled::before {\n display: inline-block;\n margin-right: 0.5rem;\n content: \"«\"; }\n\n.pagination-next a::after,\n.pagination-next.disabled::after {\n display: inline-block;\n margin-left: 0.5rem;\n content: \"»\"; }\n\n.has-tip {\n position: relative;\n display: inline-block;\n border-bottom: dotted 1px #8a8a8a;\n font-weight: bold;\n cursor: help; }\n\n.tooltip {\n position: absolute;\n top: calc(100% + 0.6495rem);\n z-index: 1200;\n max-width: 10rem;\n padding: 0.75rem;\n border-radius: 0;\n background-color: #0a0a0a;\n font-size: 80%;\n color: #fefefe; }\n .tooltip::before {\n position: absolute; }\n .tooltip.bottom::before {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 0.75rem;\n content: '';\n border-top-width: 0;\n border-color: transparent transparent #0a0a0a;\n bottom: 100%; }\n .tooltip.bottom.align-center::before {\n left: 50%;\n transform: translateX(-50%); }\n .tooltip.top::before {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 0.75rem;\n content: '';\n border-bottom-width: 0;\n border-color: #0a0a0a transparent transparent;\n top: 100%;\n bottom: auto; }\n .tooltip.top.align-center::before {\n left: 50%;\n transform: translateX(-50%); }\n .tooltip.left::before {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 0.75rem;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #0a0a0a;\n left: 100%; }\n .tooltip.left.align-center::before {\n bottom: auto;\n top: 50%;\n transform: translateY(-50%); }\n .tooltip.right::before {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 0.75rem;\n content: '';\n border-left-width: 0;\n border-color: transparent #0a0a0a transparent transparent;\n right: 100%;\n left: auto; }\n .tooltip.right.align-center::before {\n bottom: auto;\n top: 50%;\n transform: translateY(-50%); }\n .tooltip.align-top::before {\n bottom: auto;\n top: 10%; }\n .tooltip.align-bottom::before {\n bottom: 10%;\n top: auto; }\n .tooltip.align-left::before {\n left: 10%;\n right: auto; }\n .tooltip.align-right::before {\n left: auto;\n right: 10%; }\n\n.accordion {\n margin-left: 0;\n background: #fefefe;\n list-style-type: none; }\n .accordion[disabled] .accordion-title {\n cursor: not-allowed; }\n\n.accordion-item:first-child > :first-child {\n border-radius: 0 0 0 0; }\n\n.accordion-item:last-child > :last-child {\n border-radius: 0 0 0 0; }\n\n.accordion-title {\n position: relative;\n display: block;\n padding: 1.25rem 1rem;\n border: 1px solid #e6e6e6;\n border-bottom: 0;\n font-size: 0.75rem;\n line-height: 1;\n color: #1779ba; }\n :last-child:not(.is-active) > .accordion-title {\n border-bottom: 1px solid #e6e6e6;\n border-radius: 0 0 0 0; }\n .accordion-title:hover, .accordion-title:focus {\n background-color: #e6e6e6; }\n .accordion-title::before {\n position: absolute;\n top: 50%;\n right: 1rem;\n margin-top: -0.5rem;\n content: \"+\"; }\n .is-active > .accordion-title::before {\n content: \"–\"; }\n\n.accordion-content {\n display: none;\n padding: 1rem;\n border: 1px solid #e6e6e6;\n border-bottom: 0;\n background-color: #fefefe;\n color: #0a0a0a; }\n :last-child > .accordion-content:last-child {\n border-bottom: 1px solid #e6e6e6; }\n\n.media-object {\n display: block;\n margin-bottom: 1rem; }\n .media-object img {\n max-width: none; }\n\n.media-object-section {\n display: table-cell;\n vertical-align: top; }\n .media-object-section:first-child {\n padding-right: 1rem; }\n .media-object-section:last-child:not(:nth-child(2)) {\n padding-left: 1rem; }\n .media-object-section > :last-child {\n margin-bottom: 0; }\n @media print, screen and (max-width: 39.99875em) {\n .stack-for-small .media-object-section {\n padding: 0;\n padding-bottom: 1rem;\n display: block; }\n .stack-for-small .media-object-section img {\n width: 100%; } }\n .media-object-section.middle {\n vertical-align: middle; }\n .media-object-section.bottom {\n vertical-align: bottom; }\n\n.orbit {\n position: relative; }\n\n.orbit-container {\n position: relative;\n height: 0;\n margin: 0;\n list-style: none;\n overflow: hidden; }\n\n.orbit-slide {\n width: 100%;\n position: absolute; }\n .orbit-slide.no-motionui.is-active {\n top: 0;\n left: 0; }\n\n.orbit-figure {\n margin: 0; }\n\n.orbit-image {\n width: 100%;\n max-width: 100%;\n margin: 0; }\n\n.orbit-caption {\n position: absolute;\n bottom: 0;\n width: 100%;\n margin-bottom: 0;\n padding: 1rem;\n background-color: rgba(10, 10, 10, 0.5);\n color: #fefefe; }\n\n.orbit-previous, .orbit-next {\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n z-index: 10;\n padding: 1rem;\n color: #fefefe; }\n [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n outline: 0; }\n .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {\n background-color: rgba(10, 10, 10, 0.5); }\n\n.orbit-previous {\n left: 0; }\n\n.orbit-next {\n left: auto;\n right: 0; }\n\n.orbit-bullets {\n position: relative;\n margin-top: 0.8rem;\n margin-bottom: 0.8rem;\n text-align: center; }\n [data-whatinput='mouse'] .orbit-bullets {\n outline: 0; }\n .orbit-bullets button {\n width: 1.2rem;\n height: 1.2rem;\n margin: 0.1rem;\n border-radius: 50%;\n background-color: #cacaca; }\n .orbit-bullets button:hover {\n background-color: #8a8a8a; }\n .orbit-bullets button.is-active {\n background-color: #8a8a8a; }\n\n.responsive-embed,\n.flex-video {\n position: relative;\n height: 0;\n margin-bottom: 1rem;\n padding-bottom: 75%;\n overflow: hidden; }\n .responsive-embed iframe,\n .responsive-embed object,\n .responsive-embed embed,\n .responsive-embed video,\n .flex-video iframe,\n .flex-video object,\n .flex-video embed,\n .flex-video video {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%; }\n .responsive-embed.widescreen,\n .flex-video.widescreen {\n padding-bottom: 56.25%; }\n\n.tabs {\n margin: 0;\n border: 1px solid #e6e6e6;\n background: #fefefe;\n list-style-type: none; }\n .tabs::before, .tabs::after {\n display: table;\n content: ' '; }\n .tabs::after {\n clear: both; }\n\n.tabs.vertical > li {\n display: block;\n float: none;\n width: auto; }\n\n.tabs.simple > li > a {\n padding: 0; }\n .tabs.simple > li > a:hover {\n background: transparent; }\n\n.tabs.primary {\n background: #1779ba; }\n .tabs.primary > li > a {\n color: #fefefe; }\n .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n background: #1673b1; }\n\n.tabs-title {\n float: left; }\n .tabs-title > a {\n display: block;\n padding: 1.25rem 1.5rem;\n font-size: 0.75rem;\n line-height: 1;\n color: #1779ba; }\n [data-whatinput='mouse'] .tabs-title > a {\n outline: 0; }\n .tabs-title > a:hover {\n background: #fefefe;\n color: #1468a0; }\n .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n background: #e6e6e6;\n color: #1779ba; }\n\n.tabs-content {\n border: 1px solid #e6e6e6;\n border-top: 0;\n background: #fefefe;\n color: #0a0a0a;\n transition: all 0.5s ease; }\n\n.tabs-content.vertical {\n border: 1px solid #e6e6e6;\n border-left: 0; }\n\n.tabs-panel {\n display: none;\n padding: 1rem; }\n .tabs-panel.is-active {\n display: block; }\n\n.thumbnail {\n display: inline-block;\n max-width: 100%;\n margin-bottom: 1rem;\n border: 4px solid #fefefe;\n border-radius: 0;\n box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n line-height: 0; }\n\na.thumbnail {\n transition: box-shadow 200ms ease-out; }\n a.thumbnail:hover, a.thumbnail:focus {\n box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }\n a.thumbnail image {\n box-shadow: none; }\n\n.menu {\n padding: 0;\n margin: 0;\n list-style: none;\n position: relative; }\n [data-whatinput='mouse'] .menu li {\n outline: 0; }\n .menu a,\n .menu .button {\n line-height: 1;\n text-decoration: none;\n display: block;\n padding: 0.7rem 1rem; }\n .menu input,\n .menu select,\n .menu a,\n .menu button {\n margin-bottom: 0; }\n .menu input {\n display: inline-block; }\n .menu li, .menu.horizontal li {\n display: inline-block; }\n .menu.vertical li {\n display: block; }\n .menu.expanded {\n display: table;\n width: 100%; }\n .menu.expanded > li {\n display: table-cell;\n vertical-align: middle; }\n .menu.simple li + li {\n margin-left: 1rem; }\n .menu.simple a {\n padding: 0; }\n @media print, screen and (min-width: 40em) {\n .menu.medium-horizontal li {\n display: inline-block; }\n .menu.medium-vertical li {\n display: block; }\n .menu.medium-expanded {\n display: table;\n width: 100%; }\n .menu.medium-expanded > li {\n display: table-cell;\n vertical-align: middle; }\n .menu.medium-simple {\n display: table;\n width: 100%; }\n .menu.medium-simple > li {\n display: table-cell;\n vertical-align: middle; } }\n @media print, screen and (min-width: 64em) {\n .menu.large-horizontal li {\n display: inline-block; }\n .menu.large-vertical li {\n display: block; }\n .menu.large-expanded {\n display: table;\n width: 100%; }\n .menu.large-expanded > li {\n display: table-cell;\n vertical-align: middle; }\n .menu.large-simple {\n display: table;\n width: 100%; }\n .menu.large-simple > li {\n display: table-cell;\n vertical-align: middle; } }\n .menu.nested {\n margin-right: 0;\n margin-left: 1rem; }\n .menu.icons img,\n .menu.icons i,\n .menu.icons svg {\n vertical-align: middle; }\n .menu.icons img + span,\n .menu.icons i + span,\n .menu.icons svg + span {\n vertical-align: middle; }\n .menu.icon-top img,\n .menu.icon-top i,\n .menu.icon-top svg, .menu.icon-right img,\n .menu.icon-right i,\n .menu.icon-right svg, .menu.icon-bottom img,\n .menu.icon-bottom i,\n .menu.icon-bottom svg, .menu.icon-left img,\n .menu.icon-left i,\n .menu.icon-left svg {\n vertical-align: middle; }\n .menu.icon-top img + span,\n .menu.icon-top i + span,\n .menu.icon-top svg + span, .menu.icon-right img + span,\n .menu.icon-right i + span,\n .menu.icon-right svg + span, .menu.icon-bottom img + span,\n .menu.icon-bottom i + span,\n .menu.icon-bottom svg + span, .menu.icon-left img + span,\n .menu.icon-left i + span,\n .menu.icon-left svg + span {\n vertical-align: middle; }\n .menu.icon-left li a img,\n .menu.icon-left li a i,\n .menu.icon-left li a svg, .menu.nested.icon-left li a img,\n .menu.nested.icon-left li a i,\n .menu.nested.icon-left li a svg {\n margin-right: 0.25rem;\n display: inline-block; }\n .menu.icon-right li a img,\n .menu.icon-right li a i,\n .menu.icon-right li a svg, .menu.nested.icon-right li a img,\n .menu.nested.icon-right li a i,\n .menu.nested.icon-right li a svg {\n margin-left: 0.25rem;\n display: inline-block; }\n .menu.icon-top li a, .menu.nested.icon-top li a {\n text-align: center; }\n .menu.icon-top li a img,\n .menu.icon-top li a i,\n .menu.icon-top li a svg, .menu.nested.icon-top li a img,\n .menu.nested.icon-top li a i,\n .menu.nested.icon-top li a svg {\n display: block;\n margin: 0 auto 0.25rem; }\n .menu.icon-bottom li a, .menu.nested.icon-bottom li a {\n text-align: center; }\n .menu.icon-bottom li a img,\n .menu.icon-bottom li a i,\n .menu.icon-bottom li a svg, .menu.nested.icon-bottom li a img,\n .menu.nested.icon-bottom li a i,\n .menu.nested.icon-bottom li a svg {\n display: block;\n margin: 0.25rem auto 0; }\n .menu .is-active > a {\n background: #1779ba;\n color: #fefefe; }\n .menu .active > a {\n background: #1779ba;\n color: #fefefe; }\n .menu.align-left {\n text-align: left; }\n .menu.align-right {\n text-align: right; }\n .menu.align-right .submenu li {\n text-align: left; }\n .menu.align-right.vertical .submenu li {\n text-align: right; }\n .menu.align-right .nested {\n margin-right: 1rem;\n margin-left: 0; }\n .menu.align-center {\n text-align: center; }\n .menu.align-center .submenu li {\n text-align: left; }\n .menu .menu-text {\n padding: 0.7rem 1rem;\n font-weight: bold;\n line-height: 1;\n color: inherit; }\n\n.menu-centered > .menu {\n text-align: center; }\n .menu-centered > .menu .submenu li {\n text-align: left; }\n\n.no-js [data-responsive-menu] ul {\n display: none; }\n\n.menu-icon {\n position: relative;\n display: inline-block;\n vertical-align: middle;\n width: 20px;\n height: 16px;\n cursor: pointer; }\n .menu-icon::after {\n position: absolute;\n top: 0;\n left: 0;\n display: block;\n width: 100%;\n height: 2px;\n background: #fefefe;\n box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;\n content: ''; }\n .menu-icon:hover::after {\n background: #cacaca;\n box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }\n\n.menu-icon.dark {\n position: relative;\n display: inline-block;\n vertical-align: middle;\n width: 20px;\n height: 16px;\n cursor: pointer; }\n .menu-icon.dark::after {\n position: absolute;\n top: 0;\n left: 0;\n display: block;\n width: 100%;\n height: 2px;\n background: #0a0a0a;\n box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;\n content: ''; }\n .menu-icon.dark:hover::after {\n background: #8a8a8a;\n box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }\n\n.accordion-menu li {\n width: 100%; }\n\n.accordion-menu a {\n padding: 0.7rem 1rem; }\n\n.accordion-menu .is-accordion-submenu a {\n padding: 0.7rem 1rem; }\n\n.accordion-menu .nested.is-accordion-submenu {\n margin-right: 0;\n margin-left: 1rem; }\n\n.accordion-menu.align-right .nested.is-accordion-submenu {\n margin-right: 1rem;\n margin-left: 0; }\n\n.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n position: relative; }\n .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-bottom-width: 0;\n border-color: #1779ba transparent transparent;\n position: absolute;\n top: 50%;\n margin-top: -3px;\n right: 1rem; }\n\n.accordion-menu.align-left .is-accordion-submenu-parent > a::after {\n right: 1rem;\n left: auto; }\n\n.accordion-menu.align-right .is-accordion-submenu-parent > a::after {\n right: auto;\n left: 1rem; }\n\n.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n transform: rotate(180deg);\n transform-origin: 50% 50%; }\n\n.is-accordion-submenu-parent {\n position: relative; }\n\n.has-submenu-toggle > a {\n margin-right: 40px; }\n\n.submenu-toggle {\n position: absolute;\n top: 0;\n right: 0;\n width: 40px;\n height: 40px;\n cursor: pointer; }\n .submenu-toggle::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-bottom-width: 0;\n border-color: #1779ba transparent transparent;\n top: 0;\n bottom: 0;\n margin: auto; }\n\n.submenu-toggle[aria-expanded='true']::after {\n transform: scaleY(-1);\n transform-origin: 50% 50%; }\n\n.submenu-toggle-text {\n position: absolute !important;\n width: 1px !important;\n height: 1px !important;\n padding: 0 !important;\n overflow: hidden !important;\n clip: rect(0, 0, 0, 0) !important;\n white-space: nowrap !important;\n border: 0 !important; }\n\n.is-drilldown {\n position: relative;\n overflow: hidden; }\n .is-drilldown li {\n display: block; }\n .is-drilldown.animate-height {\n transition: height 0.5s; }\n\n.drilldown a {\n padding: 0.7rem 1rem;\n background: #fefefe; }\n\n.drilldown .is-drilldown-submenu {\n position: absolute;\n top: 0;\n left: 100%;\n z-index: -1;\n width: 100%;\n background: #fefefe;\n transition: transform 0.15s linear; }\n .drilldown .is-drilldown-submenu.is-active {\n z-index: 1;\n display: block;\n transform: translateX(-100%); }\n .drilldown .is-drilldown-submenu.is-closing {\n transform: translateX(100%); }\n .drilldown .is-drilldown-submenu a {\n padding: 0.7rem 1rem; }\n\n.drilldown .nested.is-drilldown-submenu {\n margin-right: 0;\n margin-left: 0; }\n\n.drilldown .drilldown-submenu-cover-previous {\n min-height: 100%; }\n\n.drilldown .is-drilldown-submenu-parent > a {\n position: relative; }\n .drilldown .is-drilldown-submenu-parent > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #1779ba;\n position: absolute;\n top: 50%;\n margin-top: -6px;\n right: 1rem; }\n\n.drilldown.align-left .is-drilldown-submenu-parent > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #1779ba;\n right: 1rem;\n left: auto; }\n\n.drilldown.align-right .is-drilldown-submenu-parent > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-left-width: 0;\n border-color: transparent #1779ba transparent transparent;\n right: auto;\n left: 1rem; }\n\n.drilldown .js-drilldown-back > a::before {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-left-width: 0;\n border-color: transparent #1779ba transparent transparent;\n display: inline-block;\n vertical-align: middle;\n margin-right: 0.75rem; }\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n top: 100%;\n right: 0;\n left: auto; }\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n top: 100%;\n right: auto;\n left: 0; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n position: relative;\n padding-right: 1.5rem; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-bottom-width: 0;\n border-color: #1779ba transparent transparent;\n right: 5px;\n left: auto;\n margin-top: -3px; }\n\n[data-whatinput='mouse'] .dropdown.menu a {\n outline: 0; }\n\n.dropdown.menu > li > a {\n padding: 0.7rem 1rem; }\n\n.dropdown.menu > li.is-active > a {\n background: transparent;\n color: #1779ba; }\n\n.no-js .dropdown.menu ul {\n display: none; }\n\n.dropdown.menu .nested.is-dropdown-submenu {\n margin-right: 0;\n margin-left: 0; }\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n top: 0; }\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n top: 0;\n right: 100%;\n left: auto; }\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n right: auto;\n left: 100%; }\n\n.dropdown.menu.vertical > li > a::after {\n right: 14px; }\n\n.dropdown.menu.vertical > li.opens-left > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-left-width: 0;\n border-color: transparent #1779ba transparent transparent;\n right: auto;\n left: 5px; }\n\n.dropdown.menu.vertical > li.opens-right > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #1779ba; }\n\n@media print, screen and (min-width: 40em) {\n .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {\n top: 100%;\n right: 0;\n left: auto; }\n .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n top: 100%;\n right: auto;\n left: 0; }\n .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n position: relative;\n padding-right: 1.5rem; }\n .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-bottom-width: 0;\n border-color: #1779ba transparent transparent;\n right: 5px;\n left: auto;\n margin-top: -3px; }\n .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n top: 0; }\n .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n top: 0;\n right: 100%;\n left: auto; }\n .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n right: auto;\n left: 100%; }\n .dropdown.menu.medium-vertical > li > a::after {\n right: 14px; }\n .dropdown.menu.medium-vertical > li.opens-left > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-left-width: 0;\n border-color: transparent #1779ba transparent transparent;\n right: auto;\n left: 5px; }\n .dropdown.menu.medium-vertical > li.opens-right > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #1779ba; } }\n\n@media print, screen and (min-width: 64em) {\n .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {\n top: 100%;\n right: 0;\n left: auto; }\n .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n top: 100%;\n right: auto;\n left: 0; }\n .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n position: relative;\n padding-right: 1.5rem; }\n .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-bottom-width: 0;\n border-color: #1779ba transparent transparent;\n right: 5px;\n left: auto;\n margin-top: -3px; }\n .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n top: 0; }\n .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n top: 0;\n right: 100%;\n left: auto; }\n .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n right: auto;\n left: 100%; }\n .dropdown.menu.large-vertical > li > a::after {\n right: 14px; }\n .dropdown.menu.large-vertical > li.opens-left > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-left-width: 0;\n border-color: transparent #1779ba transparent transparent;\n right: auto;\n left: 5px; }\n .dropdown.menu.large-vertical > li.opens-right > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #1779ba; } }\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n top: 100%;\n right: 0;\n left: auto; }\n\n.is-dropdown-menu.vertical {\n width: 100px; }\n .is-dropdown-menu.vertical.align-right {\n float: right; }\n\n.is-dropdown-submenu-parent {\n position: relative; }\n .is-dropdown-submenu-parent a::after {\n position: absolute;\n top: 50%;\n right: 5px;\n left: auto;\n margin-top: -6px; }\n .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n top: 100%;\n left: auto; }\n .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n right: 100%;\n left: auto; }\n .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n right: auto;\n left: 100%; }\n\n.is-dropdown-submenu {\n position: absolute;\n top: 0;\n left: 100%;\n z-index: 1;\n display: none;\n min-width: 200px;\n border: 1px solid #cacaca;\n background: #fefefe; }\n .dropdown .is-dropdown-submenu a {\n padding: 0.7rem 1rem; }\n .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n right: 14px; }\n .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-left-width: 0;\n border-color: transparent #1779ba transparent transparent;\n right: auto;\n left: 5px; }\n .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {\n display: block;\n width: 0;\n height: 0;\n border-style: solid;\n border-width: 6px;\n content: '';\n border-right-width: 0;\n border-color: transparent transparent transparent #1779ba; }\n .is-dropdown-submenu .is-dropdown-submenu {\n margin-top: -1px; }\n .is-dropdown-submenu > li {\n width: 100%; }\n .is-dropdown-submenu.js-dropdown-active {\n display: block; }\n\n.is-off-canvas-open {\n overflow: hidden; }\n\n.js-off-canvas-overlay {\n position: absolute;\n top: 0;\n left: 0;\n z-index: 11;\n width: 100%;\n height: 100%;\n transition: opacity 0.5s ease, visibility 0.5s ease;\n background: rgba(254, 254, 254, 0.25);\n opacity: 0;\n visibility: hidden;\n overflow: hidden; }\n .js-off-canvas-overlay.is-visible {\n opacity: 1;\n visibility: visible; }\n .js-off-canvas-overlay.is-closable {\n cursor: pointer; }\n .js-off-canvas-overlay.is-overlay-absolute {\n position: absolute; }\n .js-off-canvas-overlay.is-overlay-fixed {\n position: fixed; }\n\n.off-canvas-wrapper {\n position: relative;\n overflow: hidden; }\n\n.off-canvas {\n position: fixed;\n z-index: 12;\n transition: transform 0.5s ease;\n backface-visibility: hidden;\n background: #e6e6e6; }\n [data-whatinput='mouse'] .off-canvas {\n outline: 0; }\n .off-canvas.is-transition-push {\n z-index: 12; }\n .off-canvas.is-closed {\n visibility: hidden; }\n .off-canvas.is-transition-overlap {\n z-index: 13; }\n .off-canvas.is-transition-overlap.is-open {\n box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n .off-canvas.is-open {\n transform: translate(0, 0); }\n\n.off-canvas-absolute {\n position: absolute;\n z-index: 12;\n transition: transform 0.5s ease;\n backface-visibility: hidden;\n background: #e6e6e6; }\n [data-whatinput='mouse'] .off-canvas-absolute {\n outline: 0; }\n .off-canvas-absolute.is-transition-push {\n z-index: 12; }\n .off-canvas-absolute.is-closed {\n visibility: hidden; }\n .off-canvas-absolute.is-transition-overlap {\n z-index: 13; }\n .off-canvas-absolute.is-transition-overlap.is-open {\n box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n .off-canvas-absolute.is-open {\n transform: translate(0, 0); }\n\n.position-left {\n top: 0;\n left: 0;\n height: 100%;\n overflow-y: auto;\n -webkit-overflow-scrolling: touch;\n width: 250px;\n transform: translateX(-250px); }\n .off-canvas-content .off-canvas.position-left {\n transform: translateX(-250px); }\n .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {\n transform: translate(0, 0); }\n .off-canvas-content.is-open-left.has-transition-push {\n transform: translateX(250px); }\n .position-left.is-transition-push {\n box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-right {\n top: 0;\n right: 0;\n height: 100%;\n overflow-y: auto;\n -webkit-overflow-scrolling: touch;\n width: 250px;\n transform: translateX(250px); }\n .off-canvas-content .off-canvas.position-right {\n transform: translateX(250px); }\n .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {\n transform: translate(0, 0); }\n .off-canvas-content.is-open-right.has-transition-push {\n transform: translateX(-250px); }\n .position-right.is-transition-push {\n box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-top {\n top: 0;\n left: 0;\n width: 100%;\n overflow-x: auto;\n -webkit-overflow-scrolling: touch;\n height: 250px;\n transform: translateY(-250px); }\n .off-canvas-content .off-canvas.position-top {\n transform: translateY(-250px); }\n .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {\n transform: translate(0, 0); }\n .off-canvas-content.is-open-top.has-transition-push {\n transform: translateY(250px); }\n .position-top.is-transition-push {\n box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-bottom {\n bottom: 0;\n left: 0;\n width: 100%;\n overflow-x: auto;\n -webkit-overflow-scrolling: touch;\n height: 250px;\n transform: translateY(250px); }\n .off-canvas-content .off-canvas.position-bottom {\n transform: translateY(250px); }\n .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {\n transform: translate(0, 0); }\n .off-canvas-content.is-open-bottom.has-transition-push {\n transform: translateY(-250px); }\n .position-bottom.is-transition-push {\n box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.off-canvas-content {\n transform: none;\n backface-visibility: hidden; }\n .off-canvas-content.has-transition-overlap, .off-canvas-content.has-transition-push {\n transition: transform 0.5s ease; }\n .off-canvas-content.has-transition-push {\n transform: translate(0, 0); }\n .off-canvas-content .off-canvas.is-open {\n transform: translate(0, 0); }\n\n@media print, screen and (min-width: 40em) {\n .position-left.reveal-for-medium {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-left.reveal-for-medium .close-button {\n display: none; }\n .off-canvas-content .position-left.reveal-for-medium {\n transform: none; }\n .off-canvas-content.has-reveal-left {\n margin-left: 250px; }\n .position-left.reveal-for-medium ~ .off-canvas-content {\n margin-left: 250px; }\n .position-right.reveal-for-medium {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-right.reveal-for-medium .close-button {\n display: none; }\n .off-canvas-content .position-right.reveal-for-medium {\n transform: none; }\n .off-canvas-content.has-reveal-right {\n margin-right: 250px; }\n .position-right.reveal-for-medium ~ .off-canvas-content {\n margin-right: 250px; }\n .position-top.reveal-for-medium {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-top.reveal-for-medium .close-button {\n display: none; }\n .off-canvas-content .position-top.reveal-for-medium {\n transform: none; }\n .off-canvas-content.has-reveal-top {\n margin-top: 250px; }\n .position-top.reveal-for-medium ~ .off-canvas-content {\n margin-top: 250px; }\n .position-bottom.reveal-for-medium {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-bottom.reveal-for-medium .close-button {\n display: none; }\n .off-canvas-content .position-bottom.reveal-for-medium {\n transform: none; }\n .off-canvas-content.has-reveal-bottom {\n margin-bottom: 250px; }\n .position-bottom.reveal-for-medium ~ .off-canvas-content {\n margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 64em) {\n .position-left.reveal-for-large {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-left.reveal-for-large .close-button {\n display: none; }\n .off-canvas-content .position-left.reveal-for-large {\n transform: none; }\n .off-canvas-content.has-reveal-left {\n margin-left: 250px; }\n .position-left.reveal-for-large ~ .off-canvas-content {\n margin-left: 250px; }\n .position-right.reveal-for-large {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-right.reveal-for-large .close-button {\n display: none; }\n .off-canvas-content .position-right.reveal-for-large {\n transform: none; }\n .off-canvas-content.has-reveal-right {\n margin-right: 250px; }\n .position-right.reveal-for-large ~ .off-canvas-content {\n margin-right: 250px; }\n .position-top.reveal-for-large {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-top.reveal-for-large .close-button {\n display: none; }\n .off-canvas-content .position-top.reveal-for-large {\n transform: none; }\n .off-canvas-content.has-reveal-top {\n margin-top: 250px; }\n .position-top.reveal-for-large ~ .off-canvas-content {\n margin-top: 250px; }\n .position-bottom.reveal-for-large {\n transform: none;\n z-index: 12;\n transition: none;\n visibility: visible; }\n .position-bottom.reveal-for-large .close-button {\n display: none; }\n .off-canvas-content .position-bottom.reveal-for-large {\n transform: none; }\n .off-canvas-content.has-reveal-bottom {\n margin-bottom: 250px; }\n .position-bottom.reveal-for-large ~ .off-canvas-content {\n margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 40em) {\n .off-canvas.in-canvas-for-medium {\n visibility: visible;\n height: auto;\n position: static;\n background: none;\n width: auto;\n overflow: visible;\n transition: none; }\n .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {\n box-shadow: none;\n transform: none; }\n .off-canvas.in-canvas-for-medium .close-button {\n display: none; } }\n\n@media print, screen and (min-width: 64em) {\n .off-canvas.in-canvas-for-large {\n visibility: visible;\n height: auto;\n position: static;\n background: none;\n width: auto;\n overflow: visible;\n transition: none; }\n .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {\n box-shadow: none;\n transform: none; }\n .off-canvas.in-canvas-for-large .close-button {\n display: none; } }\n\nhtml.is-reveal-open {\n position: fixed;\n width: 100%;\n overflow-y: hidden; }\n html.is-reveal-open.zf-has-scroll {\n overflow-y: scroll;\n -webkit-overflow-scrolling: touch; }\n html.is-reveal-open body {\n overflow-y: hidden; }\n\n.reveal-overlay {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 1005;\n display: none;\n background-color: rgba(10, 10, 10, 0.45);\n overflow-y: auto;\n -webkit-overflow-scrolling: touch; }\n\n.reveal {\n z-index: 1006;\n backface-visibility: hidden;\n display: none;\n padding: 1rem;\n border: 1px solid #cacaca;\n border-radius: 0;\n background-color: #fefefe;\n position: relative;\n top: 100px;\n margin-right: auto;\n margin-left: auto;\n overflow-y: auto;\n -webkit-overflow-scrolling: touch; }\n [data-whatinput='mouse'] .reveal {\n outline: 0; }\n @media print, screen and (min-width: 40em) {\n .reveal {\n min-height: 0; } }\n .reveal .column, .reveal .columns {\n min-width: 0; }\n .reveal > :last-child {\n margin-bottom: 0; }\n @media print, screen and (min-width: 40em) {\n .reveal {\n width: 600px;\n max-width: 75rem; } }\n .reveal.collapse {\n padding: 0; }\n @media print, screen and (min-width: 40em) {\n .reveal.tiny {\n width: 30%;\n max-width: 75rem; } }\n @media print, screen and (min-width: 40em) {\n .reveal.small {\n width: 50%;\n max-width: 75rem; } }\n @media print, screen and (min-width: 40em) {\n .reveal.large {\n width: 90%;\n max-width: 75rem; } }\n .reveal.full {\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n width: 100%;\n max-width: none;\n height: 100%;\n min-height: 100%;\n margin-left: 0;\n border: 0;\n border-radius: 0; }\n @media print, screen and (max-width: 39.99875em) {\n .reveal {\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n width: 100%;\n max-width: none;\n height: 100%;\n min-height: 100%;\n margin-left: 0;\n border: 0;\n border-radius: 0; } }\n .reveal.without-overlay {\n position: fixed; }\n\n.sticky-container {\n position: relative; }\n\n.sticky {\n position: relative;\n z-index: 0;\n transform: translate3d(0, 0, 0); }\n\n.sticky.is-stuck {\n position: fixed;\n z-index: 5;\n width: 100%; }\n .sticky.is-stuck.is-at-top {\n top: 0; }\n .sticky.is-stuck.is-at-bottom {\n bottom: 0; }\n\n.sticky.is-anchored {\n position: relative;\n right: auto;\n left: auto; }\n .sticky.is-anchored.is-at-bottom {\n bottom: 0; }\n\n.title-bar {\n padding: 0.5rem;\n background: #0a0a0a;\n color: #fefefe; }\n .title-bar::before, .title-bar::after {\n display: table;\n content: ' '; }\n .title-bar::after {\n clear: both; }\n .title-bar .menu-icon {\n margin-left: 0.25rem;\n margin-right: 0.25rem; }\n\n.title-bar-left {\n float: left; }\n\n.title-bar-right {\n float: right;\n text-align: right; }\n\n.title-bar-title {\n display: inline-block;\n vertical-align: middle;\n font-weight: bold; }\n\n.top-bar {\n padding: 0.5rem; }\n .top-bar::before, .top-bar::after {\n display: table;\n content: ' '; }\n .top-bar::after {\n clear: both; }\n .top-bar,\n .top-bar ul {\n background-color: #e6e6e6; }\n .top-bar input {\n max-width: 200px;\n margin-right: 1rem; }\n .top-bar .input-group-field {\n width: 100%;\n margin-right: 0; }\n .top-bar input.button {\n width: auto; }\n .top-bar .top-bar-left,\n .top-bar .top-bar-right {\n width: 100%; }\n @media print, screen and (min-width: 40em) {\n .top-bar .top-bar-left,\n .top-bar .top-bar-right {\n width: auto; } }\n @media print, screen and (max-width: 63.99875em) {\n .top-bar.stacked-for-medium .top-bar-left,\n .top-bar.stacked-for-medium .top-bar-right {\n width: 100%; } }\n @media print, screen and (max-width: 74.99875em) {\n .top-bar.stacked-for-large .top-bar-left,\n .top-bar.stacked-for-large .top-bar-right {\n width: 100%; } }\n\n.top-bar-title {\n display: inline-block;\n float: left;\n padding: 0.5rem 1rem 0.5rem 0; }\n .top-bar-title .menu-icon {\n bottom: 2px; }\n\n.top-bar-left {\n float: left; }\n\n.top-bar-right {\n float: right; }\n\n.float-left {\n float: left !important; }\n\n.float-right {\n float: right !important; }\n\n.float-center {\n display: block;\n margin-right: auto;\n margin-left: auto; }\n\n.clearfix::before, .clearfix::after {\n display: table;\n content: ' '; }\n\n.clearfix::after {\n clear: both; }\n\n.hide {\n display: none !important; }\n\n.invisible {\n visibility: hidden; }\n\n.visible {\n visibility: visible; }\n\n@media print, screen and (max-width: 39.99875em) {\n .hide-for-small-only {\n display: none !important; } }\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n .show-for-small-only {\n display: none !important; } }\n\n@media print, screen and (min-width: 40em) {\n .hide-for-medium {\n display: none !important; } }\n\n@media screen and (max-width: 39.99875em) {\n .show-for-medium {\n display: none !important; } }\n\n@media print, screen and (min-width: 40em) and (max-width: 63.99875em) {\n .hide-for-medium-only {\n display: none !important; } }\n\n@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {\n .show-for-medium-only {\n display: none !important; } }\n\n@media print, screen and (min-width: 64em) {\n .hide-for-large {\n display: none !important; } }\n\n@media screen and (max-width: 63.99875em) {\n .show-for-large {\n display: none !important; } }\n\n@media print, screen and (min-width: 64em) and (max-width: 74.99875em) {\n .hide-for-large-only {\n display: none !important; } }\n\n@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {\n .show-for-large-only {\n display: none !important; } }\n\n.show-for-sr,\n.show-on-focus {\n position: absolute !important;\n width: 1px !important;\n height: 1px !important;\n padding: 0 !important;\n overflow: hidden !important;\n clip: rect(0, 0, 0, 0) !important;\n white-space: nowrap !important;\n border: 0 !important; }\n\n.show-on-focus:active, .show-on-focus:focus {\n position: static !important;\n width: auto !important;\n height: auto !important;\n overflow: visible !important;\n clip: auto !important;\n white-space: normal !important; }\n\n.show-for-landscape,\n.hide-for-portrait {\n display: block !important; }\n @media screen and (orientation: landscape) {\n .show-for-landscape,\n .hide-for-portrait {\n display: block !important; } }\n @media screen and (orientation: portrait) {\n .show-for-landscape,\n .hide-for-portrait {\n display: none !important; } }\n\n.hide-for-landscape,\n.show-for-portrait {\n display: none !important; }\n @media screen and (orientation: landscape) {\n .hide-for-landscape,\n .show-for-portrait {\n display: none !important; } }\n @media screen and (orientation: portrait) {\n .hide-for-landscape,\n .show-for-portrait {\n display: block !important; } }\n\n.show-for-dark-mode {\n display: none; }\n\n.hide-for-dark-mode {\n display: block; }\n\n@media screen and (prefers-color-scheme: dark) {\n .show-for-dark-mode {\n display: block !important; }\n .hide-for-dark-mode {\n display: none !important; } }\n\n.show-for-ie {\n display: none; }\n\n@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {\n .show-for-ie {\n display: block !important; }\n .hide-for-ie {\n display: none !important; } }\n\n.show-for-sticky {\n display: none; }\n\n.is-stuck .show-for-sticky {\n display: block; }\n\n.is-stuck .hide-for-sticky {\n display: none; }\n","/**\n * Foundation for Sites\n * Version 6.7.5\n * https://get.foundation\n * Licensed under MIT Open Source\n */\n\n// --- Dependencies ---\n@import 'vendor/normalize';\n@import '../_vendor/sassy-lists/stylesheets/helpers/missing-dependencies';\n@import '../_vendor/sassy-lists/stylesheets/helpers/true';\n@import '../_vendor/sassy-lists/stylesheets/functions/contain';\n@import '../_vendor/sassy-lists/stylesheets/functions/purge';\n@import '../_vendor/sassy-lists/stylesheets/functions/remove';\n@import '../_vendor/sassy-lists/stylesheets/functions/replace';\n@import '../_vendor/sassy-lists/stylesheets/functions/to-list';\n\n// --- Settings ---\n// import your own `settings` here or\n// import and modify the default settings through\n// @import 'settings/settings';\n\n// --- Components ---\n// Utilities\n@import 'util/util';\n// Global styles\n@import 'global';\n@import 'forms/forms';\n@import 'typography/typography';\n\n// Grids\n@import 'grid/grid';\n@import 'xy-grid/xy-grid';\n// Generic components\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/close-button';\n@import 'components/label';\n@import 'components/progress-bar';\n@import 'components/slider';\n@import 'components/switch';\n@import 'components/table';\n// Basic components\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/dropdown';\n@import 'components/pagination';\n@import 'components/tooltip';\n\n// Containers\n@import 'components/accordion';\n@import 'components/media-object';\n@import 'components/orbit';\n@import 'components/responsive-embed';\n@import 'components/tabs';\n@import 'components/thumbnail';\n// Menu-based containers\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/accordion-menu';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n\n// Layout components\n@import 'components/off-canvas';\n@import 'components/reveal';\n@import 'components/sticky';\n@import 'components/title-bar';\n@import 'components/top-bar';\n\n// Helpers\n@import 'components/float';\n@import 'components/flex';\n@import 'components/visibility';\n@import 'prototype/prototype';\n\n\n@mixin foundation-everything(\n $flex: true,\n $prototype: false,\n $xy-grid: $xy-grid\n) {\n @if $flex {\n $global-flexbox: true !global;\n }\n\n @if $xy-grid {\n $xy-grid: true !global;\n }\n\n // Global styles\n @include foundation-global-styles;\n @include foundation-forms;\n @include foundation-typography;\n\n // Grids\n @if not $flex {\n @include foundation-grid;\n }\n @else {\n @if $xy-grid {\n @include foundation-xy-grid-classes;\n }\n @else {\n @include foundation-flex-grid;\n }\n }\n\n // Generic components\n @include foundation-button;\n @include foundation-button-group;\n @include foundation-close-button;\n @include foundation-label;\n @include foundation-progress-bar;\n @include foundation-slider;\n @include foundation-switch;\n @include foundation-table;\n // Basic components\n @include foundation-badge;\n @include foundation-breadcrumbs;\n @include foundation-callout;\n @include foundation-card;\n @include foundation-dropdown;\n @include foundation-pagination;\n @include foundation-tooltip;\n\n // Containers\n @include foundation-accordion;\n @include foundation-media-object;\n @include foundation-orbit;\n @include foundation-responsive-embed;\n @include foundation-tabs;\n @include foundation-thumbnail;\n // Menu-based containers\n @include foundation-menu;\n @include foundation-menu-icon;\n @include foundation-accordion-menu;\n @include foundation-drilldown-menu;\n @include foundation-dropdown-menu;\n\n // Layout components\n @include foundation-off-canvas;\n @include foundation-reveal;\n @include foundation-sticky;\n @include foundation-title-bar;\n @include foundation-top-bar;\n\n // Helpers\n @include foundation-float-classes;\n @if $flex { @include foundation-flex-classes; }\n @include foundation-visibility-classes;\n @if $prototype { @include foundation-prototype-classes; }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group breakpoints\n////\n\n/// Patch to fix issue #12080\n$-zf-size: null;\n\n/// A list of named breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries.\n/// @type Map\n$breakpoints: (\n \"small\": 0,\n \"medium\": 640px,\n \"large\": 1024px,\n \"xlarge\": 1200px,\n \"xxlarge\": 1440px,\n) !default;\n\n/// A list of named HiDPI breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries for resolutions.\n/// Values must represent the device pixels / web pixels ration and be unitless or in DPPX.\n/// @type Map\n$breakpoints-hidpi: (\n \"hidpi-1\": 1,\n \"hidpi-1-5\": 1.5,\n \"hidpi-2\": 2,\n \"retina\": 2,\n \"hidpi-3\": 3\n) !default;\n\n/// The largest named breakpoint in which to include print as a media type\n/// @type Keyword\n$print-breakpoint: large !default;\n\n$-zf-zero-breakpoint: small !default;\n\n$-zf-breakpoints-keys: map-to-list($breakpoints, 'keys');\n\n@if nth(map-values($breakpoints), 1) != 0 {\n @error 'The first key in the $breakpoints map must have a value of \"0\".';\n}\n@else {\n $-zf-zero-breakpoint: nth(map-keys($breakpoints), 1);\n}\n\n/// All of the names in this list will be output as classes in your CSS, like `.small-12`, `.medium-6`, and so on. Each value in this list must also be in the `$breakpoints` map.\n/// @type List\n$breakpoint-classes: (small medium large) !default;\n\n/// Generates a media query string matching the input value. Refer to the documentation for the `breakpoint()` mixin to see what the possible inputs are.\n///\n/// @param {Keyword|Number} $val [small] - Breakpoint name, or px, rem, or em value to process.\n@function breakpoint($val: $-zf-zero-breakpoint) {\n // Web standard Pixels per inch. (1ddpx / $std-web-dpi) = 1dpi\n // See https://www.w3.org/TR/css-values-3/#absolute-lengths\n $std-web-dpi: 96;\n\n // Size or keyword\n $bp: nth($val, 1);\n // Value of the following breakpoint\n $bp-next: null;\n // Value for max-width media queries\n $bp-min: null;\n // Value for min-width media queries\n $bp-max: null;\n // Direction of media query (up, down, or only)\n $dir: if(length($val) > 1, nth($val, 2), up);\n // If named, name of the breakpoint\n $name: null;\n // If the breakpoint is a HiDPI breakpoint\n $hidpi: false;\n\n // Orientation media queries have a unique syntax\n @if $bp == 'landscape' or $bp == 'portrait' {\n @return '(orientation: #{$bp})';\n }\n\n // If a breakpoint name is given, get its value from the $breakpoints/$breakpoints-hidpi map.\n @if type-of($bp) == 'string' {\n @if map-has-key($breakpoints, $bp) {\n $name: $bp;\n $bp: map-get($breakpoints, $name);\n $bp-next: -zf-map-next($breakpoints, $name);\n }\n @else if map-has-key($breakpoints-hidpi, $bp) {\n $name: $bp;\n $bp: map-get($breakpoints-hidpi, $name);\n $bp-next: -zf-map-next-number($breakpoints-hidpi, $bp);\n $hidpi: true;\n }\n @else {\n $bp: 0;\n @warn 'breakpoint(): \"#{$val}\" is not defined in your `$breakpoints` or `$breakpoints-hidpi` setting.';\n }\n }\n\n @if not $name and $dir == 'only' {\n @warn 'breakpoint(): Only named media queries can have an `only` range.';\n @return null;\n }\n\n // Only 'only' and 'up' have a min limit.\n @if $dir == 'only' or $dir == 'up' {\n $bp-min: if($hidpi, strip-unit($bp), -zf-bp-to-em($bp));\n }\n // Only 'only' and 'down' have a max limit.\n @if $dir == 'only' or $dir == 'down' {\n // If the breakpoint is a value, use it as max limit.\n @if not $name {\n $bp-max: if($hidpi, strip-unit($bp), -zf-bp-to-em($bp));\n }\n // If the breakpoint is named, the max limit is the following breakpoint - 1px.\n @else if $bp-next {\n // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n // See https://github.com/foundation/foundation-sites/issues/11313\n $bp-max: if($hidpi, $bp-next - divide(1, $std-web-dpi), -zf-bp-to-em($bp-next) - 0.00125);\n }\n }\n\n // Generate the media query string from min and max limits.\n @if $hidpi {\n // Generate values in DPI instead of DPPX for an IE9-11/Opera mini compatibility.\n // See https://caniuse.com/#feat=css-media-resolution\n $bp-min-dpi: if($bp-min, $bp-min * $std-web-dpi * 1dpi, $bp-min);\n $bp-max-dpi: if($bp-max, $bp-max * $std-web-dpi * 1dpi, $bp-max);\n @return zf-str-join(\n -zf-bp-join($bp-min, $bp-max, '-webkit-min-device-pixel-ratio', '-webkit-max-device-pixel-ratio'),\n -zf-bp-join($bp-min-dpi, $bp-max-dpi, 'min-resolution', 'max-resolution'),\n ', ');\n }\n @else {\n @return -zf-bp-join($bp-min, $bp-max);\n }\n}\n\n/// Wraps a media query around the content you put inside the mixin. This mixin accepts a number of values:\n/// - If a string is passed, the mixin will look for it in the `$breakpoints` and `$breakpoints-hidpi` maps, and use a media query there.\n/// - If a pixel value is passed, it will be converted to an em value using `$global-font-size` as the base.\n/// - If a rem value is passed, the unit will be changed to em.\n/// - If an em value is passed, the value will be used as-is.\n///\n/// If multiple values are passed, the mixin will generate a media query for each of them as described above.\n/// Since the content is duplicated for each breakpoint, this mixin should only be used with properties that\n/// change across breakpoints.\n///\n/// @param {Keyword|Number} $values... - Breakpoint name or px/rem/em value to process.\n///\n/// @output If the breakpoint is \"0px and larger\", outputs the content as-is. Otherwise, outputs the content wrapped in a media query.\n@mixin breakpoint($values...) {\n @for $i from 1 through length($values) {\n $value: nth($values, $i);\n $str: breakpoint($value);\n $bp: index($-zf-breakpoints-keys, nth($value, 1));\n $pbp: index($-zf-breakpoints-keys, $print-breakpoint);\n // Direction of media query (up, down, or only)\n $dir: if(length($value) > 1, nth($value, 2), up);\n\n $old-zf-size: null;\n\n // Make breakpoint size available as a variable\n @if global-variable-exists(-zf-size) {\n $old-zf-size: $-zf-size;\n }\n $-zf-size: nth($value, 1) !global; // get the first value to account for `only` and `down` keywords\n\n // If $str is still an empty string, no media query is needed\n @if $str == '' {\n @content;\n }\n\n // Otherwise, wrap the content in a media query\n @else {\n // For named breakpoints less than or equal to $print-breakpoint, add print to the media types\n // generate print if the breakpoint affects the print-breakpoint (or smaller).\n // This means the current condition only needs to be extended so 'down' always generates print.\n @if $bp != null and ($bp <= $pbp or $dir == down) {\n @media print, screen and #{$str} {\n @content;\n }\n }\n @else {\n @media screen and #{$str} {\n @content;\n }\n }\n }\n\n $-zf-size: $old-zf-size !global;\n }\n}\n\n/// Converts the breakpoints map to a URL-encoded string, like this: `key1=value1&key2=value2`. The value is then dropped into the CSS for a special `` tag, which is read by the Foundation JavaScript. This is how we transfer values from Sass to JavaScript, so they can be defined in one place.\n/// @access private\n///\n/// @param {Map} $map - Map to convert.\n///\n/// @returns {String} A string containing the map's contents.\n@function -zf-bp-serialize($map) {\n $str: '';\n @each $key, $value in $map {\n $str: $str + $key + '=' + -zf-bp-to-em($value) + '&';\n }\n $str: str-slice($str, 1, -2);\n\n @return $str;\n}\n\n/// Find the next key in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $key - Key to use as a starting point.\n///\n/// @returns {Mixed} The value for the key after `$key`, if `$key` was found. If `$key` was not found, or `$key` was the last value in the map, returns `null`.\n@function -zf-map-next($map, $key) {\n\n // Store the keys of the map as a list\n $values: map-keys($map);\n\n $i: 0;\n\n // If the Key Exists, Get the index of the key within the map and add 1 to it for the next breakpoint in the map\n @if (map-has-key($map, $key)) {\n $i: index($values, $key) + 1;\n }\n\n // If the key doesn't exist, or it's the last key in the map, return null\n @if ($i > length($map) or $i == 0) {\n @return null;\n }\n // Otherwise, return the value\n @else {\n @return map-get($map, nth($values, $i));\n }\n\n}\n\n/// Find the next number in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $number - Number to use as a starting point.\n///\n/// @returns {Mixed} The number following `$number`, if `$number` was found. If `$number` was not found, or `$number` was the biggest number in the map, returns `null`.\n@function -zf-map-next-number($map, $number) {\n\n $next-number: null;\n\n @each $k, $v in $map {\n @if type-of($v) == 'number' and $v > $number and ($next-number == null or $v < $next-number) {\n $next-number: $v;\n }\n }\n\n @return $next-number;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $key - Key to use as last breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-breakpoints-less-than($key) {\n $list: ();\n $found-key: false;\n\n @each $name in $-zf-breakpoints-keys {\n @if ($name == $key) {\n $found-key: true;\n }\n @if not $found-key {\n $list: append($list, $name);\n }\n }\n @return $list;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $breakpoint - a named or non-named breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-closest-named-breakpoint($breakpoint) {\n $last: $-zf-zero-breakpoint;\n $found: false;\n\n $value: unitless-calc($breakpoint, 1px);\n @each $key, $val in $breakpoints {\n @if not $found {\n @if unitless-calc($val) > $value {\n $found: true;\n } @else {\n $last: $key;\n }\n }\n }\n\n @return $last;\n}\n\n/// Get a value for a breakpoint from a responsive config map or single value.\n/// - If the config is a single value, return it regardless of `$value`.\n/// - If the config is a map and has the key `$value`, the exact breakpoint value is returned.\n/// - If the config is a map and does *not* have the breakpoint, the value matching the next lowest breakpoint in the config map is returned.\n/// @access private\n///\n/// @param {Number|Map} $map - Responsive config map or single value.\n/// @param {Keyword} $value - Breakpoint name to use.\n///\n/// @return {Mixed} The corresponding breakpoint value.\n@function -zf-get-bp-val($map, $value) {\n // If the given map is a single value, return it\n @if type-of($map) == 'number' {\n @return $map;\n }\n\n\n // Check if the breakpoint name exists globally\n @if not map-has-key($breakpoints, $value) {\n @if type-of($value) == 'number' {\n $value: -zf-closest-named-breakpoint($value);\n } @else {\n @return null;\n }\n }\n // Check if the breakpoint name exists in the local config map\n @else if map-has-key($map, $value) {\n // If it does, just return the value\n @return map-get($map, $value);\n }\n // Otherwise, find the next lowest breakpoint and return that value\n @else {\n $anchor: null;\n $found: false;\n\n @each $key, $val in $breakpoints {\n @if not $found {\n @if map-has-key($map, $key) {\n $anchor: $key;\n }\n @if $key == $value {\n $found: true;\n }\n }\n }\n\n @return map-get($map, $anchor);\n }\n}\n\n/// Return the best breakpoint to use according to the calling context. It returns in order:\n/// 1. the given `$value` argument if it is not null.\n/// 2. the global breakpoint context `$-zf-size` if it is not null (like if called inside then `breakpoint()` mixin)\n/// 3. the given `$default` argument.\n/// @access private\n///\n/// @param {Keyword} $value [null] - Breakpoint to use in priority if non-null.\n/// @param {Keyword} $default [null] - Breakpoint to use by default if no other value can be used.\n///\n/// @return {Keyword} The resolved breakpoint.\n@function -zf-current-breakpoint($value: null, $default: null) {\n @if ($value != null) {\n @return $value;\n }\n @else if (variable-exists(-zf-size) and type-of($-zf-size) != 'number') and $-zf-size != null {\n @return $-zf-size;\n }\n @else {\n @return $default;\n }\n}\n\n/// Return media query string from the given min and/or max limits.\n/// If a limit is equal to `null` or `0`, it is ignored.\n/// @access private\n///\n/// @param {Number} $min [0] - Min media query limit.\n/// @param {Number} $max [0] - Max media query limit.\n/// @param {String} $min-name ['min-width'] - Name of the min media query limit.\n/// @param {String} $delimiter ['max-width'] - Name of the max media query limit.\n///\n/// @returns {String} Media Query string.\n@function -zf-bp-join(\n $min: 0,\n $max: 0,\n $min-name: 'min-width',\n $max-name: 'max-width'\n) {\n @return zf-str-join(\n if($min and $min > 0, '(#{$min-name}: #{$min})', null),\n if($max and $max > 0, '(#{$max-name}: #{$max})', null),\n ' and ');\n}\n\n$small-up: '';\n$small-only: '';\n\n@if map-has-key($breakpoints, small) {\n $small-up: screen;\n $small-only: unquote('screen and #{breakpoint(small only)}');\n}\n\n$medium-up: '';\n$medium-only: '';\n\n@if map-has-key($breakpoints, medium) {\n $medium-up: unquote('screen and #{breakpoint(medium)}');\n $medium-only: unquote('screen and #{breakpoint(medium only)}');\n}\n\n$large-up: '';\n$large-only: '';\n\n@if map-has-key($breakpoints, large) {\n $large-up: unquote('screen and #{breakpoint(large)}');\n $large-only: unquote('screen and #{breakpoint(large only)}');\n}\n\n$xlarge-up: '';\n$xlarge-only: '';\n\n@if map-has-key($breakpoints, xlarge) {\n $xlarge-up: unquote('screen and #{breakpoint(xlarge)}');\n $xlarge-only: unquote('screen and #{breakpoint(xlarge only)}');\n}\n\n$xxlarge-up: '';\n\n@if map-has-key($breakpoints, xxlarge) {\n $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group reveal\n////\n\n/// Default background color of a modal.\n/// @type Color\n$reveal-background: $white !default;\n\n/// Default width of a modal, with no class applied.\n/// @type Number\n$reveal-width: 600px !default;\n\n/// Default maximum width of a modal.\n/// @type Number\n$reveal-max-width: $global-width !default;\n\n/// Default padding inside a modal.\n/// @type Number\n$reveal-padding: $global-padding !default;\n\n/// Default border around a modal.\n/// @type Number\n$reveal-border: 1px solid $medium-gray !default;\n\n/// Default radius for modal.\n/// @type Number\n$reveal-radius: $global-radius !default;\n\n/// z-index for modals. The overlay uses this value, while the modal itself uses this value plus one.\n/// @type Number\n$reveal-zindex: 1005 !default;\n\n/// Background color of modal overlays.\n/// @type Color\n$reveal-overlay-background: rgba($black, 0.45) !default;\n\n\n// Placeholder selector for medium-and-up modals\n// Prevents duplicate CSS when defining multiple Reveal sizes\n// This should be in the same breakpoint then `@mixin reveal-modal-width`\n@include breakpoint(medium) {\n %reveal-centered {\n right: auto;\n left: auto;\n margin: 0 auto;\n }\n}\n\n\n/// Adds styles for a modal overlay.\n/// @param {Color} $background [$reveal-overlay-background] - Background color of the overlay.\n@mixin reveal-overlay($background: $reveal-overlay-background) {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: $reveal-zindex;\n\n display: none;\n background-color: $background;\n overflow-y: auto;\n -webkit-overflow-scrolling: touch;\n}\n\n/// Adds base styles for a modal.\n@mixin reveal-modal-base {\n @include disable-mouse-outline;\n z-index: $reveal-zindex + 1;\n // Workaround android browser z-index bug\n backface-visibility: hidden;\n\n display: none;\n padding: $reveal-padding;\n\n border: $reveal-border;\n border-radius: $reveal-radius;\n background-color: $reveal-background;\n\n @include breakpoint(medium) {\n min-height: 0;\n }\n\n // Make sure rows don't have a min-width on them\n .column {\n min-width: 0;\n }\n\n // Strip margins from the last item in the modal\n > :last-child {\n margin-bottom: 0;\n }\n}\n\n/// Adjusts the width of a modal.\n/// @param {Number} $width - Width of the modal. Generally a percentage.\n/// @param {Number} $max-width [$reveal-max-width] - Maximum width of the modal.\n@mixin reveal-modal-width(\n $width: $reveal-width,\n $max-width: $reveal-max-width\n) {\n // Extends must be made outside of breakpoints for compatibility with newer Sass versions (libsass v3.5)\n @extend %reveal-centered;\n @include breakpoint(medium) {\n width: $width;\n max-width: $max-width;\n }\n}\n\n/// Creates a full-screen modal, which stretches the full width and height of the window.\n@mixin reveal-modal-fullscreen {\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n\n width: 100%;\n max-width: none;\n height: 100%;\n min-height: 100%;\n margin-left: 0;\n\n border: 0;\n border-radius: 0;\n}\n\n@mixin foundation-reveal {\n\n /// Disables the scroll when Reveal is shown to prevent the background from shifting\n html.is-reveal-open {\n position: fixed;\n width: 100%;\n overflow-y: hidden;\n\n &.zf-has-scroll {\n overflow-y: scroll;\n -webkit-overflow-scrolling: touch;\n }\n\n body { // sass-lint:disable-line no-qualifying-elements\n overflow-y: hidden;\n }\n }\n\n // Overlay\n .reveal-overlay {\n @include reveal-overlay;\n }\n\n // Modal container\n .reveal {\n @include reveal-modal-base;\n @include reveal-modal-width($reveal-width);\n position: relative;\n top: 100px;\n margin-right: auto;\n margin-left: auto;\n overflow-y: auto;\n -webkit-overflow-scrolling: touch;\n\n // Remove padding\n &.collapse {\n padding: 0;\n }\n\n // Sizing classes\n &.tiny { @include reveal-modal-width(30%); }\n &.small { @include reveal-modal-width(50%); }\n &.large { @include reveal-modal-width(90%); }\n\n // Full-screen mode\n &.full {\n @include reveal-modal-fullscreen;\n }\n\n @include breakpoint($-zf-zero-breakpoint only) {\n @include reveal-modal-fullscreen;\n }\n\n &.without-overlay {\n position: fixed;\n }\n }\n}\n","// sass-lint:disable no-vendor-prefixes\n\n@mixin foundation-normalize() {\n /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\n\n // Document\n // ==========================================================================\n\n // 1. Correct the line height in all browsers.\n // 2. Prevent adjustments of font size after orientation changes in iOS.\n\n html {\n line-height: 1.15; // 1\n -webkit-text-size-adjust: 100%; // 2\n }\n\n // Sections\n // ==========================================================================\n\n // Remove the margin in all browsers.\n\n body {\n margin: 0;\n }\n\n // Correct the font size and margin on `h1` elements within `section` and\n // `article` contexts in Chrome, Firefox, and Safari.\n\n h1 {\n font-size: 2em;\n margin: 0.67em 0;\n }\n\n // Grouping content\n // ==========================================================================\n\n // 1. Add the correct box sizing in Firefox.\n // 2. Show the overflow in Edge and IE.\n\n hr {\n box-sizing: content-box; // 1\n height: 0; // 1\n overflow: visible; // 2\n }\n\n // 1. Correct the inheritance and scaling of font size in all browsers.\n // 2. Correct the odd `em` font sizing in all browsers.\n\n pre {\n font-family: monospace, monospace; // 1\n font-size: 1em; // 2\n }\n\n // Text-level semantics\n // ==========================================================================\n\n // Remove the gray background on active links in IE 10.\n\n a {\n background-color: transparent;\n }\n\n // 1. Remove the bottom border in Chrome 57-\n // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n\n abbr[title] {\n border-bottom: 0; // 1\n text-decoration: underline dotted; // 2\n }\n\n // Add the correct font weight in Chrome, Edge, and Safari.\n\n b,\n strong {\n font-weight: bolder;\n }\n\n // 1. Correct the inheritance and scaling of font size in all browsers.\n // 2. Correct the odd `em` font sizing in all browsers.\n\n code,\n kbd,\n samp {\n font-family: monospace, monospace; // 1\n font-size: 1em; // 2\n }\n\n // Add the correct font size in all browsers.\n\n small {\n font-size: 80%;\n }\n\n // Prevent `sub` and `sup` elements from affecting the line height in\n // all browsers.\n\n sub,\n sup {\n font-size: 75%;\n line-height: 0;\n position: relative;\n vertical-align: baseline;\n }\n\n sub {\n bottom: -0.25em;\n }\n\n sup {\n top: -0.5em;\n }\n\n // Embedded content\n // ==========================================================================\n\n // Remove the border on images inside links in IE 10.\n\n img {\n border-style: none;\n }\n\n // Forms\n // ==========================================================================\n\n // 1. Change the font styles in all browsers.\n // 2. Remove the margin in Firefox and Safari.\n\n button,\n input,\n optgroup,\n select,\n textarea {\n font-family: inherit; // 1\n font-size: 100%; // 1\n line-height: 1.15; // 1\n margin: 0; // 2\n }\n\n // Show the overflow in IE.\n // 1. Show the overflow in Edge.\n\n button,\n input { // 1\n overflow: visible;\n }\n\n // Remove the inheritance of text transform in Edge, Firefox, and IE.\n // 1. Remove the inheritance of text transform in Firefox.\n\n button,\n select { // 1\n text-transform: none;\n }\n\n // Correct the inability to style clickable types in iOS and Safari.\n\n button,\n [type=\"button\"],\n [type=\"reset\"],\n [type=\"submit\"] {\n -webkit-appearance: button;\n }\n\n // Remove the inner border and padding in Firefox.\n\n button::-moz-focus-inner,\n [type=\"button\"]::-moz-focus-inner,\n [type=\"reset\"]::-moz-focus-inner,\n [type=\"submit\"]::-moz-focus-inner {\n border-style: none;\n padding: 0;\n }\n\n // Restore the focus styles unset by the previous rule.\n\n button:-moz-focusring,\n [type=\"button\"]:-moz-focusring,\n [type=\"reset\"]:-moz-focusring,\n [type=\"submit\"]:-moz-focusring {\n outline: 1px dotted ButtonText;\n }\n\n // Correct the padding in Firefox.\n\n fieldset {\n padding: 0.35em 0.75em 0.625em;\n }\n\n // 1. Correct the text wrapping in Edge and IE.\n // 2. Correct the color inheritance from `fieldset` elements in IE.\n // 3. Remove the padding so developers are not caught out when they zero out\n // `fieldset` elements in all browsers.\n\n legend {\n box-sizing: border-box; // 1\n color: inherit; // 2\n display: table; // 1\n max-width: 100%; // 1\n padding: 0; // 3\n white-space: normal; // 1\n }\n\n // Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\n progress {\n vertical-align: baseline;\n }\n\n // Remove the default vertical scrollbar in IE 10+.\n\n textarea {\n overflow: auto;\n }\n\n // 1. Add the correct box sizing in IE 10.\n // 2. Remove the padding in IE 10.\n\n [type=\"checkbox\"],\n [type=\"radio\"] {\n box-sizing: border-box; // 1\n padding: 0; // 2\n }\n\n // Correct the cursor style of increment and decrement buttons in Chrome.\n\n [type=\"number\"]::-webkit-inner-spin-button,\n [type=\"number\"]::-webkit-outer-spin-button {\n height: auto;\n }\n\n // 1. Correct the odd appearance in Chrome and Safari.\n // 2. Correct the outline style in Safari.\n\n [type=\"search\"] {\n -webkit-appearance: textfield; // 1\n outline-offset: -2px; // 2\n }\n\n // Remove the inner padding in Chrome and Safari on macOS.\n\n [type=\"search\"]::-webkit-search-decoration {\n -webkit-appearance: none;\n }\n\n // 1. Correct the inability to style clickable types in iOS and Safari.\n // 2. Change font properties to `inherit` in Safari.\n\n ::-webkit-file-upload-button {\n -webkit-appearance: button; // 1\n font: inherit; // 2\n }\n\n // Interactive\n // ==========================================================================\n\n // Add the correct display in Edge, IE 10+, and Firefox.\n\n details {\n display: block;\n }\n\n // Add the correct display in all browsers.\n\n summary {\n display: list-item;\n }\n\n // Misc\n // ==========================================================================\n\n // Add the correct display in IE 10+.\n\n template {\n display: none;\n }\n\n // Add the correct display in IE 10.\n\n [hidden] {\n display: none;\n }\n\n // Disable outline when intent is clearly mouse and touch\n [data-whatintent=\"mouse\"],\n [data-whatintent=\"touch\"],\n [data-whatinput=\"mouse\"],\n [data-whatinput=\"touch\"] {\n *, *:focus {\n outline: none;\n }\n }\n\n // Disable iOS callouts when draggable is false\n [draggable=false] {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\n\n@import 'util/util';\n\n/// Font size attribute applied to `` and ``. We use 100% by default so the value is inherited from the user's browser settings.\n/// @type Number\n$global-font-size: 100% !default;\n\n/// Global width of your site. Used by the grid to determine row width.\n/// @type Number\n$global-width: rem-calc(1200) !default;\n\n/// Default line height for all type. `$global-lineheight` is 24px while `$global-font-size` is 16px\n/// @type Number\n$global-lineheight: 1.5 !default;\n\n/// Colors used for buttons, callouts, links, etc. There must always be a color called `primary`.\n/// @type Map\n$foundation-palette: (\n \"primary\": #1779ba,\n \"secondary\": #767676,\n \"success\": #3adb76,\n \"warning\": #ffae00,\n \"alert\": #cc4b37,\n) !default;\n\n/// Color used for light gray UI items.\n/// @type Color\n$light-gray: #e6e6e6 !default;\n\n/// Color used for medium gray UI items.\n/// @type Color\n$medium-gray: #cacaca !default;\n\n/// Color used for dark gray UI items.\n/// @type Color\n$dark-gray: #8a8a8a !default;\n\n/// Color used for black ui items.\n/// @type Color\n$black: #0a0a0a !default;\n\n/// Color used for white ui items.\n/// @type Color\n$white: #fefefe !default;\n\n/// Background color of the body.\n/// @type Color\n$body-background: $white !default;\n\n/// Text color of the body.\n/// @type Color\n$body-font-color: $black !default;\n\n/// Font stack of the body.\n/// @type List\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif !default;\n\n/// Set to `true` to enable safe padding on the body for non-rectangular devices (i.e. phones with notches)\n/// @type Boolean\n$body-safe-padding: false !default;\n\n/// Set to `true` to enable antialiased type, using the `-webkit-font-smoothing` and `-moz-osx-font-smoothing` CSS properties.\n/// @type Boolean\n$body-antialiased: true !default;\n\n/// Global value used for margin on components.\n/// @type Number\n$global-margin: 1rem !default;\n\n/// Global value used for padding on components.\n/// @type Number\n$global-padding: 1rem !default;\n\n/// Global value used for positioning on components.\n/// @type Number\n$global-position: 1rem !default;\n\n/// Global font weight used for normal type.\n/// @type Keyword | Number\n$global-weight-normal: normal !default;\n\n/// Global font weight used for bold type.\n/// @type Keyword | Number\n$global-weight-bold: bold !default;\n\n/// Global value used for all elements that have a border radius.\n/// @type Number\n$global-radius: 0 !default;\n\n/// Global value used for all menu styles. Can be overwritten at individual menu component level.\n/// @type Number\n$global-menu-padding: 0.7rem 1rem !default;\n\n/// Global value used for all menu styles. Nested margin for submenu.\n$global-menu-nested-margin: 1rem !default;\n\n/// Sets the text direction of the CSS. Can be either `ltr` or `rtl`.\n/// @type Keyword\n$global-text-direction: ltr !default;\n\n/// Enables flexbox for components that support it.\n/// @type Boolean\n$global-flexbox: true !default;\n\n/// Enabled responsive breakpoints for prototypes if applicable\n/// @type Boolean\n$global-prototype-breakpoints: false !default;\n\n/// Button cursor's value, `auto` by default\n/// @type Keyword\n$global-button-cursor: auto !default;\n\n@if not map-has-key($foundation-palette, primary) {\n @error 'In $foundation-palette, you must have a color named \"primary\".';\n}\n\n// Internal variables used for text direction\n$global-left: if($global-text-direction == rtl, right, left);\n$global-right: if($global-text-direction == rtl, left, right);\n\n// Internal variable that contains the flex justifying options\n$-zf-flex-justify: -zf-flex-justify($global-text-direction);\n\n/// Global tolerance for color pick contrast.\n/// @type Number\n$global-color-pick-contrast-tolerance: 0 !default;\n\n// Internal variables used for colors\n@include add-foundation-colors;\n\n@mixin foundation-global-styles {\n @include foundation-normalize;\n\n // These styles are applied to a tag, which is read by the Foundation JavaScript\n .foundation-mq {\n font-family: '#{-zf-bp-serialize($breakpoints)}';\n }\n\n html {\n box-sizing: border-box;\n font-size: $global-font-size;\n }\n\n // Set box-sizing globally to handle padding and border widths\n *,\n *::before,\n *::after {\n box-sizing: inherit;\n }\n\n // Default body styles\n body {\n margin: 0;\n padding: 0;\n\n @if ($body-safe-padding) {\n // using environment variables to account for non-rectangular displays e.g. phones with notches\n padding-top: env(safe-area-inset-top);\n padding-right: env(safe-area-inset-right);\n padding-bottom: env(safe-area-inset-bottom);\n padding-left: env(safe-area-inset-left);\n }\n\n background: $body-background;\n\n font-family: $body-font-family;\n font-weight: $global-weight-normal;\n line-height: $global-lineheight;\n color: $body-font-color;\n\n @if ($body-antialiased) {\n -webkit-font-smoothing: antialiased; // sass-lint:disable-line no-vendor-prefixes\n -moz-osx-font-smoothing: grayscale; // sass-lint:disable-line no-vendor-prefixes\n }\n }\n\n img {\n // Get rid of gap under images by making them display: inline-block; by default\n display: inline-block;\n vertical-align: middle;\n\n // Grid defaults to get images and embeds to work properly\n max-width: 100%;\n height: auto;\n -ms-interpolation-mode: bicubic;\n }\n\n // Make sure textarea takes on height automatically\n textarea {\n height: auto;\n min-height: 50px;\n border-radius: $global-radius;\n }\n\n // Make select elements are 100% width by default\n select {\n box-sizing: border-box;\n width: 100%;\n border-radius: $global-radius;\n }\n\n // Styles Google Maps and MapQuest embeds properly\n // sass-lint:disable-line no-ids\n .map_canvas,\n .mqa-display {\n img,\n embed,\n object {\n max-width: none !important;\n }\n }\n\n // Reset '); @@ -3691,7 +3345,6 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { 'id': linkId }); } - $sub.attr({ 'aria-labelledby': linkId, 'aria-hidden': !isActive, @@ -3700,28 +3353,24 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { }); }); var initPanes = this.$element.find('.is-active'); - if (initPanes.length) { initPanes.each(function () { _this.down($(this)); }); } - this._events(); } + /** * Adds event handlers for items within the menu. * @private */ - }, { key: "_events", value: function _events() { var _this = this; - this.$element.find('li').each(function () { var $submenu = $(this).children('[data-submenu]'); - if ($submenu.length) { if (_this.options.submenuToggle) { $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function () { @@ -3730,27 +3379,24 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { } else { $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) { e.preventDefault(); - _this.toggle($submenu); }); } } }).on('keydown.zf.accordionMenu', function (e) { var $element = $(this), - $elements = $element.parent('ul').children('li'), - $prevElement, - $nextElement, - $target = $element.children('[data-submenu]'); + $elements = $element.parent('ul').children('li'), + $prevElement, + $nextElement, + $target = $element.children('[data-submenu]'); $elements.each(function (i) { if ($(this).is($element)) { $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first(); $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first(); - if ($(this).children('[data-submenu]:visible').length) { // has open sub menu $nextElement = $element.find('li:first-child').find('a').first(); } - if ($(this).is(':first-child')) { // is first element of sub menu $prevElement = $element.parents('li').first().find('a').first(); @@ -3758,12 +3404,10 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { // if previous element has open sub menu $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first(); } - if ($(this).is(':last-child')) { // is last element of sub menu $nextElement = $element.parents('li').first().next('li').find('a').first(); } - return; } }); @@ -3771,7 +3415,6 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { open: function open() { if ($target.is(':hidden')) { _this.down($target); - $target.find('li').first().find('a').first().focus(); } }, @@ -3782,7 +3425,6 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { } else if ($element.parent('[data-submenu]').length) { // close currently open sub _this.up($element.parent('[data-submenu]')); - $element.parents('li').first().find('a').first().focus(); } }, @@ -3798,10 +3440,8 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { if (_this.options.submenuToggle) { return false; } - if ($element.children('[data-submenu]').length) { _this.toggle($element.children('[data-submenu]')); - return true; } }, @@ -3816,32 +3456,32 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { }); }); //.attr('tabindex', 0); } + /** * Closes all panes of the menu. * @function */ - }, { key: "hideAll", value: function hideAll() { this.up(this.$element.find('[data-submenu]')); } + /** * Opens all panes of the menu. * @function */ - }, { key: "showAll", value: function showAll() { this.down(this.$element.find('[data-submenu]')); } + /** * Toggles the open/close state of a submenu. * @function * @param {jQuery} $target - the submenu to toggle */ - }, { key: "toggle", value: function toggle($target) { @@ -3853,32 +3493,29 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { } } } + /** * Opens the sub-menu defined by `$target`. * @param {jQuery} $target - Sub-menu to open. * @fires AccordionMenu#down */ - }, { key: "down", value: function down($target) { var _this2 = this; - // If having multiple submenus active is disabled, close all the submenus // that are not parents or children of the targeted submenu. if (!this.options.multiOpen) { // The "branch" of the targetted submenu, from the component root to // the active submenus nested in it. - var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch. - + var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); + // All the active submenus that are not in the branch. var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch); this.up($othersActiveSubmenus); } - $target.addClass('is-active').attr({ 'aria-hidden': false }); - if (this.options.submenuToggle) { $target.prev('.submenu-toggle').attr({ 'aria-expanded': true @@ -3888,7 +3525,6 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { 'aria-expanded': true }); } - $target.slideDown(this.options.slideSpeed, function () { /** * Fires when the menu is done opening. @@ -3897,28 +3533,25 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { _this2.$element.trigger('down.zf.accordionMenu', [$target]); }); } + /** * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well. * @param {jQuery} $target - Sub-menu to close. * @fires AccordionMenu#up */ - }, { key: "up", value: function up($target) { var _this3 = this; - var $submenus = $target.find('[data-submenu]'); var $allmenus = $target.add($submenus); $submenus.slideUp(0); $allmenus.removeClass('is-active').attr('aria-hidden', true); - if (this.options.submenuToggle) { $allmenus.prev('.submenu-toggle').attr('aria-expanded', false); } else { $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false); } - $target.slideUp(this.options.slideSpeed, function () { /** * Fires when the menu is done collapsing up. @@ -3927,30 +3560,26 @@ var AccordionMenu = /*#__PURE__*/function (_Plugin) { _this3.$element.trigger('up.zf.accordionMenu', [$target]); }); } + /** * Destroys an instance of accordion menu. * @fires AccordionMenu#destroyed */ - }, { key: "_destroy", value: function _destroy() { this.$element.find('[data-submenu]').slideDown(0).css('display', ''); this.$element.find('a').off('click.zf.accordionMenu'); this.$element.find('[data-is-parent-link]').detach(); - if (this.options.submenuToggle) { this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle'); this.$element.find('.submenu-toggle').remove(); } - Nest.Burn(this.$element, 'accordion'); } }]); - return AccordionMenu; }(Plugin); - AccordionMenu.defaults = { /** * Adds the parent link to the submenu. @@ -3959,7 +3588,6 @@ AccordionMenu.defaults = { * @default false */ parentLink: false, - /** * Amount of time to animate the opening of a submenu in ms. * @option @@ -3967,21 +3595,18 @@ AccordionMenu.defaults = { * @default 250 */ slideSpeed: 250, - /** * Adds a separate submenu toggle button. This allows the parent item to have a link. * @option * @example true */ submenuToggle: false, - /** * The text used for the submenu toggle if enabled. This is used for screen readers only. * @option * @example true */ submenuToggleText: 'Toggle menu', - /** * Allow the menu to have multiple open panes. * @option @@ -3998,18 +3623,13 @@ AccordionMenu.defaults = { * @requires foundation.util.nest * @requires foundation.util.box */ - var Drilldown = /*#__PURE__*/function (_Plugin) { _inherits(Drilldown, _Plugin); - var _super = _createSuper(Drilldown); - function Drilldown() { _classCallCheck(this, Drilldown); - return _super.apply(this, arguments); } - _createClass(Drilldown, [{ key: "_setup", value: @@ -4026,7 +3646,6 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { this.className = 'Drilldown'; // ie9 back compat this._init(); - Keyboard.register('Drilldown', { 'ENTER': 'open', 'SPACE': 'open', @@ -4037,37 +3656,34 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { 'ESCAPE': 'close' }); } + /** * Initializes the drilldown by creating jQuery collections of elements * @private */ - }, { key: "_init", value: function _init() { Nest.Feather(this.$element, 'drilldown'); - if (this.options.autoApplyClass) { this.$element.addClass('drilldown'); } - this.$element.attr({ 'aria-multiselectable': false }); this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a'); this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group'); - this.$menuItems = this.$element.find('li').not('.js-drilldown-back').find('a'); // Set the main menu as current by default (unless a submenu is selected) - // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu + this.$menuItems = this.$element.find('li').not('.js-drilldown-back').find('a'); + // Set the main menu as current by default (unless a submenu is selected) + // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu this.$currentMenu = this.$element; this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')); - this._prepareMenu(); - this._registerEvents(); - this._keyboardEvents(); } + /** * prepares drilldown menu by setting attributes to links and elements * sets a min height to prevent content jumping @@ -4075,67 +3691,56 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { * @private * @function */ - }, { key: "_prepareMenu", value: function _prepareMenu() { - var _this = this; // if(!this.options.holdOpen){ + var _this = this; + // if(!this.options.holdOpen){ // this._menuLinkEvents(); // } - - this.$submenuAnchors.each(function () { var $link = $(this); var $sub = $link.parent(); - if (_this.options.parentLink) { $link.clone().prependTo($sub.children('[data-submenu]')).wrap('
  • '); } - $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0); $link.children('[data-submenu]').attr({ 'aria-hidden': true, 'tabindex': 0, 'role': 'group' }); - _this._events($link); }); this.$submenus.each(function () { var $menu = $(this), - $back = $menu.find('.js-drilldown-back'); - + $back = $menu.find('.js-drilldown-back'); if (!$back.length) { switch (_this.options.backButtonPosition) { case "bottom": $menu.append(_this.options.backButton); break; - case "top": $menu.prepend(_this.options.backButton); break; - default: console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'"); } } - _this._back($menu); }); this.$submenus.addClass('invisible'); - if (!this.options.autoHeight) { this.$submenus.addClass('drilldown-submenu-cover-previous'); - } // create a wrapper on element if it doesn't exist. - + } + // create a wrapper on element if it doesn't exist. if (!this.$element.parent().hasClass('is-drilldown')) { this.$wrapper = $(this.options.wrapper).addClass('is-drilldown'); if (this.options.animateHeight) this.$wrapper.addClass('animate-height'); this.$element.wrap(this.$wrapper); - } // set wrapper - - + } + // set wrapper this.$wrapper = this.$element.parent(); this.$wrapper.css(this._getMaxDims()); } @@ -4145,54 +3750,49 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { this.$wrapper.css({ 'max-width': 'none', 'min-height': 'none' - }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths - + }); + // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths this.$wrapper.css(this._getMaxDims()); } + /** * Adds event handlers to elements in the menu. * @function * @private * @param {jQuery} $elem - the current menu item to add handlers to. */ - }, { key: "_events", value: function _events($elem) { var _this = this; - $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) { if ($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) { e.preventDefault(); - } // if(e.target !== e.currentTarget.firstElementChild){ + } + + // if(e.target !== e.currentTarget.firstElementChild){ // return false; // } - - _this._show($elem.parent('li')); - if (_this.options.closeOnClick) { var $body = $('body'); $body.off('.zf.drilldown').on('click.zf.drilldown', function (ev) { if (ev.target === _this.$element[0] || $.contains(_this.$element[0], ev.target)) { return; } - ev.preventDefault(); - _this._hideAll(); - $body.off('.zf.drilldown'); }); } }); } + /** * Adds event handlers to the menu element. * @function * @private */ - }, { key: "_registerEvents", value: function _registerEvents() { @@ -4200,22 +3800,20 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { this._bindHandler = this._scrollTop.bind(this); this.$element.on('open.zf.drilldown hide.zf.drilldown close.zf.drilldown closed.zf.drilldown', this._bindHandler); } - this.$element.on('mutateme.zf.trigger', this._resize.bind(this)); } + /** * Scroll to Top of Element or data-scroll-top-element * @function * @fires Drilldown#scrollme */ - }, { key: "_scrollTop", value: function _scrollTop() { var _this = this; - var $scrollTopElement = _this.options.scrollTopElement !== '' ? $(_this.options.scrollTopElement) : _this.$element, - scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10); + scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10); $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing, function () { @@ -4226,21 +3824,20 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { if (this === $('html')[0]) _this.$element.trigger('scrollme.zf.drilldown'); }); } + /** * Adds keydown event listener to `li`'s in the menu. * @private */ - }, { key: "_keyboardEvents", value: function _keyboardEvents() { var _this = this; - this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) { var $element = $(this), - $elements = $element.parent('li').parent('ul').children('li').children('a'), - $prevElement, - $nextElement; + $elements = $element.parent('li').parent('ul').children('li').children('a'), + $prevElement, + $nextElement; $elements.each(function (i) { if ($(this).is($element)) { $prevElement = $elements.eq(Math.max(0, i - 1)); @@ -4252,7 +3849,6 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { next: function next() { if ($element.is(_this.$submenuAnchors)) { _this._show($element.parent('li')); - $element.parent('li').one(transitionend($element), function () { $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus(); }); @@ -4261,7 +3857,6 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { }, previous: function previous() { _this._hide($element.parent('li').parent('ul')); - $element.parent('li').parent('ul').one(transitionend($element), function () { setTimeout(function () { $element.parent('li').parent('ul').parent('li').children('a').first().focus(); @@ -4270,20 +3865,19 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { return true; }, up: function up() { - $prevElement.focus(); // Don't tap focus on first element in root ul - + $prevElement.focus(); + // Don't tap focus on first element in root ul return !$element.is(_this.$element.find('> li:first-child > a')); }, down: function down() { - $nextElement.focus(); // Don't tap focus on last element in root ul - + $nextElement.focus(); + // Don't tap focus on last element in root ul return !$element.is(_this.$element.find('> li:last-child > a')); }, close: function close() { // Don't close on element in root ul if (!$element.is(_this.$element.find('> li > a'))) { _this._hide($element.parent().parent()); - $element.parent().parent().siblings('a').focus(); } }, @@ -4294,7 +3888,6 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { } else if (!$element.is(_this.$menuItems)) { // not menu item means back button _this._hide($element.parent('li').parent('ul')); - $element.parent('li').parent('ul').one(transitionend($element), function () { setTimeout(function () { $element.parent('li').parent('ul').parent('li').children('a').first().focus(); @@ -4304,7 +3897,6 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item _this._show($element.parent('li')); - $element.parent('li').one(transitionend($element), function () { $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus(); }); @@ -4319,64 +3911,59 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { }); }); // end keyboardAccess } + /** * Closes all open elements, and returns to root menu. * @function * @fires Drilldown#close * @fires Drilldown#closed */ - }, { key: "_hideAll", value: function _hideAll() { var _this2 = this; - var $elem = this.$element.find('.is-drilldown-submenu.is-active'); $elem.addClass('is-closing'); $elem.parent().closest('ul').removeClass('invisible'); - if (this.options.autoHeight) { var calcHeight = $elem.parent().closest('ul').data('calcHeight'); this.$wrapper.css({ height: calcHeight }); } + /** * Fires when the menu is closing. * @event Drilldown#close */ - - this.$element.trigger('close.zf.drilldown'); $elem.one(transitionend($elem), function () { $elem.removeClass('is-active is-closing'); + /** * Fires when the menu is fully closed. * @event Drilldown#closed */ - _this2.$element.trigger('closed.zf.drilldown'); }); } + /** * Adds event listener for each `back` button, and closes open menus. * @function * @fires Drilldown#back * @param {jQuery} $elem - the current sub-menu to add `back` event. */ - }, { key: "_back", value: function _back($elem) { var _this = this; - $elem.off('click.zf.drilldown'); $elem.children('.js-drilldown-back').on('click.zf.drilldown', function () { - _this._hide($elem); // If there is a parent submenu, call show - + _this._hide($elem); + // If there is a parent submenu, call show var parentSubMenu = $elem.parent('li').parent('ul').parent('li'); - if (parentSubMenu.length) { _this._show(parentSubMenu); } else { @@ -4384,23 +3971,23 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { } }); } + /** * Adds event listener to menu items w/o submenus to close open menus on click. * @function * @private */ - }, { key: "_menuLinkEvents", value: function _menuLinkEvents() { var _this = this; - this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function () { setTimeout(function () { _this._hideAll(); }, 0); }); } + /** * Sets the CSS classes for submenu to show it. * @function @@ -4408,17 +3995,16 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { * @param {jQuery} $elem - the target submenu (`ul` tag) * @param {boolean} trigger - trigger drilldown event */ - }, { key: "_setShowSubMenuClasses", value: function _setShowSubMenuClasses($elem, trigger) { $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false); $elem.parent('li').attr('aria-expanded', true); - if (trigger === true) { this.$element.trigger('open.zf.drilldown', [$elem]); } } + /** * Sets the CSS classes for submenu to hide it. * @function @@ -4426,17 +4012,16 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { * @param {jQuery} $elem - the target submenu (`ul` tag) * @param {boolean} trigger - trigger drilldown event */ - }, { key: "_setHideSubMenuClasses", value: function _setHideSubMenuClasses($elem, trigger) { $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true); $elem.parent('li').attr('aria-expanded', false); - if (trigger === true) { $elem.trigger('hide.zf.drilldown', [$elem]); } } + /** * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible. * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it. @@ -4445,38 +4030,40 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { * @param {jQuery} $elem - the target (sub)menu (`ul` tag) * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused */ - }, { key: "_showMenu", value: function _showMenu($elem, autoFocus) { - var _this = this; // Reset drilldown - + var _this = this; + // Reset drilldown var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]'); $expandedSubmenus.each(function () { _this._setHideSubMenuClasses($(this)); - }); // Save the menu as the currently displayed one. + }); - this.$currentMenu = $elem; // If target menu is root, focus first link & exit + // Save the menu as the currently displayed one. + this.$currentMenu = $elem; + // If target menu is root, focus first link & exit if ($elem.is('[data-drilldown]')) { if (autoFocus === true) $elem.find('li > a').first().focus(); if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight')); return; - } // Find all submenus on way to root incl. the element itself - + } - var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root + // Find all submenus on way to root incl. the element itself + var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); + // Open target menu and all submenus on its way to root $submenus.each(function (index) { // Update height of first child (target menu) if autoHeight option true if (index === 0 && _this.options.autoHeight) { _this.$wrapper.css('height', $(this).data('calcHeight')); } + var isLastChild = index === $submenus.length - 1; - var isLastChild = index === $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link + // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link // Last child makes sure the event gets always triggered even if going through several menus - if (isLastChild === true) { $(this).one(transitionend($(this)), function () { if (autoFocus === true) { @@ -4484,49 +4071,48 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { } }); } - _this._setShowSubMenuClasses($(this), isLastChild); }); } + /** * Opens a submenu. * @function * @fires Drilldown#open * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag. */ - }, { key: "_show", value: function _show($elem) { var $submenu = $elem.children('[data-submenu]'); $elem.attr('aria-expanded', true); - this.$currentMenu = $submenu; //hide drilldown parent menu when submenu is open - // this removes it from the dom so that the tab key will take the user to the next visible element + this.$currentMenu = $submenu; - $elem.parent().closest('ul').addClass('invisible'); // add visible class to submenu to override invisible class above + //hide drilldown parent menu when submenu is open + // this removes it from the dom so that the tab key will take the user to the next visible element + $elem.parent().closest('ul').addClass('invisible'); + // add visible class to submenu to override invisible class above $submenu.addClass('is-active visible').removeClass('invisible').attr('aria-hidden', false); - if (this.options.autoHeight) { this.$wrapper.css({ height: $submenu.data('calcHeight') }); } + /** * Fires when the submenu has opened. * @event Drilldown#open */ - - this.$element.trigger('open.zf.drilldown', [$elem]); } + /** * Hides a submenu * @function * @fires Drilldown#hide * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag. */ - }, { key: "_hide", value: function _hide($elem) { @@ -4544,28 +4130,26 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { * Fires when the submenu has closed. * @event Drilldown#hide */ - $elem.trigger('hide.zf.drilldown', [$elem]); } + /** * Iterates through the nested menus to calculate the min-height, and max-width for the menu. * Prevents content jumping. * @function * @private */ - }, { key: "_getMaxDims", value: function _getMaxDims() { var maxHeight = 0, - result = {}, - _this = this; // Recalculate menu heights and total max height - + result = {}, + _this = this; + // Recalculate menu heights and total max height this.$submenus.add(this.$element).each(function () { var height = Box.GetDimensions(this).height; maxHeight = height > maxHeight ? height : maxHeight; - if (_this.options.autoHeight) { $(this).data('calcHeight', height); } @@ -4574,19 +4158,17 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { result['max-width'] = "".concat(this.$element[0].getBoundingClientRect().width, "px"); return result; } + /** * Destroys the Drilldown Menu * @function */ - }, { key: "_destroy", value: function _destroy() { $('body').off('.zf.drilldown'); if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler); - this._hideAll(); - this.$element.off('mutateme.zf.trigger'); Nest.Burn(this.$element, 'drilldown'); this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').off('transitionend otransitionend webkitTransitionEnd').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role'); @@ -4598,7 +4180,6 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { this.$element.find('a').each(function () { var $link = $(this); $link.removeAttr('tabindex'); - if ($link.data('savedHref')) { $link.attr('href', $link.data('savedHref')).removeData('savedHref'); } else { @@ -4607,10 +4188,8 @@ var Drilldown = /*#__PURE__*/function (_Plugin) { }); } }]); - return Drilldown; }(Plugin); - Drilldown.defaults = { /** * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are @@ -4620,7 +4199,6 @@ Drilldown.defaults = { * @default true */ autoApplyClass: true, - /** * Markup used for JS generated back button. Prepended or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting. * @option @@ -4628,7 +4206,6 @@ Drilldown.defaults = { * @default '
  • Back
  • ' */ backButton: '
  • Back
  • ', - /** * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`. * @option @@ -4636,7 +4213,6 @@ Drilldown.defaults = { * @default top */ backButtonPosition: 'top', - /** * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\`) if copy and pasting. * @option @@ -4644,7 +4220,6 @@ Drilldown.defaults = { * @default '
    ' */ wrapper: '
    ', - /** * Adds the parent link to the submenu. * @option @@ -4652,7 +4227,6 @@ Drilldown.defaults = { * @default false */ parentLink: false, - /** * Allow the menu to return to root list on body click. * @option @@ -4660,7 +4234,6 @@ Drilldown.defaults = { * @default false */ closeOnClick: false, - /** * Allow the menu to auto adjust height. * @option @@ -4668,7 +4241,6 @@ Drilldown.defaults = { * @default false */ autoHeight: false, - /** * Animate the auto adjust height. * @option @@ -4676,7 +4248,6 @@ Drilldown.defaults = { * @default false */ animateHeight: false, - /** * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button * @option @@ -4684,7 +4255,6 @@ Drilldown.defaults = { * @default false */ scrollTop: false, - /** * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken * @option @@ -4692,7 +4262,6 @@ Drilldown.defaults = { * @default '' */ scrollTopElement: '', - /** * ScrollTop offset * @option @@ -4700,7 +4269,6 @@ Drilldown.defaults = { * @default 0 */ scrollTopOffset: 0, - /** * Scroll animation duration * @option @@ -4708,7 +4276,6 @@ Drilldown.defaults = { * @default 500 */ animationDuration: 500, - /** * Scroll animation easing. Can be `'swing'` or `'linear'`. * @option @@ -4716,8 +4283,8 @@ Drilldown.defaults = { * @see {@link https://api.jquery.com/animate|JQuery animate} * @default 'swing' */ - animationEasing: 'swing' // holdOpen: false - + animationEasing: 'swing' + // holdOpen: false }; var POSITIONS = ['left', 'right', 'top', 'bottom']; @@ -4729,28 +4296,21 @@ var ALIGNMENTS = { 'top': HORIZONTAL_ALIGNMENTS, 'bottom': HORIZONTAL_ALIGNMENTS }; - function nextItem(item, array) { var currentIdx = array.indexOf(item); - if (currentIdx === array.length - 1) { return array[0]; } else { return array[currentIdx + 1]; } } - var Positionable = /*#__PURE__*/function (_Plugin) { _inherits(Positionable, _Plugin); - var _super = _createSuper(Positionable); - function Positionable() { _classCallCheck(this, Positionable); - return _super.apply(this, arguments); } - _createClass(Positionable, [{ key: "_init", value: @@ -4763,6 +4323,7 @@ var Positionable = /*#__PURE__*/function (_Plugin) { * generated) by explicitly declaring them. * **/ + function _init() { this.triedPositions = {}; this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position; @@ -4782,19 +4343,18 @@ var Positionable = /*#__PURE__*/function (_Plugin) { case 'bottom': case 'top': return rtl() ? 'right' : 'left'; - case 'left': case 'right': return 'bottom'; } } + /** * Adjusts the positionable possible positions by iterating through alignments * and positions. * @function * @private */ - }, { key: "_reposition", value: function _reposition() { @@ -4805,18 +4365,17 @@ var Positionable = /*#__PURE__*/function (_Plugin) { this._realign(); } } + /** * Adjusts the dropdown pane possible positions by iterating through alignments * on the current position. * @function * @private */ - }, { key: "_realign", value: function _realign() { this._addTriedPosition(this.position, this.alignment); - this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]); } }, { @@ -4829,24 +4388,23 @@ var Positionable = /*#__PURE__*/function (_Plugin) { key: "_positionsExhausted", value: function _positionsExhausted() { var isExhausted = true; - for (var i = 0; i < POSITIONS.length; i++) { isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]); } - return isExhausted; } }, { key: "_alignmentsExhausted", value: function _alignmentsExhausted(position) { return this.triedPositions[position] && this.triedPositions[position].length === ALIGNMENTS[position].length; - } // When we're trying to center, we don't want to apply offset that's going to + } + + // When we're trying to center, we don't want to apply offset that's going to // take us just off center, so wrap around to return 0 for the appropriate // offset in those alignments. TODO: Figure out if we want to make this // configurable behavior... it feels more intuitive, especially for tooltips, but // it's possible someone might actually want to start from center and then nudge // slightly off. - }, { key: "_getVOffset", value: function _getVOffset() { @@ -4863,30 +4421,24 @@ var Positionable = /*#__PURE__*/function (_Plugin) { if ($anchor.attr('aria-expanded') === 'false') { return false; } - if (!this.options.allowOverlap) { // restore original position & alignment before checking overlap this.position = this.originalPosition; this.alignment = this.originalAlignment; } - $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset())); - if (!this.options.allowOverlap) { - var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better - + var minOverlap = 100000000; + // default coordinates to how we start, in case we can't figure out better var minCoordinates = { position: this.position, alignment: this.alignment }; - while (!this._positionsExhausted()) { var overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap); - if (overlap === 0) { return; } - if (overlap < minOverlap) { minOverlap = overlap; minCoordinates = { @@ -4894,24 +4446,19 @@ var Positionable = /*#__PURE__*/function (_Plugin) { alignment: this.alignment }; } - this._reposition(); - $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset())); - } // If we get through the entire loop, there was no non-overlapping + } + // If we get through the entire loop, there was no non-overlapping // position available. Pick the version with least overlap. - - this.position = minCoordinates.position; this.alignment = minCoordinates.alignment; $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset())); } } }]); - return Positionable; }(Plugin); - Positionable.defaults = { /** * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto. @@ -4920,7 +4467,6 @@ Positionable.defaults = { * @default 'auto' */ position: 'auto', - /** * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto. * @option @@ -4928,7 +4474,6 @@ Positionable.defaults = { * @default 'auto' */ alignment: 'auto', - /** * Allow overlap of container/window. If false, dropdown positionable first * try to position as defined by data-position and data-alignment, but @@ -4938,7 +4483,6 @@ Positionable.defaults = { * @default false */ allowOverlap: false, - /** * Allow overlap of only the bottom of the container. This is the most common * behavior for dropdowns, allowing the dropdown to extend the bottom of the @@ -4948,7 +4492,6 @@ Positionable.defaults = { * @default true */ allowBottomOverlap: true, - /** * Number of pixels the positionable should be separated vertically from anchor * @option @@ -4956,7 +4499,6 @@ Positionable.defaults = { * @default 0 */ vOffset: 0, - /** * Number of pixels the positionable should be separated horizontally from anchor * @option @@ -4974,18 +4516,13 @@ Positionable.defaults = { * @requires foundation.util.touch * @requires foundation.util.triggers */ - var Dropdown = /*#__PURE__*/function (_Positionable) { _inherits(Dropdown, _Positionable); - var _super = _createSuper(Dropdown); - function Dropdown() { _classCallCheck(this, Dropdown); - return _super.apply(this, arguments); } - _createClass(Dropdown, [{ key: "_setup", value: @@ -5001,25 +4538,23 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { this.$element = element; this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options); this.className = 'Dropdown'; // ie9 back compat - // Touch and Triggers init are idempotent, just need to make sure they are initialized + // Touch and Triggers init are idempotent, just need to make sure they are initialized Touch.init($); Triggers.init($); - this._init(); - Keyboard.register('Dropdown', { 'ENTER': 'toggle', 'SPACE': 'toggle', 'ESCAPE': 'close' }); } + /** * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor. * @function * @private */ - }, { key: "_init", value: function _init() { @@ -5032,33 +4567,27 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { 'aria-haspopup': true, 'aria-expanded': false }); - this._setCurrentAnchor(this.$anchors.first()); - if (this.options.parentClass) { this.$parent = this.$element.parents('.' + this.options.parentClass); } else { this.$parent = null; - } // Set [aria-labelledby] on the Dropdown if it is not set - + } + // Set [aria-labelledby] on the Dropdown if it is not set if (typeof this.$element.attr('aria-labelledby') === 'undefined') { // Get the anchor ID or create one if (typeof this.$currentAnchor.attr('id') === 'undefined') { this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor')); } - this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id')); } - this.$element.attr({ 'aria-hidden': 'true', 'data-yeti-box': $id, 'data-resize': $id }); - _get(_getPrototypeOf(Dropdown.prototype), "_init", this).call(this); - this._events(); } }, { @@ -5066,7 +4595,6 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { value: function _getDefaultPosition() { // handle legacy classnames var position = this.$element[0].className.match(/(top|left|right|bottom)/g); - if (position) { return position[0]; } else { @@ -5078,29 +4606,26 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { value: function _getDefaultAlignment() { // handle legacy float approach var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class')); - if (horizontalPosition) { return horizontalPosition[1]; } - return _get(_getPrototypeOf(Dropdown.prototype), "_getDefaultAlignment", this).call(this); } + /** * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true. * Recursively calls itself if a collision is detected, with a new position class. * @function * @private */ - }, { key: "_setPosition", value: function _setPosition() { this.$element.removeClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment)); - _get(_getPrototypeOf(Dropdown.prototype), "_setPosition", this).call(this, this.$currentAnchor, this.$element, this.$parent); - this.$element.addClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment)); } + /** * Make it a current anchor. * Current anchor as the reference for the position of Dropdown panes. @@ -5108,24 +4633,22 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { * @function * @private */ - }, { key: "_setCurrentAnchor", value: function _setCurrentAnchor(el) { this.$currentAnchor = $(el); } + /** * Adds event listeners to the element utilizing the triggers utility library. * @function * @private */ - }, { key: "_events", value: function _events() { var _this = this, - hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined'; - + hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined'; this.$element.on({ 'open.zf.trigger': this.open.bind(this), 'close.zf.trigger': this.close.bind(this), @@ -5134,26 +4657,23 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { }); this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function (e) { _this._setCurrentAnchor(this); - - if ( // if forceFollow false, always prevent default action - _this.options.forceFollow === false || // if forceFollow true and hover option true, only prevent default action on 1st click + if ( + // if forceFollow false, always prevent default action + _this.options.forceFollow === false || + // if forceFollow true and hover option true, only prevent default action on 1st click // on 2nd click (dropown opened) the default action (e.g. follow a href) gets executed hasTouch && _this.options.hover && _this.$element.hasClass('is-open') === false) { e.preventDefault(); } }); - if (this.options.hover) { this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () { _this._setCurrentAnchor(this); - var bodyData = $('body').data(); - if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') { clearTimeout(_this.timeout); _this.timeout = setTimeout(function () { _this.open(); - _this.$anchors.data('hover', true); }, _this.options.hoverDelay); } @@ -5161,11 +4681,9 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { clearTimeout(_this.timeout); _this.timeout = setTimeout(function () { _this.close(); - _this.$anchors.data('hover', false); }, _this.options.hoverDelay); })); - if (this.options.hoverPane) { this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () { clearTimeout(_this.timeout); @@ -5173,71 +4691,61 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { clearTimeout(_this.timeout); _this.timeout = setTimeout(function () { _this.close(); - _this.$anchors.data('hover', false); }, _this.options.hoverDelay); })); } } - this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) { var $target = $(this); Keyboard.handleKey(e, 'Dropdown', { open: function open() { if ($target.is(_this.$anchors) && !$target.is('input, textarea')) { _this.open(); - _this.$element.attr('tabindex', -1).focus(); - e.preventDefault(); } }, close: function close() { _this.close(); - _this.$anchors.focus(); } }); }); } + /** * Adds an event handler to the body to close any dropdowns on a click. * @function * @private */ - }, { key: "_addBodyHandler", value: function _addBodyHandler() { var $body = $(document.body).not(this.$element), - _this = this; - + _this = this; $body.off('click.zf.dropdown tap.zf.dropdown').on('click.zf.dropdown tap.zf.dropdown', function (e) { if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) { return; } - if (_this.$element.is(e.target) || _this.$element.find(e.target).length) { return; } - _this.close(); - $body.off('click.zf.dropdown tap.zf.dropdown'); }); } + /** * Opens the dropdown pane, and fires a bubbling event to close other dropdowns. * @function * @fires Dropdown#closeme * @fires Dropdown#show */ - }, { key: "open", value: function open() { // var _this = this; - /** * Fires to close other open dropdowns, typically when dropdown is opening * @event Dropdown#closeme @@ -5245,72 +4753,64 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id')); this.$anchors.addClass('hover').attr({ 'aria-expanded': true - }); // this.$element/*.show()*/; + }); + // this.$element/*.show()*/; this.$element.addClass('is-opening'); - this._setPosition(); - this.$element.removeClass('is-opening').addClass('is-open').attr({ 'aria-hidden': false }); - if (this.options.autoFocus) { var $focusable = Keyboard.findFocusable(this.$element); - if ($focusable.length) { $focusable.eq(0).focus(); } } - if (this.options.closeOnClick) { this._addBodyHandler(); } - if (this.options.trapFocus) { Keyboard.trapFocus(this.$element); } + /** * Fires once the dropdown is visible. * @event Dropdown#show */ - - this.$element.trigger('show.zf.dropdown', [this.$element]); } + /** * Closes the open dropdown pane. * @function * @fires Dropdown#hide */ - }, { key: "close", value: function close() { if (!this.$element.hasClass('is-open')) { return false; } - this.$element.removeClass('is-open').attr({ 'aria-hidden': true }); this.$anchors.removeClass('hover').attr('aria-expanded', false); + /** * Fires once the dropdown is no longer visible. * @event Dropdown#hide */ - this.$element.trigger('hide.zf.dropdown', [this.$element]); - if (this.options.trapFocus) { Keyboard.releaseFocus(this.$element); } } + /** * Toggles the dropdown pane's visibility. * @function */ - }, { key: "toggle", value: function toggle() { @@ -5321,11 +4821,11 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { this.open(); } } + /** * Destroys the dropdown. * @function */ - }, { key: "_destroy", value: function _destroy() { @@ -5334,10 +4834,8 @@ var Dropdown = /*#__PURE__*/function (_Positionable) { $(document.body).off('click.zf.dropdown tap.zf.dropdown'); } }]); - return Dropdown; }(Positionable); - Dropdown.defaults = { /** * Class that designates bounding container of Dropdown (default: window) @@ -5346,7 +4844,6 @@ Dropdown.defaults = { * @default null */ parentClass: null, - /** * Amount of time to delay opening a submenu on hover event. * @option @@ -5354,7 +4851,6 @@ Dropdown.defaults = { * @default 250 */ hoverDelay: 250, - /** * Allow submenus to open on hover events * @option @@ -5362,7 +4858,6 @@ Dropdown.defaults = { * @default false */ hover: false, - /** * Don't close dropdown when hovering over dropdown pane * @option @@ -5370,7 +4865,6 @@ Dropdown.defaults = { * @default false */ hoverPane: false, - /** * Number of pixels between the dropdown pane and the triggering element on open. * @option @@ -5378,7 +4872,6 @@ Dropdown.defaults = { * @default 0 */ vOffset: 0, - /** * Number of pixels between the dropdown pane and the triggering element on open. * @option @@ -5386,7 +4879,6 @@ Dropdown.defaults = { * @default 0 */ hOffset: 0, - /** * Position of dropdown. Can be left, right, bottom, top, or auto. * @option @@ -5394,7 +4886,6 @@ Dropdown.defaults = { * @default 'auto' */ position: 'auto', - /** * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto. * @option @@ -5402,7 +4893,6 @@ Dropdown.defaults = { * @default 'auto' */ alignment: 'auto', - /** * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow. * @option @@ -5410,7 +4900,6 @@ Dropdown.defaults = { * @default false */ allowOverlap: false, - /** * Allow overlap of only the bottom of the container. This is the most common * behavior for dropdowns, allowing the dropdown to extend the bottom of the @@ -5420,7 +4909,6 @@ Dropdown.defaults = { * @default true */ allowBottomOverlap: true, - /** * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands. * @option @@ -5428,7 +4916,6 @@ Dropdown.defaults = { * @default false */ trapFocus: false, - /** * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening. * @option @@ -5436,7 +4923,6 @@ Dropdown.defaults = { * @default false */ autoFocus: false, - /** * Allows a click on the body to close the dropdown. * @option @@ -5444,7 +4930,6 @@ Dropdown.defaults = { * @default false */ closeOnClick: false, - /** * If true the default action of the toggle (e.g. follow a link with href) gets executed on click. If hover option is also true the default action gets prevented on first click for mobile / touch devices and executed on second click. * @option @@ -5462,18 +4947,13 @@ Dropdown.defaults = { * @requires foundation.util.nest * @requires foundation.util.touch */ - var DropdownMenu = /*#__PURE__*/function (_Plugin) { _inherits(DropdownMenu, _Plugin); - var _super = _createSuper(DropdownMenu); - function DropdownMenu() { _classCallCheck(this, DropdownMenu); - return _super.apply(this, arguments); } - _createClass(DropdownMenu, [{ key: "_setup", value: @@ -5493,7 +4973,6 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied. this._init(); - Keyboard.register('DropdownMenu', { 'ENTER': 'open', 'SPACE': 'open', @@ -5504,12 +4983,12 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { 'ESCAPE': 'close' }); } + /** * Initializes the plugin, and calls _prepareMenu * @private * @function */ - }, { key: "_init", value: function _init() { @@ -5519,7 +4998,6 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { this.$menuItems = this.$element.find('li[role="none"]'); this.$tabs = this.$element.children('li[role="none"]'); this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass); - if (this.options.alignment === 'auto') { if (this.$element.hasClass(this.options.rightClass) || rtl() || this.$element.parents('.top-bar-right').is('*')) { this.options.alignment = 'right'; @@ -5535,9 +5013,7 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { subs.addClass('opens-right'); } } - this.changed = false; - this._events(); } }, { @@ -5550,70 +5026,60 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { value: function _isRtl() { return this.$element.hasClass('align-right') || rtl() && !this.$element.hasClass('align-left'); } + /** * Adds event listeners to elements within the menu * @private * @function */ - }, { key: "_events", value: function _events() { var _this = this, - hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined', - parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers - + hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined', + parClass = 'is-dropdown-submenu-parent'; + // used for onClick and in the keyboard handlers var handleClickFn = function handleClickFn(e) { var $elem = $(e.target).parentsUntil('ul', ".".concat(parClass)), - hasSub = $elem.hasClass(parClass), - hasClicked = $elem.attr('data-is-click') === 'true', - $sub = $elem.children('.is-dropdown-submenu'); - + hasSub = $elem.hasClass(parClass), + hasClicked = $elem.attr('data-is-click') === 'true', + $sub = $elem.children('.is-dropdown-submenu'); if (hasSub) { if (hasClicked) { if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) { return; } - e.stopImmediatePropagation(); e.preventDefault(); - _this._hide($elem); } else { e.stopImmediatePropagation(); e.preventDefault(); - _this._show($sub); - $elem.add($elem.parentsUntil(_this.$element, ".".concat(parClass))).attr('data-is-click', true); } } }; - if (this.options.clickOpen || hasTouch) { this.$menuItems.on('click.zf.dropdownMenu touchstart.zf.dropdownMenu', handleClickFn); - } // Handle Leaf element Clicks - + } + // Handle Leaf element Clicks if (_this.options.closeOnClickInside) { this.$menuItems.on('click.zf.dropdownMenu', function () { var $elem = $(this), - hasSub = $elem.hasClass(parClass); - + hasSub = $elem.hasClass(parClass); if (!hasSub) { _this._hide(); } }); } - if (hasTouch && this.options.disableHoverOnTouch) this.options.disableHover = true; - if (!this.options.disableHover) { this.$menuItems.on('mouseenter.zf.dropdownMenu', function () { var $elem = $(this), - hasSub = $elem.hasClass(parClass); - + hasSub = $elem.hasClass(parClass); if (hasSub) { clearTimeout($elem.data('_delay')); $elem.data('_delay', setTimeout(function () { @@ -5622,13 +5088,11 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { } }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function () { var $elem = $(this), - hasSub = $elem.hasClass(parClass); - + hasSub = $elem.hasClass(parClass); if (hasSub && _this.options.autoclose) { if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; } - clearTimeout($elem.data('_delay')); $elem.data('_delay', setTimeout(function () { _this._hide($elem); @@ -5636,13 +5100,12 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { } })); } - this.$menuItems.on('keydown.zf.dropdownMenu', function (e) { var $element = $(e.target).parentsUntil('ul', '[role="none"]'), - isTab = _this.$tabs.index($element) > -1, - $elements = isTab ? _this.$tabs : $element.siblings('li').add($element), - $prevElement, - $nextElement; + isTab = _this.$tabs.index($element) > -1, + $elements = isTab ? _this.$tabs : $element.siblings('li').add($element), + $prevElement, + $nextElement; $elements.each(function (i) { if ($(this).is($element)) { $prevElement = $elements.eq(i - 1); @@ -5650,49 +5113,41 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { return; } }); - var nextSibling = function nextSibling() { - $nextElement.children('a:first').focus(); - e.preventDefault(); - }, - prevSibling = function prevSibling() { - $prevElement.children('a:first').focus(); - e.preventDefault(); - }, - openSub = function openSub() { - var $sub = $element.children('ul.is-dropdown-submenu'); - - if ($sub.length) { - _this._show($sub); - - $element.find('li > a:first').focus(); + $nextElement.children('a:first').focus(); e.preventDefault(); - } else { - return; - } - }, - closeSub = function closeSub() { - //if ($element.is(':first-child')) { - var close = $element.parent('ul').parent('li'); - close.children('a:first').focus(); - - _this._hide(close); - - e.preventDefault(); //} - }; + }, + prevSibling = function prevSibling() { + $prevElement.children('a:first').focus(); + e.preventDefault(); + }, + openSub = function openSub() { + var $sub = $element.children('ul.is-dropdown-submenu'); + if ($sub.length) { + _this._show($sub); + $element.find('li > a:first').focus(); + e.preventDefault(); + } else { + return; + } + }, + closeSub = function closeSub() { + //if ($element.is(':first-child')) { + var close = $element.parent('ul').parent('li'); + close.children('a:first').focus(); + _this._hide(close); + e.preventDefault(); + //} + }; var functions = { open: openSub, close: function close() { _this._hide(_this.$element); - _this.$menuItems.eq(0).children('a').focus(); // focus to first element - - e.preventDefault(); } }; - if (isTab) { if (_this._isVertical()) { // vertical menu @@ -5753,45 +5208,40 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { }); } } - Keyboard.handleKey(e, 'DropdownMenu', functions); }); } + /** * Adds an event handler to the body to close any dropdowns on a click. * @function * @private */ - }, { key: "_addBodyHandler", value: function _addBodyHandler() { var _this2 = this; - var $body = $(document.body); - this._removeBodyHandler(); - $body.on('click.zf.dropdownMenu tap.zf.dropdownMenu', function (e) { var isItself = !!$(e.target).closest(_this2.$element).length; if (isItself) return; - _this2._hide(); - _this2._removeBodyHandler(); }); } + /** * Remove the body event handler. See `_addBodyHandler`. * @function * @private */ - }, { key: "_removeBodyHandler", value: function _removeBodyHandler() { $(document.body).off('click.zf.dropdownMenu tap.zf.dropdownMenu'); } + /** * Opens a dropdown pane, and checks for collisions first. * @param {jQuery} $sub - ul element that is a submenu to show @@ -5799,7 +5249,6 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { * @private * @fires DropdownMenu#show */ - }, { key: "_show", value: function _show($sub) { @@ -5807,27 +5256,20 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { return $(el).find($sub).length > 0; })); var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent'); - this._hide($sibs, idx); - $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active'); var clear = Box.ImNotTouchingYou($sub, null, true); - if (!clear) { var oldClass = this.options.alignment === 'left' ? '-right' : '-left', - $parentLi = $sub.parent('.is-dropdown-submenu-parent'); + $parentLi = $sub.parent('.is-dropdown-submenu-parent'); $parentLi.removeClass("opens".concat(oldClass)).addClass("opens-".concat(this.options.alignment)); clear = Box.ImNotTouchingYou($sub, null, true); - if (!clear) { $parentLi.removeClass("opens-".concat(this.options.alignment)).addClass('opens-inner'); } - this.changed = true; } - $sub.css('visibility', ''); - if (this.options.closeOnClick) { this._addBodyHandler(); } @@ -5835,10 +5277,9 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { * Fires when the new dropdown pane is visible. * @event DropdownMenu#show */ - - this.$element.trigger('show.zf.dropdownMenu', [$sub]); } + /** * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything. * @function @@ -5847,12 +5288,10 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { * @fires DropdownMenu#hide * @private */ - }, { key: "_hide", value: function _hide($elem, idx) { var $toClose; - if ($elem && $elem.length) { $toClose = $elem; } else if (typeof idx !== 'undefined') { @@ -5862,39 +5301,33 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { } else { $toClose = this.$element; } - var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0; - if (somethingToClose) { var $activeItem = $toClose.find('li.is-active'); $activeItem.add($toClose).attr({ 'data-is-click': false }).removeClass('is-active'); $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active'); - if (this.changed || $toClose.find('opens-inner').length) { var oldClass = this.options.alignment === 'left' ? 'right' : 'left'; $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(oldClass)); this.changed = false; } - clearTimeout($activeItem.data('_delay')); - this._removeBodyHandler(); + /** * Fires when the open menus are closed. * @event DropdownMenu#hide */ - - this.$element.trigger('hide.zf.dropdownMenu', [$toClose]); } } + /** * Destroys the plugin. * @function */ - }, { key: "_destroy", value: function _destroy() { @@ -5903,14 +5336,11 @@ var DropdownMenu = /*#__PURE__*/function (_Plugin) { Nest.Burn(this.$element, 'dropdown'); } }]); - return DropdownMenu; }(Plugin); /** * Default settings for plugin */ - - DropdownMenu.defaults = { /** * Disallows hover events from opening submenus @@ -5919,7 +5349,6 @@ DropdownMenu.defaults = { * @default false */ disableHover: false, - /** * Disallows hover on touch devices * @option @@ -5927,7 +5356,6 @@ DropdownMenu.defaults = { * @default true */ disableHoverOnTouch: true, - /** * Allow a submenu to automatically close on a mouseleave event, if not clicked open. * @option @@ -5935,7 +5363,6 @@ DropdownMenu.defaults = { * @default true */ autoclose: true, - /** * Amount of time to delay opening a submenu on hover event. * @option @@ -5943,7 +5370,6 @@ DropdownMenu.defaults = { * @default 50 */ hoverDelay: 50, - /** * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu. * @option @@ -5951,15 +5377,14 @@ DropdownMenu.defaults = { * @default false */ clickOpen: false, - /** * Amount of time to delay closing a submenu on a mouseleave event. * @option * @type {number} * @default 500 */ - closingTime: 500, + closingTime: 500, /** * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`. * @option @@ -5967,7 +5392,6 @@ DropdownMenu.defaults = { * @default 'auto' */ alignment: 'auto', - /** * Allow clicks on the body to close any open submenus. * @option @@ -5975,7 +5399,6 @@ DropdownMenu.defaults = { * @default true */ closeOnClick: true, - /** * Allow clicks on leaf anchor links to close any open submenus. * @option @@ -5983,7 +5406,6 @@ DropdownMenu.defaults = { * @default true */ closeOnClickInside: true, - /** * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class. * @option @@ -5991,7 +5413,6 @@ DropdownMenu.defaults = { * @default 'vertical' */ verticalClass: 'vertical', - /** * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class. * @option @@ -5999,7 +5420,6 @@ DropdownMenu.defaults = { * @default 'align-right' */ rightClass: 'align-right', - /** * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile. * @option @@ -6015,18 +5435,13 @@ DropdownMenu.defaults = { * @requires foundation.util.mediaQuery * @requires foundation.util.imageLoader if equalizer contains images */ - var Equalizer = /*#__PURE__*/function (_Plugin) { _inherits(Equalizer, _Plugin); - var _super = _createSuper(Equalizer); - function Equalizer() { _classCallCheck(this, Equalizer); - return _super.apply(this, arguments); } - _createClass(Equalizer, [{ key: "_setup", value: @@ -6045,19 +5460,17 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { this._init(); } + /** * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load. * @private */ - }, { key: "_init", value: function _init() { var eqId = this.$element.attr('data-equalizer') || ''; var $watched = this.$element.find("[data-equalizer-watch=\"".concat(eqId, "\"]")); - MediaQuery._init(); - this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]'); this.$element.attr('data-resize', eqId || GetYoDigits(6, 'eq')); this.$element.attr('data-mutate', eqId || GetYoDigits(6, 'eq')); @@ -6070,14 +5483,12 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { }; var imgs = this.$element.find('img'); var tooSmall; - if (this.options.equalizeOn) { tooSmall = this._checkMQ(); $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this)); } else { this._events(); } - if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') { if (imgs.length) { onImagesLoaded(imgs, this._reflow.bind(this)); @@ -6086,11 +5497,11 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { } } } + /** * Removes event listeners if the breakpoint is too small. * @private */ - }, { key: "_pauseEvents", value: function _pauseEvents() { @@ -6101,21 +5512,21 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { 'mutateme.zf.trigger': this._bindHandler.onResizeMeBound }); } + /** * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound * @private */ - }, { key: "_onResizeMe", value: function _onResizeMe() { this._reflow(); } + /** * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound * @private */ - }, { key: "_onPostEqualized", value: function _onPostEqualized(e) { @@ -6123,39 +5534,35 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { this._reflow(); } } + /** * Initializes events for Equalizer. * @private */ - }, { key: "_events", value: function _events() { this._pauseEvents(); - if (this.hasNested) { this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound); } else { this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound); this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound); } - this.isOn = true; } + /** * Checks the current breakpoint to the minimum required size. * @private */ - }, { key: "_checkMQ", value: function _checkMQ() { var tooSmall = !MediaQuery.is(this.options.equalizeOn); - if (tooSmall) { if (this.isOn) { this._pauseEvents(); - this.$watched.css('height', 'auto'); } } else { @@ -6163,24 +5570,23 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { this._events(); } } - return tooSmall; } + /** * A noop version for the plugin * @private */ - }, { key: "_killswitch", value: function _killswitch() { return; } + /** * Calls necessary functions to update Equalizer upon DOM change * @private */ - }, { key: "_reflow", value: function _reflow() { @@ -6190,74 +5596,66 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { return false; } } - if (this.options.equalizeByRow) { this.getHeightsByRow(this.applyHeightByRow.bind(this)); } else { this.getHeights(this.applyHeight.bind(this)); } } + /** * Manually determines if the first 2 elements are *NOT* stacked. * @private */ - }, { key: "_isStacked", value: function _isStacked() { if (!this.$watched[0] || !this.$watched[1]) { return true; } - return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top; } + /** * Finds the outer heights of children contained within an Equalizer parent and returns them in an array * @param {Function} cb - A non-optional callback to return the heights array to. * @returns {Array} heights - An array of heights of children within Equalizer container */ - }, { key: "getHeights", value: function getHeights(cb) { var heights = []; - for (var i = 0, len = this.$watched.length; i < len; i++) { this.$watched[i].style.height = 'auto'; heights.push(this.$watched[i].offsetHeight); } - cb(heights); } + /** * Finds the outer heights of children contained within an Equalizer parent and returns them in an array * @param {Function} cb - A non-optional callback to return the heights array to. * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child */ - }, { key: "getHeightsByRow", value: function getHeightsByRow(cb) { var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0, - groups = [], - group = 0; //group by Row - + groups = [], + group = 0; + //group by Row groups[group] = []; - for (var i = 0, len = this.$watched.length; i < len; i++) { - this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop - + this.$watched[i].style.height = 'auto'; + //maybe could use this.$watched[i].offsetTop var elOffsetTop = $(this.$watched[i]).offset().top; - if (elOffsetTop !== lastElTopOffset) { group++; groups[group] = []; lastElTopOffset = elOffsetTop; } - groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]); } - for (var j = 0, ln = groups.length; j < ln; j++) { var heights = $(groups[j]).map(function () { return this[1]; @@ -6265,16 +5663,15 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { var max = Math.max.apply(null, heights); groups[j].push(max); } - cb(groups); } + /** * Changes the CSS height property of each child in an Equalizer parent to match the tallest * @param {array} heights - An array of heights of children within Equalizer container * @fires Equalizer#preequalized * @fires Equalizer#postequalized */ - }, { key: "applyHeight", value: function applyHeight(heights) { @@ -6283,16 +5680,16 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { * Fires before the heights are applied * @event Equalizer#preequalized */ - this.$element.trigger('preequalized.zf.equalizer'); this.$watched.css('height', max); + /** * Fires when the heights have been applied * @event Equalizer#postequalized */ - this.$element.trigger('postequalized.zf.equalizer'); } + /** * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child @@ -6301,7 +5698,6 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { * @fires Equalizer#postequalizedrow * @fires Equalizer#postequalized */ - }, { key: "applyHeightByRow", value: function applyHeightByRow(groups) { @@ -6309,11 +5705,9 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { * Fires before the heights are applied */ this.$element.trigger('preequalized.zf.equalizer'); - for (var i = 0, len = groups.length; i < len; i++) { var groupsILength = groups[i].length, - max = groups[i][groupsILength - 1]; - + max = groups[i][groupsILength - 1]; if (groupsILength <= 2) { $(groups[i][0][0]).css({ 'height': 'auto' @@ -6324,10 +5718,7 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { * Fires before the heights per row are applied * @event Equalizer#preequalizedrow */ - - this.$element.trigger('preequalizedrow.zf.equalizer'); - for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) { $(groups[i][j][0]).css({ 'height': max @@ -6337,38 +5728,30 @@ var Equalizer = /*#__PURE__*/function (_Plugin) { * Fires when the heights per row have been applied * @event Equalizer#postequalizedrow */ - - this.$element.trigger('postequalizedrow.zf.equalizer'); } /** * Fires when the heights have been applied */ - - this.$element.trigger('postequalized.zf.equalizer'); } + /** * Destroys an instance of Equalizer. * @function */ - }, { key: "_destroy", value: function _destroy() { this._pauseEvents(); - this.$watched.css('height', 'auto'); } }]); - return Equalizer; }(Plugin); /** * Default settings for plugin */ - - Equalizer.defaults = { /** * Enable height equalization when stacked on smaller screens. @@ -6377,7 +5760,6 @@ Equalizer.defaults = { * @default false */ equalizeOnStack: false, - /** * Enable height equalization row by row. * @option @@ -6385,7 +5767,6 @@ Equalizer.defaults = { * @default false */ equalizeByRow: false, - /** * String representing the minimum breakpoint size the plugin should equalize heights on. * @option @@ -6400,18 +5781,13 @@ Equalizer.defaults = { * @module foundation.interchange * @requires foundation.util.mediaQuery */ - var Interchange = /*#__PURE__*/function (_Plugin) { _inherits(Interchange, _Plugin); - var _super = _createSuper(Interchange); - function Interchange() { _classCallCheck(this, Interchange); - return _super.apply(this, arguments); } - _createClass(Interchange, [{ key: "_setup", value: @@ -6429,86 +5805,77 @@ var Interchange = /*#__PURE__*/function (_Plugin) { this.rules = []; this.currentPath = ''; this.className = 'Interchange'; // ie9 back compat - // Triggers init is idempotent, just need to make sure it is initialized + // Triggers init is idempotent, just need to make sure it is initialized Triggers.init($); - this._init(); - this._events(); } + /** * Initializes the Interchange plugin and calls functions to get interchange functioning on load. * @function * @private */ - }, { key: "_init", value: function _init() { MediaQuery._init(); - var id = this.$element[0].id || GetYoDigits(6, 'interchange'); this.$element.attr({ 'data-resize': id, 'id': id }); - this._parseOptions(); - this._addBreakpoints(); - this._generateRules(); - this._reflow(); } + /** * Initializes events for Interchange. * @function * @private */ - }, { key: "_events", value: function _events() { var _this = this; - this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () { return _this._reflow(); }); } + /** * Calls necessary functions to update Interchange upon DOM change * @function * @private */ - }, { key: "_reflow", value: function _reflow() { - var match; // Iterate through each rule, but only save the last match + var match; + // Iterate through each rule, but only save the last match for (var i in this.rules) { if (this.rules.hasOwnProperty(i)) { var rule = this.rules[i]; - if (window.matchMedia(rule.query).matches) { match = rule; } } } - if (match) { this.replace(match.path); } } + /** * Check options valifity and set defaults for: * - `data-interchange-type`: if set, enforce the type of replacement (auto, src, background or html) * @function * @private */ - }, { key: "_parseOptions", value: function _parseOptions() { @@ -6518,12 +5885,12 @@ var Interchange = /*#__PURE__*/function (_Plugin) { this.options.type = 'auto'; } } + /** * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object. * @function * @private */ - }, { key: "_addBreakpoints", value: function _addBreakpoints() { @@ -6534,112 +5901,102 @@ var Interchange = /*#__PURE__*/function (_Plugin) { } } } + /** * Checks the Interchange element for the provided media query + content pairings * @function * @private * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys */ - }, { key: "_generateRules", value: function _generateRules() { var rulesList = []; var rules; - if (this.options.rules) { rules = this.options.rules; } else { rules = this.$element.data('interchange'); } - rules = typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules; - for (var i in rules) { if (rules.hasOwnProperty(i)) { var rule = rules[i].slice(1, -1).split(', '); var path = rule.slice(0, -1).join(''); var query = rule[rule.length - 1]; - if (Interchange.SPECIAL_QUERIES[query]) { query = Interchange.SPECIAL_QUERIES[query]; } - rulesList.push({ path: path, query: query }); } } - this.rules = rulesList; } + /** * Update the `src` property of an image, or change the HTML of a container, to the specified path. * @function * @param {String} path - Path to the image or HTML partial. * @fires Interchange#replaced */ - }, { key: "replace", value: function replace(path) { var _this2 = this; - if (this.currentPath === path) return; var trigger = 'replaced.zf.interchange'; var type = this.options.type; - if (type === 'auto') { if (this.$element[0].nodeName === 'IMG') type = 'src';else if (path.match(/\.(gif|jpe?g|png|svg|tiff)([?#].*)?/i)) type = 'background';else type = 'html'; - } // Replacing images - + } + // Replacing images if (type === 'src') { this.$element.attr('src', path).on('load', function () { _this2.currentPath = path; }).trigger(trigger); - } // Replacing background images + } + // Replacing background images else if (type === 'background') { path = path.replace(/\(/g, '%28').replace(/\)/g, '%29'); this.$element.css({ 'background-image': 'url(' + path + ')' }).trigger(trigger); - } // Replacing HTML + } + // Replacing HTML else if (type === 'html') { $.get(path, function (response) { _this2.$element.html(response).trigger(trigger); - $(response).foundation(); _this2.currentPath = path; }); } + /** * Fires when content in an Interchange element is done being loaded. * @event Interchange#replaced */ // this.$element.trigger('replaced.zf.interchange'); - } + /** * Destroys an instance of interchange. * @function */ - }, { key: "_destroy", value: function _destroy() { this.$element.off('resizeme.zf.trigger'); } }]); - return Interchange; }(Plugin); /** * Default settings for plugin */ - - Interchange.defaults = { /** * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation. @@ -6648,7 +6005,6 @@ Interchange.defaults = { * @default null */ rules: null, - /** * Type of the responsive ressource to replace. It can take the following options: * - `auto` (default): choose the type according to the element tag or the ressource extension, @@ -6671,18 +6027,13 @@ Interchange.SPECIAL_QUERIES = { * SmoothScroll module. * @module foundation.smoothScroll */ - var SmoothScroll = /*#__PURE__*/function (_Plugin) { _inherits(SmoothScroll, _Plugin); - var _super = _createSuper(SmoothScroll); - function SmoothScroll() { _classCallCheck(this, SmoothScroll); - return _super.apply(this, arguments); } - _createClass(SmoothScroll, [{ key: "_setup", value: @@ -6701,11 +6052,11 @@ var SmoothScroll = /*#__PURE__*/function (_Plugin) { this._init(); } + /** * Initialize the SmoothScroll plugin * @private */ - }, { key: "_init", value: function _init() { @@ -6713,14 +6064,13 @@ var SmoothScroll = /*#__PURE__*/function (_Plugin) { this.$element.attr({ id: id }); - this._events(); } + /** * Initializes events for SmoothScroll. * @private */ - }, { key: "_events", value: function _events() { @@ -6728,18 +6078,17 @@ var SmoothScroll = /*#__PURE__*/function (_Plugin) { this.$element.on('click.zf.smoothScroll', this._linkClickListener); this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener); } + /** * Handle the given event to smoothly scroll to the anchor pointed by the event target. * @param {*} e - event * @function * @private */ - }, { key: "_handleLinkClick", value: function _handleLinkClick(e) { var _this = this; - // Follow the link if it does not point to an anchor. if (!$(e.currentTarget).is('a[href^="#"]')) return; var arrival = e.currentTarget.getAttribute('href'); @@ -6774,8 +6123,9 @@ var SmoothScroll = /*#__PURE__*/function (_Plugin) { function scrollToLoc(loc) { var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults; var callback = arguments.length > 2 ? arguments[2] : undefined; - var $loc = $(loc); // Do nothing if target does not exist to prevent errors + var $loc = $(loc); + // Do nothing if target does not exist to prevent errors if (!$loc.length) return false; var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset); $('html, body').stop(true).animate({ @@ -6787,14 +6137,11 @@ var SmoothScroll = /*#__PURE__*/function (_Plugin) { }); } }]); - return SmoothScroll; }(Plugin); /** * Default settings for plugin. */ - - SmoothScroll.defaults = { /** * Amount of time, in ms, the animated scrolling should take between locations. @@ -6803,7 +6150,6 @@ SmoothScroll.defaults = { * @default 500 */ animationDuration: 500, - /** * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`. * @option @@ -6812,7 +6158,6 @@ SmoothScroll.defaults = { * @see {@link https://api.jquery.com/animate|Jquery animate} */ animationEasing: 'linear', - /** * Number of pixels to use as a marker for location changes. * @option @@ -6820,7 +6165,6 @@ SmoothScroll.defaults = { * @default 50 */ threshold: 50, - /** * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar. * @option @@ -6836,18 +6180,13 @@ SmoothScroll.defaults = { * @requires foundation.smoothScroll * @requires foundation.util.triggers */ - var Magellan = /*#__PURE__*/function (_Plugin) { _inherits(Magellan, _Plugin); - var _super = _createSuper(Magellan); - function Magellan() { _classCallCheck(this, Magellan); - return _super.apply(this, arguments); } - _createClass(Magellan, [{ key: "_setup", value: @@ -6863,19 +6202,17 @@ var Magellan = /*#__PURE__*/function (_Plugin) { this.$element = element; this.options = $.extend({}, Magellan.defaults, this.$element.data(), options); this.className = 'Magellan'; // ie9 back compat - // Triggers init is idempotent, just need to make sure it is initialized + // Triggers init is idempotent, just need to make sure it is initialized Triggers.init($); - this._init(); - this.calcPoints(); } + /** * Initializes the Magellan plugin and calls functions to get equalizer functioning on load. * @private */ - }, { key: "_init", value: function _init() { @@ -6889,52 +6226,46 @@ var Magellan = /*#__PURE__*/function (_Plugin) { }); this.$active = $(); this.scrollPos = parseInt(window.pageYOffset, 10); - this._events(); } + /** * Calculates an array of pixel values that are the demarcation lines between locations on the page. * Can be invoked if new elements are added or the size of a location changes. * @function */ - }, { key: "calcPoints", value: function calcPoints() { var _this = this, - body = document.body, - html = document.documentElement; - + body = document.body, + html = document.documentElement; this.points = []; this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight)); this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight)); this.$targets.each(function () { var $tar = $(this), - pt = Math.round($tar.offset().top - _this.options.threshold); + pt = Math.round($tar.offset().top - _this.options.threshold); $tar.targetPoint = pt; - _this.points.push(pt); }); } + /** * Initializes events for Magellan. * @private */ - }, { key: "_events", value: function _events() { var _this = this; - $(window).one('load', function () { if (_this.options.deepLinking) { if (location.hash) { _this.scrollToLoc(location.hash); } } - _this.calcPoints(); - _this._updateActive(); }); _this.onLoadListener = onLoad($(window), function () { @@ -6944,32 +6275,27 @@ var Magellan = /*#__PURE__*/function (_Plugin) { }).on('click.zf.magellan', 'a[href^="#"]', function (e) { e.preventDefault(); var arrival = this.getAttribute('href'); - _this.scrollToLoc(arrival); }); }); - this._deepLinkScroll = function () { if (_this.options.deepLinking) { _this.scrollToLoc(window.location.hash); } }; - $(window).on('hashchange', this._deepLinkScroll); } + /** * Function to scroll to a given location on the page. * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo' * @function */ - }, { key: "scrollToLoc", value: function scrollToLoc(loc) { this._inTransition = true; - var _this = this; - var options = { animationEasing: this.options.animationEasing, animationDuration: this.options.animationDuration, @@ -6980,74 +6306,71 @@ var Magellan = /*#__PURE__*/function (_Plugin) { _this._inTransition = false; }); } + /** * Calls necessary functions to update Magellan upon DOM change * @function */ - }, { key: "reflow", value: function reflow() { this.calcPoints(); - this._updateActive(); } + /** * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled. * @private * @function * @fires Magellan#update */ - }, { key: "_updateActive", - value: function - /*evt, elem, scrollPos*/ - _updateActive() { + value: function _updateActive( /*evt, elem, scrollPos*/ + ) { var _this2 = this; - if (this._inTransition) return; var newScrollPos = parseInt(window.pageYOffset, 10); var isScrollingUp = this.scrollPos > newScrollPos; this.scrollPos = newScrollPos; - var activeIdx; // Before the first point: no link - - if (newScrollPos < this.points[0] - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) ; // At the bottom of the page: last link + var activeIdx; + // Before the first point: no link + if (newScrollPos < this.points[0] - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) ; + // At the bottom of the page: last link else if (newScrollPos + this.winHeight === this.docHeight) { activeIdx = this.points.length - 1; - } // Otherwhise, use the last visible link + } + // Otherwhise, use the last visible link else { var visibleLinks = this.points.filter(function (p) { return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos; }); activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0; - } // Get the new active link - + } + // Get the new active link var $oldActive = this.$active; var activeHash = ''; - if (typeof activeIdx !== 'undefined') { this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]'); if (this.$active.length) activeHash = this.$active[0].getAttribute('href'); } else { this.$active = $(); } - var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive); - var isNewHash = activeHash !== window.location.hash; // Update the active link element + var isNewHash = activeHash !== window.location.hash; + // Update the active link element if (isNewActive) { $oldActive.removeClass(this.options.activeClass); this.$active.addClass(this.options.activeClass); - } // Update the hash (it may have changed with the same active link) - + } + // Update the hash (it may have changed with the same active link) if (this.options.deepLinking && isNewHash) { if (window.history.pushState) { // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384 var url = activeHash ? activeHash : window.location.pathname + window.location.search; - if (this.options.updateHistory) { window.history.pushState({}, '', url); } else { @@ -7057,7 +6380,6 @@ var Magellan = /*#__PURE__*/function (_Plugin) { window.location.hash = activeHash; } } - if (isNewActive) { /** * Fires when magellan is finished updating to the new active element. @@ -7066,33 +6388,28 @@ var Magellan = /*#__PURE__*/function (_Plugin) { this.$element.trigger('update.zf.magellan', [this.$active]); } } + /** * Destroys an instance of Magellan and resets the url of the window. * @function */ - }, { key: "_destroy", value: function _destroy() { this.$element.off('.zf.trigger .zf.magellan').find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass); - if (this.options.deepLinking) { var hash = this.$active[0].getAttribute('href'); window.location.hash.replace(hash, ''); } - $(window).off('hashchange', this._deepLinkScroll); if (this.onLoadListener) $(window).off(this.onLoadListener); } }]); - return Magellan; }(Plugin); /** * Default settings for plugin */ - - Magellan.defaults = { /** * Amount of time, in ms, the animated scrolling should take between locations. @@ -7101,7 +6418,6 @@ Magellan.defaults = { * @default 500 */ animationDuration: 500, - /** * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`. * @option @@ -7110,7 +6426,6 @@ Magellan.defaults = { * @see {@link https://api.jquery.com/animate|Jquery animate} */ animationEasing: 'linear', - /** * Number of pixels to use as a marker for location changes. * @option @@ -7118,7 +6433,6 @@ Magellan.defaults = { * @default 50 */ threshold: 50, - /** * Class applied to the active locations link on the magellan container. * @option @@ -7126,7 +6440,6 @@ Magellan.defaults = { * @default 'is-active' */ activeClass: 'is-active', - /** * Allows the script to manipulate the url of the current page, and if supported, alter the history. * @option @@ -7134,7 +6447,6 @@ Magellan.defaults = { * @default false */ deepLinking: false, - /** * Update the browser history with the active link, if deep linking is enabled. * @option @@ -7142,7 +6454,6 @@ Magellan.defaults = { * @default false */ updateHistory: false, - /** * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar. * @option @@ -7159,18 +6470,13 @@ Magellan.defaults = { * @requires foundation.util.mediaQuery * @requires foundation.util.triggers */ - var OffCanvas = /*#__PURE__*/function (_Plugin) { _inherits(OffCanvas, _Plugin); - var _super = _createSuper(OffCanvas); - function OffCanvas() { _classCallCheck(this, OffCanvas); - return _super.apply(this, arguments); } - _createClass(OffCanvas, [{ key: "_setup", value: @@ -7184,9 +6490,7 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { */ function _setup(element, options) { var _this2 = this; - this.className = 'OffCanvas'; // ie9 back compat - this.$element = element; this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options); this.contentClasses = { @@ -7199,41 +6503,39 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { this.$content = $(); this.nested = !!this.options.nested; this.$sticky = $(); - this.isInCanvas = false; // Defines the CSS transition/position classes of the off-canvas content container. + this.isInCanvas = false; + // Defines the CSS transition/position classes of the off-canvas content container. $(['push', 'overlap']).each(function (index, val) { _this2.contentClasses.base.push('has-transition-' + val); }); $(['left', 'right', 'top', 'bottom']).each(function (index, val) { _this2.contentClasses.base.push('has-position-' + val); - _this2.contentClasses.reveal.push('has-reveal-' + val); - }); // Triggers init is idempotent, just need to make sure it is initialized + }); + // Triggers init is idempotent, just need to make sure it is initialized Triggers.init($); - MediaQuery._init(); - this._init(); - this._events(); - Keyboard.register('OffCanvas', { 'ESCAPE': 'close' }); } + /** * Initializes the off-canvas wrapper by adding the exit overlay (if needed). * @function * @private */ - }, { key: "_init", value: function _init() { var id = this.$element.attr('id'); - this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback) + this.$element.attr('aria-hidden', 'true'); + // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback) if (this.options.contentId) { this.$content = $('#' + this.options.contentId); } else if (this.$element.siblings('[data-off-canvas-content]').length) { @@ -7241,7 +6543,6 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } else { this.$content = this.$element.closest('[data-off-canvas-content]').first(); } - if (!this.options.contentId) { // Assume that the off-canvas element is nested if it isn't a sibling of the content this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0; @@ -7250,64 +6551,58 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { // Once the element is nested it is required to work properly in this case console.warn('Remember to use the nested option if using the content ID option!'); } - if (this.nested === true) { // Force transition overlap if nested - this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup - + this.options.transition = 'overlap'; + // Remove appropriate classes if already assigned in markup this.$element.removeClass('is-transition-push'); } + this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); - this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); // Find triggers that affect this element and add aria-expanded to them + // Find triggers that affect this element and add aria-expanded to them + this.$triggers = $(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); - this.$triggers = $(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class - - this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary + // Get position by checking for related CSS class + this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; + // Add an overlay over the content if necessary if (this.options.contentOverlay === true) { var overlay = document.createElement('div'); var overlayPosition = $(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute'; overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition); this.$overlay = $(overlay); - if (overlayPosition === 'is-overlay-fixed') { $(this.$overlay).insertAfter(this.$element); } else { this.$content.append(this.$overlay); } - } // Get the revealOn option from the class. - + } + // Get the revealOn option from the class. var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\s]+)', 'g'); var revealOnClass = revealOnRegExp.exec(this.$element[0].className); - if (revealOnClass) { this.options.isRevealed = true; this.options.revealOn = this.options.revealOn || revealOnClass[1]; - } // Ensure the `reveal-on-*` class is set. - + } + // Ensure the `reveal-on-*` class is set. if (this.options.isRevealed === true && this.options.revealOn) { this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn)); - this._setMQChecker(); } - if (this.options.transitionTime) { this.$element.css('transition-duration', this.options.transitionTime); - } // Find fixed elements that should stay fixed while off-canvas is opened - + } + // Find fixed elements that should stay fixed while off-canvas is opened this.$sticky = this.$content.find('[data-off-canvas-sticky]'); - if (this.$sticky.length > 0 && this.options.transition === 'push') { // If there's at least one match force contentScroll:false because the absolute top value doesn't get recalculated on scroll // Limit to push transition since there's no transform scope for overlap this.options.contentScroll = false; } - var inCanvasFor = this.$element.attr('class').match(/\bin-canvas-for-(\w+)/); - if (inCanvasFor && inCanvasFor.length === 2) { // Set `inCanvasOn` option if found in-canvas-for-[BREAKPONT] CSS class this.options.inCanvasOn = inCanvasFor[1]; @@ -7315,55 +6610,50 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { // Ensure the CSS class is set this.$element.addClass("in-canvas-for-".concat(this.options.inCanvasOn)); } - if (this.options.inCanvasOn) { this._checkInCanvas(); - } // Initally remove all transition/position CSS classes from off-canvas content container. - + } + // Initally remove all transition/position CSS classes from off-canvas content container. this._removeContentClasses(); } + /** * Adds event handlers to the off-canvas wrapper and the exit overlay. * @function * @private */ - }, { key: "_events", value: function _events() { var _this3 = this; - this.$element.off('.zf.trigger .zf.offCanvas').on({ 'open.zf.trigger': this.open.bind(this), 'close.zf.trigger': this.close.bind(this), 'toggle.zf.trigger': this.toggle.bind(this), 'keydown.zf.offCanvas': this._handleKeyboard.bind(this) }); - if (this.options.closeOnClick === true) { var $target = this.options.contentOverlay ? this.$overlay : this.$content; $target.on({ 'click.zf.offCanvas': this.close.bind(this) }); } - if (this.options.inCanvasOn) { $(window).on('changed.zf.mediaquery', function () { _this3._checkInCanvas(); }); } } + /** * Applies event listener for elements that will reveal at certain breakpoints. * @private */ - }, { key: "_setMQChecker", value: function _setMQChecker() { var _this = this; - this.onLoadListener = onLoad($(window), function () { if (MediaQuery.atLeast(_this.options.revealOn)) { _this.reveal(true); @@ -7377,27 +6667,26 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } }); } + /** * Checks if InCanvas on current breakpoint and adjust off-canvas accordingly * @private */ - }, { key: "_checkInCanvas", value: function _checkInCanvas() { this.isInCanvas = MediaQuery.atLeast(this.options.inCanvasOn); - if (this.isInCanvas === true) { this.close(); } } + /** * Removes the CSS transition/position classes of the off-canvas content container. * Removing the classes is important when another off-canvas gets opened that uses the same content container. * @param {Boolean} hasReveal - true if related off-canvas element is revealed. * @private */ - }, { key: "_removeContentClasses", value: function _removeContentClasses(hasReveal) { @@ -7407,37 +6696,37 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { this.$content.removeClass("has-reveal-".concat(this.position)); } } + /** * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element. * Beforehand any transition/position class gets removed. * @param {Boolean} hasReveal - true if related off-canvas element is revealed. * @private */ - }, { key: "_addContentClasses", value: function _addContentClasses(hasReveal) { this._removeContentClasses(hasReveal); - if (typeof hasReveal !== 'boolean') { this.$content.addClass("has-transition-".concat(this.options.transition, " has-position-").concat(this.position)); } else if (hasReveal === true) { this.$content.addClass("has-reveal-".concat(this.position)); } } + /** * Preserves the fixed behavior of sticky elements on opening an off-canvas with push transition. * Since the off-canvas container has got a transform scope in such a case, it is done by calculating position absolute values. * @private */ - }, { key: "_fixStickyElements", value: function _fixStickyElements() { this.$sticky.each(function (_, el) { - var $el = $(el); // If sticky element is currently fixed, adjust its top value to match absolute position due to transform scope - // Limit to push transition because postion:fixed works without problems for overlap (no transform scope) + var $el = $(el); + // If sticky element is currently fixed, adjust its top value to match absolute position due to transform scope + // Limit to push transition because postion:fixed works without problems for overlap (no transform scope) if ($el.css('position') === 'fixed') { // Save current inline styling to restore it if undoing the absolute fixing var topVal = parseInt($el.css('top'), 10); @@ -7453,19 +6742,20 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } }); } + /** * Restores the original fixed styling of sticky elements after having closed an off-canvas that got pseudo fixed beforehand. * This reverts the changes of _fixStickyElements() * @private */ - }, { key: "_unfixStickyElements", value: function _unfixStickyElements() { this.$sticky.each(function (_, el) { var $el = $(el); - var stickyData = $el.data('offCanvasSticky'); // If sticky element has got data object with prior values (meaning it was originally fixed) restore these values once off-canvas is closed + var stickyData = $el.data('offCanvasSticky'); + // If sticky element has got data object with prior values (meaning it was originally fixed) restore these values once off-canvas is closed if (_typeof(stickyData) === 'object') { $el.css({ top: "".concat(stickyData.top, "px"), @@ -7476,12 +6766,12 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } }); } + /** * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open. * @param {Boolean} isRevealed - true if element should be revealed. * @function */ - }, { key: "reveal", value: function reveal(isRevealed) { @@ -7500,38 +6790,37 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { }); this.$element.addClass('is-closed'); } - this._addContentClasses(isRevealed); } + /** * Stops scrolling of the body when OffCanvas is open on mobile Safari and other troublesome browsers. * @function * @private */ - }, { key: "_stopScrolling", value: function _stopScrolling() { return false; } + /** * Save current finger y-position * @param event * @private */ - }, { key: "_recordScrollable", value: function _recordScrollable(event) { var elem = this; elem.lastY = event.touches[0].pageY; } + /** * Prevent further scrolling when it hits the edges * @param event * @private */ - }, { key: "_preventDefaultAtEdges", value: function _preventDefaultAtEdges(event) { @@ -7539,18 +6828,17 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { var _this = event.data; var delta = elem.lastY - event.touches[0].pageY; elem.lastY = event.touches[0].pageY; - if (!_this._canScroll(delta, elem)) { event.preventDefault(); } } + /** * Handle continuous scrolling of scrollbox * Don't bubble up to _preventDefaultAtEdges * @param event * @private */ - }, { key: "_scrollboxTouchMoved", value: function _scrollboxTouchMoved(event) { @@ -7560,7 +6848,6 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { var delta = elem.lastY - event.touches[0].pageY; parent.lastY = elem.lastY = event.touches[0].pageY; event.stopPropagation(); - if (!_this._canScroll(delta, elem)) { if (!_this._canScroll(delta, parent)) { event.preventDefault(); @@ -7569,6 +6856,7 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } } } + /** * Detect possibility of scrolling * @param delta @@ -7576,7 +6864,6 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { * @returns boolean * @private */ - }, { key: "_canScroll", value: function _canScroll(delta, elem) { @@ -7586,6 +6873,7 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { var allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight; return up && allowUp || down && allowDown; } + /** * Opens the off-canvas menu. * @function @@ -7594,39 +6882,33 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { * @fires OffCanvas#opened * @todo also trigger 'open' event? */ - }, { key: "open", value: function open(event, trigger) { var _this4 = this; - if (this.$element.hasClass('is-open') || this.isRevealed || this.isInCanvas) { return; } - var _this = this; - if (trigger) { this.$lastTrigger = trigger; } - if (this.options.forceTo === 'top') { window.scrollTo(0, 0); } else if (this.options.forceTo === 'bottom') { window.scrollTo(0, document.body.scrollHeight); } - if (this.options.transitionTime && this.options.transition !== 'overlap') { this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime); } else { this.$element.siblings('[data-off-canvas-content]').css('transition-duration', ''); } - this.$element.addClass('is-open').removeClass('is-closed'); this.$triggers.attr('aria-expanded', 'true'); this.$element.attr('aria-hidden', 'false'); - this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices. + this.$content.addClass('is-open-' + this.position); + // If `contentScroll` is set to false, add class and disable scrolling on touch devices. if (this.options.contentScroll === false) { $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling); this.$element.on('touchstart', this._recordScrollable); @@ -7634,15 +6916,12 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { this.$element.on('touchstart', '[data-off-canvas-scrollbox]', this._recordScrollable); this.$element.on('touchmove', '[data-off-canvas-scrollbox]', this, this._scrollboxTouchMoved); } - if (this.options.contentOverlay === true) { this.$overlay.addClass('is-visible'); } - if (this.options.closeOnClick === true && this.options.contentOverlay === true) { this.$overlay.addClass('is-closable'); } - if (this.options.autoFocus === true) { this.$element.one(transitionend(this.$element), function () { if (!_this.$element.hasClass('is-open')) { @@ -7650,7 +6929,6 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } var canvasFocus = _this.$element.find('[data-autofocus]'); - if (canvasFocus.length) { canvasFocus.eq(0).focus(); } else { @@ -7658,33 +6936,30 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } }); } - if (this.options.trapFocus === true) { this.$content.attr('tabindex', '-1'); Keyboard.trapFocus(this.$element); } - if (this.options.transition === 'push') { this._fixStickyElements(); } - this._addContentClasses(); + /** * Fires when the off-canvas menu opens. * @event OffCanvas#opened */ - - this.$element.trigger('opened.zf.offCanvas'); + /** * Fires when the off-canvas menu open transition is done. * @event OffCanvas#openedEnd */ - this.$element.one(transitionend(this.$element), function () { _this4.$element.trigger('openedEnd.zf.offCanvas'); }); } + /** * Closes the off-canvas menu. * @function @@ -7692,79 +6967,65 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { * @fires OffCanvas#close * @fires OffCanvas#closed */ - }, { key: "close", value: function close() { var _this5 = this; - if (!this.$element.hasClass('is-open') || this.isRevealed) { return; } + /** * Fires when the off-canvas menu closes. * @event OffCanvas#close */ - - this.$element.trigger('close.zf.offCanvas'); this.$element.removeClass('is-open'); this.$element.attr('aria-hidden', 'true'); this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); - if (this.options.contentOverlay === true) { this.$overlay.removeClass('is-visible'); } - if (this.options.closeOnClick === true && this.options.contentOverlay === true) { this.$overlay.removeClass('is-closable'); } + this.$triggers.attr('aria-expanded', 'false'); - this.$triggers.attr('aria-expanded', 'false'); // Listen to transitionEnd: add class, re-enable scrolling and release focus when done. - + // Listen to transitionEnd: add class, re-enable scrolling and release focus when done. this.$element.one(transitionend(this.$element), function () { _this5.$element.addClass('is-closed'); - _this5._removeContentClasses(); - if (_this5.options.transition === 'push') { _this5._unfixStickyElements(); - } // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices. - + } + // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices. if (_this5.options.contentScroll === false) { $('body').removeClass('is-off-canvas-open').off('touchmove', _this5._stopScrolling); - _this5.$element.off('touchstart', _this5._recordScrollable); - _this5.$element.off('touchmove', _this5._preventDefaultAtEdges); - _this5.$element.off('touchstart', '[data-off-canvas-scrollbox]', _this5._recordScrollable); - _this5.$element.off('touchmove', '[data-off-canvas-scrollbox]', _this5._scrollboxTouchMoved); } - if (_this5.options.trapFocus === true) { _this5.$content.removeAttr('tabindex'); - Keyboard.releaseFocus(_this5.$element); } + /** * Fires when the off-canvas menu close transition is done. * @event OffCanvas#closed */ - - _this5.$element.trigger('closed.zf.offCanvas'); }); } + /** * Toggles the off-canvas menu open or closed. * @function * @param {Object} event - Event object passed from listener. * @param {jQuery} trigger - element that triggered the off-canvas to open. */ - }, { key: "toggle", value: function toggle(event, trigger) { @@ -7774,23 +7035,20 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { this.open(event, trigger); } } + /** * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu. * @function * @private */ - }, { key: "_handleKeyboard", value: function _handleKeyboard(e) { var _this6 = this; - Keyboard.handleKey(e, 'OffCanvas', { close: function close() { _this6.close(); - _this6.$lastTrigger.focus(); - return true; }, handled: function handled() { @@ -7798,11 +7056,11 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { } }); } + /** * Destroys the OffCanvas plugin. * @function */ - }, { key: "_destroy", value: function _destroy() { @@ -7812,10 +7070,8 @@ var OffCanvas = /*#__PURE__*/function (_Plugin) { if (this.onLoadListener) $(window).off(this.onLoadListener); } }]); - return OffCanvas; }(Plugin); - OffCanvas.defaults = { /** * Allow the user to click outside of the menu to close it. @@ -7824,7 +7080,6 @@ OffCanvas.defaults = { * @default true */ closeOnClick: true, - /** * Adds an overlay on top of `[data-off-canvas-content]`. * @option @@ -7832,7 +7087,6 @@ OffCanvas.defaults = { * @default true */ contentOverlay: true, - /** * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken. * @option @@ -7840,7 +7094,6 @@ OffCanvas.defaults = { * @default null */ contentId: null, - /** * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element. * @option @@ -7848,7 +7101,6 @@ OffCanvas.defaults = { * @default null */ nested: null, - /** * Enable/disable scrolling of the main content when an off canvas panel is open. * @option @@ -7856,7 +7108,6 @@ OffCanvas.defaults = { * @default true */ contentScroll: true, - /** * Amount of time the open and close transition requires, including the appropriate milliseconds (`ms`) or seconds (`s`) unit (e.g. `500ms`, `.75s`) If none selected, pulls from body style. * @option @@ -7864,7 +7115,6 @@ OffCanvas.defaults = { * @default null */ transitionTime: null, - /** * Type of transition for the OffCanvas menu. Options are 'push', 'detached' or 'slide'. * @option @@ -7872,7 +7122,6 @@ OffCanvas.defaults = { * @default push */ transition: 'push', - /** * Force the page to scroll to top or bottom on open. * @option @@ -7880,7 +7129,6 @@ OffCanvas.defaults = { * @default null */ forceTo: null, - /** * Allow the OffCanvas to remain open for certain breakpoints. * @option @@ -7888,7 +7136,6 @@ OffCanvas.defaults = { * @default false */ isRevealed: false, - /** * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option. * @option @@ -7896,7 +7143,6 @@ OffCanvas.defaults = { * @default null */ revealOn: null, - /** * Breakpoint at which the off-canvas gets moved into canvas content and acts as regular page element. * @option @@ -7904,7 +7150,6 @@ OffCanvas.defaults = { * @default null */ inCanvasOn: null, - /** * Force focus to the offcanvas on open. If true, will focus the opening trigger on close. * @option @@ -7912,7 +7157,6 @@ OffCanvas.defaults = { * @default true */ autoFocus: true, - /** * Class used to force an OffCanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`. * @option @@ -7921,7 +7165,6 @@ OffCanvas.defaults = { * @todo improve the regex testing for this. */ revealClass: 'reveal-for-', - /** * Triggers optional focus trapping when opening an OffCanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes. * @option @@ -7940,18 +7183,13 @@ OffCanvas.defaults = { * @requires foundation.util.imageLoader * @requires foundation.util.touch */ - var Orbit = /*#__PURE__*/function (_Plugin) { _inherits(Orbit, _Plugin); - var _super = _createSuper(Orbit); - function Orbit() { _classCallCheck(this, Orbit); - return _super.apply(this, arguments); } - _createClass(Orbit, [{ key: "_setup", value: @@ -7970,7 +7208,6 @@ var Orbit = /*#__PURE__*/function (_Plugin) { Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied. this._init(); - Keyboard.register('Orbit', { 'ltr': { 'ARROW_RIGHT': 'next', @@ -7982,79 +7219,70 @@ var Orbit = /*#__PURE__*/function (_Plugin) { } }); } + /** * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation. * @function * @private */ - }, { key: "_init", value: function _init() { // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide this._reset(); - this.$wrapper = this.$element.find(".".concat(this.options.containerClass)); this.$slides = this.$element.find(".".concat(this.options.slideClass)); var $images = this.$element.find('img'), - initActive = this.$slides.filter('.is-active'), - id = this.$element[0].id || GetYoDigits(6, 'orbit'); + initActive = this.$slides.filter('.is-active'), + id = this.$element[0].id || GetYoDigits(6, 'orbit'); this.$element.attr({ 'data-resize': id, 'id': id }); - if (!initActive.length) { this.$slides.eq(0).addClass('is-active'); } - if (!this.options.useMUI) { this.$slides.addClass('no-motionui'); } - if ($images.length) { onImagesLoaded($images, this._prepareForOrbit.bind(this)); } else { this._prepareForOrbit(); //hehe - } if (this.options.bullets) { this._loadBullets(); } - this._events(); - if (this.options.autoPlay && this.$slides.length > 1) { this.geoSync(); } - if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation this.$wrapper.attr('tabindex', 0); } } + /** * Creates a jQuery collection of bullets, if they are being used. * @function * @private */ - }, { key: "_loadBullets", value: function _loadBullets() { this.$bullets = this.$element.find(".".concat(this.options.boxOfBullets)).find('button'); } + /** * Sets a `timer` object on the orbit, and starts the counter for the next slide. * @function */ - }, { key: "geoSync", value: function geoSync() { var _this = this; - this.timer = new Timer(this.$element, { duration: this.options.timerDelay, infinite: false @@ -8063,64 +7291,60 @@ var Orbit = /*#__PURE__*/function (_Plugin) { }); this.timer.start(); } + /** * Sets wrapper and slide heights for the orbit. * @function * @private */ - }, { key: "_prepareForOrbit", value: function _prepareForOrbit() { this._setWrapperHeight(); } + /** * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height. * @function * @private * @param {Function} cb - a callback function to fire when complete. */ - }, { key: "_setWrapperHeight", value: function _setWrapperHeight(cb) { //rewrite this to `for` loop var max = 0, - temp, - counter = 0, - _this = this; - + temp, + counter = 0, + _this = this; this.$slides.each(function () { temp = this.getBoundingClientRect().height; - $(this).attr('data-slide', counter); // hide all slides but the active one + $(this).attr('data-slide', counter); + // hide all slides but the active one if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) { $(this).css({ 'display': 'none' }); } - max = temp > max ? temp : max; counter++; }); - if (counter === this.$slides.length) { this.$wrapper.css({ 'height': max }); //only change the wrapper height property once. - if (cb) { cb(max); } //fire callback with max height dimension. - } } + /** * Sets the max-height of each slide. * @function * @private */ - }, { key: "_setSlideHeight", value: function _setSlideHeight(height) { @@ -8128,47 +7352,42 @@ var Orbit = /*#__PURE__*/function (_Plugin) { $(this).css('max-height', height); }); } + /** * Adds event listeners to basically everything within the element. * @function * @private */ - }, { key: "_events", value: function _events() { - var _this = this; //*************************************** + var _this = this; + + //*************************************** //**Now using custom event - thanks to:** //** Yohai Ararat of Toronto ** //*************************************** // - - this.$element.off('.resizeme.zf.trigger').on({ 'resizeme.zf.trigger': this._prepareForOrbit.bind(this) }); - if (this.$slides.length > 1) { if (this.options.swipe) { this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) { e.preventDefault(); - _this.changeSlide(true); }).on('swiperight.zf.orbit', function (e) { e.preventDefault(); - _this.changeSlide(false); }); - } //*************************************** - + } + //*************************************** if (this.options.autoPlay) { this.$slides.on('click.zf.orbit', function () { _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true); - _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start'](); }); - if (this.options.pauseOnHover) { this.$element.on('mouseenter.zf.orbit', function () { _this.timer.pause(); @@ -8179,32 +7398,26 @@ var Orbit = /*#__PURE__*/function (_Plugin) { }); } } - if (this.options.navButtons) { var $controls = this.$element.find(".".concat(this.options.nextClass, ", .").concat(this.options.prevClass)); - $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses + $controls.attr('tabindex', 0) + //also need to handle enter/return and spacebar key presses .on('click.zf.orbit touchend.zf.orbit', function (e) { e.preventDefault(); - _this.changeSlide($(this).hasClass(_this.options.nextClass)); }); } - if (this.options.bullets) { this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () { if (/is-active/g.test(this.className)) { return false; } //if this is active, kick out of function. - - var idx = $(this).data('slide'), - ltr = idx > _this.$slides.filter('.is-active').data('slide'), - $slide = _this.$slides.eq(idx); - + ltr = idx > _this.$slides.filter('.is-active').data('slide'), + $slide = _this.$slides.eq(idx); _this.changeSlide(ltr, $slide, idx); }); } - if (this.options.accessible) { this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) { // handle keyboard event with keyboard util @@ -8226,10 +7439,10 @@ var Orbit = /*#__PURE__*/function (_Plugin) { } } } + /** * Resets Orbit so it can be reinitialized */ - }, { key: "_reset", value: function _reset() { @@ -8237,29 +7450,33 @@ var Orbit = /*#__PURE__*/function (_Plugin) { if (typeof this.$slides === 'undefined') { return; } - if (this.$slides.length > 1) { // Remove old events - this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled + this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); + // Restart timer if autoPlay is enabled if (this.options.autoPlay) { this.timer.restart(); - } // Reset all sliddes - + } + // Reset all sliddes this.$slides.each(function (el) { $(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide(); - }); // Show the first slide + }); - this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating + // Show the first slide + this.$slides.first().addClass('is-active').show(); - this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present + // Triggers when the slide has finished animating + this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); + // Select first bullet if bullets are present if (this.options.bullets) { this._updateBullets(0); } } } + /** * Changes the current slide to a new one. * @function @@ -8268,51 +7485,42 @@ var Orbit = /*#__PURE__*/function (_Plugin) { * @param {Number} idx - the index of the new slide in its collection, if one chosen. * @fires Orbit#slidechange */ - }, { key: "changeSlide", value: function changeSlide(isLTR, chosenSlide, idx) { if (!this.$slides) { return; } // Don't freak out if we're in the middle of cleanup - - var $curSlide = this.$slides.filter('.is-active').eq(0); - if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function - var $firstSlide = this.$slides.first(), - $lastSlide = this.$slides.last(), - dirIn = isLTR ? 'Right' : 'Left', - dirOut = isLTR ? 'Left' : 'Right', - _this = this, - $newSlide; - + $lastSlide = this.$slides.last(), + dirIn = isLTR ? 'Right' : 'Left', + dirOut = isLTR ? 'Left' : 'Right', + _this = this, + $newSlide; if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons. - $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!! + $newSlide = isLTR ? + //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!! this.options.infiniteWrap ? $curSlide.next(".".concat(this.options.slideClass)).length ? $curSlide.next(".".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(".".concat(this.options.slideClass)) //pick next slide if moving left to right : this.options.infiniteWrap ? $curSlide.prev(".".concat(this.options.slideClass)).length ? $curSlide.prev(".".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(".".concat(this.options.slideClass)); //pick prev slide if moving right to left } else { $newSlide = chosenSlide; } - if ($newSlide.length) { /** * Triggers before the next slide starts animating in and only if a next slide has been found. * @event Orbit#beforeslidechange */ this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]); - if (this.options.bullets) { idx = idx || this.$slides.index($newSlide); //grab index to update bullets - this._updateBullets(idx); } - if (this.options.useMUI && !this.$element.is(':hidden')) { Motion.animateIn($newSlide.addClass('is-active'), this.options["animInFrom".concat(dirIn)], function () { $newSlide.css({ @@ -8321,16 +7529,14 @@ var Orbit = /*#__PURE__*/function (_Plugin) { }); Motion.animateOut($curSlide.removeClass('is-active'), this.options["animOutTo".concat(dirOut)], function () { $curSlide.removeAttr('aria-live'); - if (_this.options.autoPlay && !_this.timer.isPaused) { _this.timer.restart(); - } //do stuff? - + } + //do stuff? }); } else { $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide(); $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show(); - if (this.options.autoPlay && !this.timer.isPaused) { this.timer.restart(); } @@ -8339,11 +7545,10 @@ var Orbit = /*#__PURE__*/function (_Plugin) { * Triggers when the slide has finished animating in. * @event Orbit#slidechange */ - - this.$element.trigger('slidechange.zf.orbit', [$newSlide]); } } + /** * Updates the active state of the bullets, if displayed. * Move the descriptor of the current slide `[data-slide-active-label]` to the newly active bullet. @@ -8353,7 +7558,6 @@ var Orbit = /*#__PURE__*/function (_Plugin) { * @private * @param {Number} idx - the index of the current slide. */ - }, { key: "_updateBullets", value: function _updateBullets(idx) { @@ -8361,45 +7565,46 @@ var Orbit = /*#__PURE__*/function (_Plugin) { var $othersBullets = this.$bullets.not('.is-active'); var $newBullet = this.$bullets.eq(idx); $oldBullet.removeClass('is-active').blur(); - $newBullet.addClass('is-active'); // Find the descriptor for the current slide to move it to the new slide button + $newBullet.addClass('is-active'); - var activeStateDescriptor = $oldBullet.children('[data-slide-active-label]').last(); // If not explicitely given, search for the last "exceeding" span element (compared to others bullets). + // Find the descriptor for the current slide to move it to the new slide button + var activeStateDescriptor = $oldBullet.children('[data-slide-active-label]').last(); + // If not explicitely given, search for the last "exceeding" span element (compared to others bullets). if (!activeStateDescriptor.length) { var spans = $oldBullet.children('span'); var spanCountInOthersBullets = $othersBullets.toArray().map(function (b) { return $(b).children('span').length; - }); // If there is an exceeding span element, use it as current slide descriptor + }); + // If there is an exceeding span element, use it as current slide descriptor if (spanCountInOthersBullets.every(function (count) { return count < spans.length; })) { activeStateDescriptor = spans.last(); activeStateDescriptor.attr('data-slide-active-label', ''); } - } // Move the current slide descriptor to the new slide button - + } + // Move the current slide descriptor to the new slide button if (activeStateDescriptor.length) { activeStateDescriptor.detach(); $newBullet.append(activeStateDescriptor); } } + /** * Destroys the carousel and hides the element. * @function */ - }, { key: "_destroy", value: function _destroy() { this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide(); } }]); - return Orbit; }(Plugin); - Orbit.defaults = { /** * Tells the JS to look for and loadBullets. @@ -8408,7 +7613,6 @@ Orbit.defaults = { * @default true */ bullets: true, - /** * Tells the JS to apply event listeners to nav buttons * @option @@ -8416,7 +7620,6 @@ Orbit.defaults = { * @default true */ navButtons: true, - /** * motion-ui animation class to apply * @option @@ -8424,7 +7627,6 @@ Orbit.defaults = { * @default 'slide-in-right' */ animInFromRight: 'slide-in-right', - /** * motion-ui animation class to apply * @option @@ -8432,7 +7634,6 @@ Orbit.defaults = { * @default 'slide-out-right' */ animOutToRight: 'slide-out-right', - /** * motion-ui animation class to apply * @option @@ -8441,7 +7642,6 @@ Orbit.defaults = { * */ animInFromLeft: 'slide-in-left', - /** * motion-ui animation class to apply * @option @@ -8449,7 +7649,6 @@ Orbit.defaults = { * @default 'slide-out-left' */ animOutToLeft: 'slide-out-left', - /** * Allows Orbit to automatically animate on page load. * @option @@ -8457,7 +7656,6 @@ Orbit.defaults = { * @default true */ autoPlay: true, - /** * Amount of time, in ms, between slide transitions * @option @@ -8465,7 +7663,6 @@ Orbit.defaults = { * @default 5000 */ timerDelay: 5000, - /** * Allows Orbit to infinitely loop through the slides * @option @@ -8473,7 +7670,6 @@ Orbit.defaults = { * @default true */ infiniteWrap: true, - /** * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library * @option @@ -8481,7 +7677,6 @@ Orbit.defaults = { * @default true */ swipe: true, - /** * Allows the timing function to pause animation on hover. * @option @@ -8489,7 +7684,6 @@ Orbit.defaults = { * @default true */ pauseOnHover: true, - /** * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys * @option @@ -8497,7 +7691,6 @@ Orbit.defaults = { * @default true */ accessible: true, - /** * Class applied to the container of Orbit * @option @@ -8505,7 +7698,6 @@ Orbit.defaults = { * @default 'orbit-container' */ containerClass: 'orbit-container', - /** * Class applied to individual slides. * @option @@ -8513,7 +7705,6 @@ Orbit.defaults = { * @default 'orbit-slide' */ slideClass: 'orbit-slide', - /** * Class applied to the bullet container. You're welcome. * @option @@ -8521,7 +7712,6 @@ Orbit.defaults = { * @default 'orbit-bullets' */ boxOfBullets: 'orbit-bullets', - /** * Class applied to the `next` navigation button. * @option @@ -8529,7 +7719,6 @@ Orbit.defaults = { * @default 'orbit-next' */ nextClass: 'orbit-next', - /** * Class applied to the `previous` navigation button. * @option @@ -8537,7 +7726,6 @@ Orbit.defaults = { * @default 'orbit-previous' */ prevClass: 'orbit-previous', - /** * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility. * @option @@ -8560,7 +7748,9 @@ var MenuPlugins = { cssClass: 'accordion-menu', plugin: AccordionMenu } -}; // import "foundation.util.triggers.js"; +}; + +// import "foundation.util.triggers.js"; /** * ResponsiveMenu module. @@ -8568,18 +7758,13 @@ var MenuPlugins = { * @requires foundation.util.triggers * @requires foundation.util.mediaQuery */ - var ResponsiveMenu = /*#__PURE__*/function (_Plugin) { _inherits(ResponsiveMenu, _Plugin); - var _super = _createSuper(ResponsiveMenu); - function ResponsiveMenu() { _classCallCheck(this, ResponsiveMenu); - return _super.apply(this, arguments); } - _createClass(ResponsiveMenu, [{ key: "_setup", value: @@ -8599,100 +7784,100 @@ var ResponsiveMenu = /*#__PURE__*/function (_Plugin) { this.className = 'ResponsiveMenu'; // ie9 back compat this._init(); - this._events(); } + /** * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element. * @function * @private */ - }, { key: "_init", value: function _init() { - MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules - - + MediaQuery._init(); + // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules if (typeof this.rules === 'string') { - var rulesTree = {}; // Parse rules from "classes" pulled from data attribute + var rulesTree = {}; - var rules = this.rules.split(' '); // Iterate through every rule found + // Parse rules from "classes" pulled from data attribute + var rules = this.rules.split(' '); + // Iterate through every rule found for (var i = 0; i < rules.length; i++) { var rule = rules[i].split('-'); var ruleSize = rule.length > 1 ? rule[0] : 'small'; var rulePlugin = rule.length > 1 ? rule[1] : rule[0]; - if (MenuPlugins[rulePlugin] !== null) { rulesTree[ruleSize] = MenuPlugins[rulePlugin]; } } - this.rules = rulesTree; } - if (!$.isEmptyObject(this.rules)) { this._checkMediaQueries(); - } // Add data-mutate since children may need it. - - + } + // Add data-mutate since children may need it. this.$element.attr('data-mutate', this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')); } + /** * Initializes events for the Menu. * @function * @private */ - }, { key: "_events", value: function _events() { var _this = this; - $(window).on('changed.zf.mediaquery', function () { _this._checkMediaQueries(); - }); // $(window).on('resize.zf.ResponsiveMenu', function() { + }); + // $(window).on('resize.zf.ResponsiveMenu', function() { // _this._checkMediaQueries(); // }); } + /** * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out. * @function * @private */ - }, { key: "_checkMediaQueries", value: function _checkMediaQueries() { var matchedMq, - _this = this; // Iterate through each rule and find the last matching rule - - + _this = this; + // Iterate through each rule and find the last matching rule $.each(this.rules, function (key) { if (MediaQuery.atLeast(key)) { matchedMq = key; } - }); // No match? No dice + }); - if (!matchedMq) return; // Plugin already initialized? We good + // No match? No dice + if (!matchedMq) return; - if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes + // Plugin already initialized? We good + if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; + // Remove existing plugin-specific CSS classes $.each(MenuPlugins, function (key, value) { _this.$element.removeClass(value.cssClass); - }); // Add the CSS class for the new plugin + }); - this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin + // Add the CSS class for the new plugin + this.$element.addClass(this.rules[matchedMq].cssClass); + // Create an instance of the new plugin if (this.currentPlugin) this.currentPlugin.destroy(); this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {}); } + /** * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out. * @function */ - }, { key: "_destroy", value: function _destroy() { @@ -8700,10 +7885,8 @@ var ResponsiveMenu = /*#__PURE__*/function (_Plugin) { $(window).off('.zf.ResponsiveMenu'); } }]); - return ResponsiveMenu; }(Plugin); - ResponsiveMenu.defaults = {}; /** @@ -8712,18 +7895,13 @@ ResponsiveMenu.defaults = {}; * @requires foundation.util.mediaQuery * @requires foundation.util.motion */ - var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { _inherits(ResponsiveToggle, _Plugin); - var _super = _createSuper(ResponsiveToggle); - function ResponsiveToggle() { _classCallCheck(this, ResponsiveToggle); - return _super.apply(this, arguments); } - _createClass(ResponsiveToggle, [{ key: "_setup", value: @@ -8741,47 +7919,43 @@ var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { this.className = 'ResponsiveToggle'; // ie9 back compat this._init(); - this._events(); } + /** * Initializes the tab bar by finding the target element, toggling element, and running update(). * @function * @private */ - }, { key: "_init", value: function _init() { MediaQuery._init(); - var targetID = this.$element.data('responsive-toggle'); - if (!targetID) { console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.'); } - this.$targetMenu = $("#".concat(targetID)); this.$toggler = this.$element.find('[data-toggle]').filter(function () { var target = $(this).data('toggle'); return target === targetID || target === ""; }); - this.options = $.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes + this.options = $.extend({}, this.options, this.$targetMenu.data()); + // If they were set, parse the animation classes if (this.options.animate) { var input = this.options.animate.split(' '); this.animationIn = input[0]; this.animationOut = input[1] || null; } - this._update(); } + /** * Adds necessary event handlers for the tab bar to work. * @function * @private */ - }, { key: "_events", value: function _events() { @@ -8789,12 +7963,12 @@ var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { $(window).on('changed.zf.mediaquery', this._updateMqHandler); this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this)); } + /** * Checks the current media query to determine if the tab bar should be visible or hidden. * @function * @private */ - }, { key: "_update", value: function _update() { @@ -8802,23 +7976,24 @@ var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { if (!MediaQuery.atLeast(this.options.hideFor)) { this.$element.show(); this.$targetMenu.hide(); - } // Desktop + } + + // Desktop else { this.$element.hide(); this.$targetMenu.show(); } } + /** * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it. * @function * @fires ResponsiveToggle#toggled */ - }, { key: "toggleMenu", value: function toggleMenu() { var _this = this; - if (!MediaQuery.atLeast(this.options.hideFor)) { /** * Fires when the element attached to the tab bar toggles. @@ -8828,7 +8003,6 @@ var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { if (this.$targetMenu.is(':hidden')) { Motion.animateIn(this.$targetMenu, this.animationIn, function () { _this.$element.trigger('toggled.zf.responsiveToggle'); - _this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger'); }); } else { @@ -8851,10 +8025,8 @@ var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { $(window).off('changed.zf.mediaquery', this._updateMqHandler); } }]); - return ResponsiveToggle; }(Plugin); - ResponsiveToggle.defaults = { /** * The breakpoint after which the menu is always shown, and the tab bar is hidden. @@ -8863,7 +8035,6 @@ ResponsiveToggle.defaults = { * @default 'medium' */ hideFor: 'medium', - /** * To decide if the toggle should be animated or not. * @option @@ -8882,18 +8053,13 @@ ResponsiveToggle.defaults = { * @requires foundation.util.mediaQuery * @requires foundation.util.motion if using animations */ - var Reveal = /*#__PURE__*/function (_Plugin) { _inherits(Reveal, _Plugin); - var _super = _createSuper(Reveal); - function Reveal() { _classCallCheck(this, Reveal); - return _super.apply(this, arguments); } - _createClass(Reveal, [{ key: "_setup", value: @@ -8908,28 +8074,25 @@ var Reveal = /*#__PURE__*/function (_Plugin) { this.$element = element; this.options = $.extend({}, Reveal.defaults, this.$element.data(), options); this.className = 'Reveal'; // ie9 back compat + this._init(); - this._init(); // Touch and Triggers init are idempotent, just need to make sure they are initialized - - + // Touch and Triggers init are idempotent, just need to make sure they are initialized Touch.init($); Triggers.init($); Keyboard.register('Reveal', { 'ESCAPE': 'close' }); } + /** * Initializes the modal by adding the overlay and close buttons, (if selected). * @private */ - }, { key: "_init", value: function _init() { var _this2 = this; - MediaQuery._init(); - this.id = this.$element.attr('id'); this.isActive = false; this.cached = { @@ -8941,60 +8104,52 @@ var Reveal = /*#__PURE__*/function (_Plugin) { 'aria-haspopup': 'dialog', 'tabindex': 0 }); - if (this.options.fullScreen || this.$element.hasClass('full')) { this.options.fullScreen = true; this.options.overlay = false; } - if (this.options.overlay && !this.$overlay) { this.$overlay = this._makeOverlay(this.id); } - this.$element.attr({ 'role': 'dialog', 'aria-hidden': true, 'data-yeti-box': this.id, 'data-resize': this.id }); - if (this.$overlay) { this.$element.detach().appendTo(this.$overlay); } else { this.$element.detach().appendTo($(this.options.appendTo)); this.$element.addClass('without-overlay'); } - this._events(); - if (this.options.deepLink && window.location.hash === "#".concat(this.id)) { this.onLoadListener = onLoad($(window), function () { return _this2.open(); }); } } + /** * Creates an overlay div to display behind the modal. * @private */ - }, { key: "_makeOverlay", value: function _makeOverlay() { var additionalOverlayClasses = ''; - if (this.options.additionalOverlayClasses) { additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses; } - return $('
    ').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo); } + /** * Updates position of modal * TODO: Figure out if we actually need to cache these values or if it doesn't matter * @private */ - }, { key: "_updatePosition", value: function _updatePosition() { @@ -9003,14 +8158,12 @@ var Reveal = /*#__PURE__*/function (_Plugin) { var height = this.$element.outerHeight(); var outerHeight = $(window).height(); var left, - top = null; - + top = null; if (this.options.hOffset === 'auto') { left = parseInt((outerWidth - width) / 2, 10); } else { left = parseInt(this.options.hOffset, 10); } - if (this.options.vOffset === 'auto') { if (height > outerHeight) { top = parseInt(Math.min(100, outerHeight / 10), 10); @@ -9020,15 +8173,14 @@ var Reveal = /*#__PURE__*/function (_Plugin) { } else if (this.options.vOffset !== null) { top = parseInt(this.options.vOffset, 10); } - if (top !== null) { this.$element.css({ top: top + 'px' }); - } // only worry about left if we don't have an overlay or we have a horizontal offset, - // otherwise we're perfectly in the middle - + } + // only worry about left if we don't have an overlay or we have a horizontal offset, + // otherwise we're perfectly in the middle if (!this.$overlay || this.options.hOffset !== 'auto') { this.$element.css({ left: left + 'px' @@ -9038,18 +8190,16 @@ var Reveal = /*#__PURE__*/function (_Plugin) { }); } } + /** * Adds event handlers for the modal. * @private */ - }, { key: "_events", value: function _events() { var _this3 = this; - var _this = this; - this.$element.on({ 'open.zf.trigger': this.open.bind(this), 'close.zf.trigger': function closeZfTrigger(event, $element) { @@ -9063,26 +8213,23 @@ var Reveal = /*#__PURE__*/function (_Plugin) { _this._updatePosition(); } }); - if (this.options.closeOnClick && this.options.overlay) { this.$overlay.off('.zf.reveal').on('click.zf.dropdown tap.zf.dropdown', function (e) { if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target) || !$.contains(document, e.target)) { return; } - _this.close(); }); } - if (this.options.deepLink) { $(window).on("hashchange.zf.reveal:".concat(this.id), this._handleState.bind(this)); } } + /** * Handles modal methods on back/forward button clicks or any other event that triggers hashchange. * @private */ - }, { key: "_handleState", value: function _handleState() { @@ -9092,50 +8239,46 @@ var Reveal = /*#__PURE__*/function (_Plugin) { this.close(); } } + /** * Disables the scroll when Reveal is shown to prevent the background from shifting * @param {number} scrollTop - Scroll to visually apply, window current scroll by default */ - }, { key: "_disableScroll", value: function _disableScroll(scrollTop) { scrollTop = scrollTop || $(window).scrollTop(); - if ($(document).height() > $(window).height()) { $("html").css("top", -scrollTop); } } + /** * Reenables the scroll when Reveal closes * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`) */ - }, { key: "_enableScroll", value: function _enableScroll(scrollTop) { scrollTop = scrollTop || parseInt($("html").css("top"), 10); - if ($(document).height() > $(window).height()) { $("html").css("top", ""); $(window).scrollTop(-scrollTop); } } + /** * Opens the modal controlled by `this.$anchor`, and closes all others by default. * @function * @fires Reveal#closeme * @fires Reveal#open */ - }, { key: "open", value: function open() { var _this4 = this; - // either update or replace browser history var hash = "#".concat(this.id); - if (this.options.deepLink && window.location.hash !== hash) { if (window.history.pushState) { if (this.options.updateHistory) { @@ -9146,40 +8289,35 @@ var Reveal = /*#__PURE__*/function (_Plugin) { } else { window.location.hash = hash; } - } // Remember anchor that opened it to set focus back later, have general anchors as fallback - + } + // Remember anchor that opened it to set focus back later, have general anchors as fallback this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor; - this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning + this.isActive = true; + // Make elements invisible, but remove display: none so we can get size and positioning this.$element.css({ 'visibility': 'hidden' }).show().scrollTop(0); - if (this.options.overlay) { this.$overlay.css({ 'visibility': 'hidden' }).show(); } - this._updatePosition(); - this.$element.hide().css({ 'visibility': '' }); - if (this.$overlay) { this.$overlay.css({ 'visibility': '' }).hide(); - if (this.$element.hasClass('fast')) { this.$overlay.addClass('fast'); } else if (this.$element.hasClass('slow')) { this.$overlay.addClass('slow'); } } - if (!this.options.multipleOpened) { /** * Fires immediately before the modal opens. @@ -9188,30 +8326,24 @@ var Reveal = /*#__PURE__*/function (_Plugin) { */ this.$element.trigger('closeme.zf.reveal', this.id); } - if ($('.reveal:visible').length === 0) { this._disableScroll(); } + var _this = this; - var _this = this; // Motion UI method of reveal - - + // Motion UI method of reveal if (this.options.animationIn) { var afterAnimation = function afterAnimation() { _this.$element.attr({ 'aria-hidden': false, 'tabindex': -1 }).focus(); - _this._addGlobalClasses(); - Keyboard.trapFocus(_this.$element); }; - if (this.options.overlay) { Motion.animateIn(this.$overlay, 'fade-in'); } - Motion.animateIn(this.$element, this.options.animationIn, function () { if (_this4.$element) { // protect against object having been removed @@ -9219,33 +8351,31 @@ var Reveal = /*#__PURE__*/function (_Plugin) { afterAnimation(); } }); - } // jQuery method of reveal + } + // jQuery method of reveal else { if (this.options.overlay) { this.$overlay.show(0); } - this.$element.show(this.options.showDelay); - } // handle accessibility - + } + // handle accessibility this.$element.attr({ 'aria-hidden': false, 'tabindex': -1 }).focus(); Keyboard.trapFocus(this.$element); - this._addGlobalClasses(); - this._addGlobalListeners(); + /** * Fires when the modal has successfully opened. * @event Reveal#open */ - - this.$element.trigger('open.zf.reveal'); } + /** * Adds classes and listeners on document required by open modals. * @@ -9257,25 +8387,23 @@ var Reveal = /*#__PURE__*/function (_Plugin) { * * @private */ - }, { key: "_addGlobalClasses", value: function _addGlobalClasses() { var updateScrollbarClass = function updateScrollbarClass() { $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height())); }; - this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () { return updateScrollbarClass(); }); updateScrollbarClass(); $('html').addClass('is-reveal-open'); } + /** * Removes classes and listeners on document that were required by open modals. * @private */ - }, { key: "_removeGlobalClasses", value: function _removeGlobalClasses() { @@ -9283,33 +8411,27 @@ var Reveal = /*#__PURE__*/function (_Plugin) { $('html').removeClass('is-reveal-open'); $('html').removeClass('zf-has-scroll'); } + /** * Adds extra event handlers for the body and window if necessary. * @private */ - }, { key: "_addGlobalListeners", value: function _addGlobalListeners() { var _this = this; - if (!this.$element) { return; } // If we're in the middle of cleanup, don't freak out - - this.focusableElements = Keyboard.findFocusable(this.$element); - if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) { $('body').on('click.zf.dropdown tap.zf.dropdown', function (e) { if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target) || !$.contains(document, e.target)) { return; } - _this.close(); }); } - if (this.options.closeOnEsc) { $(window).on('keydown.zf.reveal', function (e) { Keyboard.handleKey(e, 'Reveal', { @@ -9322,93 +8444,80 @@ var Reveal = /*#__PURE__*/function (_Plugin) { }); } } + /** * Closes the modal. * @function * @fires Reveal#closed */ - }, { key: "close", value: function close() { if (!this.isActive || !this.$element.is(':visible')) { return false; } + var _this = this; - var _this = this; // Motion UI method of hiding - - + // Motion UI method of hiding if (this.options.animationOut) { if (this.options.overlay) { Motion.animateOut(this.$overlay, 'fade-out'); } - Motion.animateOut(this.$element, this.options.animationOut, finishUp); - } // jQuery method of hiding + } + // jQuery method of hiding else { this.$element.hide(this.options.hideDelay); - if (this.options.overlay) { this.$overlay.hide(0, finishUp); } else { finishUp(); } - } // Conditionals to remove extra event listeners added on open - + } + // Conditionals to remove extra event listeners added on open if (this.options.closeOnEsc) { $(window).off('keydown.zf.reveal'); } - if (!this.options.overlay && this.options.closeOnClick) { $('body').off('click.zf.dropdown tap.zf.dropdown'); } - this.$element.off('keydown.zf.reveal'); - function finishUp() { // Get the current top before the modal is closed and restore the scroll after. // TODO: use component properties instead of HTML properties // See https://github.com/foundation/foundation-sites/pull/10786 var scrollTop = parseInt($("html").css("top"), 10); - if ($('.reveal:visible').length === 0) { _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal - } Keyboard.releaseFocus(_this.$element); - _this.$element.attr('aria-hidden', true); - if ($('.reveal:visible').length === 0) { _this._enableScroll(scrollTop); } + /** * Fires when the modal is done closing. * @event Reveal#closed */ - - _this.$element.trigger('closed.zf.reveal'); } + /** * Resets the modal content * This prevents a running video to keep going in the background */ - - if (this.options.resetOnClose) { this.$element.html(this.$element.html()); } - - this.isActive = false; // If deepLink and we did not switched to an other modal... - + this.isActive = false; + // If deepLink and we did not switched to an other modal... if (_this.options.deepLink && window.location.hash === "#".concat(this.id)) { // Remove the history hash if (window.history.replaceState) { var urlWithoutHash = window.location.pathname + window.location.search; - if (this.options.updateHistory) { window.history.pushState({}, '', urlWithoutHash); // remove the hash } else { @@ -9418,14 +8527,13 @@ var Reveal = /*#__PURE__*/function (_Plugin) { window.location.hash = ''; } } - this.$activeAnchor.focus(); } + /** * Toggles the open/closed state of a modal. * @function */ - }, { key: "toggle", value: function toggle() { @@ -9445,25 +8553,19 @@ var Reveal = /*#__PURE__*/function (_Plugin) { function _destroy() { if (this.options.overlay) { this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin() - this.$overlay.hide().off().remove(); } - this.$element.hide().off(); this.$anchor.off('.zf'); $(window).off(".zf.reveal:".concat(this.id)); if (this.onLoadListener) $(window).off(this.onLoadListener); - if ($('.reveal:visible').length === 0) { this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal - } } }]); - return Reveal; }(Plugin); - Reveal.defaults = { /** * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide. @@ -9472,7 +8574,6 @@ Reveal.defaults = { * @default '' */ animationIn: '', - /** * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide. * @option @@ -9480,7 +8581,6 @@ Reveal.defaults = { * @default '' */ animationOut: '', - /** * Time, in ms, to delay the opening of a modal after a click if no animation used. * @option @@ -9488,7 +8588,6 @@ Reveal.defaults = { * @default 0 */ showDelay: 0, - /** * Time, in ms, to delay the closing of a modal after a click if no animation used. * @option @@ -9496,7 +8595,6 @@ Reveal.defaults = { * @default 0 */ hideDelay: 0, - /** * Allows a click on the body/overlay to close the modal. * @option @@ -9504,7 +8602,6 @@ Reveal.defaults = { * @default true */ closeOnClick: true, - /** * Allows the modal to close if the user presses the `ESCAPE` key. * @option @@ -9512,7 +8609,6 @@ Reveal.defaults = { * @default true */ closeOnEsc: true, - /** * If true, allows multiple modals to be displayed at once. * @option @@ -9520,7 +8616,6 @@ Reveal.defaults = { * @default false */ multipleOpened: false, - /** * Distance, in pixels, the modal should push down from the top of the screen. * @option @@ -9528,7 +8623,6 @@ Reveal.defaults = { * @default auto */ vOffset: 'auto', - /** * Distance, in pixels, the modal should push in from the side of the screen. * @option @@ -9536,7 +8630,6 @@ Reveal.defaults = { * @default auto */ hOffset: 'auto', - /** * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well. * @option @@ -9544,7 +8637,6 @@ Reveal.defaults = { * @default false */ fullScreen: false, - /** * Allows the modal to generate an overlay div, which will cover the view when modal opens. * @option @@ -9552,7 +8644,6 @@ Reveal.defaults = { * @default true */ overlay: true, - /** * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background. * @option @@ -9560,7 +8651,6 @@ Reveal.defaults = { * @default false */ resetOnClose: false, - /** * Link the location hash to the modal. * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes. @@ -9569,14 +8659,12 @@ Reveal.defaults = { * @default false */ deepLink: false, - /** * If `deepLink` is enabled, update the browser history with the open modal * @option * @default false */ updateHistory: false, - /** * Allows the modal to append to custom div. * @option @@ -9584,7 +8672,6 @@ Reveal.defaults = { * @default "body" */ appendTo: "body", - /** * Allows adding additional class names to the reveal overlay. * @option @@ -9602,18 +8689,13 @@ Reveal.defaults = { * @requires foundation.util.keyboard * @requires foundation.util.touch */ - var Slider = /*#__PURE__*/function (_Plugin) { _inherits(Slider, _Plugin); - var _super = _createSuper(Slider); - function Slider() { _classCallCheck(this, Slider); - return _super.apply(this, arguments); } - _createClass(Slider, [{ key: "_setup", value: @@ -9628,14 +8710,12 @@ var Slider = /*#__PURE__*/function (_Plugin) { this.$element = element; this.options = $.extend({}, Slider.defaults, this.$element.data(), options); this.className = 'Slider'; // ie9 back compat + this.initialized = false; - this.initialized = false; // Touch and Triggers inits are idempotent, we just need to make sure it's initialied. - + // Touch and Triggers inits are idempotent, we just need to make sure it's initialied. Touch.init($); Triggers.init($); - this._init(); - Keyboard.register('Slider', { 'ltr': { 'ARROW_RIGHT': 'increase', @@ -9657,12 +8737,12 @@ var Slider = /*#__PURE__*/function (_Plugin) { } }); } + /** * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s). * @function * @private */ - }, { key: "_init", value: function _init() { @@ -9671,44 +8751,36 @@ var Slider = /*#__PURE__*/function (_Plugin) { this.$handle = this.handles.eq(0); this.$input = this.inputs.length ? this.inputs.eq(0) : $("#".concat(this.$handle.attr('aria-controls'))); this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0); - if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) { this.options.disabled = true; this.$element.addClass(this.options.disabledClass); } - if (!this.inputs.length) { this.inputs = $().add(this.$input); this.options.binding = true; } - this._setInitAttr(0); - if (this.handles[1]) { this.options.doubleSided = true; this.$handle2 = this.handles.eq(1); this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $("#".concat(this.$handle2.attr('aria-controls'))); - if (!this.inputs[1]) { this.inputs = this.inputs.add(this.$input2); - } // this.$handle.triggerHandler('click.zf.slider'); - + } + // this.$handle.triggerHandler('click.zf.slider'); this._setInitAttr(1); - } // Set handle positions - + } + // Set handle positions this.setHandles(); - this._events(); - this.initialized = true; } }, { key: "setHandles", value: function setHandles() { var _this2 = this; - if (this.handles[1]) { this._setHandlePos(this.$handle, this.inputs.eq(0).val(), function () { _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val()); @@ -9727,30 +8799,26 @@ var Slider = /*#__PURE__*/function (_Plugin) { * @private * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value) */ - }, { key: "_pctOfBar", value: function _pctOfBar(value) { var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start); - switch (this.options.positionValueFunction) { case "pow": pctOfBar = this._logTransform(pctOfBar); break; - case "log": pctOfBar = this._powTransform(pctOfBar); break; } - return pctOfBar.toFixed(2); } + /** * @function * @private * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value */ - }, { key: "_value", value: function _value(pctOfBar) { @@ -9758,14 +8826,11 @@ var Slider = /*#__PURE__*/function (_Plugin) { case "pow": pctOfBar = this._powTransform(pctOfBar); break; - case "log": pctOfBar = this._logTransform(pctOfBar); break; } - var value; - if (this.options.vertical) { // linear interpolation which is working with negative values for start // https://math.stackexchange.com/a/1019084 @@ -9773,31 +8838,31 @@ var Slider = /*#__PURE__*/function (_Plugin) { } else { value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start); } - return value; } + /** * @function * @private * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function */ - }, { key: "_logTransform", value: function _logTransform(value) { return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1); } + /** * @function * @private * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function */ - }, { key: "_powTransform", value: function _powTransform(value) { return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1); } + /** * Sets the position of the selected handle and fill bar. * @function @@ -9808,27 +8873,23 @@ var Slider = /*#__PURE__*/function (_Plugin) { * @fires Slider#moved * @fires Slider#changed */ - }, { key: "_setHandlePos", value: function _setHandlePos($hndl, location, cb) { // don't move if the slider has been disabled since its initialization if (this.$element.hasClass(this.options.disabledClass)) { return; - } //might need to alter that slightly for bars that will have odd number selections. - - + } + //might need to alter that slightly for bars that will have odd number selections. location = parseFloat(location); //on input change events, convert string to number...grumble. - // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max + // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max if (location < this.options.start) { location = this.options.start; } else if (location > this.options.end) { location = this.options.end; } - var isDbl = this.options.doubleSided; - if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved. if (this.handles.index($hndl) === 0) { @@ -9839,59 +8900,54 @@ var Slider = /*#__PURE__*/function (_Plugin) { location = location <= h1Val ? h1Val + this.options.step : location; } } - var _this = this, - vert = this.options.vertical, - hOrW = vert ? 'height' : 'width', - lOrT = vert ? 'top' : 'left', - handleDim = $hndl[0].getBoundingClientRect()[hOrW], - elemDim = this.$element[0].getBoundingClientRect()[hOrW], - //percentage of bar min/max value based on click or drag point - pctOfBar = this._pctOfBar(location), - //number of actual pixels to shift the handle, based on the percentage obtained above - pxToMove = (elemDim - handleDim) * pctOfBar, - //percentage of bar to shift the handle - movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value - - - location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders - + vert = this.options.vertical, + hOrW = vert ? 'height' : 'width', + lOrT = vert ? 'top' : 'left', + handleDim = $hndl[0].getBoundingClientRect()[hOrW], + elemDim = this.$element[0].getBoundingClientRect()[hOrW], + //percentage of bar min/max value based on click or drag point + pctOfBar = this._pctOfBar(location), + //number of actual pixels to shift the handle, based on the percentage obtained above + pxToMove = (elemDim - handleDim) * pctOfBar, + //percentage of bar to shift the handle + movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); + //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value + location = parseFloat(location.toFixed(this.options.decimal)); + // declare empty object for css adjustments, only used with 2 handled-sliders var css = {}; + this._setValues($hndl, location); - this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs?? - - + // TODO update to calculate based on values set to respective inputs?? if (isDbl) { var isLeftHndl = this.handles.index($hndl) === 0, - //empty variable, will be used for min-height/width for fill bar - dim, - //percentage w/h of the handle compared to the slider bar - handlePct = Math.floor(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar - + //empty variable, will be used for min-height/width for fill bar + dim, + //percentage w/h of the handle compared to the slider bar + handlePct = Math.floor(percent(handleDim, elemDim) * 100); + //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar if (isLeftHndl) { //left or top percentage value to apply to the fill bar. - css[lOrT] = "".concat(movement, "%"); //calculate the new min-height/width for the fill bar. - - dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider + css[lOrT] = "".concat(movement, "%"); + //calculate the new min-height/width for the fill bar. + dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; + //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future. - if (cb && typeof cb === 'function') { cb(); } //this is only needed for the initialization of 2 handled sliders - } else { //just caching the value of the left/bottom handle's left/top property - var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0 + var handlePos = parseFloat(this.$handle[0].style[lOrT]); + //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0 //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself - dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct; - } // assign the min-height/width to our css object - - + } + // assign the min-height/width to our css object css["min-".concat(hOrW)] = "".concat(dim, "%"); - } //because we don't know exactly how the handle will be moved, check the amount of time it should take to move. - + } + //because we don't know exactly how the handle will be moved, check the amount of time it should take to move. var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime; Move(moveTime, $hndl, function () { // adjusting the left/top property of the handle, based on the percentage calculated above @@ -9902,7 +8958,6 @@ var Slider = /*#__PURE__*/function (_Plugin) { } else { $hndl.css(lOrT, "".concat(movement, "%")); } - if (!_this.options.doubleSided) { //if single-handled, a simple method to expand the fill bar _this.$fill.css(hOrW, "".concat(pctOfBar * 100, "%")); @@ -9911,7 +8966,6 @@ var Slider = /*#__PURE__*/function (_Plugin) { _this.$fill.css(css); } }); - if (this.initialized) { this.$element.one('finished.zf.animate', function () { /** @@ -9924,20 +8978,19 @@ var Slider = /*#__PURE__*/function (_Plugin) { * Fires when the value has not been change for a given time. * @event Slider#changed */ - clearTimeout(_this.timeout); _this.timeout = setTimeout(function () { _this.$element.trigger('changed.zf.slider', [$hndl]); }, _this.options.changedDelay); } } + /** * Sets the initial attribute for the slider element. * @function * @private * @param {Number} idx - index of the current handle/input to use. */ - }, { key: "_setInitAttr", value: function _setInitAttr(idx) { @@ -9960,6 +9013,7 @@ var Slider = /*#__PURE__*/function (_Plugin) { 'tabindex': 0 }); } + /** * Sets the input and `aria-valuenow` values for the slider element. * @function @@ -9967,7 +9021,6 @@ var Slider = /*#__PURE__*/function (_Plugin) { * @param {jQuery} $handle - the currently selected handle. * @param {Number} val - floating point of the new value. */ - }, { key: "_setValues", value: function _setValues($handle, val) { @@ -9975,6 +9028,7 @@ var Slider = /*#__PURE__*/function (_Plugin) { this.inputs.eq(idx).val(val); $handle.attr('aria-valuenow', val); } + /** * Handles events on the slider element. * Calculates the new location of the current handle. @@ -9986,34 +9040,29 @@ var Slider = /*#__PURE__*/function (_Plugin) { * @param {Number} val - floating point number for the new value of the slider. * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn. */ - }, { key: "_handleEvent", value: function _handleEvent(e, $handle, val) { var value; - if (!val) { //click or drag events e.preventDefault(); - var _this = this, - vertical = this.options.vertical, - param = vertical ? 'height' : 'width', - direction = vertical ? 'top' : 'left', - eventOffset = vertical ? e.pageY : e.pageX, - barDim = this.$element[0].getBoundingClientRect()[param], - windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft(); - - var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates... + vertical = this.options.vertical, + param = vertical ? 'height' : 'width', + direction = vertical ? 'top' : 'left', + eventOffset = vertical ? e.pageY : e.pageX, + barDim = this.$element[0].getBoundingClientRect()[param], + windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft(); + var elemOffset = this.$element.offset()[direction]; + + // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates... // best way to guess this is simulated is if clientY == pageY - if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; } - var eventFromBar = eventOffset - elemOffset; var barXY; - if (eventFromBar < 0) { barXY = 0; } else if (eventFromBar > barDim) { @@ -10021,29 +9070,27 @@ var Slider = /*#__PURE__*/function (_Plugin) { } else { barXY = eventFromBar; } - var offsetPct = percent(barXY, barDim); - value = this._value(offsetPct); // turn everything around for RTL, yay math! + value = this._value(offsetPct); + // turn everything around for RTL, yay math! if (rtl() && !this.options.vertical) { value = this.options.end - value; } - value = _this._adjustValue(null, value); - if (!$handle) { //figure out which handle it is, pass it to the next function. var firstHndlPos = absPosition(this.$handle, direction, barXY, param), - secndHndlPos = absPosition(this.$handle2, direction, barXY, param); + secndHndlPos = absPosition(this.$handle2, direction, barXY, param); $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2; } } else { //change event on input value = this._adjustValue(null, val); } - this._setHandlePos($handle, value); } + /** * Adjustes value for handle in regard to step value. returns adjusted value * @function @@ -10051,87 +9098,76 @@ var Slider = /*#__PURE__*/function (_Plugin) { * @param {jQuery} $handle - the selected handle. * @param {Number} value - value to adjust. used if $handle is falsy */ - }, { key: "_adjustValue", value: function _adjustValue($handle, value) { var val, - step = this.options.step, - div = parseFloat(step / 2), - left, - previousVal, - nextVal; - + step = this.options.step, + div = parseFloat(step / 2), + left, + previousVal, + nextVal; if (!!$handle) { val = parseFloat($handle.attr('aria-valuenow')); } else { val = value; } - if (val >= 0) { left = val % step; } else { left = step + val % step; } - previousVal = val - left; nextVal = previousVal + step; - if (left === 0) { return val; } - val = val >= previousVal + div ? nextVal : previousVal; return val; } + /** * Adds event listeners to the slider elements. * @function * @private */ - }, { key: "_events", value: function _events() { this._eventsForHandle(this.$handle); - if (this.handles[1]) { this._eventsForHandle(this.$handle2); } } + /** * Adds event listeners a particular handle * @function * @private * @param {jQuery} $handle - the current handle to apply listeners to. */ - }, { key: "_eventsForHandle", value: function _eventsForHandle($handle) { var _this = this, - curHandle; - + curHandle; var handleChangeEvent = function handleChangeEvent(e) { var idx = _this.inputs.index($(this)); - _this._handleEvent(e, _this.handles.eq(idx), $(this).val()); - }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification + }; + + // IE only triggers the change event when the input loses focus which strictly follows the HTML specification // listen for the enter key and trigger a change // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events - - this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) { if (e.keyCode === 13) handleChangeEvent.call(this, e); }); this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent); - if (this.options.clickSelect) { this.$element.off('click.zf.slider').on('click.zf.slider', function (e) { if (_this.$element.data('dragging')) { return false; } - if (!$(e.target).is('[data-slider-handle]')) { if (_this.options.doubleSided) { _this._handleEvent(e); @@ -10141,47 +9177,37 @@ var Slider = /*#__PURE__*/function (_Plugin) { } }); } - if (this.options.draggable) { this.handles.addTouch(); var $body = $('body'); $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) { $handle.addClass('is-dragging'); - _this.$fill.addClass('is-dragging'); // - - _this.$element.data('dragging', true); - curHandle = $(e.currentTarget); $body.on('mousemove.zf.slider', function (ev) { ev.preventDefault(); - _this._handleEvent(ev, curHandle); }).on('mouseup.zf.slider', function (ev) { _this._handleEvent(ev, curHandle); - $handle.removeClass('is-dragging'); - _this.$fill.removeClass('is-dragging'); - _this.$element.data('dragging', false); - $body.off('mousemove.zf.slider mouseup.zf.slider'); }); - }) // prevent events triggered by touch + }) + // prevent events triggered by touch .on('selectstart.zf.slider touchmove.zf.slider', function (e) { e.preventDefault(); }); } - $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) { var _$handle = $(this), - idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0, - oldValue = parseFloat($handle.attr('aria-valuenow')), - newValue; // handle keyboard event with keyboard util - + idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0, + oldValue = parseFloat($handle.attr('aria-valuenow')), + newValue; + // handle keyboard event with keyboard util Keyboard.handleKey(e, 'Slider', { decrease: function decrease() { newValue = oldValue - _this.options.step; @@ -10204,7 +9230,6 @@ var Slider = /*#__PURE__*/function (_Plugin) { handled: function handled() { // only set handle pos when event was handled specially e.preventDefault(); - _this._setHandlePos(_$handle, newValue); } }); @@ -10214,10 +9239,10 @@ var Slider = /*#__PURE__*/function (_Plugin) { }*/ }); } + /** * Destroys the slider plugin. */ - }, { key: "_destroy", value: function _destroy() { @@ -10227,10 +9252,8 @@ var Slider = /*#__PURE__*/function (_Plugin) { clearTimeout(this.timeout); } }]); - return Slider; }(Plugin); - Slider.defaults = { /** * Minimum value for the slider scale. @@ -10239,7 +9262,6 @@ Slider.defaults = { * @default 0 */ start: 0, - /** * Maximum value for the slider scale. * @option @@ -10247,7 +9269,6 @@ Slider.defaults = { * @default 100 */ end: 100, - /** * Minimum value change per change event. * @option @@ -10255,7 +9276,6 @@ Slider.defaults = { * @default 1 */ step: 1, - /** * Value at which the handle/input *(left handle/first input)* should be set to on initialization. * @option @@ -10263,7 +9283,6 @@ Slider.defaults = { * @default 0 */ initialStart: 0, - /** * Value at which the right handle/second input should be set to on initialization. * @option @@ -10271,7 +9290,6 @@ Slider.defaults = { * @default 100 */ initialEnd: 100, - /** * Allows the input to be located outside the container and visible. Set to by the JS * @option @@ -10279,7 +9297,6 @@ Slider.defaults = { * @default false */ binding: false, - /** * Allows the user to click/tap on the slider bar to select a value. * @option @@ -10287,7 +9304,6 @@ Slider.defaults = { * @default true */ clickSelect: true, - /** * Set to true and use the `vertical` class to change alignment to vertical. * @option @@ -10295,7 +9311,6 @@ Slider.defaults = { * @default false */ vertical: false, - /** * Allows the user to drag the slider handle(s) to select a value. * @option @@ -10303,7 +9318,6 @@ Slider.defaults = { * @default true */ draggable: true, - /** * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`. * @option @@ -10311,7 +9325,6 @@ Slider.defaults = { * @default false */ disabled: false, - /** * Allows the use of two handles. Double checked by the JS. Changes some logic handling. * @option @@ -10319,12 +9332,10 @@ Slider.defaults = { * @default false */ doubleSided: false, - /** * Potential future feature. */ // steps: 100, - /** * Number of decimal places the plugin should go to for floating point precision. * @option @@ -10332,12 +9343,10 @@ Slider.defaults = { * @default 2 */ decimal: 2, - /** * Time delay for dragged elements. */ // dragDelay: 0, - /** * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings. * @option @@ -10346,7 +9355,6 @@ Slider.defaults = { */ moveTime: 200, //update this if changing the transition time in the sass - /** * Class applied to disabled sliders. * @option @@ -10354,7 +9362,6 @@ Slider.defaults = { * @default 'disabled' */ disabledClass: 'disabled', - /** * Will invert the default layout for a vertical slider. * @option @@ -10362,7 +9369,6 @@ Slider.defaults = { * @default false */ invertVertical: false, - /** * Milliseconds before the `changed.zf-slider` event is triggered after value change. * @option @@ -10370,7 +9376,6 @@ Slider.defaults = { * @default 500 */ changedDelay: 500, - /** * Basevalue for non-linear sliders * @option @@ -10378,7 +9383,6 @@ Slider.defaults = { * @default 5 */ nonLinearBase: 5, - /** * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting. * @option @@ -10387,15 +9391,12 @@ Slider.defaults = { */ positionValueFunction: 'linear' }; - function percent(frac, num) { return frac / num; } - function absPosition($handle, dir, clickPos, param) { return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos); } - function baseLog(base, value) { return Math.log(value) / Math.log(base); } @@ -10406,18 +9407,13 @@ function baseLog(base, value) { * @requires foundation.util.triggers * @requires foundation.util.mediaQuery */ - var Sticky = /*#__PURE__*/function (_Plugin) { _inherits(Sticky, _Plugin); - var _super = _createSuper(Sticky); - function Sticky() { _classCallCheck(this, Sticky); - return _super.apply(this, arguments); } - _createClass(Sticky, [{ key: "_setup", value: @@ -10432,27 +9428,24 @@ var Sticky = /*#__PURE__*/function (_Plugin) { this.$element = element; this.options = $.extend({}, Sticky.defaults, this.$element.data(), options); this.className = 'Sticky'; // ie9 back compat - // Triggers init is idempotent, just need to make sure it is initialized + // Triggers init is idempotent, just need to make sure it is initialized Triggers.init($); - this._init(); } + /** * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes * @function * @private */ - }, { key: "_init", value: function _init() { MediaQuery._init(); - var $parent = this.$element.parent('[data-sticky-container]'), - id = this.$element[0].id || GetYoDigits(6, 'sticky'), - _this = this; - + id = this.$element[0].id || GetYoDigits(6, 'sticky'), + _this = this; if ($parent.length) { this.$container = $parent; } else { @@ -10460,145 +9453,122 @@ var Sticky = /*#__PURE__*/function (_Plugin) { this.$element.wrap(this.options.container); this.$container = this.$element.parent(); } - this.$container.addClass(this.options.containerClass); this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id }); - if (this.options.anchor !== '') { $('#' + _this.options.anchor).attr({ 'data-mutate': id }); } - this.scrollCount = this.options.checkEvery; this.isStuck = false; this.onLoadListener = onLoad($(window), function () { //We calculate the container height to have correct values for anchor points offset calculation. _this.containerHeight = _this.$element.css("display") === "none" ? 0 : _this.$element[0].getBoundingClientRect().height; - _this.$container.css('height', _this.containerHeight); - _this.elemHeight = _this.containerHeight; - if (_this.options.anchor !== '') { _this.$anchor = $('#' + _this.options.anchor); } else { _this._parsePoints(); } - _this._setSizes(function () { var scroll = window.pageYOffset; - - _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set. - - + _this._calc(false, scroll); + //Unstick the element will ensure that proper classes are set. if (!_this.isStuck) { _this._removeSticky(scroll >= _this.topPoint ? false : true); } }); - _this._events(id.split('-').reverse().join('-')); }); } + /** * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on. * @function * @private */ - }, { key: "_parsePoints", value: function _parsePoints() { var top = this.options.topAnchor === "" ? 1 : this.options.topAnchor, - btm = this.options.btmAnchor === "" ? document.documentElement.scrollHeight : this.options.btmAnchor, - pts = [top, btm], - breaks = {}; - + btm = this.options.btmAnchor === "" ? document.documentElement.scrollHeight : this.options.btmAnchor, + pts = [top, btm], + breaks = {}; for (var i = 0, len = pts.length; i < len && pts[i]; i++) { var pt; - if (typeof pts[i] === 'number') { pt = pts[i]; } else { var place = pts[i].split(':'), - anchor = $("#".concat(place[0])); + anchor = $("#".concat(place[0])); pt = anchor.offset().top; - if (place[1] && place[1].toLowerCase() === 'bottom') { pt += anchor[0].getBoundingClientRect().height; } } - breaks[i] = pt; } - this.points = breaks; return; } + /** * Adds event handlers for the scrolling element. * @private * @param {String} id - pseudo-random id for unique scroll event listener. */ - }, { key: "_events", value: function _events(id) { var _this = this, - scrollListener = this.scrollListener = "scroll.zf.".concat(id); - + scrollListener = this.scrollListener = "scroll.zf.".concat(id); if (this.isOn) { return; } - if (this.canStick) { this.isOn = true; $(window).off(scrollListener).on(scrollListener, function () { if (_this.scrollCount === 0) { _this.scrollCount = _this.options.checkEvery; - _this._setSizes(function () { _this._calc(false, window.pageYOffset); }); } else { _this.scrollCount--; - _this._calc(false, window.pageYOffset); } }); } - this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () { _this._eventsHandler(id); }); this.$element.on('mutateme.zf.trigger', function () { _this._eventsHandler(id); }); - if (this.$anchor) { this.$anchor.on('mutateme.zf.trigger', function () { _this._eventsHandler(id); }); } } + /** * Handler for events. * @private * @param {String} id - pseudo-random id for unique scroll event listener. */ - }, { key: "_eventsHandler", value: function _eventsHandler(id) { var _this = this, - scrollListener = this.scrollListener = "scroll.zf.".concat(id); - + scrollListener = this.scrollListener = "scroll.zf.".concat(id); _this._setSizes(function () { _this._calc(false); - if (_this.canStick) { if (!_this.isOn) { _this._events(id); @@ -10608,51 +9578,47 @@ var Sticky = /*#__PURE__*/function (_Plugin) { } }); } + /** * Removes event handlers for scroll and change events on anchor. * @fires Sticky#pause * @param {String} scrollListener - unique, namespaced scroll listener attached to `window` */ - }, { key: "_pauseListeners", value: function _pauseListeners(scrollListener) { this.isOn = false; $(window).off(scrollListener); + /** * Fires when the plugin is paused due to resize event shrinking the view. * @event Sticky#pause * @private */ - this.$element.trigger('pause.zf.sticky'); } + /** * Called on every `scroll` event and on `_init` * fires functions based on booleans and cached values * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints. * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`. */ - }, { key: "_calc", value: function _calc(checkSizes, scroll) { if (checkSizes) { this._setSizes(); } - if (!this.canStick) { if (this.isStuck) { this._removeSticky(true); } - return false; } - if (!scroll) { scroll = window.pageYOffset; } - if (scroll >= this.topPoint) { if (scroll <= this.bottomPoint) { if (!this.isStuck) { @@ -10669,6 +9635,7 @@ var Sticky = /*#__PURE__*/function (_Plugin) { } } } + /** * Causes the $element to become stuck. * Adds `position: fixed;`, and helper classes. @@ -10676,16 +9643,14 @@ var Sticky = /*#__PURE__*/function (_Plugin) { * @function * @private */ - }, { key: "_setSticky", value: function _setSticky() { var _this = this, - stickTo = this.options.stickTo, - mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom', - notStuckTo = stickTo === 'top' ? 'bottom' : 'top', - css = {}; - + stickTo = this.options.stickTo, + mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom', + notStuckTo = stickTo === 'top' ? 'bottom' : 'top', + css = {}; css[mrgn] = "".concat(this.options[mrgn], "em"); css[stickTo] = 0; css[notStuckTo] = 'auto'; @@ -10695,12 +9660,12 @@ var Sticky = /*#__PURE__*/function (_Plugin) { * Fires when the $element has become `position: fixed;` * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top` * @event Sticky#stuckto - */ - .trigger("sticky.zf.stuckto:".concat(stickTo)); + */.trigger("sticky.zf.stuckto:".concat(stickTo)); this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () { _this._setSizes(); }); } + /** * Causes the $element to become unstuck. * Removes `position: fixed;`, and helper classes. @@ -10709,67 +9674,60 @@ var Sticky = /*#__PURE__*/function (_Plugin) { * @fires Sticky#unstuckfrom * @private */ - }, { key: "_removeSticky", value: function _removeSticky(isTop) { var stickTo = this.options.stickTo, - stickToTop = stickTo === 'top', - css = {}, - anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight, - mrgn = stickToTop ? 'marginTop' : 'marginBottom', - topOrBottom = isTop ? 'top' : 'bottom'; + stickToTop = stickTo === 'top', + css = {}, + anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight, + mrgn = stickToTop ? 'marginTop' : 'marginBottom', + topOrBottom = isTop ? 'top' : 'bottom'; css[mrgn] = 0; css.bottom = 'auto'; - if (isTop) { css.top = 0; } else { css.top = anchorPt; } - this.isStuck = false; this.$element.removeClass("is-stuck is-at-".concat(stickTo)).addClass("is-anchored is-at-".concat(topOrBottom)).css(css) /** * Fires when the $element has become anchored. * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom` * @event Sticky#unstuckfrom - */ - .trigger("sticky.zf.unstuckfrom:".concat(topOrBottom)); + */.trigger("sticky.zf.unstuckfrom:".concat(topOrBottom)); } + /** * Sets the $element and $container sizes for plugin. * Calls `_setBreakPoints`. * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`. * @private */ - }, { key: "_setSizes", value: function _setSizes(cb) { this.canStick = MediaQuery.is(this.options.stickyOn); - if (!this.canStick) { if (cb && typeof cb === 'function') { cb(); } } - var newElemWidth = this.$container[0].getBoundingClientRect().width, - comp = window.getComputedStyle(this.$container[0]), - pdngl = parseInt(comp['padding-left'], 10), - pdngr = parseInt(comp['padding-right'], 10); - + comp = window.getComputedStyle(this.$container[0]), + pdngl = parseInt(comp['padding-left'], 10), + pdngr = parseInt(comp['padding-right'], 10); if (this.$anchor && this.$anchor.length) { this.anchorHeight = this.$anchor[0].getBoundingClientRect().height; } else { this._parsePoints(); } - this.$element.css({ 'max-width': "".concat(newElemWidth - pdngl - pdngr, "px") - }); // Recalculate the height only if it is "dynamic" + }); + // Recalculate the height only if it is "dynamic" if (this.options.dynamicHeight || !this.containerHeight) { // Get the sticked element height and apply it to the container to "hold the place" var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight; @@ -10777,29 +9735,26 @@ var Sticky = /*#__PURE__*/function (_Plugin) { this.$container.css('height', newContainerHeight); this.containerHeight = newContainerHeight; } - this.elemHeight = this.containerHeight; - if (!this.isStuck) { if (this.$element.hasClass('is-at-bottom')) { var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight; this.$element.css('top', anchorPt); } } - this._setBreakPoints(this.containerHeight, function () { if (cb && typeof cb === 'function') { cb(); } }); } + /** * Sets the upper and lower breakpoints for the element to become sticky/unsticky. * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`. * @param {Function} cb - optional callback function to be called on completion. * @private */ - }, { key: "_setBreakPoints", value: function _setBreakPoints(elemHeight, cb) { @@ -10810,15 +9765,13 @@ var Sticky = /*#__PURE__*/function (_Plugin) { return false; } } - var mTop = emCalc(this.options.marginTop), - mBtm = emCalc(this.options.marginBottom), - topPoint = this.points ? this.points[0] : this.$anchor.offset().top, - bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight, - // topPoint = this.$anchor.offset().top || this.points[0], - // bottomPoint = topPoint + this.anchorHeight || this.points[1], - winHeight = window.innerHeight; - + mBtm = emCalc(this.options.marginBottom), + topPoint = this.points ? this.points[0] : this.$anchor.offset().top, + bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight, + // topPoint = this.$anchor.offset().top || this.points[0], + // bottomPoint = topPoint + this.anchorHeight || this.points[1], + winHeight = window.innerHeight; if (this.options.stickTo === 'top') { topPoint -= mTop; bottomPoint -= elemHeight + mTop; @@ -10826,40 +9779,34 @@ var Sticky = /*#__PURE__*/function (_Plugin) { topPoint -= winHeight - (elemHeight + mBtm); bottomPoint -= winHeight - mBtm; } - this.topPoint = topPoint; this.bottomPoint = bottomPoint; - if (cb && typeof cb === 'function') { cb(); } } + /** * Destroys the current sticky element. * Resets the element to the top position first. * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container. * @function */ - }, { key: "_destroy", value: function _destroy() { this._removeSticky(true); - this.$element.removeClass("".concat(this.options.stickyClass, " is-anchored is-at-top")).css({ height: '', top: '', bottom: '', 'max-width': '' }).off('resizeme.zf.trigger').off('mutateme.zf.trigger'); - if (this.$anchor && this.$anchor.length) { this.$anchor.off('change.zf.sticky'); } - if (this.scrollListener) $(window).off(this.scrollListener); if (this.onLoadListener) $(window).off(this.onLoadListener); - if (this.wasWrapped) { this.$element.unwrap(); } else { @@ -10869,10 +9816,8 @@ var Sticky = /*#__PURE__*/function (_Plugin) { } } }]); - return Sticky; }(Plugin); - Sticky.defaults = { /** * Customizable container template. Add your own classes for styling and sizing. @@ -10881,7 +9826,6 @@ Sticky.defaults = { * @default '<div data-sticky-container></div>' */ container: '
    ', - /** * Location in the view the element sticks to. Can be `'top'` or `'bottom'`. * @option @@ -10889,7 +9833,6 @@ Sticky.defaults = { * @default 'top' */ stickTo: 'top', - /** * If anchored to a single element, the id of that element. * @option @@ -10897,7 +9840,6 @@ Sticky.defaults = { * @default '' */ anchor: '', - /** * If using more than one element as anchor points, the id of the top anchor. * @option @@ -10905,7 +9847,6 @@ Sticky.defaults = { * @default '' */ topAnchor: '', - /** * If using more than one element as anchor points, the id of the bottom anchor. * @option @@ -10913,7 +9854,6 @@ Sticky.defaults = { * @default '' */ btmAnchor: '', - /** * Margin, in `em`'s to apply to the top of the element when it becomes sticky. * @option @@ -10921,7 +9861,6 @@ Sticky.defaults = { * @default 1 */ marginTop: 1, - /** * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky. * @option @@ -10929,7 +9868,6 @@ Sticky.defaults = { * @default 1 */ marginBottom: 1, - /** * Breakpoint string that is the minimum screen size an element should become sticky. * @option @@ -10937,7 +9875,6 @@ Sticky.defaults = { * @default 'medium' */ stickyOn: 'medium', - /** * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`. * @option @@ -10945,7 +9882,6 @@ Sticky.defaults = { * @default 'sticky' */ stickyClass: 'sticky', - /** * Class applied to sticky container. Foundation defaults to `sticky-container`. * @option @@ -10953,7 +9889,6 @@ Sticky.defaults = { * @default 'sticky-container' */ containerClass: 'sticky-container', - /** * If true (by default), keep the sticky container the same height as the element. Otherwise, the container height is set once and does not change. * @option @@ -10961,7 +9896,6 @@ Sticky.defaults = { * @default true */ dynamicHeight: true, - /** * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll. * @option @@ -10970,11 +9904,11 @@ Sticky.defaults = { */ checkEvery: -1 }; + /** * Helper function to calculate em values * @param Number {em} - number of em's to calculate into pixels */ - function emCalc(em) { return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em; } @@ -10985,18 +9919,13 @@ function emCalc(em) { * @requires foundation.util.keyboard * @requires foundation.util.imageLoader if tabs contain images */ - var Tabs = /*#__PURE__*/function (_Plugin) { _inherits(Tabs, _Plugin); - var _super = _createSuper(Tabs); - function Tabs() { _classCallCheck(this, Tabs); - return _super.apply(this, arguments); } - _createClass(Tabs, [{ key: "_setup", value: @@ -11014,30 +9943,27 @@ var Tabs = /*#__PURE__*/function (_Plugin) { this.className = 'Tabs'; // ie9 back compat this._init(); - Keyboard.register('Tabs', { 'ENTER': 'open', 'SPACE': 'open', 'ARROW_RIGHT': 'next', 'ARROW_UP': 'previous', 'ARROW_DOWN': 'next', - 'ARROW_LEFT': 'previous' // 'TAB': 'next', + 'ARROW_LEFT': 'previous' + // 'TAB': 'next', // 'SHIFT_TAB': 'previous' - }); } + /** * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab. * @private */ - }, { key: "_init", value: function _init() { var _this2 = this; - var _this = this; - this._isInitializing = true; this.$element.attr({ 'role': 'tablist' @@ -11046,11 +9972,11 @@ var Tabs = /*#__PURE__*/function (_Plugin) { this.$tabContent = $("[data-tabs-content=\"".concat(this.$element[0].id, "\"]")); this.$tabTitles.each(function () { var $elem = $(this), - $link = $elem.find('a'), - isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)), - hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1), - linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"), - $tabContent = $("#".concat(hash)); + $link = $elem.find('a'), + isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)), + hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1), + linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"), + $tabContent = $("#".concat(hash)); $elem.attr({ 'role': 'presentation' }); @@ -11064,16 +9990,15 @@ var Tabs = /*#__PURE__*/function (_Plugin) { $tabContent.attr({ 'role': 'tabpanel', 'aria-labelledby': linkId - }); // Save up the initial hash to return to it later when going back in history + }); + // Save up the initial hash to return to it later when going back in history if (isActive) { _this._initialAnchor = "#".concat(hash); } - if (!isActive) { $tabContent.attr('aria-hidden', 'true'); } - if (isActive && _this.options.autoFocus) { _this.onLoadListener = onLoad($(window), function () { $('html, body').animate({ @@ -11084,127 +10009,110 @@ var Tabs = /*#__PURE__*/function (_Plugin) { }); } }); - if (this.options.matchHeight) { var $images = this.$tabContent.find('img'); - if ($images.length) { onImagesLoaded($images, this._setHeight.bind(this)); } else { this._setHeight(); } - } // Current context-bound function to open tabs on page load or history hashchange - + } + // Current context-bound function to open tabs on page load or history hashchange this._checkDeepLink = function () { var anchor = window.location.hash; - if (!anchor.length) { // If we are still initializing and there is no anchor, then there is nothing to do - if (_this2._isInitializing) return; // Otherwise, move to the initial anchor - + if (_this2._isInitializing) return; + // Otherwise, move to the initial anchor if (_this2._initialAnchor) anchor = _this2._initialAnchor; } - var anchorNoHash = anchor.indexOf('#') >= 0 ? anchor.slice(1) : anchor; var $anchor = anchorNoHash && $("#".concat(anchorNoHash)); - - var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"],[data-tabs-target=\"").concat(anchorNoHash, "\"]")).first(); // Whether the anchor element that has been found is part of this element - - + var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"],[data-tabs-target=\"").concat(anchorNoHash, "\"]")).first(); + // Whether the anchor element that has been found is part of this element var isOwnAnchor = !!($anchor.length && $link.length); - if (isOwnAnchor) { // If there is an anchor for the hash, select it if ($anchor && $anchor.length && $link && $link.length) { _this2.selectTab($anchor, true); - } // Otherwise, collapse everything + } + // Otherwise, collapse everything else { _this2._collapse(); - } // Roll up a little to show the titles - + } + // Roll up a little to show the titles if (_this2.options.deepLinkSmudge) { var offset = _this2.$element.offset(); - $('html, body').animate({ scrollTop: offset.top - _this2.options.deepLinkSmudgeOffset }, _this2.options.deepLinkSmudgeDelay); } + /** * Fires when the plugin has deeplinked at pageload * @event Tabs#deeplink */ - - _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]); } - }; //use browser to open a tab, if it exists in this tabset - + }; + //use browser to open a tab, if it exists in this tabset if (this.options.deepLink) { this._checkDeepLink(); } - this._events(); - this._isInitializing = false; } + /** * Adds event handlers for items within the tabs. * @private */ - }, { key: "_events", value: function _events() { this._addKeyHandler(); - this._addClickHandler(); - this._setHeightMqHandler = null; - if (this.options.matchHeight) { this._setHeightMqHandler = this._setHeight.bind(this); $(window).on('changed.zf.mediaquery', this._setHeightMqHandler); } - if (this.options.deepLink) { $(window).on('hashchange', this._checkDeepLink); } } + /** * Adds click handlers for items within the tabs. * @private */ - }, { key: "_addClickHandler", value: function _addClickHandler() { var _this = this; - this.$element.off('click.zf.tabs').on('click.zf.tabs', ".".concat(this.options.linkClass), function (e) { e.preventDefault(); - _this._handleTabChange($(this)); }); } + /** * Adds keyboard event handlers for items within the tabs. * @private */ - }, { key: "_addKeyHandler", value: function _addKeyHandler() { var _this = this; - this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) { if (e.which === 9) return; var $element = $(this), - $elements = $element.parent('ul').children('li'), - $prevElement, - $nextElement; + $elements = $element.parent('ul').children('li'), + $prevElement, + $nextElement; $elements.each(function (i) { if ($(this).is($element)) { if (_this.options.wrapOnKeys) { @@ -11214,25 +10122,22 @@ var Tabs = /*#__PURE__*/function (_Plugin) { $prevElement = $elements.eq(Math.max(0, i - 1)); $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)); } - return; } - }); // handle keyboard event with keyboard util + }); + // handle keyboard event with keyboard util Keyboard.handleKey(e, 'Tabs', { open: function open() { $element.find('[role="tab"]').focus(); - _this._handleTabChange($element); }, previous: function previous() { $prevElement.find('[role="tab"]').focus(); - _this._handleTabChange($prevElement); }, next: function next() { $nextElement.find('[role="tab"]').focus(); - _this._handleTabChange($nextElement); }, handled: function handled() { @@ -11241,6 +10146,7 @@ var Tabs = /*#__PURE__*/function (_Plugin) { }); }); } + /** * Opens the tab `$targetContent` defined by `$target`. Collapses active tab. * @param {jQuery} $target - Tab to open. @@ -11248,7 +10154,6 @@ var Tabs = /*#__PURE__*/function (_Plugin) { * @fires Tabs#change * @function */ - }, { key: "_handleTabChange", value: function _handleTabChange($target, historyHandled) { @@ -11257,22 +10162,21 @@ var Tabs = /*#__PURE__*/function (_Plugin) { if (this.options.activeCollapse) { this._collapse(); } - return; } - var $oldTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)), - $tabLink = $target.find('[role="tab"]'), - target = $tabLink.attr('data-tabs-target'), - anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash, - $targetContent = this.$tabContent.find(anchor); //close old tab - - this._collapseTab($oldTab); //open new tab + $tabLink = $target.find('[role="tab"]'), + target = $tabLink.attr('data-tabs-target'), + anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash, + $targetContent = this.$tabContent.find(anchor); + //close old tab + this._collapseTab($oldTab); - this._openTab($target); //either replace or update browser history - + //open new tab + this._openTab($target); + //either replace or update browser history if (this.options.deepLink && !historyHandled) { if (this.options.updateHistory) { history.pushState({}, '', anchor); @@ -11280,28 +10184,28 @@ var Tabs = /*#__PURE__*/function (_Plugin) { history.replaceState({}, '', anchor); } } + /** * Fires when the plugin has successfully changed tabs. * @event Tabs#change */ + this.$element.trigger('change.zf.tabs', [$target, $targetContent]); - - this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event - + //fire to children a mutation event $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger"); } + /** * Opens the tab `$targetContent` defined by `$target`. * @param {jQuery} $target - Tab to open. * @function */ - }, { key: "_openTab", value: function _openTab($target) { var $tabLink = $target.find('[role="tab"]'), - hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1), - $targetContent = this.$tabContent.find("#".concat(hash)); + hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1), + $targetContent = this.$tabContent.find("#".concat(hash)); $target.addClass("".concat(this.options.linkActiveClass)); $tabLink.attr({ 'aria-selected': 'true', @@ -11309,12 +10213,12 @@ var Tabs = /*#__PURE__*/function (_Plugin) { }); $targetContent.addClass("".concat(this.options.panelActiveClass)).removeAttr('aria-hidden'); } + /** * Collapses `$targetContent` defined by `$target`. * @param {jQuery} $target - Tab to collapse. * @function */ - }, { key: "_collapseTab", value: function _collapseTab($target) { @@ -11326,55 +10230,49 @@ var Tabs = /*#__PURE__*/function (_Plugin) { 'aria-hidden': 'true' }); } + /** * Collapses the active Tab. * @fires Tabs#collapse * @function */ - }, { key: "_collapse", value: function _collapse() { var $activeTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)); - if ($activeTab.length) { this._collapseTab($activeTab); + /** * Fires when the plugin has successfully collapsed tabs. * @event Tabs#collapse */ - - this.$element.trigger('collapse.zf.tabs', [$activeTab]); } } + /** * Public method for selecting a content pane to display. * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display. * @param {boolean} historyHandled - browser has already handled a history update * @function */ - }, { key: "selectTab", value: function selectTab(elem, historyHandled) { var idStr, hashIdStr; - if (_typeof(elem) === 'object') { idStr = elem[0].id; } else { idStr = elem; } - if (idStr.indexOf('#') < 0) { hashIdStr = "#".concat(idStr); } else { hashIdStr = idStr; idStr = idStr.slice(1); } - var $target = this.$tabTitles.has("[href$=\"".concat(hashIdStr, "\"],[data-tabs-target=\"").concat(idStr, "\"]")).first(); - this._handleTabChange($target, historyHandled); } }, { @@ -11390,16 +10288,14 @@ var Tabs = /*#__PURE__*/function (_Plugin) { */ function _setHeight() { var max = 0, - _this = this; // Lock down the `this` value for the root tabs object - + _this = this; // Lock down the `this` value for the root tabs object if (!this.$tabContent) { return; } - this.$tabContent.find(".".concat(this.options.panelClass)).css('min-height', '').each(function () { var panel = $(this), - isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child + isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child if (!isActive) { panel.css({ @@ -11407,48 +10303,40 @@ var Tabs = /*#__PURE__*/function (_Plugin) { 'display': 'block' }); } - var temp = this.getBoundingClientRect().height; - if (!isActive) { panel.css({ 'visibility': '', 'display': '' }); } - max = temp > max ? temp : max; }).css('min-height', "".concat(max, "px")); } + /** * Destroys an instance of tabs. * @fires Tabs#destroyed */ - }, { key: "_destroy", value: function _destroy() { this.$element.find(".".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(".".concat(this.options.panelClass)).hide(); - if (this.options.matchHeight) { if (this._setHeightMqHandler != null) { $(window).off('changed.zf.mediaquery', this._setHeightMqHandler); } } - if (this.options.deepLink) { $(window).off('hashchange', this._checkDeepLink); } - if (this.onLoadListener) { $(window).off(this.onLoadListener); } } }]); - return Tabs; }(Plugin); - Tabs.defaults = { /** * Link the location hash to the active pane. @@ -11458,7 +10346,6 @@ Tabs.defaults = { * @default false */ deepLink: false, - /** * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible * @option @@ -11466,7 +10353,6 @@ Tabs.defaults = { * @default false */ deepLinkSmudge: false, - /** * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment * @option @@ -11474,7 +10360,6 @@ Tabs.defaults = { * @default 300 */ deepLinkSmudgeDelay: 300, - /** * If `deepLinkSmudge` is enabled, animation offset from the top for the deep link adjustment * @option @@ -11482,7 +10367,6 @@ Tabs.defaults = { * @default 0 */ deepLinkSmudgeOffset: 0, - /** * If `deepLink` is enabled, update the browser history with the open tab * @option @@ -11490,7 +10374,6 @@ Tabs.defaults = { * @default false */ updateHistory: false, - /** * Allows the window to scroll to content of active pane on load. * Not recommended if more than one tab panel per page. @@ -11499,7 +10382,6 @@ Tabs.defaults = { * @default false */ autoFocus: false, - /** * Allows keyboard input to 'wrap' around the tab links. * @option @@ -11507,7 +10389,6 @@ Tabs.defaults = { * @default true */ wrapOnKeys: true, - /** * Allows the tab content panes to match heights if set to true. * @option @@ -11515,7 +10396,6 @@ Tabs.defaults = { * @default false */ matchHeight: false, - /** * Allows active tabs to collapse when clicked. * @option @@ -11523,7 +10403,6 @@ Tabs.defaults = { * @default false */ activeCollapse: false, - /** * Class applied to `li`'s in tab link list. * @option @@ -11531,7 +10410,6 @@ Tabs.defaults = { * @default 'tabs-title' */ linkClass: 'tabs-title', - /** * Class applied to the active `li` in tab link list. * @option @@ -11539,7 +10417,6 @@ Tabs.defaults = { * @default 'is-active' */ linkActiveClass: 'is-active', - /** * Class applied to the content containers. * @option @@ -11547,7 +10424,6 @@ Tabs.defaults = { * @default 'tabs-panel' */ panelClass: 'tabs-panel', - /** * Class applied to the active content container. * @option @@ -11563,18 +10439,13 @@ Tabs.defaults = { * @requires foundation.util.motion * @requires foundation.util.triggers */ - var Toggler = /*#__PURE__*/function (_Plugin) { _inherits(Toggler, _Plugin); - var _super = _createSuper(Toggler); - function Toggler() { _classCallCheck(this, Toggler); - return _super.apply(this, arguments); } - _createClass(Toggler, [{ key: "_setup", value: @@ -11591,49 +10462,48 @@ var Toggler = /*#__PURE__*/function (_Plugin) { this.options = $.extend({}, Toggler.defaults, element.data(), options); this.className = ''; this.className = 'Toggler'; // ie9 back compat - // Triggers init is idempotent, just need to make sure it is initialized + // Triggers init is idempotent, just need to make sure it is initialized Triggers.init($); - this._init(); - this._events(); } + /** * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate. * @function * @private */ - }, { key: "_init", value: function _init() { // Collect triggers to set ARIA attributes to var id = this.$element[0].id, - $triggers = $("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); - var input; // Parse animation classes if they were set - + $triggers = $("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); + var input; + // Parse animation classes if they were set if (this.options.animate) { input = this.options.animate.split(' '); this.animationIn = input[0]; - this.animationOut = input[1] || null; // - aria-expanded: according to the element visibility. + this.animationOut = input[1] || null; + // - aria-expanded: according to the element visibility. $triggers.attr('aria-expanded', !this.$element.is(':hidden')); - } // Otherwise, parse toggle class + } + // Otherwise, parse toggle class else { input = this.options.toggler; - if (typeof input !== 'string' || !input.length) { throw new Error("The 'toggler' option containing the target class is required, got \"".concat(input, "\"")); - } // Allow for a . at the beginning of the string - - - this.className = input[0] === '.' ? input.slice(1) : input; // - aria-expanded: according to the elements class set. + } + // Allow for a . at the beginning of the string + this.className = input[0] === '.' ? input.slice(1) : input; + // - aria-expanded: according to the elements class set. $triggers.attr('aria-expanded', this.$element.hasClass(this.className)); - } // - aria-controls: adding the element id to it if not already in it. - + } + // - aria-controls: adding the element id to it if not already in it. $triggers.each(function (index, trigger) { var $trigger = $(trigger); var controls = $trigger.attr('aria-controls') || ''; @@ -11641,24 +10511,24 @@ var Toggler = /*#__PURE__*/function (_Plugin) { if (!containsId) $trigger.attr('aria-controls', controls ? "".concat(controls, " ").concat(id) : id); }); } + /** * Initializes events for the toggle trigger. * @function * @private */ - }, { key: "_events", value: function _events() { this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this)); } + /** * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off". * @function * @fires Toggler#on * @fires Toggler#off */ - }, { key: "toggle", value: function toggle() { @@ -11669,7 +10539,6 @@ var Toggler = /*#__PURE__*/function (_Plugin) { value: function _toggleClass() { this.$element.toggleClass(this.className); var isOn = this.$element.hasClass(this.className); - if (isOn) { /** * Fires if the target element has the class after a toggle. @@ -11683,27 +10552,22 @@ var Toggler = /*#__PURE__*/function (_Plugin) { */ this.$element.trigger('off.zf.toggler'); } - this._updateARIA(isOn); - this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger'); } }, { key: "_toggleAnimate", value: function _toggleAnimate() { var _this = this; - if (this.$element.is(':hidden')) { Motion.animateIn(this.$element, this.animationIn, function () { _this._updateARIA(true); - this.trigger('on.zf.toggler'); this.find('[data-mutate]').trigger('mutateme.zf.trigger'); }); } else { Motion.animateOut(this.$element, this.animationOut, function () { _this._updateARIA(false); - this.trigger('off.zf.toggler'); this.find('[data-mutate]').trigger('mutateme.zf.trigger'); }); @@ -11717,21 +10581,19 @@ var Toggler = /*#__PURE__*/function (_Plugin) { 'aria-expanded': isOn ? true : false }); } + /** * Destroys the instance of Toggler on the element. * @function */ - }, { key: "_destroy", value: function _destroy() { this.$element.off('.zf.toggler'); } }]); - return Toggler; }(Plugin); - Toggler.defaults = { /** * Class of the element to toggle. It can be provided with or without "." @@ -11739,7 +10601,6 @@ Toggler.defaults = { * @type {string} */ toggler: undefined, - /** * Tells the plugin if the element should animated when toggled. * @option @@ -11756,18 +10617,13 @@ Toggler.defaults = { * @requires foundation.util.mediaQuery * @requires foundation.util.triggers */ - var Tooltip = /*#__PURE__*/function (_Positionable) { _inherits(Tooltip, _Positionable); - var _super = _createSuper(Tooltip); - function Tooltip() { _classCallCheck(this, Tooltip); - return _super.apply(this, arguments); } - _createClass(Tooltip, [{ key: "_setup", value: @@ -11785,32 +10641,29 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { this.className = 'Tooltip'; // ie9 back compat this.isActive = false; - this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized + this.isClick = false; + // Triggers init is idempotent, just need to make sure it is initialized Triggers.init($); - this._init(); } + /** * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor. * @private */ - }, { key: "_init", value: function _init() { MediaQuery._init(); - var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip'); this.options.tipText = this.options.tipText || this.$element.attr('title'); this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId); - if (this.options.allowHtml) { this.template.appendTo(document.body).html(this.options.tipText).hide(); } else { this.template.appendTo(document.body).text(this.options.tipText).hide(); } - this.$element.attr({ 'title': '', 'aria-describedby': elemId, @@ -11818,9 +10671,7 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { 'data-toggle': elemId, 'data-resize': elemId }).addClass(this.options.triggerClass); - _get(_getPrototypeOf(Tooltip.prototype), "_init", this).call(this); - this._events(); } }, { @@ -11828,11 +10679,9 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { value: function _getDefaultPosition() { // handle legacy classnames var elementClassName = this.$element[0].className; - if (this.$element[0] instanceof SVGElement) { elementClassName = elementClassName.baseVal; } - var position = elementClassName.match(/\b(top|left|right|bottom)\b/g); return position ? position[0] : 'top'; } @@ -11859,11 +10708,11 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { return this.options.vOffset; } } + /** * builds the tooltip element, adds attributes, and returns the template. * @private */ - }, { key: "_buildTemplate", value: function _buildTemplate(id) { @@ -11877,24 +10726,24 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { }); return $template; } + /** * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding. * if the tooltip is larger than the screen width, default to full width - any user selected margin * @private */ - }, { key: "_setPosition", value: function _setPosition() { _get(_getPrototypeOf(Tooltip.prototype), "_setPosition", this).call(this, this.$element, this.template); } + /** * reveals the tooltip, and fires an event to close any other open tooltips on the page * @fires Tooltip#closeme * @fires Tooltip#show * @function */ - }, { key: "show", value: function show() { @@ -11902,46 +10751,41 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { // console.error('The screen is too small to display this tooltip'); return false; } - var _this = this; - this.template.css('visibility', 'hidden').show(); - this._setPosition(); - this.template.removeClass('top bottom left right').addClass(this.position); this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment); + /** * Fires to close all other open tooltips on the page * @event Closeme#tooltip */ - this.$element.trigger('closeme.zf.tooltip', this.template.attr('id')); this.template.attr({ 'data-is-active': true, 'aria-hidden': false }); _this.isActive = true; - this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff? + this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () { + //maybe do stuff? }); /** * Fires when the tooltip is shown * @event Tooltip#show */ - this.$element.trigger('show.zf.tooltip'); } + /** * Hides the current tooltip, and resets the positioning class if it was changed due to collision * @fires Tooltip#hide * @function */ - }, { key: "hide", value: function hide() { var _this = this; - this.template.stop().attr({ 'aria-hidden': true, 'data-is-active': false @@ -11953,25 +10797,23 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { * fires when the tooltip is hidden * @event Tooltip#hide */ - this.$element.trigger('hide.zf.tooltip'); } + /** * adds event listeners for the tooltip and its anchor * TODO combine some of the listeners like focus and mouseenter, etc. * @private */ - }, { key: "_events", value: function _events() { var _this = this; - var hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined'; - var isFocus = false; // `disableForTouch: Fully disable the tooltip on touch devices + var isFocus = false; + // `disableForTouch: Fully disable the tooltip on touch devices if (hasTouch && this.options.disableForTouch) return; - if (!this.options.disableHover) { this.$element.on('mouseenter.zf.tooltip', function () { if (!_this.isActive) { @@ -11981,24 +10823,20 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { } }).on('mouseleave.zf.tooltip', ignoreMousedisappear(function () { clearTimeout(_this.timeout); - if (!isFocus || _this.isClick && !_this.options.clickOpen) { _this.hide(); } })); } - if (hasTouch) { this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function () { _this.isActive ? _this.hide() : _this.show(); }); } - if (this.options.clickOpen) { this.$element.on('mousedown.zf.tooltip', function () { if (_this.isClick) ; else { _this.isClick = true; - if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) { _this.show(); } @@ -12009,7 +10847,6 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { _this.isClick = true; }); } - this.$element.on({ // 'toggle.zf.trigger': this.toggle.bind(this), // 'close.zf.trigger': this.hide.bind(this) @@ -12017,14 +10854,12 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { }); this.$element.on('focus.zf.tooltip', function () { isFocus = true; - if (_this.isClick) { // If we're not showing open on clicks, we need to pretend a click-launched focus isn't // a real focus, otherwise on hover and come back we get bad behavior if (!_this.options.clickOpen) { isFocus = false; } - return false; } else { _this.show(); @@ -12032,7 +10867,6 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { }).on('focusout.zf.tooltip', function () { isFocus = false; _this.isClick = false; - _this.hide(); }).on('resizeme.zf.trigger', function () { if (_this.isActive) { @@ -12040,11 +10874,11 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { } }); } + /** * adds a toggle method, in addition to the static show() & hide() functions * @function */ - }, { key: "toggle", value: function toggle() { @@ -12054,11 +10888,11 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { this.show(); } } + /** * Destroys an instance of tooltip, removes template element from the view. * @function */ - }, { key: "_destroy", value: function _destroy() { @@ -12066,10 +10900,8 @@ var Tooltip = /*#__PURE__*/function (_Positionable) { this.template.remove(); } }]); - return Tooltip; }(Positionable); - Tooltip.defaults = { /** * Time, in ms, before a tooltip should open on hover. @@ -12078,7 +10910,6 @@ Tooltip.defaults = { * @default 200 */ hoverDelay: 200, - /** * Time, in ms, a tooltip should take to fade into view. * @option @@ -12086,7 +10917,6 @@ Tooltip.defaults = { * @default 150 */ fadeInDuration: 150, - /** * Time, in ms, a tooltip should take to fade out of view. * @option @@ -12094,7 +10924,6 @@ Tooltip.defaults = { * @default 150 */ fadeOutDuration: 150, - /** * Disables hover events from opening the tooltip if set to true * @option @@ -12102,7 +10931,6 @@ Tooltip.defaults = { * @default false */ disableHover: false, - /** * Disable the tooltip for touch devices. * This can be useful to make elements with a tooltip on it trigger their @@ -12112,7 +10940,6 @@ Tooltip.defaults = { * @default false */ disableForTouch: false, - /** * Optional addtional classes to apply to the tooltip template on init. * @option @@ -12120,7 +10947,6 @@ Tooltip.defaults = { * @default '' */ templateClasses: '', - /** * Non-optional class added to tooltip templates. Foundation default is 'tooltip'. * @option @@ -12128,7 +10954,6 @@ Tooltip.defaults = { * @default 'tooltip' */ tooltipClass: 'tooltip', - /** * Class applied to the tooltip anchor element. * @option @@ -12136,7 +10961,6 @@ Tooltip.defaults = { * @default 'has-tip' */ triggerClass: 'has-tip', - /** * Minimum breakpoint size at which to open the tooltip. * @option @@ -12144,7 +10968,6 @@ Tooltip.defaults = { * @default 'small' */ showOn: 'small', - /** * Custom template to be used to generate markup for tooltip. * @option @@ -12152,7 +10975,6 @@ Tooltip.defaults = { * @default '' */ template: '', - /** * Text displayed in the tooltip template on open. * @option @@ -12161,7 +10983,6 @@ Tooltip.defaults = { */ tipText: '', touchCloseText: 'Tap to close.', - /** * Allows the tooltip to remain open if triggered with a click or touch event. * @option @@ -12169,7 +10990,6 @@ Tooltip.defaults = { * @default true */ clickOpen: true, - /** * Position of tooltip. Can be left, right, bottom, top, or auto. * @option @@ -12177,7 +10997,6 @@ Tooltip.defaults = { * @default 'auto' */ position: 'auto', - /** * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto. * @option @@ -12185,7 +11004,6 @@ Tooltip.defaults = { * @default 'auto' */ alignment: 'auto', - /** * Allow overlap of container/window. If false, tooltip will first try to * position as defined by data-position and data-alignment, but reposition if @@ -12194,7 +11012,6 @@ Tooltip.defaults = { * @default false */ allowOverlap: false, - /** * Allow overlap of only the bottom of the container. This is the most common * behavior for dropdowns, allowing the dropdown to extend the bottom of the @@ -12205,7 +11022,6 @@ Tooltip.defaults = { * @default false */ allowBottomOverlap: false, - /** * Distance, in pixels, the template should push away from the anchor on the Y axis. * @option @@ -12213,7 +11029,6 @@ Tooltip.defaults = { * @default 0 */ vOffset: 0, - /** * Distance, in pixels, the template should push away from the anchor on the X axis * @option @@ -12221,7 +11036,6 @@ Tooltip.defaults = { * @default 0 */ hOffset: 0, - /** * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip * @option @@ -12229,7 +11043,6 @@ Tooltip.defaults = { * @default 14 */ tooltipHeight: 14, - /** * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip * @option @@ -12237,7 +11050,6 @@ Tooltip.defaults = { * @default 12 */ tooltipWidth: 12, - /** * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips, * allowing HTML may open yourself up to XSS attacks. @@ -12248,6 +11060,7 @@ Tooltip.defaults = { allowHtml: false }; +// The plugin matches the plugin classes with these plugin instances. var MenuPlugins$1 = { tabs: { cssClass: 'tabs', @@ -12255,13 +11068,10 @@ var MenuPlugins$1 = { open: function open(plugin, target) { return plugin.selectTab(target); }, - close: null - /* not supported */ - , - toggle: null - /* not supported */ - + close: null /* not supported */, + toggle: null /* not supported */ }, + accordion: { cssClass: 'accordion', plugin: Accordion, @@ -12276,6 +11086,7 @@ var MenuPlugins$1 = { } } }; + /** * ResponsiveAccordionTabs module. * @module foundation.responsiveAccordionTabs @@ -12283,20 +11094,16 @@ var MenuPlugins$1 = { * @requires foundation.accordion * @requires foundation.tabs */ - var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { _inherits(ResponsiveAccordionTabs, _Plugin); - var _super = _createSuper(ResponsiveAccordionTabs); - function ResponsiveAccordionTabs(element, options) { var _this2; - _classCallCheck(this, ResponsiveAccordionTabs); - _this2 = _super.call(this, element, options); return _possibleConstructorReturn(_this2, _this2.options.reflow && _this2.storezfData || _assertThisInitialized(_this2)); } + /** * Creates a new instance of a responsive accordion tabs. * @class @@ -12305,8 +11112,6 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs. * @param {Object} options - Overrides to the default plugin settings. */ - - _createClass(ResponsiveAccordionTabs, [{ key: "_setup", value: function _setup(element, options) { @@ -12318,47 +11123,42 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { this.currentRule = null; this.currentPlugin = null; this.className = 'ResponsiveAccordionTabs'; // ie9 back compat - if (!this.$element.attr('id')) { this.$element.attr('id', GetYoDigits(6, 'responsiveaccordiontabs')); } - this._init(); - this._events(); } + /** * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element. * @function * @private */ - }, { key: "_init", value: function _init() { - MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules - + MediaQuery._init(); + // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules if (typeof this.rules === 'string') { - var rulesTree = {}; // Parse rules from "classes" pulled from data attribute + var rulesTree = {}; - var rules = this.rules.split(' '); // Iterate through every rule found + // Parse rules from "classes" pulled from data attribute + var rules = this.rules.split(' '); + // Iterate through every rule found for (var i = 0; i < rules.length; i++) { var rule = rules[i].split('-'); var ruleSize = rule.length > 1 ? rule[0] : 'small'; var rulePlugin = rule.length > 1 ? rule[1] : rule[0]; - if (MenuPlugins$1[rulePlugin] !== null) { rulesTree[ruleSize] = MenuPlugins$1[rulePlugin]; } } - this.rules = rulesTree; } - this._getAllOptions(); - if (!$.isEmptyObject(this.rules)) { this._checkMediaQueries(); } @@ -12368,24 +11168,19 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { value: function _getAllOptions() { //get all defaults and options var _this = this; - _this.allOptions = {}; - for (var key in MenuPlugins$1) { if (MenuPlugins$1.hasOwnProperty(key)) { var obj = MenuPlugins$1[key]; - try { var dummyPlugin = $('
      '); var tmpPlugin = new obj.plugin(dummyPlugin, _this.options); - for (var keyKey in tmpPlugin.options) { if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') { var objObj = tmpPlugin.options[keyKey]; _this.allOptions[keyKey] = objObj; } } - tmpPlugin.destroy(); } catch (e) { console.warn("Warning: Problems getting Accordion/Tab options: ".concat(e)); @@ -12393,55 +11188,57 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { } } } + /** * Initializes events for the Menu. * @function * @private */ - }, { key: "_events", value: function _events() { this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this); $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler); } + /** * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out. * @function * @private */ - }, { key: "_checkMediaQueries", value: function _checkMediaQueries() { var matchedMq, - _this = this; // Iterate through each rule and find the last matching rule - - + _this = this; + // Iterate through each rule and find the last matching rule $.each(this.rules, function (key) { if (MediaQuery.atLeast(key)) { matchedMq = key; } - }); // No match? No dice + }); - if (!matchedMq) return; // Plugin already initialized? We good + // No match? No dice + if (!matchedMq) return; - if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes + // Plugin already initialized? We good + if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; + // Remove existing plugin-specific CSS classes $.each(MenuPlugins$1, function (key, value) { _this.$element.removeClass(value.cssClass); - }); // Add the CSS class for the new plugin + }); - this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin + // Add the CSS class for the new plugin + this.$element.addClass(this.rules[matchedMq].cssClass); + // Create an instance of the new plugin if (this.currentPlugin) { //don't know why but on nested elements data zfPlugin get's lost if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData); this.currentPlugin.destroy(); } - this._handleMarkup(this.rules[matchedMq].cssClass); - this.currentRule = this.rules[matchedMq]; this.currentPlugin = new this.currentRule.plugin(this.$element, this.options); this.storezfData = this.currentPlugin.$element.data('zfPlugin'); @@ -12450,28 +11247,23 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { key: "_handleMarkup", value: function _handleMarkup(toSet) { var _this = this, - fromString = 'accordion'; - + fromString = 'accordion'; var $panels = $('[data-tabs-content=' + this.$element.attr('id') + ']'); if ($panels.length) fromString = 'tabs'; - if (fromString === toSet) { return; } - var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title'; var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel'; this.$element.removeAttr('role'); var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item'); var $liHeadsA = $liHeads.children('a').removeClass('accordion-title'); - if (fromString === 'tabs') { $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby'); $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected'); } else { $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content'); } - $panels.css({ display: '', visibility: '' @@ -12480,7 +11272,6 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { display: '', visibility: '' }); - if (toSet === 'accordion') { $panels.each(function (key, value) { $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({ @@ -12493,19 +11284,16 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { } else if (toSet === 'tabs') { var $tabsContent = $('[data-tabs-content=' + _this.$element.attr('id') + ']'); var $placeholder = $('#tabs-placeholder-' + _this.$element.attr('id')); - if ($placeholder.length) { $tabsContent = $('
      ').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id')); $placeholder.remove(); } else { $tabsContent = $('
      ').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id')); } - $panels.each(function (key, value) { var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel); var hash = $liHeadsA.get(key).hash.slice(1); var id = $(value).attr('id') || GetYoDigits(6, 'accordion'); - if (hash !== id) { if (hash !== '') { $(value).attr('id', hash); @@ -12515,9 +11303,7 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { $($liHeadsA.get(key)).attr('href', $($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash); } } - var isActive = $($liHeads.get(key)).hasClass('is-active'); - if (isActive) { tempValue.addClass('is-active'); } @@ -12525,6 +11311,7 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { $liHeads.addClass(tabsTitle); } } + /** * Opens the plugin pane defined by `target`. * @param {jQuery | String} target - jQuery object or string of the id of the pane to open. @@ -12532,53 +11319,49 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { * @see Tabs.selectTab * @function */ - }, { key: "open", value: function open() { if (this.currentRule && typeof this.currentRule.open === 'function') { var _this$currentRule; - return (_this$currentRule = this.currentRule).open.apply(_this$currentRule, [this.currentPlugin].concat(Array.prototype.slice.call(arguments))); } } + /** * Closes the plugin pane defined by `target`. Not availaible for Tabs. * @param {jQuery | String} target - jQuery object or string of the id of the pane to close. * @see Accordion.up * @function */ - }, { key: "close", value: function close() { if (this.currentRule && typeof this.currentRule.close === 'function') { var _this$currentRule2; - return (_this$currentRule2 = this.currentRule).close.apply(_this$currentRule2, [this.currentPlugin].concat(Array.prototype.slice.call(arguments))); } } + /** * Toggles the plugin pane defined by `target`. Not availaible for Tabs. * @param {jQuery | String} target - jQuery object or string of the id of the pane to toggle. * @see Accordion.toggle * @function */ - }, { key: "toggle", value: function toggle() { if (this.currentRule && typeof this.currentRule.toggle === 'function') { var _this$currentRule3; - return (_this$currentRule3 = this.currentRule).toggle.apply(_this$currentRule3, [this.currentPlugin].concat(Array.prototype.slice.call(arguments))); } } + /** * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out. * @function */ - }, { key: "_destroy", value: function _destroy() { @@ -12586,15 +11369,14 @@ var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler); } }]); - return ResponsiveAccordionTabs; }(Plugin); - ResponsiveAccordionTabs.defaults = {}; -Foundation.addToJquery($); // Add Foundation Utils to Foundation global namespace for backwards -// compatibility. +Foundation.addToJquery($); +// Add Foundation Utils to Foundation global namespace for backwards +// compatibility. Foundation.rtl = rtl; Foundation.GetYoDigits = GetYoDigits; Foundation.transitionend = transitionend; @@ -12607,14 +11389,13 @@ Foundation.MediaQuery = MediaQuery; Foundation.Motion = Motion; Foundation.Move = Move; Foundation.Nest = Nest; -Foundation.Timer = Timer; // Touch and Triggers previously were almost purely sede effect driven, -// so no need to add it to Foundation, just init them. +Foundation.Timer = Timer; +// Touch and Triggers previously were almost purely sede effect driven, +// so no need to add it to Foundation, just init them. Touch.init($); Triggers.init($, Foundation); - MediaQuery._init(); - Foundation.plugin(Abide, 'Abide'); Foundation.plugin(Accordion, 'Accordion'); Foundation.plugin(AccordionMenu, 'AccordionMenu'); diff --git a/dist/js/foundation.cjs.js.map b/dist/js/foundation.cjs.js.map index afdce4c6ec..9f541f24f8 100644 --- a/dist/js/foundation.cjs.js.map +++ b/dist/js/foundation.cjs.js.map @@ -1 +1 @@ -{"version":3,"file":"foundation.cjs.js","sources":["../../js/foundation.core.utils.js","../../js/foundation.util.mediaQuery.js","../../js/foundation.core.js","../../js/foundation.util.box.js","../../js/foundation.util.imageLoader.js","../../js/foundation.util.keyboard.js","../../js/foundation.util.motion.js","../../js/foundation.util.nest.js","../../js/foundation.util.timer.js","../../js/foundation.util.touch.js","../../js/foundation.util.triggers.js","../../js/foundation.core.plugin.js","../../js/foundation.abide.js","../../js/foundation.accordion.js","../../js/foundation.accordionMenu.js","../../js/foundation.drilldown.js","../../js/foundation.positionable.js","../../js/foundation.dropdown.js","../../js/foundation.dropdownMenu.js","../../js/foundation.equalizer.js","../../js/foundation.interchange.js","../../js/foundation.smoothScroll.js","../../js/foundation.magellan.js","../../js/foundation.offcanvas.js","../../js/foundation.orbit.js","../../js/foundation.responsiveMenu.js","../../js/foundation.responsiveToggle.js","../../js/foundation.reveal.js","../../js/foundation.slider.js","../../js/foundation.sticky.js","../../js/foundation.tabs.js","../../js/foundation.toggler.js","../../js/foundation.tooltip.js","../../js/foundation.responsiveAccordionTabs.js","../../js/entries/foundation.js"],"sourcesContent":["import $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n /**\n * Returns a boolean for RTL support\n */\nfunction rtl() {\n return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length = 6, namespace){\n let str = '';\n const chars = '0123456789abcdefghijklmnopqrstuvwxyz';\n const charsLength = chars.length;\n for (let i = 0; i < length; i++) {\n str += chars[Math.floor(Math.random() * charsLength)];\n }\n return namespace ? `${str}-${namespace}` : str;\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n var transitions = {\n 'transition': 'transitionend',\n 'WebkitTransition': 'webkitTransitionEnd',\n 'MozTransition': 'transitionend',\n 'OTransition': 'otransitionend'\n };\n var elem = document.createElement('div'),\n end;\n\n for (let transition in transitions){\n if (typeof elem.style[transition] !== 'undefined'){\n end = transitions[transition];\n }\n }\n if (end) {\n return end;\n } else {\n setTimeout(function(){\n $elem.triggerHandler('transitionend', [$elem]);\n }, 1);\n return 'transitionend';\n }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n const didLoad = document.readyState === 'complete';\n const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n const cb = () => $elem.triggerHandler(eventType);\n\n if ($elem) {\n if (handler) $elem.one(eventType, handler);\n\n if (didLoad)\n setTimeout(cb);\n else\n $(window).one('load', cb);\n }\n\n return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n * (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n * outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n return function leaveEventHandler(eLeave, ...rest) {\n const callback = handler.bind(this, eLeave, ...rest);\n\n // The mouse left: call the given callback if the mouse entered elsewhere\n if (eLeave.relatedTarget !== null) {\n return callback();\n }\n\n // Otherwise, check if the mouse actually left the window.\n // In firefox if the user switched between windows, the window sill have the focus by the time\n // the event is triggered. We have to debounce the event to test this case.\n setTimeout(function leaveEventDebouncer() {\n if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n return callback();\n }\n\n // Otherwise, wait for the mouse to reeapear outside of the element,\n if (!ignoreReappear) {\n $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n // Fill where the mouse finally entered.\n eLeave.relatedTarget = eReenter.target;\n callback();\n }\n });\n }\n\n }, 0);\n };\n}\n\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","import $ from 'jquery';\n\n// Default set of media queries\n// const defaultQueries = {\n// 'default' : 'only screen',\n// landscape : 'only screen and (orientation: landscape)',\n// portrait : 'only screen and (orientation: portrait)',\n// retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n// 'only screen and (min--moz-device-pixel-ratio: 2),' +\n// 'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n// 'only screen and (min-device-pixel-ratio: 2),' +\n// 'only screen and (min-resolution: 192dpi),' +\n// 'only screen and (min-resolution: 2dppx)'\n// };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright © 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n \"use strict\";\n\n // For browsers that support matchMedium api such as IE 9 and webkit\n var styleMedia = (window.styleMedia || window.media);\n\n // For those that don't support matchMedium\n if (!styleMedia) {\n var style = document.createElement('style'),\n script = document.getElementsByTagName('script')[0],\n info = null;\n\n style.type = 'text/css';\n style.id = 'matchmediajs-test';\n\n if (!script) {\n document.head.appendChild(style);\n } else {\n script.parentNode.insertBefore(style, script);\n }\n\n // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n styleMedia = {\n matchMedium: function (media) {\n var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n if (style.styleSheet) {\n style.styleSheet.cssText = text;\n } else {\n style.textContent = text;\n }\n\n // Test if media query is true or false\n return info.width === '1px';\n }\n };\n }\n\n return function(media) {\n return {\n matches: styleMedia.matchMedium(media || 'all'),\n media: media || 'all'\n };\n };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n queries: [],\n\n current: '',\n\n /**\n * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n * @function\n * @private\n */\n _init() {\n\n // make sure the initialization is only done once when calling _init() several times\n if (this.isInitialized === true) {\n return this;\n } else {\n this.isInitialized = true;\n }\n\n var self = this;\n var $meta = $('meta.foundation-mq');\n if(!$meta.length){\n $('').appendTo(document.head);\n }\n\n var extractedStyles = $('.foundation-mq').css('font-family');\n var namedQueries;\n\n namedQueries = parseStyleToObject(extractedStyles);\n\n self.queries = []; // reset\n\n for (var key in namedQueries) {\n if(namedQueries.hasOwnProperty(key)) {\n self.queries.push({\n name: key,\n value: `only screen and (min-width: ${namedQueries[key]})`\n });\n }\n }\n\n this.current = this._getCurrentSize();\n\n this._watcher();\n },\n\n /**\n * Reinitializes the media query helper.\n * Useful if your CSS breakpoint configuration has just been loaded or has changed since the initialization.\n * @function\n * @private\n */\n _reInit() {\n this.isInitialized = false;\n this._init();\n },\n\n /**\n * Checks if the screen is at least as wide as a breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint to check.\n * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n */\n atLeast(size) {\n var query = this.get(size);\n\n if (query) {\n return window.matchMedia(query).matches;\n }\n\n return false;\n },\n\n /**\n * Checks if the screen is within the given breakpoint.\n * If smaller than the breakpoint of larger than its upper limit it returns false.\n * @function\n * @param {String} size - Name of the breakpoint to check.\n * @returns {Boolean} `true` if the breakpoint matches, `false` otherwise.\n */\n only(size) {\n return size === this._getCurrentSize();\n },\n\n /**\n * Checks if the screen is within a breakpoint or smaller.\n * @function\n * @param {String} size - Name of the breakpoint to check.\n * @returns {Boolean} `true` if the breakpoint matches, `false` if it's larger.\n */\n upTo(size) {\n const nextSize = this.next(size);\n\n // If the next breakpoint does not match, the screen is smaller than\n // the upper limit of this breakpoint.\n if (nextSize) {\n return !this.atLeast(nextSize);\n }\n\n // If there is no next breakpoint, the \"size\" breakpoint does not have\n // an upper limit and the screen will always be within it or smaller.\n return true;\n },\n\n /**\n * Checks if the screen matches to a breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n */\n is(size) {\n const parts = size.trim().split(' ').filter(p => !!p.length);\n const [bpSize, bpModifier = ''] = parts;\n\n // Only the breakpont\n if (bpModifier === 'only') {\n return this.only(bpSize);\n }\n // At least the breakpoint (included)\n if (!bpModifier || bpModifier === 'up') {\n return this.atLeast(bpSize);\n }\n // Up to the breakpoint (included)\n if (bpModifier === 'down') {\n return this.upTo(bpSize);\n }\n\n throw new Error(`\n Invalid breakpoint passed to MediaQuery.is().\n Expected a breakpoint name formatted like \" \", got \"${size}\".\n `);\n },\n\n /**\n * Gets the media query of a breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint to get.\n * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n */\n get(size) {\n for (var i in this.queries) {\n if(this.queries.hasOwnProperty(i)) {\n var query = this.queries[i];\n if (size === query.name) return query.value;\n }\n }\n\n return null;\n },\n\n /**\n * Get the breakpoint following the given breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint.\n * @returns {String|null} - The name of the following breakpoint, or `null` if the passed breakpoint was the last one.\n */\n next(size) {\n const queryIndex = this.queries.findIndex((q) => this._getQueryName(q) === size);\n if (queryIndex === -1) {\n throw new Error(`\n Unknown breakpoint \"${size}\" passed to MediaQuery.next().\n Ensure it is present in your Sass \"$breakpoints\" setting.\n `);\n }\n\n const nextQuery = this.queries[queryIndex + 1];\n return nextQuery ? nextQuery.name : null;\n },\n\n /**\n * Returns the name of the breakpoint related to the given value.\n * @function\n * @private\n * @param {String|Object} value - Breakpoint name or query object.\n * @returns {String} Name of the breakpoint.\n */\n _getQueryName(value) {\n if (typeof value === 'string')\n return value;\n if (typeof value === 'object')\n return value.name;\n throw new TypeError(`\n Invalid value passed to MediaQuery._getQueryName().\n Expected a breakpoint name (String) or a breakpoint query (Object), got \"${value}\" (${typeof value})\n `);\n },\n\n /**\n * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n * @function\n * @private\n * @returns {String} Name of the current breakpoint.\n */\n _getCurrentSize() {\n var matched;\n\n for (var i = 0; i < this.queries.length; i++) {\n var query = this.queries[i];\n\n if (window.matchMedia(query.value).matches) {\n matched = query;\n }\n }\n\n return matched && this._getQueryName(matched);\n },\n\n /**\n * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n * @function\n * @private\n */\n _watcher() {\n $(window).on('resize.zf.trigger', () => {\n var newSize = this._getCurrentSize(), currentSize = this.current;\n\n if (newSize !== currentSize) {\n // Change the current media query\n this.current = newSize;\n\n // Broadcast the media query change on the window\n $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n }\n });\n }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n var styleObject = {};\n\n if (typeof str !== 'string') {\n return styleObject;\n }\n\n str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n if (!str) {\n return styleObject;\n }\n\n styleObject = str.split('&').reduce(function(ret, param) {\n var parts = param.replace(/\\+/g, ' ').split('=');\n var key = parts[0];\n var val = parts[1];\n key = decodeURIComponent(key);\n\n // missing `=` should be `null`:\n // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n if (!ret.hasOwnProperty(key)) {\n ret[key] = val;\n } else if (Array.isArray(ret[key])) {\n ret[key].push(val);\n } else {\n ret[key] = [ret[key], val];\n }\n return ret;\n }, {});\n\n return styleObject;\n}\n\nexport {MediaQuery};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.7.5';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n version: FOUNDATION_VERSION,\n\n /**\n * Stores initialized plugins.\n */\n _plugins: {},\n\n /**\n * Stores generated unique ids for plugin instances\n */\n _uuids: [],\n\n /**\n * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n * @param {Object} plugin - The constructor of the plugin.\n */\n plugin: function(plugin, name) {\n // Object key to use when adding to global Foundation object\n // Examples: Foundation.Reveal, Foundation.OffCanvas\n var className = (name || functionName(plugin));\n // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n // Examples: data-reveal, data-off-canvas\n var attrName = hyphenate(className);\n\n // Add to the Foundation object and the plugins list (for reflowing)\n this._plugins[attrName] = this[className] = plugin;\n },\n /**\n * @function\n * Populates the _uuids array with pointers to each individual plugin instance.\n * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n * Also fires the initialization event for each plugin, consolidating repetitive code.\n * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n * @param {String} name - the name of the plugin, passed as a camelCased string.\n * @fires Plugin#init\n */\n registerPlugin: function(plugin, name){\n var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n plugin.uuid = GetYoDigits(6, pluginName);\n\n if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n /**\n * Fires when the plugin has initialized.\n * @event Plugin#init\n */\n plugin.$element.trigger(`init.zf.${pluginName}`);\n\n this._uuids.push(plugin.uuid);\n\n return;\n },\n /**\n * @function\n * Removes the plugins uuid from the _uuids array.\n * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n * Also fires the destroyed event for the plugin, consolidating repetitive code.\n * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n * @fires Plugin#destroyed\n */\n unregisterPlugin: function(plugin){\n var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n /**\n * Fires when the plugin has been destroyed.\n * @event Plugin#destroyed\n */\n .trigger(`destroyed.zf.${pluginName}`);\n for(var prop in plugin){\n if(typeof plugin[prop] === 'function'){\n plugin[prop] = null; //clean up script to prep for garbage collection.\n }\n }\n return;\n },\n\n /**\n * @function\n * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n * @default If no argument is passed, reflow all currently active plugins.\n */\n reInit: function(plugins){\n var isJQ = plugins instanceof $;\n try{\n if(isJQ){\n plugins.each(function(){\n $(this).data('zfPlugin')._init();\n });\n }else{\n var type = typeof plugins,\n _this = this,\n fns = {\n 'object': function(plgs){\n plgs.forEach(function(p){\n p = hyphenate(p);\n $('[data-'+ p +']').foundation('_init');\n });\n },\n 'string': function(){\n plugins = hyphenate(plugins);\n $('[data-'+ plugins +']').foundation('_init');\n },\n 'undefined': function(){\n this.object(Object.keys(_this._plugins));\n }\n };\n fns[type](plugins);\n }\n }catch(err){\n console.error(err);\n }finally{\n return plugins;\n }\n },\n\n /**\n * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n */\n reflow: function(elem, plugins) {\n\n // If plugins is undefined, just grab everything\n if (typeof plugins === 'undefined') {\n plugins = Object.keys(this._plugins);\n }\n // If plugins is a string, convert it to an array with one item\n else if (typeof plugins === 'string') {\n plugins = [plugins];\n }\n\n var _this = this;\n\n // Iterate through each plugin\n $.each(plugins, function(i, name) {\n // Get the current plugin\n var plugin = _this._plugins[name];\n\n // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']').filter(function () {\n return typeof $(this).data(\"zfPlugin\") === 'undefined';\n });\n\n // For each plugin found, initialize it\n $elem.each(function() {\n var $el = $(this),\n opts = { reflow: true };\n\n if($el.attr('data-options')){\n $el.attr('data-options').split(';').forEach(function(option){\n var opt = option.split(':').map(function(el){ return el.trim(); });\n if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n });\n }\n try{\n $el.data('zfPlugin', new plugin($(this), opts));\n }catch(er){\n console.error(er);\n }finally{\n return;\n }\n });\n });\n },\n getFnName: functionName,\n\n addToJquery: function() {\n // TODO: consider not making this a jQuery function\n // TODO: need way to reflow vs. re-initialize\n /**\n * The Foundation jQuery method.\n * @param {String|Array} method - An action to perform on the current jQuery object.\n */\n var foundation = function(method) {\n var type = typeof method,\n $noJS = $('.no-js');\n\n if($noJS.length){\n $noJS.removeClass('no-js');\n }\n\n if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n MediaQuery._init();\n Foundation.reflow(this);\n }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n if(this.length === 1){//if there's only one, call it directly.\n plugClass[method].apply(plugClass, args);\n }else{\n this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n plugClass[method].apply($(el).data('zfPlugin'), args);\n });\n }\n }else{//error for no class or no method\n throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n }\n }else{//error for invalid argument type\n throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n }\n return this;\n };\n $.fn.foundation = foundation;\n return $;\n }\n};\n\nFoundation.util = {\n /**\n * Function for applying a debounce effect to a function call.\n * @function\n * @param {Function} func - Function to be called at end of timeout.\n * @param {Number} delay - Time in ms to delay the call of `func`.\n * @returns function\n */\n throttle: function (func, delay) {\n var timer = null;\n\n return function () {\n var context = this, args = arguments;\n\n if (timer === null) {\n timer = setTimeout(function () {\n func.apply(context, args);\n timer = null;\n }, delay);\n }\n };\n }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n if (!Date.now || !window.Date.now)\n window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n var vendors = ['webkit', 'moz'];\n for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n var vp = vendors[i];\n window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n || window[vp+'CancelRequestAnimationFrame']);\n }\n if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n var lastTime = 0;\n window.requestAnimationFrame = function(callback) {\n var now = Date.now();\n var nextTime = Math.max(lastTime + 16, now);\n return setTimeout(function() { callback(lastTime = nextTime); },\n nextTime - now);\n };\n window.cancelAnimationFrame = clearTimeout;\n }\n /**\n * Polyfill for performance.now, required by rAF\n */\n if(!window.performance || !window.performance.now){\n window.performance = {\n start: Date.now(),\n now: function(){ return Date.now() - this.start; }\n };\n }\n})();\nif (!Function.prototype.bind) {\n /* eslint-disable no-extend-native */\n Function.prototype.bind = function(oThis) {\n if (typeof this !== 'function') {\n // closest thing possible to the ECMAScript 5\n // internal IsCallable function\n throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n }\n\n var aArgs = Array.prototype.slice.call(arguments, 1),\n fToBind = this,\n fNOP = function() {},\n fBound = function() {\n return fToBind.apply(this instanceof fNOP\n ? this\n : oThis,\n aArgs.concat(Array.prototype.slice.call(arguments)));\n };\n\n if (this.prototype) {\n // native functions don't have a prototype\n fNOP.prototype = this.prototype;\n }\n fBound.prototype = new fNOP();\n\n return fBound;\n };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n if (typeof Function.prototype.name === 'undefined') {\n var funcNameRegex = /function\\s([^(]{1,})\\(/;\n var results = (funcNameRegex).exec((fn).toString());\n return (results && results.length > 1) ? results[1].trim() : \"\";\n }\n else if (typeof fn.prototype === 'undefined') {\n return fn.constructor.name;\n }\n else {\n return fn.prototype.constructor.name;\n }\n}\nfunction parseValue(str){\n if ('true' === str) return true;\n else if ('false' === str) return false;\n else if (!isNaN(str * 1)) return parseFloat(str);\n return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","var Box = {\n ImNotTouchingYou: ImNotTouchingYou,\n OverlapArea: OverlapArea,\n GetDimensions: GetDimensions,\n GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n}\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n var eleDims = GetDimensions(element),\n topOver, bottomOver, leftOver, rightOver;\n if (parent) {\n var parDims = GetDimensions(parent);\n\n bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n topOver = eleDims.offset.top - parDims.offset.top;\n leftOver = eleDims.offset.left - parDims.offset.left;\n rightOver = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n }\n else {\n bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n topOver = eleDims.offset.top - eleDims.windowDims.offset.top;\n leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;\n rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n }\n\n bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n topOver = Math.min(topOver, 0);\n leftOver = Math.min(leftOver, 0);\n rightOver = Math.min(rightOver, 0);\n\n if (lrOnly) {\n return leftOver + rightOver;\n }\n if (tbOnly) {\n return topOver + bottomOver;\n }\n\n // use sum of squares b/c we care about overlap area.\n return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n elem = elem.length ? elem[0] : elem;\n\n if (elem === window || elem === document) {\n throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n }\n\n var rect = elem.getBoundingClientRect(),\n parRect = elem.parentNode.getBoundingClientRect(),\n winRect = document.body.getBoundingClientRect(),\n winY = window.pageYOffset,\n winX = window.pageXOffset;\n\n return {\n width: rect.width,\n height: rect.height,\n offset: {\n top: rect.top + winY,\n left: rect.left + winX\n },\n parentDims: {\n width: parRect.width,\n height: parRect.height,\n offset: {\n top: parRect.top + winY,\n left: parRect.left + winX\n }\n },\n windowDims: {\n width: winRect.width,\n height: winRect.height,\n offset: {\n top: winY,\n left: winX\n }\n }\n }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n var $eleDims = GetDimensions(element),\n $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n var topVal, leftVal;\n\n if ($anchorDims !== null) {\n // set position related attribute\n switch (position) {\n case 'top':\n topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n break;\n case 'bottom':\n topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n break;\n case 'left':\n leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n break;\n case 'right':\n leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n break;\n }\n\n // set alignment related attribute\n switch (position) {\n case 'top':\n case 'bottom':\n switch (alignment) {\n case 'left':\n leftVal = $anchorDims.offset.left + hOffset;\n break;\n case 'right':\n leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n break;\n case 'center':\n leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n break;\n }\n break;\n case 'right':\n case 'left':\n switch (alignment) {\n case 'bottom':\n topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n break;\n case 'top':\n topVal = $anchorDims.offset.top + vOffset\n break;\n case 'center':\n topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n break;\n }\n break;\n }\n }\n\n return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n","import $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n var unloaded = images.length;\n\n if (unloaded === 0) {\n callback();\n }\n\n images.each(function(){\n // Check if image is loaded\n if (this.complete && typeof this.naturalWidth !== 'undefined') {\n singleImageLoaded();\n }\n else {\n // If the above check failed, simulate loading on detached element.\n var image = new Image();\n // Still count image as loaded if it finalizes with an error.\n var events = \"load.zf.images error.zf.images\";\n $(image).one(events, function me(){\n // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n $(this).off(events, me);\n singleImageLoaded();\n });\n image.src = $(this).attr('src');\n }\n });\n\n function singleImageLoaded() {\n unloaded--;\n if (unloaded === 0) {\n callback();\n }\n }\n}\n\nexport { onImagesLoaded };\n","/*******************************************\n * *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n * *\n ******************************************/\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n 9: 'TAB',\n 13: 'ENTER',\n 27: 'ESCAPE',\n 32: 'SPACE',\n 35: 'END',\n 36: 'HOME',\n 37: 'ARROW_LEFT',\n 38: 'ARROW_UP',\n 39: 'ARROW_RIGHT',\n 40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n if(!$element) {return false; }\n return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n return true;\n })\n .sort( function( a, b ) {\n if ($(a).attr('tabindex') === $(b).attr('tabindex')) {\n return 0;\n }\n let aTabIndex = parseInt($(a).attr('tabindex'), 10),\n bTabIndex = parseInt($(b).attr('tabindex'), 10);\n // Undefined is treated the same as 0\n if (typeof $(a).attr('tabindex') === 'undefined' && bTabIndex > 0) {\n return 1;\n }\n if (typeof $(b).attr('tabindex') === 'undefined' && aTabIndex > 0) {\n return -1;\n }\n if (aTabIndex === 0 && bTabIndex > 0) {\n return 1;\n }\n if (bTabIndex === 0 && aTabIndex > 0) {\n return -1;\n }\n if (aTabIndex < bTabIndex) {\n return -1;\n }\n if (aTabIndex > bTabIndex) {\n return 1;\n }\n });\n}\n\nfunction parseKey(event) {\n var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n key = key.replace(/\\W+/, '');\n\n if (event.shiftKey) key = `SHIFT_${key}`;\n if (event.ctrlKey) key = `CTRL_${key}`;\n if (event.altKey) key = `ALT_${key}`;\n\n // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n key = key.replace(/_$/, '');\n\n return key;\n}\n\nvar Keyboard = {\n keys: getKeyCodes(keyCodes),\n\n /**\n * Parses the (keyboard) event and returns a String that represents its key\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n * @param {Event} event - the event generated by the event handler\n * @return String key - String that represents the key pressed\n */\n parseKey: parseKey,\n\n /**\n * Handles the given (keyboard) event\n * @param {Event} event - the event generated by the event handler\n * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n * @param {Objects} functions - collection of functions that are to be executed\n */\n handleKey(event, component, functions) {\n var commandList = commands[component],\n keyCode = this.parseKey(event),\n cmds,\n command,\n fn;\n\n if (!commandList) return console.warn('Component not defined!');\n\n // Ignore the event if it was already handled\n if (event.zfIsKeyHandled === true) return;\n\n // This component does not differentiate between ltr and rtl\n if (typeof commandList.ltr === 'undefined') {\n cmds = commandList; // use plain list\n } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n }\n command = cmds[keyCode];\n\n fn = functions[command];\n // Execute the handler if found\n if (fn && typeof fn === 'function') {\n var returnValue = fn.apply();\n\n // Mark the event as \"handled\" to prevent future handlings\n event.zfIsKeyHandled = true;\n\n // Execute function when event was handled\n if (functions.handled || typeof functions.handled === 'function') {\n functions.handled(returnValue);\n }\n } else {\n // Execute function when event was not handled\n if (functions.unhandled || typeof functions.unhandled === 'function') {\n functions.unhandled();\n }\n }\n },\n\n /**\n * Finds all focusable elements within the given `$element`\n * @param {jQuery} $element - jQuery object to search within\n * @return {jQuery} $focusable - all focusable elements within `$element`\n */\n\n findFocusable: findFocusable,\n\n /**\n * Returns the component name name\n * @param {Object} component - Foundation component, e.g. Slider or Reveal\n * @return String componentName\n */\n\n register(componentName, cmds) {\n commands[componentName] = cmds;\n },\n\n\n // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n //\n /**\n * Traps the focus in the given element.\n * @param {jQuery} $element jQuery object to trap the foucs into.\n */\n trapFocus($element) {\n var $focusable = findFocusable($element),\n $firstFocusable = $focusable.eq(0),\n $lastFocusable = $focusable.eq(-1);\n\n $element.on('keydown.zf.trapfocus', function(event) {\n if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n event.preventDefault();\n $firstFocusable.focus();\n }\n else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n event.preventDefault();\n $lastFocusable.focus();\n }\n });\n },\n /**\n * Releases the trapped focus from the given element.\n * @param {jQuery} $element jQuery object to release the focus for.\n */\n releaseFocus($element) {\n $element.off('keydown.zf.trapfocus');\n }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n var k = {};\n for (var kc in kcs) {\n if (kcs.hasOwnProperty(kc)) k[kcs[kc]] = kcs[kc];\n }\n return k;\n}\n\nexport {Keyboard};\n","import $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n animateIn: function(element, animation, cb) {\n animate(true, element, animation, cb);\n },\n\n animateOut: function(element, animation, cb) {\n animate(false, element, animation, cb);\n }\n}\n\nfunction Move(duration, elem, fn){\n var anim, prog, start = null;\n\n if (duration === 0) {\n fn.apply(elem);\n elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n return;\n }\n\n function move(ts){\n if(!start) start = ts;\n prog = ts - start;\n fn.apply(elem);\n\n if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n else{\n window.cancelAnimationFrame(anim);\n elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n }\n }\n anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n element = $(element).eq(0);\n\n if (!element.length) return;\n\n var initClass = isIn ? initClasses[0] : initClasses[1];\n var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n // Set up the animation\n reset();\n\n element\n .addClass(animation)\n .css('transition', 'none');\n\n requestAnimationFrame(() => {\n element.addClass(initClass);\n if (isIn) element.show();\n });\n\n // Start the animation\n requestAnimationFrame(() => {\n // will trigger the browser to synchronously calculate the style and layout\n // also called reflow or layout thrashing\n // see https://gist.github.com/paulirish/5d52fb081b3570c81e3a\n element[0].offsetWidth;\n element\n .css('transition', '')\n .addClass(activeClass);\n });\n\n // Clean up the animation when it finishes\n element.one(transitionend(element), finish);\n\n // Hides the element (for out animations), resets the element, and runs a callback\n function finish() {\n if (!isIn) element.hide();\n reset();\n if (cb) cb.apply(element);\n }\n\n // Resets transitions and removes motion-specific classes\n function reset() {\n element[0].style.transitionDuration = 0;\n element.removeClass(`${initClass} ${activeClass} ${animation}`);\n }\n}\n\nexport { Move, Motion };\n\n","import $ from 'jquery';\n\nconst Nest = {\n Feather(menu, type = 'zf') {\n menu.attr('role', 'menubar');\n menu.find('a').attr({'role': 'menuitem'});\n\n var items = menu.find('li').attr({'role': 'none'}),\n subMenuClass = `is-${type}-submenu`,\n subItemClass = `${subMenuClass}-item`,\n hasSubClass = `is-${type}-submenu-parent`,\n applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n items.each(function() {\n var $item = $(this),\n $sub = $item.children('ul');\n\n if ($sub.length) {\n $item.addClass(hasSubClass);\n if(applyAria) {\n const firstItem = $item.children('a:first');\n firstItem.attr({\n 'aria-haspopup': true,\n 'aria-label': firstItem.attr('aria-label') || firstItem.text()\n });\n // Note: Drilldowns behave differently in how they hide, and so need\n // additional attributes. We should look if this possibly over-generalized\n // utility (Nest) is appropriate when we rework menus in 6.4\n if(type === 'drilldown') {\n $item.attr({'aria-expanded': false});\n }\n }\n $sub\n .addClass(`submenu ${subMenuClass}`)\n .attr({\n 'data-submenu': '',\n 'role': 'menubar'\n });\n if(type === 'drilldown') {\n $sub.attr({'aria-hidden': true});\n }\n }\n\n if ($item.parent('[data-submenu]').length) {\n $item.addClass(`is-submenu-item ${subItemClass}`);\n }\n });\n\n return;\n },\n\n Burn(menu, type) {\n var //items = menu.find('li'),\n subMenuClass = `is-${type}-submenu`,\n subItemClass = `${subMenuClass}-item`,\n hasSubClass = `is-${type}-submenu-parent`;\n\n menu\n .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n .removeAttr('data-submenu').css('display', '');\n\n }\n}\n\nexport {Nest};\n","function Timer(elem, options, cb) {\n var _this = this,\n duration = options.duration,//options is an object for easily adding features later.\n nameSpace = Object.keys(elem.data())[0] || 'timer',\n remain = -1,\n start,\n timer;\n\n this.isPaused = false;\n\n this.restart = function() {\n remain = -1;\n clearTimeout(timer);\n this.start();\n }\n\n this.start = function() {\n this.isPaused = false;\n // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n clearTimeout(timer);\n remain = remain <= 0 ? duration : remain;\n elem.data('paused', false);\n start = Date.now();\n timer = setTimeout(function(){\n if(options.infinite){\n _this.restart();//rerun the timer.\n }\n if (cb && typeof cb === 'function') { cb(); }\n }, remain);\n elem.trigger(`timerstart.zf.${nameSpace}`);\n }\n\n this.pause = function() {\n this.isPaused = true;\n //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n clearTimeout(timer);\n elem.data('paused', true);\n var end = Date.now();\n remain = remain - (end - start);\n elem.trigger(`timerpaused.zf.${nameSpace}`);\n }\n}\n\nexport {Timer};\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n startTime,\n elapsedTime,\n startEvent,\n isMoving = false,\n didMoved = false;\n\nfunction onTouchEnd(e) {\n this.removeEventListener('touchmove', onTouchMove);\n this.removeEventListener('touchend', onTouchEnd);\n\n // If the touch did not move, consider it as a \"tap\"\n if (!didMoved) {\n var tapEvent = $.Event('tap', startEvent || e);\n $(this).trigger(tapEvent);\n }\n\n startEvent = null;\n isMoving = false;\n didMoved = false;\n}\n\nfunction onTouchMove(e) {\n if (true === $.spotSwipe.preventDefault) { e.preventDefault(); }\n\n if(isMoving) {\n var x = e.touches[0].pageX;\n // var y = e.touches[0].pageY;\n var dx = startPosX - x;\n // var dy = startPosY - y;\n var dir;\n didMoved = true;\n elapsedTime = new Date().getTime() - startTime;\n if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n dir = dx > 0 ? 'left' : 'right';\n }\n // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n // dir = dy > 0 ? 'down' : 'up';\n // }\n if(dir) {\n e.preventDefault();\n onTouchEnd.apply(this, arguments);\n $(this)\n .trigger($.Event('swipe', Object.assign({}, e)), dir)\n .trigger($.Event(`swipe${dir}`, Object.assign({}, e)));\n }\n }\n\n}\n\nfunction onTouchStart(e) {\n\n if (e.touches.length === 1) {\n startPosX = e.touches[0].pageX;\n startEvent = e;\n isMoving = true;\n didMoved = false;\n startTime = new Date().getTime();\n this.addEventListener('touchmove', onTouchMove, { passive : true === $.spotSwipe.preventDefault });\n this.addEventListener('touchend', onTouchEnd, false);\n }\n}\n\nfunction init() {\n this.addEventListener && this.addEventListener('touchstart', onTouchStart, { passive : true });\n}\n\n// function teardown() {\n// this.removeEventListener('touchstart', onTouchStart);\n// }\n\nclass SpotSwipe {\n constructor() {\n this.version = '1.0.0';\n this.enabled = 'ontouchstart' in document.documentElement;\n this.preventDefault = false;\n this.moveThreshold = 75;\n this.timeThreshold = 200;\n this._init();\n }\n\n _init() {\n $.event.special.swipe = { setup: init };\n $.event.special.tap = { setup: init };\n\n $.each(['left', 'up', 'down', 'right'], function () {\n $.event.special[`swipe${this}`] = { setup: function(){\n $(this).on('swipe', $.noop);\n } };\n });\n }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and *\n * setupTouchHandler should be idempotent, *\n * because they directly replace functions & *\n * values, and do not add event handlers directly. *\n ****************************************************/\n\nTouch.setupSpotSwipe = function() {\n $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function() {\n $.fn.addTouch = function(){\n this.each(function(i, el){\n $(el).bind('touchstart touchmove touchend touchcancel', function(event) {\n //we pass the original event object because the jQuery event\n //object is normalized to w3c specs and does not provide the TouchList\n handleTouch(event);\n });\n });\n\n var handleTouch = function(event) {\n var touches = event.changedTouches,\n first = touches[0],\n eventTypes = {\n touchstart: 'mousedown',\n touchmove: 'mousemove',\n touchend: 'mouseup'\n },\n type = eventTypes[event.type],\n simulatedEvent\n ;\n\n if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n simulatedEvent = new window.MouseEvent(type, {\n 'bubbles': true,\n 'cancelable': true,\n 'screenX': first.screenX,\n 'screenY': first.screenY,\n 'clientX': first.clientX,\n 'clientY': first.clientY\n });\n } else {\n simulatedEvent = document.createEvent('MouseEvent');\n simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n }\n first.target.dispatchEvent(simulatedEvent);\n };\n };\n};\n\nTouch.init = function () {\n if(typeof($.spotSwipe) === 'undefined') {\n Touch.setupSpotSwipe($);\n Touch.setupTouchHandler($);\n }\n};\n\nexport {Touch};\n","import $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n for (var i=0; i < prefixes.length; i++) {\n if (`${prefixes[i]}MutationObserver` in window) {\n return window[`${prefixes[i]}MutationObserver`];\n }\n }\n return false;\n})();\n\nconst triggers = (el, type) => {\n el.data(type).split(' ').forEach(id => {\n $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n });\n};\n\nvar Triggers = {\n Listeners: {\n Basic: {},\n Global: {}\n },\n Initializers: {}\n}\n\nTriggers.Listeners.Basic = {\n openListener: function() {\n triggers($(this), 'open');\n },\n closeListener: function() {\n let id = $(this).data('close');\n if (id) {\n triggers($(this), 'close');\n }\n else {\n $(this).trigger('close.zf.trigger');\n }\n },\n toggleListener: function() {\n let id = $(this).data('toggle');\n if (id) {\n triggers($(this), 'toggle');\n } else {\n $(this).trigger('toggle.zf.trigger');\n }\n },\n closeableListener: function(e) {\n let animation = $(this).data('closable');\n\n // Only close the first closable element. See https://git.io/zf-7833\n e.stopPropagation();\n\n if(animation !== ''){\n Motion.animateOut($(this), animation, function() {\n $(this).trigger('closed.zf');\n });\n }else{\n $(this).fadeOut().trigger('closed.zf');\n }\n },\n toggleFocusListener: function() {\n let id = $(this).data('toggle-focus');\n $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global = {\n resizeListener: function($nodes) {\n if(!MutationObserver){//fallback for IE 9\n $nodes.each(function(){\n $(this).triggerHandler('resizeme.zf.trigger');\n });\n }\n //trigger all listening elements and signal a resize event\n $nodes.attr('data-events', \"resize\");\n },\n scrollListener: function($nodes) {\n if(!MutationObserver){//fallback for IE 9\n $nodes.each(function(){\n $(this).triggerHandler('scrollme.zf.trigger');\n });\n }\n //trigger all listening elements and signal a scroll event\n $nodes.attr('data-events', \"scroll\");\n },\n closeMeListener: function(e, pluginId){\n let plugin = e.namespace.split('.')[0];\n let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n plugins.each(function(){\n let _this = $(this);\n _this.triggerHandler('close.zf.trigger', [_this]);\n });\n }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n var yetiBoxes = $('[data-yeti-box]'),\n plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n if(pluginName){\n if(typeof pluginName === 'string'){\n plugNames.push(pluginName);\n }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n plugNames = plugNames.concat(pluginName);\n }else{\n console.error('Plugin names must be strings');\n }\n }\n if(yetiBoxes.length){\n let listeners = plugNames.map((name) => {\n return `closeme.zf.${name}`;\n }).join(' ');\n\n $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n let timer, args = Array.prototype.slice.call(arguments, 3);\n $(window).on(trigger, function() {\n if (timer) { clearTimeout(timer); }\n timer = setTimeout(function(){\n listener.apply(null, args);\n }, debounce || 10); //default time to emit scroll event\n });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n let $nodes = $('[data-resize]');\n if($nodes.length){\n debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n let $nodes = $('[data-scroll]');\n if($nodes.length){\n debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n if(!MutationObserver){ return false; }\n let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n //element callback\n var listeningElementsMutation = function (mutationRecordsList) {\n var $target = $(mutationRecordsList[0].target);\n\n //trigger the event handler for the element depending on type\n switch (mutationRecordsList[0].type) {\n case \"attributes\":\n if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n }\n if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n $target.triggerHandler('resizeme.zf.trigger', [$target]);\n }\n if (mutationRecordsList[0].attributeName === \"style\") {\n $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n }\n break;\n\n case \"childList\":\n $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n break;\n\n default:\n return false;\n //nothing\n }\n };\n\n if ($nodes.length) {\n //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n for (var i = 0; i <= $nodes.length - 1; i++) {\n var elementObserver = new MutationObserver(listeningElementsMutation);\n elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n }\n }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n let $document = $(document);\n\n Triggers.Initializers.addOpenListener($document);\n Triggers.Initializers.addCloseListener($document);\n Triggers.Initializers.addToggleListener($document);\n Triggers.Initializers.addCloseableListener($document);\n Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n let $document = $(document);\n Triggers.Initializers.addMutationEventsListener($document);\n Triggers.Initializers.addResizeListener(250);\n Triggers.Initializers.addScrollListener();\n Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function (__, Foundation) {\n onLoad($(window), function () {\n if ($.triggersInitialized !== true) {\n Triggers.Initializers.addSimpleListeners();\n Triggers.Initializers.addGlobalListeners();\n $.triggersInitialized = true;\n }\n });\n\n if(Foundation) {\n Foundation.Triggers = Triggers;\n // Legacy included to be backwards compatible for now.\n Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n }\n}\n\nexport {Triggers};\n","import { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n constructor(element, options) {\n this._setup(element, options);\n var pluginName = getPluginName(this);\n this.uuid = GetYoDigits(6, pluginName);\n\n if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n /**\n * Fires when the plugin has initialized.\n * @event Plugin#init\n */\n this.$element.trigger(`init.zf.${pluginName}`);\n }\n\n destroy() {\n this._destroy();\n var pluginName = getPluginName(this);\n this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n /**\n * Fires when the plugin has been destroyed.\n * @event Plugin#destroyed\n */\n .trigger(`destroyed.zf.${pluginName}`);\n for(var prop in this){\n if (this.hasOwnProperty(prop)) {\n this[prop] = null; //clean up script to prep for garbage collection.\n }\n }\n }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n return hyphenate(obj.className);\n}\n\nexport {Plugin};\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n /**\n * Creates a new instance of Abide.\n * @class\n * @name Abide\n * @fires Abide#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options = {}) {\n this.$element = element;\n this.options = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n this.isEnabled = true;\n this.formnovalidate = null;\n\n this.className = 'Abide'; // ie9 back compat\n this._init();\n }\n\n /**\n * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n * @private\n */\n _init() {\n this.$inputs = $.merge( // Consider as input to validate:\n this.$element.find('input').not('[type=\"submit\"]'), // * all input fields expect submit\n this.$element.find('textarea, select') // * all textareas and select fields\n );\n this.$submits = this.$element.find('[type=\"submit\"]');\n const $globalErrors = this.$element.find('[data-abide-error]');\n\n // Add a11y attributes to all fields\n if (this.options.a11yAttributes) {\n this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n }\n\n this._events();\n }\n\n /**\n * Initializes events for Abide.\n * @private\n */\n _events() {\n this.$element.off('.abide')\n .on('reset.zf.abide', () => {\n this.resetForm();\n })\n .on('submit.zf.abide', () => {\n return this.validateForm();\n });\n\n this.$submits\n .off('click.zf.abide keydown.zf.abide')\n .on('click.zf.abide keydown.zf.abide', (e) => {\n if (!e.key || (e.key === ' ' || e.key === 'Enter')) {\n e.preventDefault();\n this.formnovalidate = e.target.getAttribute('formnovalidate') !== null;\n this.$element.submit();\n }\n });\n\n if (this.options.validateOn === 'fieldChange') {\n this.$inputs\n .off('change.zf.abide')\n .on('change.zf.abide', (e) => {\n this.validateInput($(e.target));\n });\n }\n\n if (this.options.liveValidate) {\n this.$inputs\n .off('input.zf.abide')\n .on('input.zf.abide', (e) => {\n this.validateInput($(e.target));\n });\n }\n\n if (this.options.validateOnBlur) {\n this.$inputs\n .off('blur.zf.abide')\n .on('blur.zf.abide', (e) => {\n this.validateInput($(e.target));\n });\n }\n }\n\n /**\n * Calls necessary functions to update Abide upon DOM change\n * @private\n */\n _reflow() {\n this._init();\n }\n\n /**\n * Checks whether the submitted form should be validated or not, consodering formnovalidate and isEnabled\n * @returns {Boolean}\n * @private\n */\n _validationIsDisabled() {\n if (this.isEnabled === false) { // whole validation disabled\n return true;\n } else if (typeof this.formnovalidate === 'boolean') { // triggered by $submit\n return this.formnovalidate;\n }\n // triggered by Enter in non-submit input\n return this.$submits.length ? this.$submits[0].getAttribute('formnovalidate') !== null : false;\n }\n\n /**\n * Enables the whole validation\n */\n enableValidation() {\n this.isEnabled = true;\n }\n\n /**\n * Disables the whole validation\n */\n disableValidation() {\n this.isEnabled = false;\n }\n\n /**\n * Checks whether or not a form element has the required attribute and if it's checked or not\n * @param {Object} element - jQuery object to check for required attribute\n * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n */\n requiredCheck($el) {\n if (!$el.attr('required')) return true;\n\n var isGood = true;\n\n switch ($el[0].type) {\n case 'checkbox':\n isGood = $el[0].checked;\n break;\n\n case 'select':\n case 'select-one':\n case 'select-multiple':\n var opt = $el.find('option:selected');\n if (!opt.length || !opt.val()) isGood = false;\n break;\n\n default:\n if (!$el.val() || !$el.val().length) isGood = false;\n }\n\n return isGood;\n }\n\n /**\n * Get:\n * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n * 1. The element's direct sibling('s).\n * 2. The element's parent's children.\n * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n *\n * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n *\n * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n * @param {String[]} [failedValidators] - List of failed validators.\n * @returns {Object} jQuery object with the selector.\n */\n findFormError($el, failedValidators) {\n var id = $el.length ? $el[0].id : '';\n var $error = $el.siblings(this.options.formErrorSelector);\n\n if (!$error.length) {\n $error = $el.parent().find(this.options.formErrorSelector);\n }\n\n if (id) {\n $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n }\n\n if (!!failedValidators) {\n $error = $error.not('[data-form-error-on]')\n\n failedValidators.forEach((v) => {\n $error = $error.add($el.siblings(`[data-form-error-on=\"${v}\"]`));\n $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"][data-form-error-on=\"${v}\"]`));\n });\n }\n\n return $error;\n }\n\n /**\n * Get the first element in this order:\n * 2. The '\n */\n backButton: '
    • Back
    • ',\n /**\n * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n * @option\n * @type {string}\n * @default top\n */\n backButtonPosition: 'top',\n /**\n * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n * @option\n * @type {string}\n * @default '
      '\n */\n wrapper: '
      ',\n /**\n * Adds the parent link to the submenu.\n * @option\n * @type {boolean}\n * @default false\n */\n parentLink: false,\n /**\n * Allow the menu to return to root list on body click.\n * @option\n * @type {boolean}\n * @default false\n */\n closeOnClick: false,\n /**\n * Allow the menu to auto adjust height.\n * @option\n * @type {boolean}\n * @default false\n */\n autoHeight: false,\n /**\n * Animate the auto adjust height.\n * @option\n * @type {boolean}\n * @default false\n */\n animateHeight: false,\n /**\n * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n * @option\n * @type {boolean}\n * @default false\n */\n scrollTop: false,\n /**\n * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n * @option\n * @type {string}\n * @default ''\n */\n scrollTopElement: '',\n /**\n * ScrollTop offset\n * @option\n * @type {number}\n * @default 0\n */\n scrollTopOffset: 0,\n /**\n * Scroll animation duration\n * @option\n * @type {number}\n * @default 500\n */\n animationDuration: 500,\n /**\n * Scroll animation easing. Can be `'swing'` or `'linear'`.\n * @option\n * @type {string}\n * @see {@link https://api.jquery.com/animate|JQuery animate}\n * @default 'swing'\n */\n animationEasing: 'swing'\n // holdOpen: false\n};\n\nexport {Drilldown};\n","import { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n 'left': VERTICAL_ALIGNMENTS,\n 'right': VERTICAL_ALIGNMENTS,\n 'top': HORIZONTAL_ALIGNMENTS,\n 'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n var currentIdx = array.indexOf(item);\n if(currentIdx === array.length - 1) {\n return array[0];\n } else {\n return array[currentIdx + 1];\n }\n}\n\n\nclass Positionable extends Plugin {\n /**\n * Abstract class encapsulating the tether-like explicit positioning logic\n * including repositioning based on overlap.\n * Expects classes to define defaults for vOffset, hOffset, position,\n * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n * extending the defaults, or (for now recommended due to the way docs are\n * generated) by explicitly declaring them.\n *\n **/\n\n _init() {\n this.triedPositions = {};\n this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n this.originalPosition = this.position;\n this.originalAlignment = this.alignment;\n }\n\n _getDefaultPosition () {\n return 'bottom';\n }\n\n _getDefaultAlignment() {\n switch(this.position) {\n case 'bottom':\n case 'top':\n return Rtl() ? 'right' : 'left';\n case 'left':\n case 'right':\n return 'bottom';\n }\n }\n\n /**\n * Adjusts the positionable possible positions by iterating through alignments\n * and positions.\n * @function\n * @private\n */\n _reposition() {\n if(this._alignmentsExhausted(this.position)) {\n this.position = nextItem(this.position, POSITIONS);\n this.alignment = ALIGNMENTS[this.position][0];\n } else {\n this._realign();\n }\n }\n\n /**\n * Adjusts the dropdown pane possible positions by iterating through alignments\n * on the current position.\n * @function\n * @private\n */\n _realign() {\n this._addTriedPosition(this.position, this.alignment)\n this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n }\n\n _addTriedPosition(position, alignment) {\n this.triedPositions[position] = this.triedPositions[position] || []\n this.triedPositions[position].push(alignment);\n }\n\n _positionsExhausted() {\n var isExhausted = true;\n for(var i = 0; i < POSITIONS.length; i++) {\n isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n }\n return isExhausted;\n }\n\n _alignmentsExhausted(position) {\n return this.triedPositions[position] && this.triedPositions[position].length === ALIGNMENTS[position].length;\n }\n\n\n // When we're trying to center, we don't want to apply offset that's going to\n // take us just off center, so wrap around to return 0 for the appropriate\n // offset in those alignments. TODO: Figure out if we want to make this\n // configurable behavior... it feels more intuitive, especially for tooltips, but\n // it's possible someone might actually want to start from center and then nudge\n // slightly off.\n _getVOffset() {\n return this.options.vOffset;\n }\n\n _getHOffset() {\n return this.options.hOffset;\n }\n\n _setPosition($anchor, $element, $parent) {\n if($anchor.attr('aria-expanded') === 'false'){ return false; }\n\n if (!this.options.allowOverlap) {\n // restore original position & alignment before checking overlap\n this.position = this.originalPosition;\n this.alignment = this.originalAlignment;\n }\n\n $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n if(!this.options.allowOverlap) {\n var minOverlap = 100000000;\n // default coordinates to how we start, in case we can't figure out better\n var minCoordinates = {position: this.position, alignment: this.alignment};\n while(!this._positionsExhausted()) {\n let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n if(overlap === 0) {\n return;\n }\n\n if(overlap < minOverlap) {\n minOverlap = overlap;\n minCoordinates = {position: this.position, alignment: this.alignment};\n }\n\n this._reposition();\n\n $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n }\n // If we get through the entire loop, there was no non-overlapping\n // position available. Pick the version with least overlap.\n this.position = minCoordinates.position;\n this.alignment = minCoordinates.alignment;\n $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n }\n }\n\n}\n\nPositionable.defaults = {\n /**\n * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n * @option\n * @type {string}\n * @default 'auto'\n */\n position: 'auto',\n /**\n * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n * @option\n * @type {string}\n * @default 'auto'\n */\n alignment: 'auto',\n /**\n * Allow overlap of container/window. If false, dropdown positionable first\n * try to position as defined by data-position and data-alignment, but\n * reposition if it would cause an overflow.\n * @option\n * @type {boolean}\n * @default false\n */\n allowOverlap: false,\n /**\n * Allow overlap of only the bottom of the container. This is the most common\n * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n * screen but not otherwise influence or break out of the container.\n * @option\n * @type {boolean}\n * @default true\n */\n allowBottomOverlap: true,\n /**\n * Number of pixels the positionable should be separated vertically from anchor\n * @option\n * @type {number}\n * @default 0\n */\n vOffset: 0,\n /**\n * Number of pixels the positionable should be separated horizontally from anchor\n * @option\n * @type {number}\n * @default 0\n */\n hOffset: 0,\n}\n\nexport {Positionable};\n","import $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { Positionable } from './foundation.positionable';\n\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.touch\n * @requires foundation.util.triggers\n */\nclass Dropdown extends Positionable {\n /**\n * Creates a new instance of a dropdown.\n * @class\n * @name Dropdown\n * @param {jQuery} element - jQuery object to make into a dropdown.\n * Object should be of the dropdown panel, rather than its anchor.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n this.className = 'Dropdown'; // ie9 back compat\n\n // Touch and Triggers init are idempotent, just need to make sure they are initialized\n Touch.init($);\n Triggers.init($);\n\n this._init();\n\n Keyboard.register('Dropdown', {\n 'ENTER': 'toggle',\n 'SPACE': 'toggle',\n 'ESCAPE': 'close'\n });\n }\n\n /**\n * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n * @function\n * @private\n */\n _init() {\n var $id = this.$element.attr('id');\n\n this.$anchors = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n this.$anchors.attr({\n 'aria-controls': $id,\n 'data-is-focus': false,\n 'data-yeti-box': $id,\n 'aria-haspopup': true,\n 'aria-expanded': false\n });\n\n this._setCurrentAnchor(this.$anchors.first());\n\n if(this.options.parentClass){\n this.$parent = this.$element.parents('.' + this.options.parentClass);\n }else{\n this.$parent = null;\n }\n\n // Set [aria-labelledby] on the Dropdown if it is not set\n if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n // Get the anchor ID or create one\n if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));\n }\n\n this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n }\n\n this.$element.attr({\n 'aria-hidden': 'true',\n 'data-yeti-box': $id,\n 'data-resize': $id,\n });\n\n super._init();\n this._events();\n }\n\n _getDefaultPosition() {\n // handle legacy classnames\n var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n if(position) {\n return position[0];\n } else {\n return 'bottom'\n }\n }\n\n _getDefaultAlignment() {\n // handle legacy float approach\n var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n if(horizontalPosition) {\n return horizontalPosition[1];\n }\n\n return super._getDefaultAlignment();\n }\n\n\n\n /**\n * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n * Recursively calls itself if a collision is detected, with a new position class.\n * @function\n * @private\n */\n _setPosition() {\n this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n super._setPosition(this.$currentAnchor, this.$element, this.$parent);\n this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n }\n\n /**\n * Make it a current anchor.\n * Current anchor as the reference for the position of Dropdown panes.\n * @param {HTML} el - DOM element of the anchor.\n * @function\n * @private\n */\n _setCurrentAnchor(el) {\n this.$currentAnchor = $(el);\n }\n\n /**\n * Adds event listeners to the element utilizing the triggers utility library.\n * @function\n * @private\n */\n _events() {\n var _this = this,\n hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined');\n\n this.$element.on({\n 'open.zf.trigger': this.open.bind(this),\n 'close.zf.trigger': this.close.bind(this),\n 'toggle.zf.trigger': this.toggle.bind(this),\n 'resizeme.zf.trigger': this._setPosition.bind(this)\n });\n\n this.$anchors.off('click.zf.trigger')\n .on('click.zf.trigger', function(e) {\n _this._setCurrentAnchor(this);\n\n if (\n // if forceFollow false, always prevent default action\n (_this.options.forceFollow === false) ||\n // if forceFollow true and hover option true, only prevent default action on 1st click\n // on 2nd click (dropown opened) the default action (e.g. follow a href) gets executed\n (hasTouch && _this.options.hover && _this.$element.hasClass('is-open') === false)\n ) {\n e.preventDefault();\n }\n });\n\n if(this.options.hover){\n this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n .on('mouseenter.zf.dropdown', function(){\n _this._setCurrentAnchor(this);\n\n var bodyData = $('body').data();\n if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {\n clearTimeout(_this.timeout);\n _this.timeout = setTimeout(function(){\n _this.open();\n _this.$anchors.data('hover', true);\n }, _this.options.hoverDelay);\n }\n }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n clearTimeout(_this.timeout);\n _this.timeout = setTimeout(function(){\n _this.close();\n _this.$anchors.data('hover', false);\n }, _this.options.hoverDelay);\n }));\n if(this.options.hoverPane){\n this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n .on('mouseenter.zf.dropdown', function(){\n clearTimeout(_this.timeout);\n }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n clearTimeout(_this.timeout);\n _this.timeout = setTimeout(function(){\n _this.close();\n _this.$anchors.data('hover', false);\n }, _this.options.hoverDelay);\n }));\n }\n }\n this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n var $target = $(this);\n\n Keyboard.handleKey(e, 'Dropdown', {\n open: function() {\n if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n _this.open();\n _this.$element.attr('tabindex', -1).focus();\n e.preventDefault();\n }\n },\n close: function() {\n _this.close();\n _this.$anchors.focus();\n }\n });\n });\n }\n\n /**\n * Adds an event handler to the body to close any dropdowns on a click.\n * @function\n * @private\n */\n _addBodyHandler() {\n var $body = $(document.body).not(this.$element),\n _this = this;\n $body.off('click.zf.dropdown tap.zf.dropdown')\n .on('click.zf.dropdown tap.zf.dropdown', function (e) {\n if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n return;\n }\n if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n return;\n }\n _this.close();\n $body.off('click.zf.dropdown tap.zf.dropdown');\n });\n }\n\n /**\n * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n * @function\n * @fires Dropdown#closeme\n * @fires Dropdown#show\n */\n open() {\n // var _this = this;\n /**\n * Fires to close other open dropdowns, typically when dropdown is opening\n * @event Dropdown#closeme\n */\n this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n this.$anchors.addClass('hover')\n .attr({'aria-expanded': true});\n // this.$element/*.show()*/;\n\n this.$element.addClass('is-opening');\n this._setPosition();\n this.$element.removeClass('is-opening').addClass('is-open')\n .attr({'aria-hidden': false});\n\n if(this.options.autoFocus){\n var $focusable = Keyboard.findFocusable(this.$element);\n if($focusable.length){\n $focusable.eq(0).focus();\n }\n }\n\n if(this.options.closeOnClick){ this._addBodyHandler(); }\n\n if (this.options.trapFocus) {\n Keyboard.trapFocus(this.$element);\n }\n\n /**\n * Fires once the dropdown is visible.\n * @event Dropdown#show\n */\n this.$element.trigger('show.zf.dropdown', [this.$element]);\n }\n\n /**\n * Closes the open dropdown pane.\n * @function\n * @fires Dropdown#hide\n */\n close() {\n if(!this.$element.hasClass('is-open')){\n return false;\n }\n this.$element.removeClass('is-open')\n .attr({'aria-hidden': true});\n\n this.$anchors.removeClass('hover')\n .attr('aria-expanded', false);\n\n /**\n * Fires once the dropdown is no longer visible.\n * @event Dropdown#hide\n */\n this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n if (this.options.trapFocus) {\n Keyboard.releaseFocus(this.$element);\n }\n }\n\n /**\n * Toggles the dropdown pane's visibility.\n * @function\n */\n toggle() {\n if(this.$element.hasClass('is-open')){\n if(this.$anchors.data('hover')) return;\n this.close();\n }else{\n this.open();\n }\n }\n\n /**\n * Destroys the dropdown.\n * @function\n */\n _destroy() {\n this.$element.off('.zf.trigger').hide();\n this.$anchors.off('.zf.dropdown');\n $(document.body).off('click.zf.dropdown tap.zf.dropdown');\n\n }\n}\n\nDropdown.defaults = {\n /**\n * Class that designates bounding container of Dropdown (default: window)\n * @option\n * @type {?string}\n * @default null\n */\n parentClass: null,\n /**\n * Amount of time to delay opening a submenu on hover event.\n * @option\n * @type {number}\n * @default 250\n */\n hoverDelay: 250,\n /**\n * Allow submenus to open on hover events\n * @option\n * @type {boolean}\n * @default false\n */\n hover: false,\n /**\n * Don't close dropdown when hovering over dropdown pane\n * @option\n * @type {boolean}\n * @default false\n */\n hoverPane: false,\n /**\n * Number of pixels between the dropdown pane and the triggering element on open.\n * @option\n * @type {number}\n * @default 0\n */\n vOffset: 0,\n /**\n * Number of pixels between the dropdown pane and the triggering element on open.\n * @option\n * @type {number}\n * @default 0\n */\n hOffset: 0,\n /**\n * Position of dropdown. Can be left, right, bottom, top, or auto.\n * @option\n * @type {string}\n * @default 'auto'\n */\n position: 'auto',\n /**\n * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n * @option\n * @type {string}\n * @default 'auto'\n */\n alignment: 'auto',\n /**\n * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n * @option\n * @type {boolean}\n * @default false\n */\n allowOverlap: false,\n /**\n * Allow overlap of only the bottom of the container. This is the most common\n * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n * screen but not otherwise influence or break out of the container.\n * @option\n * @type {boolean}\n * @default true\n */\n allowBottomOverlap: true,\n /**\n * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n * @option\n * @type {boolean}\n * @default false\n */\n trapFocus: false,\n /**\n * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n * @option\n * @type {boolean}\n * @default false\n */\n autoFocus: false,\n /**\n * Allows a click on the body to close the dropdown.\n * @option\n * @type {boolean}\n * @default false\n */\n closeOnClick: false,\n /**\n * If true the default action of the toggle (e.g. follow a link with href) gets executed on click. If hover option is also true the default action gets prevented on first click for mobile / touch devices and executed on second click.\n * @option\n * @type {boolean}\n * @default true\n */\n forceFollow: true\n};\n\nexport {Dropdown};\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl, ignoreMousedisappear } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { Box } from './foundation.util.box';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdownMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n * @requires foundation.util.touch\n */\n\nclass DropdownMenu extends Plugin {\n /**\n * Creates a new instance of DropdownMenu.\n * @class\n * @name DropdownMenu\n * @fires DropdownMenu#init\n * @param {jQuery} element - jQuery object to make into a dropdown menu.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n this.className = 'DropdownMenu'; // ie9 back compat\n\n Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n this._init();\n\n Keyboard.register('DropdownMenu', {\n 'ENTER': 'open',\n 'SPACE': 'open',\n 'ARROW_RIGHT': 'next',\n 'ARROW_UP': 'up',\n 'ARROW_DOWN': 'down',\n 'ARROW_LEFT': 'previous',\n 'ESCAPE': 'close'\n });\n }\n\n /**\n * Initializes the plugin, and calls _prepareMenu\n * @private\n * @function\n */\n _init() {\n Nest.Feather(this.$element, 'dropdown');\n\n var subs = this.$element.find('li.is-dropdown-submenu-parent');\n this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n\n this.$menuItems = this.$element.find('li[role=\"none\"]');\n this.$tabs = this.$element.children('li[role=\"none\"]');\n this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n if (this.options.alignment === 'auto') {\n if (this.$element.hasClass(this.options.rightClass) || Rtl() || this.$element.parents('.top-bar-right').is('*')) {\n this.options.alignment = 'right';\n subs.addClass('opens-left');\n } else {\n this.options.alignment = 'left';\n subs.addClass('opens-right');\n }\n } else {\n if (this.options.alignment === 'right') {\n subs.addClass('opens-left');\n } else {\n subs.addClass('opens-right');\n }\n }\n this.changed = false;\n this._events();\n };\n\n _isVertical() {\n return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n }\n\n _isRtl() {\n return this.$element.hasClass('align-right') || (Rtl() && !this.$element.hasClass('align-left'));\n }\n\n /**\n * Adds event listeners to elements within the menu\n * @private\n * @function\n */\n _events() {\n var _this = this,\n hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),\n parClass = 'is-dropdown-submenu-parent';\n\n // used for onClick and in the keyboard handlers\n var handleClickFn = function(e) {\n var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),\n hasSub = $elem.hasClass(parClass),\n hasClicked = $elem.attr('data-is-click') === 'true',\n $sub = $elem.children('.is-dropdown-submenu');\n\n if (hasSub) {\n if (hasClicked) {\n if (!_this.options.closeOnClick\n || (!_this.options.clickOpen && !hasTouch)\n || (_this.options.forceFollow && hasTouch)) {\n return;\n }\n e.stopImmediatePropagation();\n e.preventDefault();\n _this._hide($elem);\n }\n else {\n e.stopImmediatePropagation();\n e.preventDefault();\n _this._show($sub);\n $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);\n }\n }\n };\n\n if (this.options.clickOpen || hasTouch) {\n this.$menuItems.on('click.zf.dropdownMenu touchstart.zf.dropdownMenu', handleClickFn);\n }\n\n // Handle Leaf element Clicks\n if(_this.options.closeOnClickInside){\n this.$menuItems.on('click.zf.dropdownMenu', function() {\n var $elem = $(this),\n hasSub = $elem.hasClass(parClass);\n if(!hasSub){\n _this._hide();\n }\n });\n }\n\n if (hasTouch && this.options.disableHoverOnTouch) this.options.disableHover = true;\n\n if (!this.options.disableHover) {\n this.$menuItems.on('mouseenter.zf.dropdownMenu', function () {\n var $elem = $(this),\n hasSub = $elem.hasClass(parClass);\n\n if (hasSub) {\n clearTimeout($elem.data('_delay'));\n $elem.data('_delay', setTimeout(function () {\n _this._show($elem.children('.is-dropdown-submenu'));\n }, _this.options.hoverDelay));\n }\n }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function () {\n var $elem = $(this),\n hasSub = $elem.hasClass(parClass);\n if (hasSub && _this.options.autoclose) {\n if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }\n\n clearTimeout($elem.data('_delay'));\n $elem.data('_delay', setTimeout(function () {\n _this._hide($elem);\n }, _this.options.closingTime));\n }\n }));\n }\n this.$menuItems.on('keydown.zf.dropdownMenu', function(e) {\n var $element = $(e.target).parentsUntil('ul', '[role=\"none\"]'),\n isTab = _this.$tabs.index($element) > -1,\n $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n $prevElement,\n $nextElement;\n\n $elements.each(function(i) {\n if ($(this).is($element)) {\n $prevElement = $elements.eq(i-1);\n $nextElement = $elements.eq(i+1);\n return;\n }\n });\n\n var nextSibling = function() {\n $nextElement.children('a:first').focus();\n e.preventDefault();\n }, prevSibling = function() {\n $prevElement.children('a:first').focus();\n e.preventDefault();\n }, openSub = function() {\n var $sub = $element.children('ul.is-dropdown-submenu');\n if ($sub.length) {\n _this._show($sub);\n $element.find('li > a:first').focus();\n e.preventDefault();\n } else { return; }\n }, closeSub = function() {\n //if ($element.is(':first-child')) {\n var close = $element.parent('ul').parent('li');\n close.children('a:first').focus();\n _this._hide(close);\n e.preventDefault();\n //}\n };\n var functions = {\n open: openSub,\n close: function() {\n _this._hide(_this.$element);\n _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n e.preventDefault();\n }\n };\n\n if (isTab) {\n if (_this._isVertical()) { // vertical menu\n if (_this._isRtl()) { // right aligned\n $.extend(functions, {\n down: nextSibling,\n up: prevSibling,\n next: closeSub,\n previous: openSub\n });\n } else { // left aligned\n $.extend(functions, {\n down: nextSibling,\n up: prevSibling,\n next: openSub,\n previous: closeSub\n });\n }\n } else { // horizontal menu\n if (_this._isRtl()) { // right aligned\n $.extend(functions, {\n next: prevSibling,\n previous: nextSibling,\n down: openSub,\n up: closeSub\n });\n } else { // left aligned\n $.extend(functions, {\n next: nextSibling,\n previous: prevSibling,\n down: openSub,\n up: closeSub\n });\n }\n }\n } else { // not tabs -> one sub\n if (_this._isRtl()) { // right aligned\n $.extend(functions, {\n next: closeSub,\n previous: openSub,\n down: nextSibling,\n up: prevSibling\n });\n } else { // left aligned\n $.extend(functions, {\n next: openSub,\n previous: closeSub,\n down: nextSibling,\n up: prevSibling\n });\n }\n }\n Keyboard.handleKey(e, 'DropdownMenu', functions);\n\n });\n }\n\n /**\n * Adds an event handler to the body to close any dropdowns on a click.\n * @function\n * @private\n */\n _addBodyHandler() {\n const $body = $(document.body);\n this._removeBodyHandler();\n $body.on('click.zf.dropdownMenu tap.zf.dropdownMenu', (e) => {\n var isItself = !!$(e.target).closest(this.$element).length;\n if (isItself) return;\n\n this._hide();\n this._removeBodyHandler();\n });\n }\n\n /**\n * Remove the body event handler. See `_addBodyHandler`.\n * @function\n * @private\n */\n _removeBodyHandler() {\n $(document.body).off('click.zf.dropdownMenu tap.zf.dropdownMenu');\n }\n\n /**\n * Opens a dropdown pane, and checks for collisions first.\n * @param {jQuery} $sub - ul element that is a submenu to show\n * @function\n * @private\n * @fires DropdownMenu#show\n */\n _show($sub) {\n var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {\n return $(el).find($sub).length > 0;\n }));\n var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n this._hide($sibs, idx);\n $sub.css('visibility', 'hidden').addClass('js-dropdown-active')\n .parent('li.is-dropdown-submenu-parent').addClass('is-active');\n var clear = Box.ImNotTouchingYou($sub, null, true);\n if (!clear) {\n var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);\n clear = Box.ImNotTouchingYou($sub, null, true);\n if (!clear) {\n $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');\n }\n this.changed = true;\n }\n $sub.css('visibility', '');\n if (this.options.closeOnClick) { this._addBodyHandler(); }\n /**\n * Fires when the new dropdown pane is visible.\n * @event DropdownMenu#show\n */\n this.$element.trigger('show.zf.dropdownMenu', [$sub]);\n }\n\n /**\n * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n * @function\n * @param {jQuery} $elem - element with a submenu to hide\n * @param {Number} idx - index of the $tabs collection to hide\n * @fires DropdownMenu#hide\n * @private\n */\n _hide($elem, idx) {\n var $toClose;\n if ($elem && $elem.length) {\n $toClose = $elem;\n } else if (typeof idx !== 'undefined') {\n $toClose = this.$tabs.not(function(i) {\n return i === idx;\n });\n }\n else {\n $toClose = this.$element;\n }\n var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n if (somethingToClose) {\n var $activeItem = $toClose.find('li.is-active');\n $activeItem.add($toClose).attr({\n 'data-is-click': false\n }).removeClass('is-active');\n\n $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n if (this.changed || $toClose.find('opens-inner').length) {\n var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n $toClose.find('li.is-dropdown-submenu-parent').add($toClose)\n .removeClass(`opens-inner opens-${this.options.alignment}`)\n .addClass(`opens-${oldClass}`);\n this.changed = false;\n }\n\n clearTimeout($activeItem.data('_delay'));\n this._removeBodyHandler();\n\n /**\n * Fires when the open menus are closed.\n * @event DropdownMenu#hide\n */\n this.$element.trigger('hide.zf.dropdownMenu', [$toClose]);\n }\n }\n\n /**\n * Destroys the plugin.\n * @function\n */\n _destroy() {\n this.$menuItems.off('.zf.dropdownMenu').removeAttr('data-is-click')\n .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n $(document.body).off('.zf.dropdownMenu');\n Nest.Burn(this.$element, 'dropdown');\n }\n}\n\n/**\n * Default settings for plugin\n */\nDropdownMenu.defaults = {\n /**\n * Disallows hover events from opening submenus\n * @option\n * @type {boolean}\n * @default false\n */\n disableHover: false,\n /**\n * Disallows hover on touch devices\n * @option\n * @type {boolean}\n * @default true\n */\n disableHoverOnTouch: true,\n /**\n * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n * @option\n * @type {boolean}\n * @default true\n */\n autoclose: true,\n /**\n * Amount of time to delay opening a submenu on hover event.\n * @option\n * @type {number}\n * @default 50\n */\n hoverDelay: 50,\n /**\n * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n * @option\n * @type {boolean}\n * @default false\n */\n clickOpen: false,\n /**\n * Amount of time to delay closing a submenu on a mouseleave event.\n * @option\n * @type {number}\n * @default 500\n */\n\n closingTime: 500,\n /**\n * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n * @option\n * @type {string}\n * @default 'auto'\n */\n alignment: 'auto',\n /**\n * Allow clicks on the body to close any open submenus.\n * @option\n * @type {boolean}\n * @default true\n */\n closeOnClick: true,\n /**\n * Allow clicks on leaf anchor links to close any open submenus.\n * @option\n * @type {boolean}\n * @default true\n */\n closeOnClickInside: true,\n /**\n * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n * @option\n * @type {string}\n * @default 'vertical'\n */\n verticalClass: 'vertical',\n /**\n * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n * @option\n * @type {string}\n * @default 'align-right'\n */\n rightClass: 'align-right',\n /**\n * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n * @option\n * @type {boolean}\n * @default true\n */\n forceFollow: true\n};\n\nexport {DropdownMenu};\n","import $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nclass Equalizer extends Plugin {\n /**\n * Creates a new instance of Equalizer.\n * @class\n * @name Equalizer\n * @fires Equalizer#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options){\n this.$element = element;\n this.options = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n this.className = 'Equalizer'; // ie9 back compat\n\n this._init();\n }\n\n /**\n * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n * @private\n */\n _init() {\n var eqId = this.$element.attr('data-equalizer') || '';\n var $watched = this.$element.find(`[data-equalizer-watch=\"${eqId}\"]`);\n\n MediaQuery._init();\n\n this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));\n this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));\n\n this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n this.isOn = false;\n this._bindHandler = {\n onResizeMeBound: this._onResizeMe.bind(this),\n onPostEqualizedBound: this._onPostEqualized.bind(this)\n };\n\n var imgs = this.$element.find('img');\n var tooSmall;\n if(this.options.equalizeOn){\n tooSmall = this._checkMQ();\n $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n }else{\n this._events();\n }\n if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){\n if(imgs.length){\n onImagesLoaded(imgs, this._reflow.bind(this));\n }else{\n this._reflow();\n }\n }\n }\n\n /**\n * Removes event listeners if the breakpoint is too small.\n * @private\n */\n _pauseEvents() {\n this.isOn = false;\n this.$element.off({\n '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n 'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n\t 'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n });\n }\n\n /**\n * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n * @private\n */\n _onResizeMe() {\n this._reflow();\n }\n\n /**\n * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n * @private\n */\n _onPostEqualized(e) {\n if(e.target !== this.$element[0]){ this._reflow(); }\n }\n\n /**\n * Initializes events for Equalizer.\n * @private\n */\n _events() {\n this._pauseEvents();\n if(this.hasNested){\n this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n }else{\n this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n\t this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n }\n this.isOn = true;\n }\n\n /**\n * Checks the current breakpoint to the minimum required size.\n * @private\n */\n _checkMQ() {\n var tooSmall = !MediaQuery.is(this.options.equalizeOn);\n if(tooSmall){\n if(this.isOn){\n this._pauseEvents();\n this.$watched.css('height', 'auto');\n }\n }else{\n if(!this.isOn){\n this._events();\n }\n }\n return tooSmall;\n }\n\n /**\n * A noop version for the plugin\n * @private\n */\n _killswitch() {\n return;\n }\n\n /**\n * Calls necessary functions to update Equalizer upon DOM change\n * @private\n */\n _reflow() {\n if(!this.options.equalizeOnStack){\n if(this._isStacked()){\n this.$watched.css('height', 'auto');\n return false;\n }\n }\n if (this.options.equalizeByRow) {\n this.getHeightsByRow(this.applyHeightByRow.bind(this));\n }else{\n this.getHeights(this.applyHeight.bind(this));\n }\n }\n\n /**\n * Manually determines if the first 2 elements are *NOT* stacked.\n * @private\n */\n _isStacked() {\n if (!this.$watched[0] || !this.$watched[1]) {\n return true;\n }\n return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n }\n\n /**\n * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n * @param {Function} cb - A non-optional callback to return the heights array to.\n * @returns {Array} heights - An array of heights of children within Equalizer container\n */\n getHeights(cb) {\n var heights = [];\n for(var i = 0, len = this.$watched.length; i < len; i++){\n this.$watched[i].style.height = 'auto';\n heights.push(this.$watched[i].offsetHeight);\n }\n cb(heights);\n }\n\n /**\n * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n * @param {Function} cb - A non-optional callback to return the heights array to.\n * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n */\n getHeightsByRow(cb) {\n var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),\n groups = [],\n group = 0;\n //group by Row\n groups[group] = [];\n for(var i = 0, len = this.$watched.length; i < len; i++){\n this.$watched[i].style.height = 'auto';\n //maybe could use this.$watched[i].offsetTop\n var elOffsetTop = $(this.$watched[i]).offset().top;\n if (elOffsetTop !== lastElTopOffset) {\n group++;\n groups[group] = [];\n lastElTopOffset=elOffsetTop;\n }\n groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);\n }\n\n for (var j = 0, ln = groups.length; j < ln; j++) {\n var heights = $(groups[j]).map(function(){ return this[1]; }).get();\n var max = Math.max.apply(null, heights);\n groups[j].push(max);\n }\n cb(groups);\n }\n\n /**\n * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n * @param {array} heights - An array of heights of children within Equalizer container\n * @fires Equalizer#preequalized\n * @fires Equalizer#postequalized\n */\n applyHeight(heights) {\n var max = Math.max.apply(null, heights);\n /**\n * Fires before the heights are applied\n * @event Equalizer#preequalized\n */\n this.$element.trigger('preequalized.zf.equalizer');\n\n this.$watched.css('height', max);\n\n /**\n * Fires when the heights have been applied\n * @event Equalizer#postequalized\n */\n this.$element.trigger('postequalized.zf.equalizer');\n }\n\n /**\n * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n * @fires Equalizer#preequalized\n * @fires Equalizer#preequalizedrow\n * @fires Equalizer#postequalizedrow\n * @fires Equalizer#postequalized\n */\n applyHeightByRow(groups) {\n /**\n * Fires before the heights are applied\n */\n this.$element.trigger('preequalized.zf.equalizer');\n for (var i = 0, len = groups.length; i < len ; i++) {\n var groupsILength = groups[i].length,\n max = groups[i][groupsILength - 1];\n if (groupsILength<=2) {\n $(groups[i][0][0]).css({'height':'auto'});\n continue;\n }\n /**\n * Fires before the heights per row are applied\n * @event Equalizer#preequalizedrow\n */\n this.$element.trigger('preequalizedrow.zf.equalizer');\n for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {\n $(groups[i][j][0]).css({'height':max});\n }\n /**\n * Fires when the heights per row have been applied\n * @event Equalizer#postequalizedrow\n */\n this.$element.trigger('postequalizedrow.zf.equalizer');\n }\n /**\n * Fires when the heights have been applied\n */\n this.$element.trigger('postequalized.zf.equalizer');\n }\n\n /**\n * Destroys an instance of Equalizer.\n * @function\n */\n _destroy() {\n this._pauseEvents();\n this.$watched.css('height', 'auto');\n }\n}\n\n/**\n * Default settings for plugin\n */\nEqualizer.defaults = {\n /**\n * Enable height equalization when stacked on smaller screens.\n * @option\n * @type {boolean}\n * @default false\n */\n equalizeOnStack: false,\n /**\n * Enable height equalization row by row.\n * @option\n * @type {boolean}\n * @default false\n */\n equalizeByRow: false,\n /**\n * String representing the minimum breakpoint size the plugin should equalize heights on.\n * @option\n * @type {string}\n * @default ''\n */\n equalizeOn: ''\n};\n\nexport {Equalizer};\n","import $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nclass Interchange extends Plugin {\n /**\n * Creates a new instance of Interchange.\n * @class\n * @name Interchange\n * @fires Interchange#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Interchange.defaults, this.$element.data(), options);\n this.rules = [];\n this.currentPath = '';\n this.className = 'Interchange'; // ie9 back compat\n\n // Triggers init is idempotent, just need to make sure it is initialized\n Triggers.init($);\n\n this._init();\n this._events();\n }\n\n /**\n * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n * @function\n * @private\n */\n _init() {\n MediaQuery._init();\n\n var id = this.$element[0].id || GetYoDigits(6, 'interchange');\n this.$element.attr({\n 'data-resize': id,\n 'id': id\n });\n\n this._parseOptions();\n this._addBreakpoints();\n this._generateRules();\n this._reflow();\n }\n\n /**\n * Initializes events for Interchange.\n * @function\n * @private\n */\n _events() {\n this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());\n }\n\n /**\n * Calls necessary functions to update Interchange upon DOM change\n * @function\n * @private\n */\n _reflow() {\n var match;\n\n // Iterate through each rule, but only save the last match\n for (var i in this.rules) {\n if(this.rules.hasOwnProperty(i)) {\n var rule = this.rules[i];\n if (window.matchMedia(rule.query).matches) {\n match = rule;\n }\n }\n }\n\n if (match) {\n this.replace(match.path);\n }\n }\n\n /**\n * Check options valifity and set defaults for:\n * - `data-interchange-type`: if set, enforce the type of replacement (auto, src, background or html)\n * @function\n * @private\n */\n _parseOptions() {\n var types = ['auto', 'src', 'background', 'html'];\n if (typeof this.options.type === 'undefined')\n this.options.type = 'auto';\n else if (types.indexOf(this.options.type) === -1) {\n console.warn(`Warning: invalid value \"${this.options.type}\" for Interchange option \"type\"`);\n this.options.type = 'auto';\n }\n }\n\n /**\n * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n * @function\n * @private\n */\n _addBreakpoints() {\n for (var i in MediaQuery.queries) {\n if (MediaQuery.queries.hasOwnProperty(i)) {\n var query = MediaQuery.queries[i];\n Interchange.SPECIAL_QUERIES[query.name] = query.value;\n }\n }\n }\n\n /**\n * Checks the Interchange element for the provided media query + content pairings\n * @function\n * @private\n * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n */\n _generateRules() {\n var rulesList = [];\n var rules;\n\n if (this.options.rules) {\n rules = this.options.rules;\n }\n else {\n rules = this.$element.data('interchange');\n }\n\n rules = typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n for (var i in rules) {\n if(rules.hasOwnProperty(i)) {\n var rule = rules[i].slice(1, -1).split(', ');\n var path = rule.slice(0, -1).join('');\n var query = rule[rule.length - 1];\n\n if (Interchange.SPECIAL_QUERIES[query]) {\n query = Interchange.SPECIAL_QUERIES[query];\n }\n\n rulesList.push({\n path: path,\n query: query\n });\n }\n }\n\n this.rules = rulesList;\n }\n\n /**\n * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n * @function\n * @param {String} path - Path to the image or HTML partial.\n * @fires Interchange#replaced\n */\n replace(path) {\n if (this.currentPath === path) return;\n\n var trigger = 'replaced.zf.interchange';\n\n var type = this.options.type;\n if (type === 'auto') {\n if (this.$element[0].nodeName === 'IMG')\n type = 'src';\n else if (path.match(/\\.(gif|jpe?g|png|svg|tiff)([?#].*)?/i))\n type = 'background';\n else\n type = 'html';\n }\n\n // Replacing images\n if (type === 'src') {\n this.$element.attr('src', path)\n .on('load', () => { this.currentPath = path; })\n .trigger(trigger);\n }\n // Replacing background images\n else if (type === 'background') {\n path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n this.$element\n .css({ 'background-image': 'url(' + path + ')' })\n .trigger(trigger);\n }\n // Replacing HTML\n else if (type === 'html') {\n $.get(path, (response) => {\n this.$element\n .html(response)\n .trigger(trigger);\n $(response).foundation();\n this.currentPath = path;\n });\n }\n\n /**\n * Fires when content in an Interchange element is done being loaded.\n * @event Interchange#replaced\n */\n // this.$element.trigger('replaced.zf.interchange');\n }\n\n /**\n * Destroys an instance of interchange.\n * @function\n */\n _destroy() {\n this.$element.off('resizeme.zf.trigger')\n }\n}\n\n/**\n * Default settings for plugin\n */\nInterchange.defaults = {\n /**\n * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n * @option\n * @type {?array}\n * @default null\n */\n rules: null,\n\n /**\n * Type of the responsive ressource to replace. It can take the following options:\n * - `auto` (default): choose the type according to the element tag or the ressource extension,\n * - `src`: replace the `[src]` attribute, recommended for images ``.\n * - `background`: replace the `background-image` CSS property.\n * - `html`: replace the element content.\n * @option\n * @type {string}\n * @default 'auto'\n */\n type: 'auto'\n};\n\nInterchange.SPECIAL_QUERIES = {\n 'landscape': 'screen and (orientation: landscape)',\n 'portrait': 'screen and (orientation: portrait)',\n 'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\nexport {Interchange};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * SmoothScroll module.\n * @module foundation.smoothScroll\n */\nclass SmoothScroll extends Plugin {\n /**\n * Creates a new instance of SmoothScroll.\n * @class\n * @name SmoothScroll\n * @fires SmoothScroll#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n this.className = 'SmoothScroll'; // ie9 back compat\n\n this._init();\n }\n\n /**\n * Initialize the SmoothScroll plugin\n * @private\n */\n _init() {\n const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');\n this.$element.attr({ id });\n\n this._events();\n }\n\n /**\n * Initializes events for SmoothScroll.\n * @private\n */\n _events() {\n this._linkClickListener = this._handleLinkClick.bind(this);\n this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n }\n\n /**\n * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n * @param {*} e - event\n * @function\n * @private\n */\n _handleLinkClick(e) {\n // Follow the link if it does not point to an anchor.\n if (!$(e.currentTarget).is('a[href^=\"#\"]')) return;\n\n const arrival = e.currentTarget.getAttribute('href');\n\n this._inTransition = true;\n\n SmoothScroll.scrollToLoc(arrival, this.options, () => {\n this._inTransition = false;\n });\n\n e.preventDefault();\n };\n\n /**\n * Function to scroll to a given location on the page.\n * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n * @param {Object} options - The options to use.\n * @param {Function} callback - The callback function.\n * @static\n * @function\n */\n static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {\n const $loc = $(loc);\n\n // Do nothing if target does not exist to prevent errors\n if (!$loc.length) return false;\n\n var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n\n $('html, body').stop(true).animate(\n { scrollTop: scrollPos },\n options.animationDuration,\n options.animationEasing,\n () => {\n if (typeof callback === 'function'){\n callback();\n }\n }\n );\n }\n\n /**\n * Destroys the SmoothScroll instance.\n * @function\n */\n _destroy() {\n this.$element.off('click.zf.smoothScroll', this._linkClickListener)\n this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n }\n}\n\n/**\n * Default settings for plugin.\n */\nSmoothScroll.defaults = {\n /**\n * Amount of time, in ms, the animated scrolling should take between locations.\n * @option\n * @type {number}\n * @default 500\n */\n animationDuration: 500,\n /**\n * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n * @option\n * @type {string}\n * @default 'linear'\n * @see {@link https://api.jquery.com/animate|Jquery animate}\n */\n animationEasing: 'linear',\n /**\n * Number of pixels to use as a marker for location changes.\n * @option\n * @type {number}\n * @default 50\n */\n threshold: 50,\n /**\n * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n * @option\n * @type {number}\n * @default 0\n */\n offset: 0\n}\n\nexport {SmoothScroll}\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { SmoothScroll } from './foundation.smoothScroll';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n * @requires foundation.util.triggers\n */\n\nclass Magellan extends Plugin {\n /**\n * Creates a new instance of Magellan.\n * @class\n * @name Magellan\n * @fires Magellan#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Magellan.defaults, this.$element.data(), options);\n this.className = 'Magellan'; // ie9 back compat\n\n // Triggers init is idempotent, just need to make sure it is initialized\n Triggers.init($);\n\n this._init();\n this.calcPoints();\n }\n\n /**\n * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n * @private\n */\n _init() {\n var id = this.$element[0].id || GetYoDigits(6, 'magellan');\n this.$targets = $('[data-magellan-target]');\n this.$links = this.$element.find('a');\n this.$element.attr({\n 'data-resize': id,\n 'data-scroll': id,\n 'id': id\n });\n this.$active = $();\n this.scrollPos = parseInt(window.pageYOffset, 10);\n\n this._events();\n }\n\n /**\n * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n * Can be invoked if new elements are added or the size of a location changes.\n * @function\n */\n calcPoints() {\n var _this = this,\n body = document.body,\n html = document.documentElement;\n\n this.points = [];\n this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n\n this.$targets.each(function(){\n var $tar = $(this),\n pt = Math.round($tar.offset().top - _this.options.threshold);\n $tar.targetPoint = pt;\n _this.points.push(pt);\n });\n }\n\n /**\n * Initializes events for Magellan.\n * @private\n */\n _events() {\n var _this = this;\n\n $(window).one('load', function(){\n if(_this.options.deepLinking){\n if(location.hash){\n _this.scrollToLoc(location.hash);\n }\n }\n _this.calcPoints();\n _this._updateActive();\n });\n\n _this.onLoadListener = onLoad($(window), function () {\n _this.$element\n .on({\n 'resizeme.zf.trigger': _this.reflow.bind(_this),\n 'scrollme.zf.trigger': _this._updateActive.bind(_this)\n })\n .on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n e.preventDefault();\n var arrival = this.getAttribute('href');\n _this.scrollToLoc(arrival);\n });\n });\n\n this._deepLinkScroll = function() {\n if(_this.options.deepLinking) {\n _this.scrollToLoc(window.location.hash);\n }\n };\n\n $(window).on('hashchange', this._deepLinkScroll);\n }\n\n /**\n * Function to scroll to a given location on the page.\n * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n * @function\n */\n scrollToLoc(loc) {\n this._inTransition = true;\n var _this = this;\n\n var options = {\n animationEasing: this.options.animationEasing,\n animationDuration: this.options.animationDuration,\n threshold: this.options.threshold,\n offset: this.options.offset\n };\n\n SmoothScroll.scrollToLoc(loc, options, function() {\n _this._inTransition = false;\n })\n }\n\n /**\n * Calls necessary functions to update Magellan upon DOM change\n * @function\n */\n reflow() {\n this.calcPoints();\n this._updateActive();\n }\n\n /**\n * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n * @private\n * @function\n * @fires Magellan#update\n */\n _updateActive(/*evt, elem, scrollPos*/) {\n if(this._inTransition) return;\n\n const newScrollPos = parseInt(window.pageYOffset, 10);\n const isScrollingUp = this.scrollPos > newScrollPos;\n this.scrollPos = newScrollPos;\n\n let activeIdx;\n // Before the first point: no link\n if(newScrollPos < this.points[0] - this.options.offset - (isScrollingUp ? this.options.threshold : 0)){ /* do nothing */ }\n // At the bottom of the page: last link\n else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }\n // Otherwhise, use the last visible link\n else{\n const visibleLinks = this.points.filter((p) => {\n return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;\n });\n activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n }\n\n // Get the new active link\n const $oldActive = this.$active;\n let activeHash = '';\n if(typeof activeIdx !== 'undefined'){\n this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n }else{\n this.$active = $();\n }\n const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n const isNewHash = activeHash !== window.location.hash;\n\n // Update the active link element\n if(isNewActive) {\n $oldActive.removeClass(this.options.activeClass);\n this.$active.addClass(this.options.activeClass);\n }\n\n // Update the hash (it may have changed with the same active link)\n if(this.options.deepLinking && isNewHash){\n if(window.history.pushState){\n // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n const url = activeHash ? activeHash : window.location.pathname + window.location.search;\n if(this.options.updateHistory){\n window.history.pushState({}, '', url);\n }else{\n window.history.replaceState({}, '', url);\n }\n }else{\n window.location.hash = activeHash;\n }\n }\n\n if (isNewActive) {\n /**\n * Fires when magellan is finished updating to the new active element.\n * @event Magellan#update\n */\n \tthis.$element.trigger('update.zf.magellan', [this.$active]);\n\t }\n }\n\n /**\n * Destroys an instance of Magellan and resets the url of the window.\n * @function\n */\n _destroy() {\n this.$element.off('.zf.trigger .zf.magellan')\n .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);\n\n if(this.options.deepLinking){\n var hash = this.$active[0].getAttribute('href');\n window.location.hash.replace(hash, '');\n }\n\n $(window).off('hashchange', this._deepLinkScroll)\n if (this.onLoadListener) $(window).off(this.onLoadListener);\n }\n}\n\n/**\n * Default settings for plugin\n */\nMagellan.defaults = {\n /**\n * Amount of time, in ms, the animated scrolling should take between locations.\n * @option\n * @type {number}\n * @default 500\n */\n animationDuration: 500,\n /**\n * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n * @option\n * @type {string}\n * @default 'linear'\n * @see {@link https://api.jquery.com/animate|Jquery animate}\n */\n animationEasing: 'linear',\n /**\n * Number of pixels to use as a marker for location changes.\n * @option\n * @type {number}\n * @default 50\n */\n threshold: 50,\n /**\n * Class applied to the active locations link on the magellan container.\n * @option\n * @type {string}\n * @default 'is-active'\n */\n activeClass: 'is-active',\n /**\n * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n * @option\n * @type {boolean}\n * @default false\n */\n deepLinking: false,\n /**\n * Update the browser history with the active link, if deep linking is enabled.\n * @option\n * @type {boolean}\n * @default false\n */\n updateHistory: false,\n /**\n * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n * @option\n * @type {number}\n * @default 0\n */\n offset: 0\n}\n\nexport {Magellan};\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { onLoad, transitionend, RegExpEscape } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * OffCanvas module.\n * @module foundation.offCanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass OffCanvas extends Plugin {\n /**\n * Creates a new instance of an off-canvas wrapper.\n * @class\n * @name OffCanvas\n * @fires OffCanvas#init\n * @param {Object} element - jQuery object to initialize.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.className = 'OffCanvas'; // ie9 back compat\n this.$element = element;\n this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n this.contentClasses = { base: [], reveal: [] };\n this.$lastTrigger = $();\n this.$triggers = $();\n this.position = 'left';\n this.$content = $();\n this.nested = !!(this.options.nested);\n this.$sticky = $();\n this.isInCanvas = false;\n\n // Defines the CSS transition/position classes of the off-canvas content container.\n $(['push', 'overlap']).each((index, val) => {\n this.contentClasses.base.push('has-transition-'+val);\n });\n $(['left', 'right', 'top', 'bottom']).each((index, val) => {\n this.contentClasses.base.push('has-position-'+val);\n this.contentClasses.reveal.push('has-reveal-'+val);\n });\n\n // Triggers init is idempotent, just need to make sure it is initialized\n Triggers.init($);\n MediaQuery._init();\n\n this._init();\n this._events();\n\n Keyboard.register('OffCanvas', {\n 'ESCAPE': 'close'\n });\n\n }\n\n /**\n * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n * @function\n * @private\n */\n _init() {\n var id = this.$element.attr('id');\n\n this.$element.attr('aria-hidden', 'true');\n\n // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n if (this.options.contentId) {\n this.$content = $('#'+this.options.contentId);\n } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n } else {\n this.$content = this.$element.closest('[data-off-canvas-content]').first();\n }\n\n if (!this.options.contentId) {\n // Assume that the off-canvas element is nested if it isn't a sibling of the content\n this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n\n } else if (this.options.contentId && this.options.nested === null) {\n // Warning if using content ID without setting the nested option\n // Once the element is nested it is required to work properly in this case\n console.warn('Remember to use the nested option if using the content ID option!');\n }\n\n if (this.nested === true) {\n // Force transition overlap if nested\n this.options.transition = 'overlap';\n // Remove appropriate classes if already assigned in markup\n this.$element.removeClass('is-transition-push');\n }\n\n this.$element.addClass(`is-transition-${this.options.transition} is-closed`);\n\n // Find triggers that affect this element and add aria-expanded to them\n this.$triggers = $(document)\n .find('[data-open=\"'+id+'\"], [data-close=\"'+id+'\"], [data-toggle=\"'+id+'\"]')\n .attr('aria-expanded', 'false')\n .attr('aria-controls', id);\n\n // Get position by checking for related CSS class\n this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position;\n\n // Add an overlay over the content if necessary\n if (this.options.contentOverlay === true) {\n var overlay = document.createElement('div');\n var overlayPosition = $(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n this.$overlay = $(overlay);\n if(overlayPosition === 'is-overlay-fixed') {\n $(this.$overlay).insertAfter(this.$element);\n } else {\n this.$content.append(this.$overlay);\n }\n }\n\n // Get the revealOn option from the class.\n var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\\\s]+)', 'g');\n var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n if (revealOnClass) {\n this.options.isRevealed = true;\n this.options.revealOn = this.options.revealOn || revealOnClass[1];\n }\n\n // Ensure the `reveal-on-*` class is set.\n if (this.options.isRevealed === true && this.options.revealOn) {\n this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);\n this._setMQChecker();\n }\n\n if (this.options.transitionTime) {\n this.$element.css('transition-duration', this.options.transitionTime);\n }\n\n // Find fixed elements that should stay fixed while off-canvas is opened\n this.$sticky = this.$content.find('[data-off-canvas-sticky]');\n if (this.$sticky.length > 0 && this.options.transition === 'push') {\n // If there's at least one match force contentScroll:false because the absolute top value doesn't get recalculated on scroll\n // Limit to push transition since there's no transform scope for overlap\n this.options.contentScroll = false;\n }\n\n let inCanvasFor = this.$element.attr('class').match(/\\bin-canvas-for-(\\w+)/);\n if (inCanvasFor && inCanvasFor.length === 2) {\n // Set `inCanvasOn` option if found in-canvas-for-[BREAKPONT] CSS class\n this.options.inCanvasOn = inCanvasFor[1];\n } else if (this.options.inCanvasOn) {\n // Ensure the CSS class is set\n this.$element.addClass(`in-canvas-for-${this.options.inCanvasOn}`);\n }\n\n if (this.options.inCanvasOn) {\n this._checkInCanvas();\n }\n\n // Initally remove all transition/position CSS classes from off-canvas content container.\n this._removeContentClasses();\n }\n\n /**\n * Adds event handlers to the off-canvas wrapper and the exit overlay.\n * @function\n * @private\n */\n _events() {\n this.$element.off('.zf.trigger .zf.offCanvas').on({\n 'open.zf.trigger': this.open.bind(this),\n 'close.zf.trigger': this.close.bind(this),\n 'toggle.zf.trigger': this.toggle.bind(this),\n 'keydown.zf.offCanvas': this._handleKeyboard.bind(this)\n });\n\n if (this.options.closeOnClick === true) {\n var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n $target.on({'click.zf.offCanvas': this.close.bind(this)});\n }\n\n if (this.options.inCanvasOn) {\n $(window).on('changed.zf.mediaquery', () => {\n this._checkInCanvas();\n });\n }\n\n }\n\n /**\n * Applies event listener for elements that will reveal at certain breakpoints.\n * @private\n */\n _setMQChecker() {\n var _this = this;\n\n this.onLoadListener = onLoad($(window), function () {\n if (MediaQuery.atLeast(_this.options.revealOn)) {\n _this.reveal(true);\n }\n });\n\n $(window).on('changed.zf.mediaquery', function () {\n if (MediaQuery.atLeast(_this.options.revealOn)) {\n _this.reveal(true);\n } else {\n _this.reveal(false);\n }\n });\n }\n\n /**\n * Checks if InCanvas on current breakpoint and adjust off-canvas accordingly\n * @private\n */\n _checkInCanvas() {\n this.isInCanvas = MediaQuery.atLeast(this.options.inCanvasOn);\n if (this.isInCanvas === true) {\n this.close();\n }\n }\n\n /**\n * Removes the CSS transition/position classes of the off-canvas content container.\n * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n * @private\n */\n _removeContentClasses(hasReveal) {\n if (typeof hasReveal !== 'boolean') {\n this.$content.removeClass(this.contentClasses.base.join(' '));\n } else if (hasReveal === false) {\n this.$content.removeClass(`has-reveal-${this.position}`);\n }\n }\n\n /**\n * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n * Beforehand any transition/position class gets removed.\n * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n * @private\n */\n _addContentClasses(hasReveal) {\n this._removeContentClasses(hasReveal);\n if (typeof hasReveal !== 'boolean') {\n this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);\n } else if (hasReveal === true) {\n this.$content.addClass(`has-reveal-${this.position}`);\n }\n }\n\n /**\n * Preserves the fixed behavior of sticky elements on opening an off-canvas with push transition.\n * Since the off-canvas container has got a transform scope in such a case, it is done by calculating position absolute values.\n * @private\n */\n _fixStickyElements() {\n this.$sticky.each((_, el) => {\n const $el = $(el);\n\n // If sticky element is currently fixed, adjust its top value to match absolute position due to transform scope\n // Limit to push transition because postion:fixed works without problems for overlap (no transform scope)\n if ($el.css('position') === 'fixed') {\n\n // Save current inline styling to restore it if undoing the absolute fixing\n let topVal = parseInt($el.css('top'), 10);\n $el.data('offCanvasSticky', { top: topVal });\n\n let absoluteTopVal = $(document).scrollTop() + topVal;\n $el.css({ top: `${absoluteTopVal}px`, width: '100%', transition: 'none' });\n }\n });\n }\n\n /**\n * Restores the original fixed styling of sticky elements after having closed an off-canvas that got pseudo fixed beforehand.\n * This reverts the changes of _fixStickyElements()\n * @private\n */\n _unfixStickyElements() {\n this.$sticky.each((_, el) => {\n const $el = $(el);\n let stickyData = $el.data('offCanvasSticky');\n\n // If sticky element has got data object with prior values (meaning it was originally fixed) restore these values once off-canvas is closed\n if (typeof stickyData === 'object') {\n $el.css({ top: `${stickyData.top}px`, width: '', transition: '' })\n $el.data('offCanvasSticky', '');\n }\n });\n }\n\n /**\n * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n * @param {Boolean} isRevealed - true if element should be revealed.\n * @function\n */\n reveal(isRevealed) {\n if (isRevealed) {\n this.close();\n this.isRevealed = true;\n this.$element.attr('aria-hidden', 'false');\n this.$element.off('open.zf.trigger toggle.zf.trigger');\n this.$element.removeClass('is-closed');\n } else {\n this.isRevealed = false;\n this.$element.attr('aria-hidden', 'true');\n this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n 'open.zf.trigger': this.open.bind(this),\n 'toggle.zf.trigger': this.toggle.bind(this)\n });\n this.$element.addClass('is-closed');\n }\n this._addContentClasses(isRevealed);\n }\n\n /**\n * Stops scrolling of the body when OffCanvas is open on mobile Safari and other troublesome browsers.\n * @function\n * @private\n */\n _stopScrolling() {\n return false;\n }\n\n /**\n * Save current finger y-position\n * @param event\n * @private\n */\n _recordScrollable(event) {\n const elem = this;\n elem.lastY = event.touches[0].pageY;\n }\n\n /**\n * Prevent further scrolling when it hits the edges\n * @param event\n * @private\n */\n _preventDefaultAtEdges(event) {\n const elem = this;\n const _this = event.data;\n const delta = elem.lastY - event.touches[0].pageY;\n elem.lastY = event.touches[0].pageY;\n\n if (!_this._canScroll(delta, elem)) {\n event.preventDefault();\n }\n }\n\n /**\n * Handle continuous scrolling of scrollbox\n * Don't bubble up to _preventDefaultAtEdges\n * @param event\n * @private\n */\n _scrollboxTouchMoved(event) {\n const elem = this;\n const _this = event.data;\n const parent = elem.closest('[data-off-canvas], [data-off-canvas-scrollbox-outer]');\n const delta = elem.lastY - event.touches[0].pageY;\n parent.lastY = elem.lastY = event.touches[0].pageY;\n\n event.stopPropagation();\n\n if (!_this._canScroll(delta, elem)) {\n if (!_this._canScroll(delta, parent)) {\n event.preventDefault();\n } else {\n parent.scrollTop += delta;\n }\n }\n }\n\n /**\n * Detect possibility of scrolling\n * @param delta\n * @param elem\n * @returns boolean\n * @private\n */\n _canScroll(delta, elem) {\n const up = delta < 0;\n const down = delta > 0;\n const allowUp = elem.scrollTop > 0;\n const allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;\n return up && allowUp || down && allowDown;\n }\n\n /**\n * Opens the off-canvas menu.\n * @function\n * @param {Object} event - Event object passed from listener.\n * @param {jQuery} trigger - element that triggered the off-canvas to open.\n * @fires OffCanvas#opened\n * @todo also trigger 'open' event?\n */\n open(event, trigger) {\n if (this.$element.hasClass('is-open') || this.isRevealed || this.isInCanvas) { return; }\n var _this = this;\n\n if (trigger) {\n this.$lastTrigger = trigger;\n }\n\n if (this.options.forceTo === 'top') {\n window.scrollTo(0, 0);\n } else if (this.options.forceTo === 'bottom') {\n window.scrollTo(0,document.body.scrollHeight);\n }\n\n if (this.options.transitionTime && this.options.transition !== 'overlap') {\n this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n } else {\n this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n }\n\n this.$element.addClass('is-open').removeClass('is-closed');\n\n this.$triggers.attr('aria-expanded', 'true');\n this.$element.attr('aria-hidden', 'false');\n\n this.$content.addClass('is-open-' + this.position);\n\n // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n if (this.options.contentScroll === false) {\n $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n this.$element.on('touchstart', this._recordScrollable);\n this.$element.on('touchmove', this, this._preventDefaultAtEdges);\n this.$element.on('touchstart', '[data-off-canvas-scrollbox]', this._recordScrollable);\n this.$element.on('touchmove', '[data-off-canvas-scrollbox]', this, this._scrollboxTouchMoved);\n }\n\n if (this.options.contentOverlay === true) {\n this.$overlay.addClass('is-visible');\n }\n\n if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n this.$overlay.addClass('is-closable');\n }\n\n if (this.options.autoFocus === true) {\n this.$element.one(transitionend(this.$element), function() {\n if (!_this.$element.hasClass('is-open')) {\n return; // exit if prematurely closed\n }\n var canvasFocus = _this.$element.find('[data-autofocus]');\n if (canvasFocus.length) {\n canvasFocus.eq(0).focus();\n } else {\n _this.$element.find('a, button').eq(0).focus();\n }\n });\n }\n\n if (this.options.trapFocus === true) {\n this.$content.attr('tabindex', '-1');\n Keyboard.trapFocus(this.$element);\n }\n\n if (this.options.transition === 'push') {\n this._fixStickyElements();\n }\n\n this._addContentClasses();\n\n /**\n * Fires when the off-canvas menu opens.\n * @event OffCanvas#opened\n */\n this.$element.trigger('opened.zf.offCanvas');\n\n /**\n * Fires when the off-canvas menu open transition is done.\n * @event OffCanvas#openedEnd\n */\n this.$element.one(transitionend(this.$element), () => {\n this.$element.trigger('openedEnd.zf.offCanvas');\n });\n }\n\n /**\n * Closes the off-canvas menu.\n * @function\n * @param {Function} cb - optional cb to fire after closure.\n * @fires OffCanvas#close\n * @fires OffCanvas#closed\n */\n close() {\n if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }\n\n /**\n * Fires when the off-canvas menu closes.\n * @event OffCanvas#close\n */\n this.$element.trigger('close.zf.offCanvas');\n\n this.$element.removeClass('is-open');\n\n this.$element.attr('aria-hidden', 'true');\n\n this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');\n\n if (this.options.contentOverlay === true) {\n this.$overlay.removeClass('is-visible');\n }\n\n if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n this.$overlay.removeClass('is-closable');\n }\n\n this.$triggers.attr('aria-expanded', 'false');\n\n\n // Listen to transitionEnd: add class, re-enable scrolling and release focus when done.\n this.$element.one(transitionend(this.$element), () => {\n\n this.$element.addClass('is-closed');\n this._removeContentClasses();\n\n if (this.options.transition === 'push') {\n this._unfixStickyElements();\n }\n\n // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n if (this.options.contentScroll === false) {\n $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n this.$element.off('touchstart', this._recordScrollable);\n this.$element.off('touchmove', this._preventDefaultAtEdges);\n this.$element.off('touchstart', '[data-off-canvas-scrollbox]', this._recordScrollable);\n this.$element.off('touchmove', '[data-off-canvas-scrollbox]', this._scrollboxTouchMoved);\n }\n\n if (this.options.trapFocus === true) {\n this.$content.removeAttr('tabindex');\n Keyboard.releaseFocus(this.$element);\n }\n\n /**\n * Fires when the off-canvas menu close transition is done.\n * @event OffCanvas#closed\n */\n this.$element.trigger('closed.zf.offCanvas');\n });\n }\n\n /**\n * Toggles the off-canvas menu open or closed.\n * @function\n * @param {Object} event - Event object passed from listener.\n * @param {jQuery} trigger - element that triggered the off-canvas to open.\n */\n toggle(event, trigger) {\n if (this.$element.hasClass('is-open')) {\n this.close(event, trigger);\n }\n else {\n this.open(event, trigger);\n }\n }\n\n /**\n * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n * @function\n * @private\n */\n _handleKeyboard(e) {\n Keyboard.handleKey(e, 'OffCanvas', {\n close: () => {\n this.close();\n this.$lastTrigger.focus();\n return true;\n },\n handled: () => {\n e.preventDefault();\n }\n });\n }\n\n /**\n * Destroys the OffCanvas plugin.\n * @function\n */\n _destroy() {\n this.close();\n this.$element.off('.zf.trigger .zf.offCanvas');\n this.$overlay.off('.zf.offCanvas');\n if (this.onLoadListener) $(window).off(this.onLoadListener);\n }\n}\n\nOffCanvas.defaults = {\n /**\n * Allow the user to click outside of the menu to close it.\n * @option\n * @type {boolean}\n * @default true\n */\n closeOnClick: true,\n\n /**\n * Adds an overlay on top of `[data-off-canvas-content]`.\n * @option\n * @type {boolean}\n * @default true\n */\n contentOverlay: true,\n\n /**\n * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n * @option\n * @type {?string}\n * @default null\n */\n contentId: null,\n\n /**\n * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n * @option\n * @type {boolean}\n * @default null\n */\n nested: null,\n\n /**\n * Enable/disable scrolling of the main content when an off canvas panel is open.\n * @option\n * @type {boolean}\n * @default true\n */\n contentScroll: true,\n\n /**\n * Amount of time the open and close transition requires, including the appropriate milliseconds (`ms`) or seconds (`s`) unit (e.g. `500ms`, `.75s`) If none selected, pulls from body style.\n * @option\n * @type {string}\n * @default null\n */\n transitionTime: null,\n\n /**\n * Type of transition for the OffCanvas menu. Options are 'push', 'detached' or 'slide'.\n * @option\n * @type {string}\n * @default push\n */\n transition: 'push',\n\n /**\n * Force the page to scroll to top or bottom on open.\n * @option\n * @type {?string}\n * @default null\n */\n forceTo: null,\n\n /**\n * Allow the OffCanvas to remain open for certain breakpoints.\n * @option\n * @type {boolean}\n * @default false\n */\n isRevealed: false,\n\n /**\n * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n * @option\n * @type {?string}\n * @default null\n */\n revealOn: null,\n\n /**\n * Breakpoint at which the off-canvas gets moved into canvas content and acts as regular page element.\n * @option\n * @type {?string}\n * @default null\n */\n inCanvasOn: null,\n\n /**\n * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n * @option\n * @type {boolean}\n * @default true\n */\n autoFocus: true,\n\n /**\n * Class used to force an OffCanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n * @option\n * @type {string}\n * @default reveal-for-\n * @todo improve the regex testing for this.\n */\n revealClass: 'reveal-for-',\n\n /**\n * Triggers optional focus trapping when opening an OffCanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n * @option\n * @type {boolean}\n * @default false\n */\n trapFocus: false\n}\n\nexport {OffCanvas};\n","import $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Motion } from './foundation.util.motion';\nimport { Timer } from './foundation.util.timer';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit extends Plugin {\n /**\n * Creates a new instance of an orbit carousel.\n * @class\n * @name Orbit\n * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options){\n this.$element = element;\n this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n this.className = 'Orbit'; // ie9 back compat\n\n Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n this._init();\n\n Keyboard.register('Orbit', {\n 'ltr': {\n 'ARROW_RIGHT': 'next',\n 'ARROW_LEFT': 'previous'\n },\n 'rtl': {\n 'ARROW_LEFT': 'next',\n 'ARROW_RIGHT': 'previous'\n }\n });\n }\n\n /**\n * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n * @function\n * @private\n */\n _init() {\n // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n this._reset();\n\n this.$wrapper = this.$element.find(`.${this.options.containerClass}`);\n this.$slides = this.$element.find(`.${this.options.slideClass}`);\n\n var $images = this.$element.find('img'),\n initActive = this.$slides.filter('.is-active'),\n id = this.$element[0].id || GetYoDigits(6, 'orbit');\n\n this.$element.attr({\n 'data-resize': id,\n 'id': id\n });\n\n if (!initActive.length) {\n this.$slides.eq(0).addClass('is-active');\n }\n\n if (!this.options.useMUI) {\n this.$slides.addClass('no-motionui');\n }\n\n if ($images.length) {\n onImagesLoaded($images, this._prepareForOrbit.bind(this));\n } else {\n this._prepareForOrbit();//hehe\n }\n\n if (this.options.bullets) {\n this._loadBullets();\n }\n\n this._events();\n\n if (this.options.autoPlay && this.$slides.length > 1) {\n this.geoSync();\n }\n\n if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation\n this.$wrapper.attr('tabindex', 0);\n }\n }\n\n /**\n * Creates a jQuery collection of bullets, if they are being used.\n * @function\n * @private\n */\n _loadBullets() {\n this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');\n }\n\n /**\n * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n * @function\n */\n geoSync() {\n var _this = this;\n this.timer = new Timer(\n this.$element,\n {\n duration: this.options.timerDelay,\n infinite: false\n },\n function() {\n _this.changeSlide(true);\n });\n this.timer.start();\n }\n\n /**\n * Sets wrapper and slide heights for the orbit.\n * @function\n * @private\n */\n _prepareForOrbit() {\n this._setWrapperHeight();\n }\n\n /**\n * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n * @function\n * @private\n * @param {Function} cb - a callback function to fire when complete.\n */\n _setWrapperHeight(cb) {//rewrite this to `for` loop\n var max = 0, temp, counter = 0, _this = this;\n\n this.$slides.each(function() {\n temp = this.getBoundingClientRect().height;\n $(this).attr('data-slide', counter);\n\n // hide all slides but the active one\n if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n $(this).css({'display': 'none'});\n }\n max = temp > max ? temp : max;\n counter++;\n });\n\n if (counter === this.$slides.length) {\n this.$wrapper.css({'height': max}); //only change the wrapper height property once.\n if(cb) {cb(max);} //fire callback with max height dimension.\n }\n }\n\n /**\n * Sets the max-height of each slide.\n * @function\n * @private\n */\n _setSlideHeight(height) {\n this.$slides.each(function() {\n $(this).css('max-height', height);\n });\n }\n\n /**\n * Adds event listeners to basically everything within the element.\n * @function\n * @private\n */\n _events() {\n var _this = this;\n\n //***************************************\n //**Now using custom event - thanks to:**\n //** Yohai Ararat of Toronto **\n //***************************************\n //\n this.$element.off('.resizeme.zf.trigger').on({\n 'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n })\n if (this.$slides.length > 1) {\n\n if (this.options.swipe) {\n this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')\n .on('swipeleft.zf.orbit', function(e){\n e.preventDefault();\n _this.changeSlide(true);\n }).on('swiperight.zf.orbit', function(e){\n e.preventDefault();\n _this.changeSlide(false);\n });\n }\n //***************************************\n\n if (this.options.autoPlay) {\n this.$slides.on('click.zf.orbit', function() {\n _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n });\n\n if (this.options.pauseOnHover) {\n this.$element.on('mouseenter.zf.orbit', function() {\n _this.timer.pause();\n }).on('mouseleave.zf.orbit', function() {\n if (!_this.$element.data('clickedOn')) {\n _this.timer.start();\n }\n });\n }\n }\n\n if (this.options.navButtons) {\n var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);\n $controls.attr('tabindex', 0)\n //also need to handle enter/return and spacebar key presses\n .on('click.zf.orbit touchend.zf.orbit', function(e){\n\t e.preventDefault();\n _this.changeSlide($(this).hasClass(_this.options.nextClass));\n });\n }\n\n if (this.options.bullets) {\n this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {\n if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.\n var idx = $(this).data('slide'),\n ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n $slide = _this.$slides.eq(idx);\n\n _this.changeSlide(ltr, $slide, idx);\n });\n }\n\n if (this.options.accessible) {\n this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {\n // handle keyboard event with keyboard util\n Keyboard.handleKey(e, 'Orbit', {\n next: function() {\n _this.changeSlide(true);\n },\n previous: function() {\n _this.changeSlide(false);\n },\n handled: function() { // if bullet is focused, make sure focus moves\n if ($(e.target).is(_this.$bullets)) {\n _this.$bullets.filter('.is-active').focus();\n }\n }\n });\n });\n }\n }\n }\n\n /**\n * Resets Orbit so it can be reinitialized\n */\n _reset() {\n // Don't do anything if there are no slides (first run)\n if (typeof this.$slides === 'undefined') {\n return;\n }\n\n if (this.$slides.length > 1) {\n // Remove old events\n this.$element.off('.zf.orbit').find('*').off('.zf.orbit')\n\n // Restart timer if autoPlay is enabled\n if (this.options.autoPlay) {\n this.timer.restart();\n }\n\n // Reset all sliddes\n this.$slides.each(function(el) {\n $(el).removeClass('is-active is-active is-in')\n .removeAttr('aria-live')\n .hide();\n });\n\n // Show the first slide\n this.$slides.first().addClass('is-active').show();\n\n // Triggers when the slide has finished animating\n this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);\n\n // Select first bullet if bullets are present\n if (this.options.bullets) {\n this._updateBullets(0);\n }\n }\n }\n\n /**\n * Changes the current slide to a new one.\n * @function\n * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n * @fires Orbit#slidechange\n */\n changeSlide(isLTR, chosenSlide, idx) {\n if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup\n var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function\n\n var $firstSlide = this.$slides.first(),\n $lastSlide = this.$slides.last(),\n dirIn = isLTR ? 'Right' : 'Left',\n dirOut = isLTR ? 'Left' : 'Right',\n _this = this,\n $newSlide;\n\n if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.\n $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right\n :\n (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left\n } else {\n $newSlide = chosenSlide;\n }\n\n if ($newSlide.length) {\n /**\n * Triggers before the next slide starts animating in and only if a next slide has been found.\n * @event Orbit#beforeslidechange\n */\n this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n if (this.options.bullets) {\n idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n this._updateBullets(idx);\n }\n\n if (this.options.useMUI && !this.$element.is(':hidden')) {\n Motion.animateIn(\n $newSlide.addClass('is-active'),\n this.options[`animInFrom${dirIn}`],\n function(){\n $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');\n });\n\n Motion.animateOut(\n $curSlide.removeClass('is-active'),\n this.options[`animOutTo${dirOut}`],\n function(){\n $curSlide.removeAttr('aria-live');\n if(_this.options.autoPlay && !_this.timer.isPaused){\n _this.timer.restart();\n }\n //do stuff?\n });\n } else {\n $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n if (this.options.autoPlay && !this.timer.isPaused) {\n this.timer.restart();\n }\n }\n /**\n * Triggers when the slide has finished animating in.\n * @event Orbit#slidechange\n */\n this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n }\n }\n\n /**\n * Updates the active state of the bullets, if displayed.\n * Move the descriptor of the current slide `[data-slide-active-label]` to the newly active bullet.\n * If no `[data-slide-active-label]` is set, will move the exceeding `span` element.\n *\n * @function\n * @private\n * @param {Number} idx - the index of the current slide.\n */\n _updateBullets(idx) {\n var $oldBullet = this.$bullets.filter('.is-active');\n var $othersBullets = this.$bullets.not('.is-active');\n var $newBullet = this.$bullets.eq(idx);\n\n $oldBullet.removeClass('is-active').blur();\n $newBullet.addClass('is-active');\n\n // Find the descriptor for the current slide to move it to the new slide button\n var activeStateDescriptor = $oldBullet.children('[data-slide-active-label]').last();\n\n // If not explicitely given, search for the last \"exceeding\" span element (compared to others bullets).\n if (!activeStateDescriptor.length) {\n var spans = $oldBullet.children('span');\n var spanCountInOthersBullets = $othersBullets.toArray().map(b => $(b).children('span').length);\n\n // If there is an exceeding span element, use it as current slide descriptor\n if (spanCountInOthersBullets.every(count => count < spans.length)) {\n activeStateDescriptor = spans.last();\n activeStateDescriptor.attr('data-slide-active-label', '');\n }\n }\n\n // Move the current slide descriptor to the new slide button\n if (activeStateDescriptor.length) {\n activeStateDescriptor.detach();\n $newBullet.append(activeStateDescriptor);\n }\n }\n\n /**\n * Destroys the carousel and hides the element.\n * @function\n */\n _destroy() {\n this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n }\n}\n\nOrbit.defaults = {\n /**\n * Tells the JS to look for and loadBullets.\n * @option\n * @type {boolean}\n * @default true\n */\n bullets: true,\n /**\n * Tells the JS to apply event listeners to nav buttons\n * @option\n * @type {boolean}\n * @default true\n */\n navButtons: true,\n /**\n * motion-ui animation class to apply\n * @option\n * @type {string}\n * @default 'slide-in-right'\n */\n animInFromRight: 'slide-in-right',\n /**\n * motion-ui animation class to apply\n * @option\n * @type {string}\n * @default 'slide-out-right'\n */\n animOutToRight: 'slide-out-right',\n /**\n * motion-ui animation class to apply\n * @option\n * @type {string}\n * @default 'slide-in-left'\n *\n */\n animInFromLeft: 'slide-in-left',\n /**\n * motion-ui animation class to apply\n * @option\n * @type {string}\n * @default 'slide-out-left'\n */\n animOutToLeft: 'slide-out-left',\n /**\n * Allows Orbit to automatically animate on page load.\n * @option\n * @type {boolean}\n * @default true\n */\n autoPlay: true,\n /**\n * Amount of time, in ms, between slide transitions\n * @option\n * @type {number}\n * @default 5000\n */\n timerDelay: 5000,\n /**\n * Allows Orbit to infinitely loop through the slides\n * @option\n * @type {boolean}\n * @default true\n */\n infiniteWrap: true,\n /**\n * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n * @option\n * @type {boolean}\n * @default true\n */\n swipe: true,\n /**\n * Allows the timing function to pause animation on hover.\n * @option\n * @type {boolean}\n * @default true\n */\n pauseOnHover: true,\n /**\n * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n * @option\n * @type {boolean}\n * @default true\n */\n accessible: true,\n /**\n * Class applied to the container of Orbit\n * @option\n * @type {string}\n * @default 'orbit-container'\n */\n containerClass: 'orbit-container',\n /**\n * Class applied to individual slides.\n * @option\n * @type {string}\n * @default 'orbit-slide'\n */\n slideClass: 'orbit-slide',\n /**\n * Class applied to the bullet container. You're welcome.\n * @option\n * @type {string}\n * @default 'orbit-bullets'\n */\n boxOfBullets: 'orbit-bullets',\n /**\n * Class applied to the `next` navigation button.\n * @option\n * @type {string}\n * @default 'orbit-next'\n */\n nextClass: 'orbit-next',\n /**\n * Class applied to the `previous` navigation button.\n * @option\n * @type {string}\n * @default 'orbit-previous'\n */\n prevClass: 'orbit-previous',\n /**\n * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n * @option\n * @type {boolean}\n * @default true\n */\n useMUI: true\n};\n\nexport {Orbit};\n","import $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { DropdownMenu } from './foundation.dropdownMenu';\nimport { Drilldown } from './foundation.drilldown';\nimport { AccordionMenu } from './foundation.accordionMenu';\n\nlet MenuPlugins = {\n dropdown: {\n cssClass: 'dropdown',\n plugin: DropdownMenu\n },\n drilldown: {\n cssClass: 'drilldown',\n plugin: Drilldown\n },\n accordion: {\n cssClass: 'accordion-menu',\n plugin: AccordionMenu\n }\n};\n\n // import \"foundation.util.triggers.js\";\n\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu extends Plugin {\n /**\n * Creates a new instance of a responsive menu.\n * @class\n * @name ResponsiveMenu\n * @fires ResponsiveMenu#init\n * @param {jQuery} element - jQuery object to make into a dropdown menu.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element) {\n this.$element = $(element);\n this.rules = this.$element.data('responsive-menu');\n this.currentMq = null;\n this.currentPlugin = null;\n this.className = 'ResponsiveMenu'; // ie9 back compat\n\n this._init();\n this._events();\n }\n\n /**\n * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n * @function\n * @private\n */\n _init() {\n\n MediaQuery._init();\n // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n if (typeof this.rules === 'string') {\n let rulesTree = {};\n\n // Parse rules from \"classes\" pulled from data attribute\n let rules = this.rules.split(' ');\n\n // Iterate through every rule found\n for (let i = 0; i < rules.length; i++) {\n let rule = rules[i].split('-');\n let ruleSize = rule.length > 1 ? rule[0] : 'small';\n let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n if (MenuPlugins[rulePlugin] !== null) {\n rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n }\n }\n\n this.rules = rulesTree;\n }\n\n if (!$.isEmptyObject(this.rules)) {\n this._checkMediaQueries();\n }\n // Add data-mutate since children may need it.\n this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));\n }\n\n /**\n * Initializes events for the Menu.\n * @function\n * @private\n */\n _events() {\n var _this = this;\n\n $(window).on('changed.zf.mediaquery', function() {\n _this._checkMediaQueries();\n });\n // $(window).on('resize.zf.ResponsiveMenu', function() {\n // _this._checkMediaQueries();\n // });\n }\n\n /**\n * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n * @function\n * @private\n */\n _checkMediaQueries() {\n var matchedMq, _this = this;\n // Iterate through each rule and find the last matching rule\n $.each(this.rules, function(key) {\n if (MediaQuery.atLeast(key)) {\n matchedMq = key;\n }\n });\n\n // No match? No dice\n if (!matchedMq) return;\n\n // Plugin already initialized? We good\n if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n // Remove existing plugin-specific CSS classes\n $.each(MenuPlugins, function(key, value) {\n _this.$element.removeClass(value.cssClass);\n });\n\n // Add the CSS class for the new plugin\n this.$element.addClass(this.rules[matchedMq].cssClass);\n\n // Create an instance of the new plugin\n if (this.currentPlugin) this.currentPlugin.destroy();\n this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n }\n\n /**\n * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n * @function\n */\n _destroy() {\n this.currentPlugin.destroy();\n $(window).off('.zf.ResponsiveMenu');\n }\n}\n\nResponsiveMenu.defaults = {};\n\nexport {ResponsiveMenu};\n","import $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nclass ResponsiveToggle extends Plugin {\n /**\n * Creates a new instance of Tab Bar.\n * @class\n * @name ResponsiveToggle\n * @fires ResponsiveToggle#init\n * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = $(element);\n this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n this.className = 'ResponsiveToggle'; // ie9 back compat\n\n this._init();\n this._events();\n }\n\n /**\n * Initializes the tab bar by finding the target element, toggling element, and running update().\n * @function\n * @private\n */\n _init() {\n MediaQuery._init();\n var targetID = this.$element.data('responsive-toggle');\n if (!targetID) {\n console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n }\n\n this.$targetMenu = $(`#${targetID}`);\n this.$toggler = this.$element.find('[data-toggle]').filter(function() {\n var target = $(this).data('toggle');\n return (target === targetID || target === \"\");\n });\n this.options = $.extend({}, this.options, this.$targetMenu.data());\n\n // If they were set, parse the animation classes\n if(this.options.animate) {\n let input = this.options.animate.split(' ');\n\n this.animationIn = input[0];\n this.animationOut = input[1] || null;\n }\n\n this._update();\n }\n\n /**\n * Adds necessary event handlers for the tab bar to work.\n * @function\n * @private\n */\n _events() {\n this._updateMqHandler = this._update.bind(this);\n\n $(window).on('changed.zf.mediaquery', this._updateMqHandler);\n\n this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n }\n\n /**\n * Checks the current media query to determine if the tab bar should be visible or hidden.\n * @function\n * @private\n */\n _update() {\n // Mobile\n if (!MediaQuery.atLeast(this.options.hideFor)) {\n this.$element.show();\n this.$targetMenu.hide();\n }\n\n // Desktop\n else {\n this.$element.hide();\n this.$targetMenu.show();\n }\n }\n\n /**\n * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n * @function\n * @fires ResponsiveToggle#toggled\n */\n toggleMenu() {\n if (!MediaQuery.atLeast(this.options.hideFor)) {\n /**\n * Fires when the element attached to the tab bar toggles.\n * @event ResponsiveToggle#toggled\n */\n if(this.options.animate) {\n if (this.$targetMenu.is(':hidden')) {\n Motion.animateIn(this.$targetMenu, this.animationIn, () => {\n this.$element.trigger('toggled.zf.responsiveToggle');\n this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n });\n }\n else {\n Motion.animateOut(this.$targetMenu, this.animationOut, () => {\n this.$element.trigger('toggled.zf.responsiveToggle');\n });\n }\n }\n else {\n this.$targetMenu.toggle(0);\n this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n this.$element.trigger('toggled.zf.responsiveToggle');\n }\n }\n };\n\n _destroy() {\n this.$element.off('.zf.responsiveToggle');\n this.$toggler.off('.zf.responsiveToggle');\n\n $(window).off('changed.zf.mediaquery', this._updateMqHandler);\n }\n}\n\nResponsiveToggle.defaults = {\n /**\n * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n * @option\n * @type {string}\n * @default 'medium'\n */\n hideFor: 'medium',\n\n /**\n * To decide if the toggle should be animated or not.\n * @option\n * @type {boolean}\n * @default false\n */\n animate: false\n};\n\nexport { ResponsiveToggle };\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal extends Plugin {\n /**\n * Creates a new instance of Reveal.\n * @class\n * @name Reveal\n * @param {jQuery} element - jQuery object to use for the modal.\n * @param {Object} options - optional parameters.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n this.className = 'Reveal'; // ie9 back compat\n this._init();\n\n // Touch and Triggers init are idempotent, just need to make sure they are initialized\n Touch.init($);\n Triggers.init($);\n\n Keyboard.register('Reveal', {\n 'ESCAPE': 'close',\n });\n }\n\n /**\n * Initializes the modal by adding the overlay and close buttons, (if selected).\n * @private\n */\n _init() {\n MediaQuery._init();\n this.id = this.$element.attr('id');\n this.isActive = false;\n this.cached = {mq: MediaQuery.current};\n\n this.$anchor = $(`[data-open=\"${this.id}\"]`).length ? $(`[data-open=\"${this.id}\"]`) : $(`[data-toggle=\"${this.id}\"]`);\n this.$anchor.attr({\n 'aria-controls': this.id,\n 'aria-haspopup': 'dialog',\n 'tabindex': 0\n });\n\n if (this.options.fullScreen || this.$element.hasClass('full')) {\n this.options.fullScreen = true;\n this.options.overlay = false;\n }\n if (this.options.overlay && !this.$overlay) {\n this.$overlay = this._makeOverlay(this.id);\n }\n\n this.$element.attr({\n 'role': 'dialog',\n 'aria-hidden': true,\n 'data-yeti-box': this.id,\n 'data-resize': this.id\n });\n\n if(this.$overlay) {\n this.$element.detach().appendTo(this.$overlay);\n } else {\n this.$element.detach().appendTo($(this.options.appendTo));\n this.$element.addClass('without-overlay');\n }\n this._events();\n if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {\n this.onLoadListener = onLoad($(window), () => this.open());\n }\n }\n\n /**\n * Creates an overlay div to display behind the modal.\n * @private\n */\n _makeOverlay() {\n var additionalOverlayClasses = '';\n\n if (this.options.additionalOverlayClasses) {\n additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n }\n\n return $('
      ')\n .addClass('reveal-overlay' + additionalOverlayClasses)\n .appendTo(this.options.appendTo);\n }\n\n /**\n * Updates position of modal\n * TODO: Figure out if we actually need to cache these values or if it doesn't matter\n * @private\n */\n _updatePosition() {\n var width = this.$element.outerWidth();\n var outerWidth = $(window).width();\n var height = this.$element.outerHeight();\n var outerHeight = $(window).height();\n var left, top = null;\n if (this.options.hOffset === 'auto') {\n left = parseInt((outerWidth - width) / 2, 10);\n } else {\n left = parseInt(this.options.hOffset, 10);\n }\n if (this.options.vOffset === 'auto') {\n if (height > outerHeight) {\n top = parseInt(Math.min(100, outerHeight / 10), 10);\n } else {\n top = parseInt((outerHeight - height) / 4, 10);\n }\n } else if (this.options.vOffset !== null) {\n top = parseInt(this.options.vOffset, 10);\n }\n\n if (top !== null) {\n this.$element.css({top: top + 'px'});\n }\n\n // only worry about left if we don't have an overlay or we have a horizontal offset,\n // otherwise we're perfectly in the middle\n if (!this.$overlay || (this.options.hOffset !== 'auto')) {\n this.$element.css({left: left + 'px'});\n this.$element.css({margin: '0px'});\n }\n\n }\n\n /**\n * Adds event handlers for the modal.\n * @private\n */\n _events() {\n var _this = this;\n\n this.$element.on({\n 'open.zf.trigger': this.open.bind(this),\n 'close.zf.trigger': (event, $element) => {\n if ((event.target === _this.$element[0]) ||\n ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called\n return this.close.apply(this);\n }\n },\n 'toggle.zf.trigger': this.toggle.bind(this),\n 'resizeme.zf.trigger': function() {\n _this._updatePosition();\n }\n });\n\n if (this.options.closeOnClick && this.options.overlay) {\n this.$overlay.off('.zf.reveal').on('click.zf.dropdown tap.zf.dropdown', function(e) {\n if (e.target === _this.$element[0] ||\n $.contains(_this.$element[0], e.target) ||\n !$.contains(document, e.target)) {\n return;\n }\n _this.close();\n });\n }\n if (this.options.deepLink) {\n $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));\n }\n }\n\n /**\n * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n * @private\n */\n _handleState() {\n if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }\n else{ this.close(); }\n }\n\n /**\n * Disables the scroll when Reveal is shown to prevent the background from shifting\n * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n */\n _disableScroll(scrollTop) {\n scrollTop = scrollTop || $(window).scrollTop();\n if ($(document).height() > $(window).height()) {\n $(\"html\")\n .css(\"top\", -scrollTop);\n }\n }\n\n /**\n * Reenables the scroll when Reveal closes\n * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n */\n _enableScroll(scrollTop) {\n scrollTop = scrollTop || parseInt($(\"html\").css(\"top\"), 10);\n if ($(document).height() > $(window).height()) {\n $(\"html\")\n .css(\"top\", \"\");\n $(window).scrollTop(-scrollTop);\n }\n }\n\n\n /**\n * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n * @function\n * @fires Reveal#closeme\n * @fires Reveal#open\n */\n open() {\n // either update or replace browser history\n const hash = `#${this.id}`;\n if (this.options.deepLink && window.location.hash !== hash) {\n\n if (window.history.pushState) {\n if (this.options.updateHistory) {\n window.history.pushState({}, '', hash);\n } else {\n window.history.replaceState({}, '', hash);\n }\n } else {\n window.location.hash = hash;\n }\n }\n\n // Remember anchor that opened it to set focus back later, have general anchors as fallback\n this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;\n\n this.isActive = true;\n\n // Make elements invisible, but remove display: none so we can get size and positioning\n this.$element\n .css({ 'visibility': 'hidden' })\n .show()\n .scrollTop(0);\n if (this.options.overlay) {\n this.$overlay.css({'visibility': 'hidden'}).show();\n }\n\n this._updatePosition();\n\n this.$element\n .hide()\n .css({ 'visibility': '' });\n\n if(this.$overlay) {\n this.$overlay.css({'visibility': ''}).hide();\n if(this.$element.hasClass('fast')) {\n this.$overlay.addClass('fast');\n } else if (this.$element.hasClass('slow')) {\n this.$overlay.addClass('slow');\n }\n }\n\n\n if (!this.options.multipleOpened) {\n /**\n * Fires immediately before the modal opens.\n * Closes any other modals that are currently open\n * @event Reveal#closeme\n */\n this.$element.trigger('closeme.zf.reveal', this.id);\n }\n\n if ($('.reveal:visible').length === 0) {\n this._disableScroll();\n }\n\n var _this = this;\n\n // Motion UI method of reveal\n if (this.options.animationIn) {\n function afterAnimation(){\n _this.$element\n .attr({\n 'aria-hidden': false,\n 'tabindex': -1\n })\n .focus();\n _this._addGlobalClasses();\n Keyboard.trapFocus(_this.$element);\n }\n if (this.options.overlay) {\n Motion.animateIn(this.$overlay, 'fade-in');\n }\n Motion.animateIn(this.$element, this.options.animationIn, () => {\n if(this.$element) { // protect against object having been removed\n this.focusableElements = Keyboard.findFocusable(this.$element);\n afterAnimation();\n }\n });\n }\n // jQuery method of reveal\n else {\n if (this.options.overlay) {\n this.$overlay.show(0);\n }\n this.$element.show(this.options.showDelay);\n }\n\n // handle accessibility\n this.$element\n .attr({\n 'aria-hidden': false,\n 'tabindex': -1\n })\n .focus();\n Keyboard.trapFocus(this.$element);\n\n this._addGlobalClasses();\n\n this._addGlobalListeners();\n\n /**\n * Fires when the modal has successfully opened.\n * @event Reveal#open\n */\n this.$element.trigger('open.zf.reveal');\n }\n\n /**\n * Adds classes and listeners on document required by open modals.\n *\n * The following classes are added and updated:\n * - `.is-reveal-open` - Prevents the scroll on document\n * - `.zf-has-scroll` - Displays a disabled scrollbar on document if required like if the\n * scroll was not disabled. This prevent a \"shift\" of the page content due\n * the scrollbar disappearing when the modal opens.\n *\n * @private\n */\n _addGlobalClasses() {\n const updateScrollbarClass = () => {\n $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));\n };\n\n this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());\n updateScrollbarClass();\n $('html').addClass('is-reveal-open');\n }\n\n /**\n * Removes classes and listeners on document that were required by open modals.\n * @private\n */\n _removeGlobalClasses() {\n this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n $('html').removeClass('is-reveal-open');\n $('html').removeClass('zf-has-scroll');\n }\n\n /**\n * Adds extra event handlers for the body and window if necessary.\n * @private\n */\n _addGlobalListeners() {\n var _this = this;\n if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n this.focusableElements = Keyboard.findFocusable(this.$element);\n\n if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n $('body').on('click.zf.dropdown tap.zf.dropdown', function(e) {\n if (e.target === _this.$element[0] ||\n $.contains(_this.$element[0], e.target) ||\n !$.contains(document, e.target)) { return; }\n _this.close();\n });\n }\n\n if (this.options.closeOnEsc) {\n $(window).on('keydown.zf.reveal', function(e) {\n Keyboard.handleKey(e, 'Reveal', {\n close: function() {\n if (_this.options.closeOnEsc) {\n _this.close();\n }\n }\n });\n });\n }\n }\n\n /**\n * Closes the modal.\n * @function\n * @fires Reveal#closed\n */\n close() {\n if (!this.isActive || !this.$element.is(':visible')) {\n return false;\n }\n var _this = this;\n\n // Motion UI method of hiding\n if (this.options.animationOut) {\n if (this.options.overlay) {\n Motion.animateOut(this.$overlay, 'fade-out');\n }\n\n Motion.animateOut(this.$element, this.options.animationOut, finishUp);\n }\n // jQuery method of hiding\n else {\n this.$element.hide(this.options.hideDelay);\n\n if (this.options.overlay) {\n this.$overlay.hide(0, finishUp);\n }\n else {\n finishUp();\n }\n }\n\n // Conditionals to remove extra event listeners added on open\n if (this.options.closeOnEsc) {\n $(window).off('keydown.zf.reveal');\n }\n\n if (!this.options.overlay && this.options.closeOnClick) {\n $('body').off('click.zf.dropdown tap.zf.dropdown');\n }\n\n this.$element.off('keydown.zf.reveal');\n\n function finishUp() {\n\n // Get the current top before the modal is closed and restore the scroll after.\n // TODO: use component properties instead of HTML properties\n // See https://github.com/foundation/foundation-sites/pull/10786\n var scrollTop = parseInt($(\"html\").css(\"top\"), 10);\n\n if ($('.reveal:visible').length === 0) {\n _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n }\n\n Keyboard.releaseFocus(_this.$element);\n\n _this.$element.attr('aria-hidden', true);\n\n if ($('.reveal:visible').length === 0) {\n _this._enableScroll(scrollTop);\n }\n\n /**\n * Fires when the modal is done closing.\n * @event Reveal#closed\n */\n _this.$element.trigger('closed.zf.reveal');\n }\n\n /**\n * Resets the modal content\n * This prevents a running video to keep going in the background\n */\n if (this.options.resetOnClose) {\n this.$element.html(this.$element.html());\n }\n\n this.isActive = false;\n // If deepLink and we did not switched to an other modal...\n if (_this.options.deepLink && window.location.hash === `#${this.id}`) {\n // Remove the history hash\n if (window.history.replaceState) {\n const urlWithoutHash = window.location.pathname + window.location.search;\n if (this.options.updateHistory) {\n window.history.pushState({}, '', urlWithoutHash); // remove the hash\n } else {\n window.history.replaceState('', document.title, urlWithoutHash);\n }\n } else {\n window.location.hash = '';\n }\n }\n\n this.$activeAnchor.focus();\n }\n\n /**\n * Toggles the open/closed state of a modal.\n * @function\n */\n toggle() {\n if (this.isActive) {\n this.close();\n } else {\n this.open();\n }\n };\n\n /**\n * Destroys an instance of a modal.\n * @function\n */\n _destroy() {\n if (this.options.overlay) {\n this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n this.$overlay.hide().off().remove();\n }\n this.$element.hide().off();\n this.$anchor.off('.zf');\n $(window).off(`.zf.reveal:${this.id}`)\n if (this.onLoadListener) $(window).off(this.onLoadListener);\n\n if ($('.reveal:visible').length === 0) {\n this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n }\n };\n}\n\nReveal.defaults = {\n /**\n * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n * @option\n * @type {string}\n * @default ''\n */\n animationIn: '',\n /**\n * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n * @option\n * @type {string}\n * @default ''\n */\n animationOut: '',\n /**\n * Time, in ms, to delay the opening of a modal after a click if no animation used.\n * @option\n * @type {number}\n * @default 0\n */\n showDelay: 0,\n /**\n * Time, in ms, to delay the closing of a modal after a click if no animation used.\n * @option\n * @type {number}\n * @default 0\n */\n hideDelay: 0,\n /**\n * Allows a click on the body/overlay to close the modal.\n * @option\n * @type {boolean}\n * @default true\n */\n closeOnClick: true,\n /**\n * Allows the modal to close if the user presses the `ESCAPE` key.\n * @option\n * @type {boolean}\n * @default true\n */\n closeOnEsc: true,\n /**\n * If true, allows multiple modals to be displayed at once.\n * @option\n * @type {boolean}\n * @default false\n */\n multipleOpened: false,\n /**\n * Distance, in pixels, the modal should push down from the top of the screen.\n * @option\n * @type {number|string}\n * @default auto\n */\n vOffset: 'auto',\n /**\n * Distance, in pixels, the modal should push in from the side of the screen.\n * @option\n * @type {number|string}\n * @default auto\n */\n hOffset: 'auto',\n /**\n * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n * @option\n * @type {boolean}\n * @default false\n */\n fullScreen: false,\n /**\n * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n * @option\n * @type {boolean}\n * @default true\n */\n overlay: true,\n /**\n * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n * @option\n * @type {boolean}\n * @default false\n */\n resetOnClose: false,\n /**\n * Link the location hash to the modal.\n * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n * @option\n * @type {boolean}\n * @default false\n */\n deepLink: false,\n /**\n * If `deepLink` is enabled, update the browser history with the open modal\n * @option\n * @default false\n */\n updateHistory: false,\n /**\n * Allows the modal to append to custom div.\n * @option\n * @type {string}\n * @default \"body\"\n */\n appendTo: \"body\",\n /**\n * Allows adding additional class names to the reveal overlay.\n * @option\n * @type {string}\n * @default ''\n */\n additionalOverlayClasses: ''\n};\n\nexport {Reveal};\n","import $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Move } from './foundation.util.motion';\nimport { GetYoDigits, rtl as Rtl } from './foundation.core.utils';\n\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Touch } from './foundation.util.touch';\n\nimport { Triggers } from './foundation.util.triggers';\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nclass Slider extends Plugin {\n /**\n * Creates a new instance of a slider control.\n * @class\n * @name Slider\n * @param {jQuery} element - jQuery object to make into a slider control.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n this.className = 'Slider'; // ie9 back compat\n this.initialized = false;\n\n // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n Touch.init($);\n Triggers.init($);\n\n this._init();\n\n Keyboard.register('Slider', {\n 'ltr': {\n 'ARROW_RIGHT': 'increase',\n 'ARROW_UP': 'increase',\n 'ARROW_DOWN': 'decrease',\n 'ARROW_LEFT': 'decrease',\n 'SHIFT_ARROW_RIGHT': 'increaseFast',\n 'SHIFT_ARROW_UP': 'increaseFast',\n 'SHIFT_ARROW_DOWN': 'decreaseFast',\n 'SHIFT_ARROW_LEFT': 'decreaseFast',\n 'HOME': 'min',\n 'END': 'max'\n },\n 'rtl': {\n 'ARROW_LEFT': 'increase',\n 'ARROW_RIGHT': 'decrease',\n 'SHIFT_ARROW_LEFT': 'increaseFast',\n 'SHIFT_ARROW_RIGHT': 'decreaseFast'\n }\n });\n }\n\n /**\n * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n * @function\n * @private\n */\n _init() {\n this.inputs = this.$element.find('input');\n this.handles = this.$element.find('[data-slider-handle]');\n\n this.$handle = this.handles.eq(0);\n this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);\n this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n this.options.disabled = true;\n this.$element.addClass(this.options.disabledClass);\n }\n if (!this.inputs.length) {\n this.inputs = $().add(this.$input);\n this.options.binding = true;\n }\n\n this._setInitAttr(0);\n\n if (this.handles[1]) {\n this.options.doubleSided = true;\n this.$handle2 = this.handles.eq(1);\n this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);\n\n if (!this.inputs[1]) {\n this.inputs = this.inputs.add(this.$input2);\n }\n\n // this.$handle.triggerHandler('click.zf.slider');\n this._setInitAttr(1);\n }\n\n // Set handle positions\n this.setHandles();\n\n this._events();\n this.initialized = true;\n }\n\n setHandles() {\n if(this.handles[1]) {\n this._setHandlePos(this.$handle, this.inputs.eq(0).val(), () => {\n this._setHandlePos(this.$handle2, this.inputs.eq(1).val());\n });\n } else {\n this._setHandlePos(this.$handle, this.inputs.eq(0).val());\n }\n }\n\n _reflow() {\n this.setHandles();\n }\n /**\n * @function\n * @private\n * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n */\n _pctOfBar(value) {\n var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start)\n\n switch(this.options.positionValueFunction) {\n case \"pow\":\n pctOfBar = this._logTransform(pctOfBar);\n break;\n case \"log\":\n pctOfBar = this._powTransform(pctOfBar);\n break;\n }\n\n return pctOfBar.toFixed(2)\n }\n\n /**\n * @function\n * @private\n * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n */\n _value(pctOfBar) {\n switch(this.options.positionValueFunction) {\n case \"pow\":\n pctOfBar = this._powTransform(pctOfBar);\n break;\n case \"log\":\n pctOfBar = this._logTransform(pctOfBar);\n break;\n }\n\n var value\n if (this.options.vertical) {\n // linear interpolation which is working with negative values for start\n // https://math.stackexchange.com/a/1019084\n value = parseFloat(this.options.end) + pctOfBar * (this.options.start - this.options.end)\n } else {\n value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n }\n\n return value\n }\n\n /**\n * @function\n * @private\n * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n */\n _logTransform(value) {\n return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))\n }\n\n /**\n * @function\n * @private\n * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n */\n _powTransform(value) {\n return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)\n }\n\n /**\n * Sets the position of the selected handle and fill bar.\n * @function\n * @private\n * @param {jQuery} $hndl - the selected handle to move.\n * @param {Number} location - floating point between the start and end values of the slider bar.\n * @param {Function} cb - callback function to fire on completion.\n * @fires Slider#moved\n * @fires Slider#changed\n */\n _setHandlePos($hndl, location, cb) {\n // don't move if the slider has been disabled since its initialization\n if (this.$element.hasClass(this.options.disabledClass)) {\n return;\n }\n //might need to alter that slightly for bars that will have odd number selections.\n location = parseFloat(location);//on input change events, convert string to number...grumble.\n\n // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n if (location < this.options.start) { location = this.options.start; }\n else if (location > this.options.end) { location = this.options.end; }\n\n var isDbl = this.options.doubleSided;\n\n if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n if (this.handles.index($hndl) === 0) {\n var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n location = location >= h2Val ? h2Val - this.options.step : location;\n } else {\n var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n location = location <= h1Val ? h1Val + this.options.step : location;\n }\n }\n\n var _this = this,\n vert = this.options.vertical,\n hOrW = vert ? 'height' : 'width',\n lOrT = vert ? 'top' : 'left',\n handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n //percentage of bar min/max value based on click or drag point\n pctOfBar = this._pctOfBar(location),\n //number of actual pixels to shift the handle, based on the percentage obtained above\n pxToMove = (elemDim - handleDim) * pctOfBar,\n //percentage of bar to shift the handle\n movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);\n //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n location = parseFloat(location.toFixed(this.options.decimal));\n // declare empty object for css adjustments, only used with 2 handled-sliders\n var css = {};\n\n this._setValues($hndl, location);\n\n // TODO update to calculate based on values set to respective inputs??\n if (isDbl) {\n var isLeftHndl = this.handles.index($hndl) === 0,\n //empty variable, will be used for min-height/width for fill bar\n dim,\n //percentage w/h of the handle compared to the slider bar\n handlePct = Math.floor(percent(handleDim, elemDim) * 100);\n //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n if (isLeftHndl) {\n //left or top percentage value to apply to the fill bar.\n css[lOrT] = `${movement}%`;\n //calculate the new min-height/width for the fill bar.\n dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;\n //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders\n } else {\n //just caching the value of the left/bottom handle's left/top property\n var handlePos = parseFloat(this.$handle[0].style[lOrT]);\n //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;\n }\n // assign the min-height/width to our css object\n css[`min-${hOrW}`] = `${dim}%`;\n }\n\n //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;\n\n Move(moveTime, $hndl, function() {\n // adjusting the left/top property of the handle, based on the percentage calculated above\n // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n // fall back to next best guess.\n if (isNaN(movement)) {\n $hndl.css(lOrT, `${pctOfBar * 100}%`);\n }\n else {\n $hndl.css(lOrT, `${movement}%`);\n }\n\n if (!_this.options.doubleSided) {\n //if single-handled, a simple method to expand the fill bar\n _this.$fill.css(hOrW, `${pctOfBar * 100}%`);\n } else {\n //otherwise, use the css object we created above\n _this.$fill.css(css);\n }\n });\n\n if (this.initialized) {\n this.$element.one('finished.zf.animate', function() {\n /**\n * Fires when the handle is done moving.\n * @event Slider#moved\n */\n _this.$element.trigger('moved.zf.slider', [$hndl]);\n });\n /**\n * Fires when the value has not been change for a given time.\n * @event Slider#changed\n */\n clearTimeout(_this.timeout);\n _this.timeout = setTimeout(function(){\n _this.$element.trigger('changed.zf.slider', [$hndl]);\n }, _this.options.changedDelay);\n }\n }\n\n /**\n * Sets the initial attribute for the slider element.\n * @function\n * @private\n * @param {Number} idx - index of the current handle/input to use.\n */\n _setInitAttr(idx) {\n var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd)\n var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');\n this.inputs.eq(idx).attr({\n 'id': id,\n 'max': this.options.end,\n 'min': this.options.start,\n 'step': this.options.step\n });\n this.inputs.eq(idx).val(initVal);\n this.handles.eq(idx).attr({\n 'role': 'slider',\n 'aria-controls': id,\n 'aria-valuemax': this.options.end,\n 'aria-valuemin': this.options.start,\n 'aria-valuenow': initVal,\n 'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n 'tabindex': 0\n });\n }\n\n /**\n * Sets the input and `aria-valuenow` values for the slider element.\n * @function\n * @private\n * @param {jQuery} $handle - the currently selected handle.\n * @param {Number} val - floating point of the new value.\n */\n _setValues($handle, val) {\n var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n this.inputs.eq(idx).val(val);\n $handle.attr('aria-valuenow', val);\n }\n\n /**\n * Handles events on the slider element.\n * Calculates the new location of the current handle.\n * If there are two handles and the bar was clicked, it determines which handle to move.\n * @function\n * @private\n * @param {Object} e - the `event` object passed from the listener.\n * @param {jQuery} $handle - the current handle to calculate for, if selected.\n * @param {Number} val - floating point number for the new value of the slider.\n * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n */\n _handleEvent(e, $handle, val) {\n var value;\n if (!val) {//click or drag events\n e.preventDefault();\n var _this = this,\n vertical = this.options.vertical,\n param = vertical ? 'height' : 'width',\n direction = vertical ? 'top' : 'left',\n eventOffset = vertical ? e.pageY : e.pageX,\n barDim = this.$element[0].getBoundingClientRect()[param],\n windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();\n\n var elemOffset = this.$element.offset()[direction];\n\n // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n // best way to guess this is simulated is if clientY == pageY\n if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }\n var eventFromBar = eventOffset - elemOffset;\n var barXY;\n if (eventFromBar < 0) {\n barXY = 0;\n } else if (eventFromBar > barDim) {\n barXY = barDim;\n } else {\n barXY = eventFromBar;\n }\n var offsetPct = percent(barXY, barDim);\n\n value = this._value(offsetPct);\n\n // turn everything around for RTL, yay math!\n if (Rtl() && !this.options.vertical) {value = this.options.end - value;}\n\n value = _this._adjustValue(null, value);\n\n if (!$handle) {//figure out which handle it is, pass it to the next function.\n var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n }\n\n } else {//change event on input\n value = this._adjustValue(null, val);\n }\n\n this._setHandlePos($handle, value);\n }\n\n /**\n * Adjustes value for handle in regard to step value. returns adjusted value\n * @function\n * @private\n * @param {jQuery} $handle - the selected handle.\n * @param {Number} value - value to adjust. used if $handle is falsy\n */\n _adjustValue($handle, value) {\n var val,\n step = this.options.step,\n div = parseFloat(step/2),\n left, previousVal, nextVal;\n if (!!$handle) {\n val = parseFloat($handle.attr('aria-valuenow'));\n }\n else {\n val = value;\n }\n if (val >= 0) {\n left = val % step;\n } else {\n left = step + (val % step);\n }\n previousVal = val - left;\n nextVal = previousVal + step;\n if (left === 0) {\n return val;\n }\n val = val >= previousVal + div ? nextVal : previousVal;\n return val;\n }\n\n /**\n * Adds event listeners to the slider elements.\n * @function\n * @private\n */\n _events() {\n this._eventsForHandle(this.$handle);\n if(this.handles[1]) {\n this._eventsForHandle(this.$handle2);\n }\n }\n\n\n /**\n * Adds event listeners a particular handle\n * @function\n * @private\n * @param {jQuery} $handle - the current handle to apply listeners to.\n */\n _eventsForHandle($handle) {\n var _this = this,\n curHandle;\n\n const handleChangeEvent = function(e) {\n const idx = _this.inputs.index($(this));\n _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n };\n\n // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n // listen for the enter key and trigger a change\n // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n if(e.keyCode === 13) handleChangeEvent.call(this, e);\n });\n\n this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n if (this.options.clickSelect) {\n this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {\n if (_this.$element.data('dragging')) { return false; }\n\n if (!$(e.target).is('[data-slider-handle]')) {\n if (_this.options.doubleSided) {\n _this._handleEvent(e);\n } else {\n _this._handleEvent(e, _this.$handle);\n }\n }\n });\n }\n\n if (this.options.draggable) {\n this.handles.addTouch();\n\n var $body = $('body');\n $handle\n .off('mousedown.zf.slider')\n .on('mousedown.zf.slider', function(e) {\n $handle.addClass('is-dragging');\n _this.$fill.addClass('is-dragging');//\n _this.$element.data('dragging', true);\n\n curHandle = $(e.currentTarget);\n\n $body.on('mousemove.zf.slider', function(ev) {\n ev.preventDefault();\n _this._handleEvent(ev, curHandle);\n\n }).on('mouseup.zf.slider', function(ev) {\n _this._handleEvent(ev, curHandle);\n\n $handle.removeClass('is-dragging');\n _this.$fill.removeClass('is-dragging');\n _this.$element.data('dragging', false);\n\n $body.off('mousemove.zf.slider mouseup.zf.slider');\n });\n })\n // prevent events triggered by touch\n .on('selectstart.zf.slider touchmove.zf.slider', function(e) {\n e.preventDefault();\n });\n }\n\n $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {\n var _$handle = $(this),\n idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n oldValue = parseFloat($handle.attr('aria-valuenow')),\n newValue;\n\n // handle keyboard event with keyboard util\n Keyboard.handleKey(e, 'Slider', {\n decrease: function() {\n newValue = oldValue - _this.options.step;\n },\n increase: function() {\n newValue = oldValue + _this.options.step;\n },\n decreaseFast: function() {\n newValue = oldValue - _this.options.step * 10;\n },\n increaseFast: function() {\n newValue = oldValue + _this.options.step * 10;\n },\n min: function() {\n newValue = _this.options.start;\n },\n max: function() {\n newValue = _this.options.end;\n },\n handled: function() { // only set handle pos when event was handled specially\n e.preventDefault();\n _this._setHandlePos(_$handle, newValue);\n }\n });\n /*if (newValue) { // if pressed key has special function, update value\n e.preventDefault();\n _this._setHandlePos(_$handle, newValue);\n }*/\n });\n }\n\n /**\n * Destroys the slider plugin.\n */\n _destroy() {\n this.handles.off('.zf.slider');\n this.inputs.off('.zf.slider');\n this.$element.off('.zf.slider');\n\n clearTimeout(this.timeout);\n }\n}\n\nSlider.defaults = {\n /**\n * Minimum value for the slider scale.\n * @option\n * @type {number}\n * @default 0\n */\n start: 0,\n /**\n * Maximum value for the slider scale.\n * @option\n * @type {number}\n * @default 100\n */\n end: 100,\n /**\n * Minimum value change per change event.\n * @option\n * @type {number}\n * @default 1\n */\n step: 1,\n /**\n * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n * @option\n * @type {number}\n * @default 0\n */\n initialStart: 0,\n /**\n * Value at which the right handle/second input should be set to on initialization.\n * @option\n * @type {number}\n * @default 100\n */\n initialEnd: 100,\n /**\n * Allows the input to be located outside the container and visible. Set to by the JS\n * @option\n * @type {boolean}\n * @default false\n */\n binding: false,\n /**\n * Allows the user to click/tap on the slider bar to select a value.\n * @option\n * @type {boolean}\n * @default true\n */\n clickSelect: true,\n /**\n * Set to true and use the `vertical` class to change alignment to vertical.\n * @option\n * @type {boolean}\n * @default false\n */\n vertical: false,\n /**\n * Allows the user to drag the slider handle(s) to select a value.\n * @option\n * @type {boolean}\n * @default true\n */\n draggable: true,\n /**\n * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n * @option\n * @type {boolean}\n * @default false\n */\n disabled: false,\n /**\n * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n * @option\n * @type {boolean}\n * @default false\n */\n doubleSided: false,\n /**\n * Potential future feature.\n */\n // steps: 100,\n /**\n * Number of decimal places the plugin should go to for floating point precision.\n * @option\n * @type {number}\n * @default 2\n */\n decimal: 2,\n /**\n * Time delay for dragged elements.\n */\n // dragDelay: 0,\n /**\n * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n * @option\n * @type {number}\n * @default 200\n */\n moveTime: 200,//update this if changing the transition time in the sass\n /**\n * Class applied to disabled sliders.\n * @option\n * @type {string}\n * @default 'disabled'\n */\n disabledClass: 'disabled',\n /**\n * Will invert the default layout for a vertical slider.\n * @option\n * @type {boolean}\n * @default false\n */\n invertVertical: false,\n /**\n * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n * @option\n * @type {number}\n * @default 500\n */\n changedDelay: 500,\n /**\n * Basevalue for non-linear sliders\n * @option\n * @type {number}\n * @default 5\n */\n nonLinearBase: 5,\n /**\n * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n * @option\n * @type {string}\n * @default 'linear'\n */\n positionValueFunction: 'linear',\n};\n\nfunction percent(frac, num) {\n return (frac / num);\n}\nfunction absPosition($handle, dir, clickPos, param) {\n return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);\n}\nfunction baseLog(base, value) {\n return Math.log(value)/Math.log(base)\n}\n\nexport {Slider};\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky extends Plugin {\n /**\n * Creates a new instance of a sticky thing.\n * @class\n * @name Sticky\n * @param {jQuery} element - jQuery object to make sticky.\n * @param {Object} options - options object passed when creating the element programmatically.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n this.className = 'Sticky'; // ie9 back compat\n\n // Triggers init is idempotent, just need to make sure it is initialized\n Triggers.init($);\n\n this._init();\n }\n\n /**\n * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n * @function\n * @private\n */\n _init() {\n MediaQuery._init();\n\n var $parent = this.$element.parent('[data-sticky-container]'),\n id = this.$element[0].id || GetYoDigits(6, 'sticky'),\n _this = this;\n\n if($parent.length){\n this.$container = $parent;\n } else {\n this.wasWrapped = true;\n this.$element.wrap(this.options.container);\n this.$container = this.$element.parent();\n }\n this.$container.addClass(this.options.containerClass);\n\n this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });\n if (this.options.anchor !== '') {\n $('#' + _this.options.anchor).attr({ 'data-mutate': id });\n }\n\n this.scrollCount = this.options.checkEvery;\n this.isStuck = false;\n this.onLoadListener = onLoad($(window), function () {\n //We calculate the container height to have correct values for anchor points offset calculation.\n _this.containerHeight = _this.$element.css(\"display\") === \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n _this.$container.css('height', _this.containerHeight);\n _this.elemHeight = _this.containerHeight;\n if (_this.options.anchor !== '') {\n _this.$anchor = $('#' + _this.options.anchor);\n } else {\n _this._parsePoints();\n }\n\n _this._setSizes(function () {\n var scroll = window.pageYOffset;\n _this._calc(false, scroll);\n //Unstick the element will ensure that proper classes are set.\n if (!_this.isStuck) {\n _this._removeSticky((scroll >= _this.topPoint) ? false : true);\n }\n });\n _this._events(id.split('-').reverse().join('-'));\n });\n }\n\n /**\n * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n * @function\n * @private\n */\n _parsePoints() {\n var top = this.options.topAnchor === \"\" ? 1 : this.options.topAnchor,\n btm = this.options.btmAnchor === \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n pts = [top, btm],\n breaks = {};\n for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n var pt;\n if (typeof pts[i] === 'number') {\n pt = pts[i];\n } else {\n var place = pts[i].split(':'),\n anchor = $(`#${place[0]}`);\n\n pt = anchor.offset().top;\n if (place[1] && place[1].toLowerCase() === 'bottom') {\n pt += anchor[0].getBoundingClientRect().height;\n }\n }\n breaks[i] = pt;\n }\n\n\n this.points = breaks;\n return;\n }\n\n /**\n * Adds event handlers for the scrolling element.\n * @private\n * @param {String} id - pseudo-random id for unique scroll event listener.\n */\n _events(id) {\n var _this = this,\n scrollListener = this.scrollListener = `scroll.zf.${id}`;\n if (this.isOn) { return; }\n if (this.canStick) {\n this.isOn = true;\n $(window).off(scrollListener)\n .on(scrollListener, function() {\n if (_this.scrollCount === 0) {\n _this.scrollCount = _this.options.checkEvery;\n _this._setSizes(function() {\n _this._calc(false, window.pageYOffset);\n });\n } else {\n _this.scrollCount--;\n _this._calc(false, window.pageYOffset);\n }\n });\n }\n\n this.$element.off('resizeme.zf.trigger')\n .on('resizeme.zf.trigger', function() {\n _this._eventsHandler(id);\n });\n\n this.$element.on('mutateme.zf.trigger', function () {\n _this._eventsHandler(id);\n });\n\n if(this.$anchor) {\n this.$anchor.on('mutateme.zf.trigger', function () {\n _this._eventsHandler(id);\n });\n }\n }\n\n /**\n * Handler for events.\n * @private\n * @param {String} id - pseudo-random id for unique scroll event listener.\n */\n _eventsHandler(id) {\n var _this = this,\n scrollListener = this.scrollListener = `scroll.zf.${id}`;\n\n _this._setSizes(function() {\n _this._calc(false);\n if (_this.canStick) {\n if (!_this.isOn) {\n _this._events(id);\n }\n } else if (_this.isOn) {\n _this._pauseListeners(scrollListener);\n }\n });\n }\n\n /**\n * Removes event handlers for scroll and change events on anchor.\n * @fires Sticky#pause\n * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n */\n _pauseListeners(scrollListener) {\n this.isOn = false;\n $(window).off(scrollListener);\n\n /**\n * Fires when the plugin is paused due to resize event shrinking the view.\n * @event Sticky#pause\n * @private\n */\n this.$element.trigger('pause.zf.sticky');\n }\n\n /**\n * Called on every `scroll` event and on `_init`\n * fires functions based on booleans and cached values\n * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n */\n _calc(checkSizes, scroll) {\n if (checkSizes) { this._setSizes(); }\n\n if (!this.canStick) {\n if (this.isStuck) {\n this._removeSticky(true);\n }\n return false;\n }\n\n if (!scroll) { scroll = window.pageYOffset; }\n\n if (scroll >= this.topPoint) {\n if (scroll <= this.bottomPoint) {\n if (!this.isStuck) {\n this._setSticky();\n }\n } else {\n if (this.isStuck) {\n this._removeSticky(false);\n }\n }\n } else {\n if (this.isStuck) {\n this._removeSticky(true);\n }\n }\n }\n\n /**\n * Causes the $element to become stuck.\n * Adds `position: fixed;`, and helper classes.\n * @fires Sticky#stuckto\n * @function\n * @private\n */\n _setSticky() {\n var _this = this,\n stickTo = this.options.stickTo,\n mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n css = {};\n\n css[mrgn] = `${this.options[mrgn]}em`;\n css[stickTo] = 0;\n css[notStuckTo] = 'auto';\n this.isStuck = true;\n this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)\n .addClass(`is-stuck is-at-${stickTo}`)\n .css(css)\n /**\n * Fires when the $element has become `position: fixed;`\n * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n * @event Sticky#stuckto\n */\n .trigger(`sticky.zf.stuckto:${stickTo}`);\n this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function() {\n _this._setSizes();\n });\n }\n\n /**\n * Causes the $element to become unstuck.\n * Removes `position: fixed;`, and helper classes.\n * Adds other helper classes.\n * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n * @fires Sticky#unstuckfrom\n * @private\n */\n _removeSticky(isTop) {\n var stickTo = this.options.stickTo,\n stickToTop = stickTo === 'top',\n css = {},\n anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n topOrBottom = isTop ? 'top' : 'bottom';\n\n css[mrgn] = 0;\n\n css.bottom = 'auto';\n if(isTop) {\n css.top = 0;\n } else {\n css.top = anchorPt;\n }\n\n this.isStuck = false;\n this.$element.removeClass(`is-stuck is-at-${stickTo}`)\n .addClass(`is-anchored is-at-${topOrBottom}`)\n .css(css)\n /**\n * Fires when the $element has become anchored.\n * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n * @event Sticky#unstuckfrom\n */\n .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);\n }\n\n /**\n * Sets the $element and $container sizes for plugin.\n * Calls `_setBreakPoints`.\n * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n * @private\n */\n _setSizes(cb) {\n this.canStick = MediaQuery.is(this.options.stickyOn);\n if (!this.canStick) {\n if (cb && typeof cb === 'function') { cb(); }\n }\n\n var newElemWidth = this.$container[0].getBoundingClientRect().width,\n comp = window.getComputedStyle(this.$container[0]),\n pdngl = parseInt(comp['padding-left'], 10),\n pdngr = parseInt(comp['padding-right'], 10);\n\n if (this.$anchor && this.$anchor.length) {\n this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n } else {\n this._parsePoints();\n }\n\n this.$element.css({\n 'max-width': `${newElemWidth - pdngl - pdngr}px`\n });\n\n // Recalculate the height only if it is \"dynamic\"\n if (this.options.dynamicHeight || !this.containerHeight) {\n // Get the sticked element height and apply it to the container to \"hold the place\"\n var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n newContainerHeight = this.$element.css(\"display\") === \"none\" ? 0 : newContainerHeight;\n this.$container.css('height', newContainerHeight);\n this.containerHeight = newContainerHeight;\n }\n this.elemHeight = this.containerHeight;\n\n if (!this.isStuck) {\n if (this.$element.hasClass('is-at-bottom')) {\n var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n this.$element.css('top', anchorPt);\n }\n }\n\n this._setBreakPoints(this.containerHeight, function() {\n if (cb && typeof cb === 'function') { cb(); }\n });\n }\n\n /**\n * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n * @param {Function} cb - optional callback function to be called on completion.\n * @private\n */\n _setBreakPoints(elemHeight, cb) {\n if (!this.canStick) {\n if (cb && typeof cb === 'function') { cb(); }\n else { return false; }\n }\n var mTop = emCalc(this.options.marginTop),\n mBtm = emCalc(this.options.marginBottom),\n topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n // topPoint = this.$anchor.offset().top || this.points[0],\n // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n winHeight = window.innerHeight;\n\n if (this.options.stickTo === 'top') {\n topPoint -= mTop;\n bottomPoint -= (elemHeight + mTop);\n } else if (this.options.stickTo === 'bottom') {\n topPoint -= (winHeight - (elemHeight + mBtm));\n bottomPoint -= (winHeight - mBtm);\n } else {\n //this would be the stickTo: both option... tricky\n }\n\n this.topPoint = topPoint;\n this.bottomPoint = bottomPoint;\n\n if (cb && typeof cb === 'function') { cb(); }\n }\n\n /**\n * Destroys the current sticky element.\n * Resets the element to the top position first.\n * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n * @function\n */\n _destroy() {\n this._removeSticky(true);\n\n this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)\n .css({\n height: '',\n top: '',\n bottom: '',\n 'max-width': ''\n })\n .off('resizeme.zf.trigger')\n .off('mutateme.zf.trigger');\n if (this.$anchor && this.$anchor.length) {\n this.$anchor.off('change.zf.sticky');\n }\n if (this.scrollListener) $(window).off(this.scrollListener)\n if (this.onLoadListener) $(window).off(this.onLoadListener)\n\n if (this.wasWrapped) {\n this.$element.unwrap();\n } else {\n this.$container.removeClass(this.options.containerClass)\n .css({\n height: ''\n });\n }\n }\n}\n\nSticky.defaults = {\n /**\n * Customizable container template. Add your own classes for styling and sizing.\n * @option\n * @type {string}\n * @default '<div data-sticky-container></div>'\n */\n container: '
      ',\n /**\n * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n * @option\n * @type {string}\n * @default 'top'\n */\n stickTo: 'top',\n /**\n * If anchored to a single element, the id of that element.\n * @option\n * @type {string}\n * @default ''\n */\n anchor: '',\n /**\n * If using more than one element as anchor points, the id of the top anchor.\n * @option\n * @type {string}\n * @default ''\n */\n topAnchor: '',\n /**\n * If using more than one element as anchor points, the id of the bottom anchor.\n * @option\n * @type {string}\n * @default ''\n */\n btmAnchor: '',\n /**\n * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n * @option\n * @type {number}\n * @default 1\n */\n marginTop: 1,\n /**\n * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n * @option\n * @type {number}\n * @default 1\n */\n marginBottom: 1,\n /**\n * Breakpoint string that is the minimum screen size an element should become sticky.\n * @option\n * @type {string}\n * @default 'medium'\n */\n stickyOn: 'medium',\n /**\n * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n * @option\n * @type {string}\n * @default 'sticky'\n */\n stickyClass: 'sticky',\n /**\n * Class applied to sticky container. Foundation defaults to `sticky-container`.\n * @option\n * @type {string}\n * @default 'sticky-container'\n */\n containerClass: 'sticky-container',\n /**\n * If true (by default), keep the sticky container the same height as the element. Otherwise, the container height is set once and does not change.\n * @option\n * @type {boolean}\n * @default true\n */\n dynamicHeight: true,\n /**\n * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n * @option\n * @type {number}\n * @default -1\n */\n checkEvery: -1\n};\n\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\nfunction emCalc(em) {\n return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\nexport {Sticky};\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nclass Tabs extends Plugin {\n /**\n * Creates a new instance of tabs.\n * @class\n * @name Tabs\n * @fires Tabs#init\n * @param {jQuery} element - jQuery object to make into tabs.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n this.className = 'Tabs'; // ie9 back compat\n\n this._init();\n Keyboard.register('Tabs', {\n 'ENTER': 'open',\n 'SPACE': 'open',\n 'ARROW_RIGHT': 'next',\n 'ARROW_UP': 'previous',\n 'ARROW_DOWN': 'next',\n 'ARROW_LEFT': 'previous'\n // 'TAB': 'next',\n // 'SHIFT_TAB': 'previous'\n });\n }\n\n /**\n * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n * @private\n */\n _init() {\n var _this = this;\n this._isInitializing = true;\n\n this.$element.attr({'role': 'tablist'});\n this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);\n this.$tabContent = $(`[data-tabs-content=\"${this.$element[0].id}\"]`);\n\n this.$tabTitles.each(function(){\n var $elem = $(this),\n $link = $elem.find('a'),\n isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),\n hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n linkId = $link[0].id ? $link[0].id : `${hash}-label`,\n $tabContent = $(`#${hash}`);\n\n $elem.attr({'role': 'presentation'});\n\n $link.attr({\n 'role': 'tab',\n 'aria-controls': hash,\n 'aria-selected': isActive,\n 'id': linkId,\n 'tabindex': isActive ? '0' : '-1'\n });\n\n $tabContent.attr({\n 'role': 'tabpanel',\n 'aria-labelledby': linkId\n });\n\n // Save up the initial hash to return to it later when going back in history\n if (isActive) {\n _this._initialAnchor = `#${hash}`;\n }\n\n if(!isActive) {\n $tabContent.attr('aria-hidden', 'true');\n }\n\n if(isActive && _this.options.autoFocus){\n _this.onLoadListener = onLoad($(window), function() {\n $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {\n $link.focus();\n });\n });\n }\n });\n\n if(this.options.matchHeight) {\n var $images = this.$tabContent.find('img');\n\n if ($images.length) {\n onImagesLoaded($images, this._setHeight.bind(this));\n } else {\n this._setHeight();\n }\n }\n\n // Current context-bound function to open tabs on page load or history hashchange\n this._checkDeepLink = () => {\n var anchor = window.location.hash;\n\n if (!anchor.length) {\n // If we are still initializing and there is no anchor, then there is nothing to do\n if (this._isInitializing) return;\n // Otherwise, move to the initial anchor\n if (this._initialAnchor) anchor = this._initialAnchor;\n }\n\n var anchorNoHash = anchor.indexOf('#') >= 0 ? anchor.slice(1) : anchor;\n var $anchor = anchorNoHash && $(`#${anchorNoHash}`);\n var $link = anchor && this.$element.find(`[href$=\"${anchor}\"],[data-tabs-target=\"${anchorNoHash}\"]`).first();\n // Whether the anchor element that has been found is part of this element\n var isOwnAnchor = !!($anchor.length && $link.length);\n\n if (isOwnAnchor) {\n // If there is an anchor for the hash, select it\n if ($anchor && $anchor.length && $link && $link.length) {\n this.selectTab($anchor, true);\n }\n // Otherwise, collapse everything\n else {\n this._collapse();\n }\n\n // Roll up a little to show the titles\n if (this.options.deepLinkSmudge) {\n var offset = this.$element.offset();\n $('html, body').animate({ scrollTop: offset.top - this.options.deepLinkSmudgeOffset}, this.options.deepLinkSmudgeDelay);\n }\n\n /**\n * Fires when the plugin has deeplinked at pageload\n * @event Tabs#deeplink\n */\n this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n }\n }\n\n //use browser to open a tab, if it exists in this tabset\n if (this.options.deepLink) {\n this._checkDeepLink();\n }\n\n this._events();\n\n this._isInitializing = false;\n }\n\n /**\n * Adds event handlers for items within the tabs.\n * @private\n */\n _events() {\n this._addKeyHandler();\n this._addClickHandler();\n this._setHeightMqHandler = null;\n\n if (this.options.matchHeight) {\n this._setHeightMqHandler = this._setHeight.bind(this);\n\n $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n }\n\n if(this.options.deepLink) {\n $(window).on('hashchange', this._checkDeepLink);\n }\n }\n\n /**\n * Adds click handlers for items within the tabs.\n * @private\n */\n _addClickHandler() {\n var _this = this;\n\n this.$element\n .off('click.zf.tabs')\n .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){\n e.preventDefault();\n _this._handleTabChange($(this));\n });\n }\n\n /**\n * Adds keyboard event handlers for items within the tabs.\n * @private\n */\n _addKeyHandler() {\n var _this = this;\n\n this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){\n if (e.which === 9) return;\n\n\n var $element = $(this),\n $elements = $element.parent('ul').children('li'),\n $prevElement,\n $nextElement;\n\n $elements.each(function(i) {\n if ($(this).is($element)) {\n if (_this.options.wrapOnKeys) {\n $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);\n $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);\n } else {\n $prevElement = $elements.eq(Math.max(0, i-1));\n $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n }\n return;\n }\n });\n\n // handle keyboard event with keyboard util\n Keyboard.handleKey(e, 'Tabs', {\n open: function() {\n $element.find('[role=\"tab\"]').focus();\n _this._handleTabChange($element);\n },\n previous: function() {\n $prevElement.find('[role=\"tab\"]').focus();\n _this._handleTabChange($prevElement);\n },\n next: function() {\n $nextElement.find('[role=\"tab\"]').focus();\n _this._handleTabChange($nextElement);\n },\n handled: function() {\n e.preventDefault();\n }\n });\n });\n }\n\n /**\n * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n * @param {jQuery} $target - Tab to open.\n * @param {boolean} historyHandled - browser has already handled a history update\n * @fires Tabs#change\n * @function\n */\n _handleTabChange($target, historyHandled) {\n\n // With `activeCollapse`, if the target is the active Tab, collapse it.\n if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n if(this.options.activeCollapse) {\n this._collapse();\n }\n return;\n }\n\n var $oldTab = this.$element.\n find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),\n $tabLink = $target.find('[role=\"tab\"]'),\n target = $tabLink.attr('data-tabs-target'),\n anchor = target && target.length ? `#${target}` : $tabLink[0].hash,\n $targetContent = this.$tabContent.find(anchor);\n\n //close old tab\n this._collapseTab($oldTab);\n\n //open new tab\n this._openTab($target);\n\n //either replace or update browser history\n if (this.options.deepLink && !historyHandled) {\n if (this.options.updateHistory) {\n history.pushState({}, '', anchor);\n } else {\n history.replaceState({}, '', anchor);\n }\n }\n\n /**\n * Fires when the plugin has successfully changed tabs.\n * @event Tabs#change\n */\n this.$element.trigger('change.zf.tabs', [$target, $targetContent]);\n\n //fire to children a mutation event\n $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n }\n\n /**\n * Opens the tab `$targetContent` defined by `$target`.\n * @param {jQuery} $target - Tab to open.\n * @function\n */\n _openTab($target) {\n var $tabLink = $target.find('[role=\"tab\"]'),\n hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n $targetContent = this.$tabContent.find(`#${hash}`);\n\n $target.addClass(`${this.options.linkActiveClass}`);\n\n $tabLink.attr({\n 'aria-selected': 'true',\n 'tabindex': '0'\n });\n\n $targetContent\n .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');\n }\n\n /**\n * Collapses `$targetContent` defined by `$target`.\n * @param {jQuery} $target - Tab to collapse.\n * @function\n */\n _collapseTab($target) {\n var $targetAnchor = $target\n .removeClass(`${this.options.linkActiveClass}`)\n .find('[role=\"tab\"]')\n .attr({\n 'aria-selected': 'false',\n 'tabindex': -1\n });\n\n $(`#${$targetAnchor.attr('aria-controls')}`)\n .removeClass(`${this.options.panelActiveClass}`)\n .attr({ 'aria-hidden': 'true' })\n }\n\n /**\n * Collapses the active Tab.\n * @fires Tabs#collapse\n * @function\n */\n _collapse() {\n var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);\n\n if ($activeTab.length) {\n this._collapseTab($activeTab);\n\n /**\n * Fires when the plugin has successfully collapsed tabs.\n * @event Tabs#collapse\n */\n this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n }\n }\n\n /**\n * Public method for selecting a content pane to display.\n * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n * @param {boolean} historyHandled - browser has already handled a history update\n * @function\n */\n selectTab(elem, historyHandled) {\n var idStr, hashIdStr;\n\n if (typeof elem === 'object') {\n idStr = elem[0].id;\n } else {\n idStr = elem;\n }\n\n if (idStr.indexOf('#') < 0) {\n hashIdStr = `#${idStr}`;\n } else {\n hashIdStr = idStr;\n idStr = idStr.slice(1);\n }\n\n var $target = this.$tabTitles.has(`[href$=\"${hashIdStr}\"],[data-tabs-target=\"${idStr}\"]`).first();\n\n this._handleTabChange($target, historyHandled);\n };\n\n /**\n * Sets the height of each panel to the height of the tallest panel.\n * If enabled in options, gets called on media query change.\n * If loading content via external source, can be called directly or with _reflow.\n * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n * @function\n * @private\n */\n _setHeight() {\n var max = 0,\n _this = this; // Lock down the `this` value for the root tabs object\n\n if (!this.$tabContent) {\n return;\n }\n\n this.$tabContent\n .find(`.${this.options.panelClass}`)\n .css('min-height', '')\n .each(function() {\n\n var panel = $(this),\n isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child\n\n if (!isActive) {\n panel.css({'visibility': 'hidden', 'display': 'block'});\n }\n\n var temp = this.getBoundingClientRect().height;\n\n if (!isActive) {\n panel.css({\n 'visibility': '',\n 'display': ''\n });\n }\n\n max = temp > max ? temp : max;\n })\n .css('min-height', `${max}px`);\n }\n\n /**\n * Destroys an instance of tabs.\n * @fires Tabs#destroyed\n */\n _destroy() {\n this.$element\n .find(`.${this.options.linkClass}`)\n .off('.zf.tabs').hide().end()\n .find(`.${this.options.panelClass}`)\n .hide();\n\n if (this.options.matchHeight) {\n if (this._setHeightMqHandler != null) {\n $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n }\n }\n\n if (this.options.deepLink) {\n $(window).off('hashchange', this._checkDeepLink);\n }\n\n if (this.onLoadListener) {\n $(window).off(this.onLoadListener);\n }\n }\n}\n\nTabs.defaults = {\n /**\n * Link the location hash to the active pane.\n * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n * @option\n * @type {boolean}\n * @default false\n */\n deepLink: false,\n\n /**\n * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n * @option\n * @type {boolean}\n * @default false\n */\n deepLinkSmudge: false,\n\n /**\n * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n * @option\n * @type {number}\n * @default 300\n */\n deepLinkSmudgeDelay: 300,\n\n /**\n * If `deepLinkSmudge` is enabled, animation offset from the top for the deep link adjustment\n * @option\n * @type {number}\n * @default 0\n */\n deepLinkSmudgeOffset: 0,\n\n /**\n * If `deepLink` is enabled, update the browser history with the open tab\n * @option\n * @type {boolean}\n * @default false\n */\n updateHistory: false,\n\n /**\n * Allows the window to scroll to content of active pane on load.\n * Not recommended if more than one tab panel per page.\n * @option\n * @type {boolean}\n * @default false\n */\n autoFocus: false,\n\n /**\n * Allows keyboard input to 'wrap' around the tab links.\n * @option\n * @type {boolean}\n * @default true\n */\n wrapOnKeys: true,\n\n /**\n * Allows the tab content panes to match heights if set to true.\n * @option\n * @type {boolean}\n * @default false\n */\n matchHeight: false,\n\n /**\n * Allows active tabs to collapse when clicked.\n * @option\n * @type {boolean}\n * @default false\n */\n activeCollapse: false,\n\n /**\n * Class applied to `li`'s in tab link list.\n * @option\n * @type {string}\n * @default 'tabs-title'\n */\n linkClass: 'tabs-title',\n\n /**\n * Class applied to the active `li` in tab link list.\n * @option\n * @type {string}\n * @default 'is-active'\n */\n linkActiveClass: 'is-active',\n\n /**\n * Class applied to the content containers.\n * @option\n * @type {string}\n * @default 'tabs-panel'\n */\n panelClass: 'tabs-panel',\n\n /**\n * Class applied to the active content container.\n * @option\n * @type {string}\n * @default 'is-active'\n */\n panelActiveClass: 'is-active'\n};\n\nexport {Tabs};\n","import $ from 'jquery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { RegExpEscape } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler extends Plugin {\n /**\n * Creates a new instance of Toggler.\n * @class\n * @name Toggler\n * @fires Toggler#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Toggler.defaults, element.data(), options);\n this.className = '';\n this.className = 'Toggler'; // ie9 back compat\n\n // Triggers init is idempotent, just need to make sure it is initialized\n Triggers.init($);\n\n this._init();\n this._events();\n }\n\n /**\n * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n * @function\n * @private\n */\n _init() {\n // Collect triggers to set ARIA attributes to\n var id = this.$element[0].id,\n $triggers = $(`[data-open~=\"${id}\"], [data-close~=\"${id}\"], [data-toggle~=\"${id}\"]`);\n\n var input;\n // Parse animation classes if they were set\n if (this.options.animate) {\n input = this.options.animate.split(' ');\n\n this.animationIn = input[0];\n this.animationOut = input[1] || null;\n\n // - aria-expanded: according to the element visibility.\n $triggers.attr('aria-expanded', !this.$element.is(':hidden'));\n }\n // Otherwise, parse toggle class\n else {\n input = this.options.toggler;\n if (typeof input !== 'string' || !input.length) {\n throw new Error(`The 'toggler' option containing the target class is required, got \"${input}\"`);\n }\n // Allow for a . at the beginning of the string\n this.className = input[0] === '.' ? input.slice(1) : input;\n\n // - aria-expanded: according to the elements class set.\n $triggers.attr('aria-expanded', this.$element.hasClass(this.className));\n }\n\n // - aria-controls: adding the element id to it if not already in it.\n $triggers.each((index, trigger) => {\n const $trigger = $(trigger);\n const controls = $trigger.attr('aria-controls') || '';\n\n const containsId = new RegExp(`\\\\b${RegExpEscape(id)}\\\\b`).test(controls);\n if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);\n });\n }\n\n /**\n * Initializes events for the toggle trigger.\n * @function\n * @private\n */\n _events() {\n this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n }\n\n /**\n * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n * @function\n * @fires Toggler#on\n * @fires Toggler#off\n */\n toggle() {\n this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n }\n\n _toggleClass() {\n this.$element.toggleClass(this.className);\n\n var isOn = this.$element.hasClass(this.className);\n if (isOn) {\n /**\n * Fires if the target element has the class after a toggle.\n * @event Toggler#on\n */\n this.$element.trigger('on.zf.toggler');\n }\n else {\n /**\n * Fires if the target element does not have the class after a toggle.\n * @event Toggler#off\n */\n this.$element.trigger('off.zf.toggler');\n }\n\n this._updateARIA(isOn);\n this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n }\n\n _toggleAnimate() {\n var _this = this;\n\n if (this.$element.is(':hidden')) {\n Motion.animateIn(this.$element, this.animationIn, function() {\n _this._updateARIA(true);\n this.trigger('on.zf.toggler');\n this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n });\n }\n else {\n Motion.animateOut(this.$element, this.animationOut, function() {\n _this._updateARIA(false);\n this.trigger('off.zf.toggler');\n this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n });\n }\n }\n\n _updateARIA(isOn) {\n var id = this.$element[0].id;\n $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n .attr({\n 'aria-expanded': isOn ? true : false\n });\n }\n\n /**\n * Destroys the instance of Toggler on the element.\n * @function\n */\n _destroy() {\n this.$element.off('.zf.toggler');\n }\n}\n\nToggler.defaults = {\n /**\n * Class of the element to toggle. It can be provided with or without \".\"\n * @option\n * @type {string}\n */\n toggler: undefined,\n /**\n * Tells the plugin if the element should animated when toggled.\n * @option\n * @type {boolean}\n * @default false\n */\n animate: false\n};\n\nexport {Toggler};\n","import $ from 'jquery';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\nimport { Positionable } from './foundation.positionable';\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass Tooltip extends Positionable {\n /**\n * Creates a new instance of a Tooltip.\n * @class\n * @name Tooltip\n * @fires Tooltip#init\n * @param {jQuery} element - jQuery object to attach a tooltip to.\n * @param {Object} options - object to extend the default configuration.\n */\n _setup(element, options) {\n this.$element = element;\n this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n this.className = 'Tooltip'; // ie9 back compat\n\n this.isActive = false;\n this.isClick = false;\n\n // Triggers init is idempotent, just need to make sure it is initialized\n Triggers.init($);\n\n this._init();\n }\n\n /**\n * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n * @private\n */\n _init() {\n MediaQuery._init();\n var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');\n\n this.options.tipText = this.options.tipText || this.$element.attr('title');\n this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);\n\n if (this.options.allowHtml) {\n this.template.appendTo(document.body)\n .html(this.options.tipText)\n .hide();\n } else {\n this.template.appendTo(document.body)\n .text(this.options.tipText)\n .hide();\n }\n\n this.$element.attr({\n 'title': '',\n 'aria-describedby': elemId,\n 'data-yeti-box': elemId,\n 'data-toggle': elemId,\n 'data-resize': elemId\n }).addClass(this.options.triggerClass);\n\n super._init();\n this._events();\n }\n\n _getDefaultPosition() {\n // handle legacy classnames\n var elementClassName = this.$element[0].className;\n if (this.$element[0] instanceof SVGElement) {\n elementClassName = elementClassName.baseVal;\n }\n var position = elementClassName.match(/\\b(top|left|right|bottom)\\b/g);\n return position ? position[0] : 'top';\n }\n\n _getDefaultAlignment() {\n return 'center';\n }\n\n _getHOffset() {\n if(this.position === 'left' || this.position === 'right') {\n return this.options.hOffset + this.options.tooltipWidth;\n } else {\n return this.options.hOffset\n }\n }\n\n _getVOffset() {\n if(this.position === 'top' || this.position === 'bottom') {\n return this.options.vOffset + this.options.tooltipHeight;\n } else {\n return this.options.vOffset\n }\n }\n\n /**\n * builds the tooltip element, adds attributes, and returns the template.\n * @private\n */\n _buildTemplate(id) {\n var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();\n var $template = $('
      ').addClass(templateClasses).attr({\n 'role': 'tooltip',\n 'aria-hidden': true,\n 'data-is-active': false,\n 'data-is-focus': false,\n 'id': id\n });\n return $template;\n }\n\n /**\n * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n * if the tooltip is larger than the screen width, default to full width - any user selected margin\n * @private\n */\n _setPosition() {\n super._setPosition(this.$element, this.template);\n }\n\n /**\n * reveals the tooltip, and fires an event to close any other open tooltips on the page\n * @fires Tooltip#closeme\n * @fires Tooltip#show\n * @function\n */\n show() {\n if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {\n // console.error('The screen is too small to display this tooltip');\n return false;\n }\n\n var _this = this;\n this.template.css('visibility', 'hidden').show();\n this._setPosition();\n this.template.removeClass('top bottom left right').addClass(this.position)\n this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n\n /**\n * Fires to close all other open tooltips on the page\n * @event Closeme#tooltip\n */\n this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n\n\n this.template.attr({\n 'data-is-active': true,\n 'aria-hidden': false\n });\n _this.isActive = true;\n this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {\n //maybe do stuff?\n });\n /**\n * Fires when the tooltip is shown\n * @event Tooltip#show\n */\n this.$element.trigger('show.zf.tooltip');\n }\n\n /**\n * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n * @fires Tooltip#hide\n * @function\n */\n hide() {\n var _this = this;\n this.template.stop().attr({\n 'aria-hidden': true,\n 'data-is-active': false\n }).fadeOut(this.options.fadeOutDuration, function() {\n _this.isActive = false;\n _this.isClick = false;\n });\n /**\n * fires when the tooltip is hidden\n * @event Tooltip#hide\n */\n this.$element.trigger('hide.zf.tooltip');\n }\n\n /**\n * adds event listeners for the tooltip and its anchor\n * TODO combine some of the listeners like focus and mouseenter, etc.\n * @private\n */\n _events() {\n const _this = this;\n const hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined');\n var isFocus = false;\n\n // `disableForTouch: Fully disable the tooltip on touch devices\n if (hasTouch && this.options.disableForTouch) return;\n\n if (!this.options.disableHover) {\n this.$element\n .on('mouseenter.zf.tooltip', function() {\n if (!_this.isActive) {\n _this.timeout = setTimeout(function() {\n _this.show();\n }, _this.options.hoverDelay);\n }\n })\n .on('mouseleave.zf.tooltip', ignoreMousedisappear(function() {\n clearTimeout(_this.timeout);\n if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {\n _this.hide();\n }\n }));\n }\n\n if (hasTouch) {\n this.$element\n .on('tap.zf.tooltip touchend.zf.tooltip', function () {\n _this.isActive ? _this.hide() : _this.show();\n });\n }\n\n if (this.options.clickOpen) {\n this.$element.on('mousedown.zf.tooltip', function() {\n if (_this.isClick) {\n //_this.hide();\n // _this.isClick = false;\n } else {\n _this.isClick = true;\n if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n _this.show();\n }\n }\n });\n } else {\n this.$element.on('mousedown.zf.tooltip', function() {\n _this.isClick = true;\n });\n }\n\n this.$element.on({\n // 'toggle.zf.trigger': this.toggle.bind(this),\n // 'close.zf.trigger': this.hide.bind(this)\n 'close.zf.trigger': this.hide.bind(this)\n });\n\n this.$element\n .on('focus.zf.tooltip', function() {\n isFocus = true;\n if (_this.isClick) {\n // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n // a real focus, otherwise on hover and come back we get bad behavior\n if(!_this.options.clickOpen) { isFocus = false; }\n return false;\n } else {\n _this.show();\n }\n })\n\n .on('focusout.zf.tooltip', function() {\n isFocus = false;\n _this.isClick = false;\n _this.hide();\n })\n\n .on('resizeme.zf.trigger', function() {\n if (_this.isActive) {\n _this._setPosition();\n }\n });\n }\n\n /**\n * adds a toggle method, in addition to the static show() & hide() functions\n * @function\n */\n toggle() {\n if (this.isActive) {\n this.hide();\n } else {\n this.show();\n }\n }\n\n /**\n * Destroys an instance of tooltip, removes template element from the view.\n * @function\n */\n _destroy() {\n this.$element.attr('title', this.template.text())\n .off('.zf.trigger .zf.tooltip')\n .removeClass(this.options.triggerClass)\n .removeClass('top right left bottom')\n .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n this.template.remove();\n }\n}\n\nTooltip.defaults = {\n /**\n * Time, in ms, before a tooltip should open on hover.\n * @option\n * @type {number}\n * @default 200\n */\n hoverDelay: 200,\n /**\n * Time, in ms, a tooltip should take to fade into view.\n * @option\n * @type {number}\n * @default 150\n */\n fadeInDuration: 150,\n /**\n * Time, in ms, a tooltip should take to fade out of view.\n * @option\n * @type {number}\n * @default 150\n */\n fadeOutDuration: 150,\n /**\n * Disables hover events from opening the tooltip if set to true\n * @option\n * @type {boolean}\n * @default false\n */\n disableHover: false,\n /**\n * Disable the tooltip for touch devices.\n * This can be useful to make elements with a tooltip on it trigger their\n * action on the first tap instead of displaying the tooltip.\n * @option\n * @type {booelan}\n * @default false\n */\n disableForTouch: false,\n /**\n * Optional addtional classes to apply to the tooltip template on init.\n * @option\n * @type {string}\n * @default ''\n */\n templateClasses: '',\n /**\n * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n * @option\n * @type {string}\n * @default 'tooltip'\n */\n tooltipClass: 'tooltip',\n /**\n * Class applied to the tooltip anchor element.\n * @option\n * @type {string}\n * @default 'has-tip'\n */\n triggerClass: 'has-tip',\n /**\n * Minimum breakpoint size at which to open the tooltip.\n * @option\n * @type {string}\n * @default 'small'\n */\n showOn: 'small',\n /**\n * Custom template to be used to generate markup for tooltip.\n * @option\n * @type {string}\n * @default ''\n */\n template: '',\n /**\n * Text displayed in the tooltip template on open.\n * @option\n * @type {string}\n * @default ''\n */\n tipText: '',\n touchCloseText: 'Tap to close.',\n /**\n * Allows the tooltip to remain open if triggered with a click or touch event.\n * @option\n * @type {boolean}\n * @default true\n */\n clickOpen: true,\n /**\n * Position of tooltip. Can be left, right, bottom, top, or auto.\n * @option\n * @type {string}\n * @default 'auto'\n */\n position: 'auto',\n /**\n * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n * @option\n * @type {string}\n * @default 'auto'\n */\n alignment: 'auto',\n /**\n * Allow overlap of container/window. If false, tooltip will first try to\n * position as defined by data-position and data-alignment, but reposition if\n * it would cause an overflow. @option\n * @type {boolean}\n * @default false\n */\n allowOverlap: false,\n /**\n * Allow overlap of only the bottom of the container. This is the most common\n * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n * screen but not otherwise influence or break out of the container.\n * Less common for tooltips.\n * @option\n * @type {boolean}\n * @default false\n */\n allowBottomOverlap: false,\n /**\n * Distance, in pixels, the template should push away from the anchor on the Y axis.\n * @option\n * @type {number}\n * @default 0\n */\n vOffset: 0,\n /**\n * Distance, in pixels, the template should push away from the anchor on the X axis\n * @option\n * @type {number}\n * @default 0\n */\n hOffset: 0,\n /**\n * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n * @option\n * @type {number}\n * @default 14\n */\n tooltipHeight: 14,\n /**\n * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n * @option\n * @type {number}\n * @default 12\n */\n tooltipWidth: 12,\n /**\n * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n * allowing HTML may open yourself up to XSS attacks.\n * @option\n * @type {boolean}\n * @default false\n */\n allowHtml: false\n};\n\n/**\n * TODO utilize resize event trigger\n */\n\nexport {Tooltip};\n","import $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin }from './foundation.core.plugin';\n\nimport { Accordion } from './foundation.accordion';\nimport { Tabs } from './foundation.tabs';\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n tabs: {\n cssClass: 'tabs',\n plugin: Tabs,\n open: (plugin, target) => plugin.selectTab(target),\n close: null /* not supported */,\n toggle: null /* not supported */,\n },\n accordion: {\n cssClass: 'accordion',\n plugin: Accordion,\n open: (plugin, target) => plugin.down($(target)),\n close: (plugin, target) => plugin.up($(target)),\n toggle: (plugin, target) => plugin.toggle($(target)),\n }\n};\n\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs extends Plugin{\n constructor(element, options) {\n super(element, options);\n return this.options.reflow && this.storezfData || this;\n }\n\n /**\n * Creates a new instance of a responsive accordion tabs.\n * @class\n * @name ResponsiveAccordionTabs\n * @fires ResponsiveAccordionTabs#init\n * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options) {\n this.$element = $(element);\n this.$element.data('zfPluginBase', this);\n this.options = $.extend({}, ResponsiveAccordionTabs.defaults, this.$element.data(), options);\n\n this.rules = this.$element.data('responsive-accordion-tabs');\n this.currentMq = null;\n this.currentRule = null;\n this.currentPlugin = null;\n this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n if (!this.$element.attr('id')) {\n this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));\n }\n\n this._init();\n this._events();\n }\n\n /**\n * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n * @function\n * @private\n */\n _init() {\n MediaQuery._init();\n\n // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n if (typeof this.rules === 'string') {\n let rulesTree = {};\n\n // Parse rules from \"classes\" pulled from data attribute\n let rules = this.rules.split(' ');\n\n // Iterate through every rule found\n for (let i = 0; i < rules.length; i++) {\n let rule = rules[i].split('-');\n let ruleSize = rule.length > 1 ? rule[0] : 'small';\n let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n if (MenuPlugins[rulePlugin] !== null) {\n rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n }\n }\n\n this.rules = rulesTree;\n }\n\n this._getAllOptions();\n\n if (!$.isEmptyObject(this.rules)) {\n this._checkMediaQueries();\n }\n }\n\n _getAllOptions() {\n //get all defaults and options\n var _this = this;\n _this.allOptions = {};\n for (var key in MenuPlugins) {\n if (MenuPlugins.hasOwnProperty(key)) {\n var obj = MenuPlugins[key];\n try {\n var dummyPlugin = $('
        ');\n var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);\n for (var keyKey in tmpPlugin.options) {\n if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n var objObj = tmpPlugin.options[keyKey];\n _this.allOptions[keyKey] = objObj;\n }\n }\n tmpPlugin.destroy();\n }\n catch(e) {\n console.warn(`Warning: Problems getting Accordion/Tab options: ${e}`);\n }\n }\n }\n }\n\n /**\n * Initializes events for the Menu.\n * @function\n * @private\n */\n _events() {\n this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n }\n\n /**\n * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n * @function\n * @private\n */\n _checkMediaQueries() {\n var matchedMq, _this = this;\n // Iterate through each rule and find the last matching rule\n $.each(this.rules, function(key) {\n if (MediaQuery.atLeast(key)) {\n matchedMq = key;\n }\n });\n\n // No match? No dice\n if (!matchedMq) return;\n\n // Plugin already initialized? We good\n if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n // Remove existing plugin-specific CSS classes\n $.each(MenuPlugins, function(key, value) {\n _this.$element.removeClass(value.cssClass);\n });\n\n // Add the CSS class for the new plugin\n this.$element.addClass(this.rules[matchedMq].cssClass);\n\n // Create an instance of the new plugin\n if (this.currentPlugin) {\n //don't know why but on nested elements data zfPlugin get's lost\n if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);\n this.currentPlugin.destroy();\n }\n this._handleMarkup(this.rules[matchedMq].cssClass);\n this.currentRule = this.rules[matchedMq];\n this.currentPlugin = new this.currentRule.plugin(this.$element, this.options);\n this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n\n }\n\n _handleMarkup(toSet){\n var _this = this, fromString = 'accordion';\n var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');\n if ($panels.length) fromString = 'tabs';\n if (fromString === toSet) {\n return;\n }\n\n var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';\n var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';\n\n this.$element.removeAttr('role');\n var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n if (fromString === 'tabs') {\n $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n } else {\n $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n }\n\n $panels.css({display:'',visibility:''});\n $liHeads.css({display:'',visibility:''});\n if (toSet === 'accordion') {\n $panels.each(function(key,value){\n $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});\n $('[data-tabs-content='+_this.$element.attr('id')+']').after('
        ').detach();\n $liHeads.addClass('accordion-item').attr('data-accordion-item','');\n $liHeadsA.addClass('accordion-title');\n });\n } else if (toSet === 'tabs') {\n var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');\n var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));\n if ($placeholder.length) {\n $tabsContent = $('
        ').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));\n $placeholder.remove();\n } else {\n $tabsContent = $('
        ').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));\n }\n $panels.each(function(key,value){\n var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);\n var hash = $liHeadsA.get(key).hash.slice(1);\n var id = $(value).attr('id') || GetYoDigits(6, 'accordion');\n if (hash !== id) {\n if (hash !== '') {\n $(value).attr('id',hash);\n } else {\n hash = id;\n $(value).attr('id',hash);\n $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);\n }\n }\n var isActive = $($liHeads.get(key)).hasClass('is-active');\n if (isActive) {\n tempValue.addClass('is-active');\n }\n });\n $liHeads.addClass(tabsTitle);\n };\n }\n\n /**\n * Opens the plugin pane defined by `target`.\n * @param {jQuery | String} target - jQuery object or string of the id of the pane to open.\n * @see Accordion.down\n * @see Tabs.selectTab\n * @function\n */\n open() {\n if (this.currentRule && typeof this.currentRule.open === 'function') {\n return this.currentRule.open(this.currentPlugin, ...arguments);\n }\n }\n\n /**\n * Closes the plugin pane defined by `target`. Not availaible for Tabs.\n * @param {jQuery | String} target - jQuery object or string of the id of the pane to close.\n * @see Accordion.up\n * @function\n */\n close() {\n if (this.currentRule && typeof this.currentRule.close === 'function') {\n return this.currentRule.close(this.currentPlugin, ...arguments);\n }\n }\n\n /**\n * Toggles the plugin pane defined by `target`. Not availaible for Tabs.\n * @param {jQuery | String} target - jQuery object or string of the id of the pane to toggle.\n * @see Accordion.toggle\n * @function\n */\n toggle() {\n if (this.currentRule && typeof this.currentRule.toggle === 'function') {\n return this.currentRule.toggle(this.currentPlugin, ...arguments);\n }\n }\n\n /**\n * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n * @function\n */\n _destroy() {\n if (this.currentPlugin) this.currentPlugin.destroy();\n $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\nexport {ResponsiveAccordionTabs};\n","import $ from 'jquery';\n\nimport { Foundation } from '../foundation.core';\nimport * as CoreUtils from '../foundation.core.utils';\nimport { Box } from '../foundation.util.box'\nimport { onImagesLoaded } from '../foundation.util.imageLoader';\nimport { Keyboard } from '../foundation.util.keyboard';\nimport { MediaQuery } from '../foundation.util.mediaQuery';\nimport { Motion, Move } from '../foundation.util.motion';\nimport { Nest } from '../foundation.util.nest';\nimport { Timer } from '../foundation.util.timer';\nimport { Touch } from '../foundation.util.touch';\nimport { Triggers } from '../foundation.util.triggers';\nimport { Abide } from '../foundation.abide';\nimport { Accordion } from '../foundation.accordion';\nimport { AccordionMenu } from '../foundation.accordionMenu';\nimport { Drilldown } from '../foundation.drilldown';\nimport { Dropdown } from '../foundation.dropdown';\nimport { DropdownMenu } from '../foundation.dropdownMenu';\nimport { Equalizer } from '../foundation.equalizer';\nimport { Interchange } from '../foundation.interchange';\nimport { Magellan } from '../foundation.magellan';\nimport { OffCanvas } from '../foundation.offcanvas';\nimport { Orbit } from '../foundation.orbit';\nimport { ResponsiveMenu } from '../foundation.responsiveMenu';\nimport { ResponsiveToggle } from '../foundation.responsiveToggle';\nimport { Reveal } from '../foundation.reveal';\nimport { Slider } from '../foundation.slider';\nimport { SmoothScroll } from '../foundation.smoothScroll';\nimport { Sticky } from '../foundation.sticky';\nimport { Tabs } from '../foundation.tabs';\nimport { Toggler } from '../foundation.toggler';\nimport { Tooltip } from '../foundation.tooltip';\nimport { ResponsiveAccordionTabs } from '../foundation.responsiveAccordionTabs';\n\nFoundation.addToJquery($);\n\n// Add Foundation Utils to Foundation global namespace for backwards\n// compatibility.\nFoundation.rtl = CoreUtils.rtl;\nFoundation.GetYoDigits = CoreUtils.GetYoDigits;\nFoundation.transitionend = CoreUtils.transitionend;\nFoundation.RegExpEscape = CoreUtils.RegExpEscape;\nFoundation.onLoad = CoreUtils.onLoad;\n\nFoundation.Box = Box;\nFoundation.onImagesLoaded = onImagesLoaded;\nFoundation.Keyboard = Keyboard;\nFoundation.MediaQuery = MediaQuery;\nFoundation.Motion = Motion;\nFoundation.Move = Move;\nFoundation.Nest = Nest;\nFoundation.Timer = Timer;\n\n// Touch and Triggers previously were almost purely sede effect driven,\n// so no need to add it to Foundation, just init them.\nTouch.init($);\nTriggers.init($, Foundation);\nMediaQuery._init();\n\nFoundation.plugin(Abide, 'Abide');\nFoundation.plugin(Accordion, 'Accordion');\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\nFoundation.plugin(Drilldown, 'Drilldown');\nFoundation.plugin(Dropdown, 'Dropdown');\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\nFoundation.plugin(Equalizer, 'Equalizer');\nFoundation.plugin(Interchange, 'Interchange');\nFoundation.plugin(Magellan, 'Magellan');\nFoundation.plugin(OffCanvas, 'OffCanvas');\nFoundation.plugin(Orbit, 'Orbit');\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\nFoundation.plugin(Reveal, 'Reveal');\nFoundation.plugin(Slider, 'Slider');\nFoundation.plugin(SmoothScroll, 'SmoothScroll');\nFoundation.plugin(Sticky, 'Sticky');\nFoundation.plugin(Tabs, 'Tabs');\nFoundation.plugin(Toggler, 'Toggler');\nFoundation.plugin(Tooltip, 'Tooltip');\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\nexport {\n Foundation,\n CoreUtils,\n Box,\n onImagesLoaded,\n Keyboard,\n MediaQuery,\n Motion,\n Nest,\n Timer,\n Touch,\n Triggers,\n Abide,\n Accordion,\n AccordionMenu,\n Drilldown,\n Dropdown,\n DropdownMenu,\n Equalizer,\n Interchange,\n Magellan,\n OffCanvas,\n Orbit,\n ResponsiveMenu,\n ResponsiveToggle,\n Reveal,\n Slider,\n SmoothScroll,\n Sticky,\n Tabs,\n Toggler,\n Tooltip,\n ResponsiveAccordionTabs\n}\n\nexport default Foundation;\n\n"],"names":["rtl","$","attr","GetYoDigits","length","namespace","str","chars","charsLength","i","Math","floor","random","RegExpEscape","replace","transitionend","$elem","transitions","elem","document","createElement","end","transition","style","setTimeout","triggerHandler","onLoad","handler","didLoad","readyState","eventType","cb","one","window","ignoreMousedisappear","ignoreLeaveWindow","ignoreReappear","leaveEventHandler","eLeave","rest","callback","bind","relatedTarget","leaveEventDebouncer","hasFocus","reenterEventHandler","eReenter","currentTarget","has","target","matchMedia","styleMedia","media","script","getElementsByTagName","info","type","id","head","appendChild","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","MediaQuery","queries","current","_init","isInitialized","self","$meta","appendTo","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","push","name","value","_getCurrentSize","_watcher","_reInit","atLeast","size","query","get","only","upTo","nextSize","next","is","parts","trim","split","filter","p","bpSize","bpModifier","Error","queryIndex","findIndex","q","_getQueryName","nextQuery","TypeError","matched","on","newSize","currentSize","trigger","styleObject","slice","reduce","ret","param","val","decodeURIComponent","Array","isArray","FOUNDATION_VERSION","Foundation","version","_plugins","_uuids","plugin","className","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","$element","data","unregisterPlugin","splice","indexOf","removeAttr","removeData","prop","reInit","plugins","isJQ","each","_this","fns","plgs","forEach","foundation","object","Object","keys","err","console","error","reflow","find","addBack","$el","opts","option","opt","map","el","parseValue","er","getFnName","addToJquery","method","$noJS","removeClass","args","prototype","call","arguments","plugClass","apply","ReferenceError","fn","util","throttle","func","delay","timer","context","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","nextTime","max","clearTimeout","performance","start","Function","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","toString","isNaN","parseFloat","Box","ImNotTouchingYou","OverlapArea","GetDimensions","GetExplicitOffsets","element","parent","lrOnly","tbOnly","ignoreBottom","eleDims","topOver","bottomOver","leftOver","rightOver","parDims","height","offset","top","left","windowDims","min","sqrt","rect","getBoundingClientRect","parRect","winRect","body","winY","pageYOffset","winX","pageXOffset","parentDims","anchor","position","alignment","vOffset","hOffset","isOverflow","$eleDims","$anchorDims","topVal","leftVal","onImagesLoaded","images","unloaded","complete","naturalWidth","singleImageLoaded","image","Image","events","me","off","src","keyCodes","commands","findFocusable","sort","a","b","aTabIndex","parseInt","bTabIndex","parseKey","event","which","keyCode","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","Keyboard","getKeyCodes","handleKey","component","functions","commandList","cmds","command","warn","zfIsKeyHandled","ltr","Rtl","extend","returnValue","handled","unhandled","register","componentName","trapFocus","$focusable","$firstFocusable","eq","$lastFocusable","preventDefault","focus","releaseFocus","kcs","k","kc","initClasses","activeClasses","Motion","animateIn","animation","animate","animateOut","Move","duration","anim","prog","move","ts","isIn","initClass","activeClass","reset","addClass","show","offsetWidth","finish","hide","transitionDuration","Nest","Feather","menu","items","subMenuClass","subItemClass","hasSubClass","applyAria","$item","$sub","children","firstItem","Burn","Timer","options","nameSpace","remain","isPaused","restart","infinite","pause","Touch","startPosX","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","e","removeEventListener","onTouchMove","tapEvent","Event","spotSwipe","x","touches","pageX","dx","dir","abs","moveThreshold","timeThreshold","assign","onTouchStart","addEventListener","passive","init","SpotSwipe","enabled","documentElement","special","swipe","setup","tap","noop","setupSpotSwipe","setupTouchHandler","addTouch","handleTouch","changedTouches","first","eventTypes","touchstart","touchmove","touchend","simulatedEvent","MouseEvent","screenX","screenY","clientX","clientY","createEvent","initMouseEvent","dispatchEvent","MutationObserver","prefixes","triggers","Triggers","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","fadeOut","toggleFocusListener","addOpenListener","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","not","addClosemeListener","yetiBoxes","plugNames","listeners","join","debounceGlobalListener","debounce","listener","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","__","triggersInitialized","IHearYou","Plugin","_setup","getPluginName","_destroy","obj","Abide","defaults","isEnabled","formnovalidate","$inputs","merge","$submits","$globalErrors","a11yAttributes","input","addA11yAttributes","addGlobalErrorA11yAttributes","_events","resetForm","validateForm","getAttribute","submit","validateOn","validateInput","liveValidate","validateOnBlur","isGood","checked","failedValidators","$error","siblings","formErrorSelector","add","v","$label","$els","labels","findLabel","$formError","findFormError","labelErrorClass","formErrorClass","inputErrorClass","addA11yErrorDescribe","$errors","$labels","elemId","label","errorId","a11yErrorLevel","groupName","findRadioLabels","$formErrors","findCheckboxLabels","removeRadioErrorClasses","removeCheckboxErrorClasses","clearRequire","requiredCheck","validator","manageErrorClasses","_validationIsDisabled","validateRadio","validateCheckbox","validateText","required","validators","equalTo","goodToGo","message","dependentElements","addErrorClasses","removeErrorClasses","acc","checkboxGroupName","initialized","noError","pattern","inputText","valid","patterns","RegExp","$group","minRequired","clear","$form","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","Accordion","_isInitializing","$tabs","idx","$content","linkId","$initActive","_initialAnchor","prev","_openSingleTab","_checkDeepLink","location","hash","$anchor","$link","isOwnAnchor","hasClass","_closeAllTabs","deepLinkSmudge","scrollTop","deepLinkSmudgeOffset","deepLinkSmudgeDelay","deepLink","$tabContent","toggle","$a","multiExpand","previous","last","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","allowAllClosed","_closeTab","$activeContents","targetContentId","slideDown","slideSpeed","slideUp","$activeTabs","stop","AccordionMenu","multiOpen","$menuLinks","subId","isActive","parentLink","clone","prependTo","wrap","submenuToggle","after","submenuToggleText","initPanes","$submenu","$elements","$prevElement","$nextElement","parents","open","close","closeAll","hideAll","$targetBranch","parentsUntil","$othersActiveSubmenus","$submenus","$allmenus","detach","remove","Drilldown","autoApplyClass","$submenuAnchors","$menuItems","$currentMenu","_prepareMenu","_registerEvents","_keyboardEvents","$menu","$back","backButtonPosition","append","backButton","prepend","_back","autoHeight","$wrapper","wrapper","animateHeight","_getMaxDims","_show","closeOnClick","$body","ev","contains","_hideAll","_bindHandler","_scrollTop","_resize","$scrollTopElement","scrollTopElement","scrollPos","scrollTopOffset","animationDuration","animationEasing","_hide","calcHeight","parentSubMenu","autoFocus","$expandedSubmenus","_setHideSubMenuClasses","index","isLastChild","_setShowSubMenuClasses","blur","maxHeight","result","unwrap","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","nextItem","item","array","currentIdx","Positionable","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","isExhausted","$parent","allowOverlap","_getVOffset","_getHOffset","minOverlap","minCoordinates","_positionsExhausted","overlap","allowBottomOverlap","_reposition","Dropdown","$id","$anchors","_setCurrentAnchor","parentClass","$currentAnchor","match","horizontalPosition","hasTouch","ontouchstart","_setPosition","forceFollow","hover","bodyData","whatinput","timeout","hoverDelay","hoverPane","_addBodyHandler","DropdownMenu","subs","verticalClass","rightClass","changed","parClass","handleClickFn","hasSub","hasClicked","clickOpen","stopImmediatePropagation","closeOnClickInside","disableHoverOnTouch","disableHover","autoclose","closingTime","isTab","nextSibling","prevSibling","openSub","closeSub","_isVertical","_isRtl","_removeBodyHandler","isItself","$sibs","oldClass","$parentLi","$toClose","somethingToClose","$activeItem","Equalizer","eqId","$watched","hasNested","isNested","isOn","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","imgs","tooSmall","equalizeOn","_checkMQ","_reflow","_pauseEvents","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","heights","len","offsetHeight","lastElTopOffset","groups","group","elOffsetTop","j","ln","groupsILength","lenJ","Interchange","rules","currentPath","_parseOptions","_addBreakpoints","_generateRules","rule","path","types","SPECIAL_QUERIES","rulesList","nodeName","response","html","SmoothScroll","_linkClickListener","_handleLinkClick","arrival","_inTransition","scrollToLoc","loc","$loc","round","threshold","Magellan","calcPoints","$targets","$links","$active","points","winHeight","innerHeight","clientHeight","docHeight","scrollHeight","$tar","pt","targetPoint","deepLinking","_updateActive","onLoadListener","_deepLinkScroll","newScrollPos","isScrollingUp","activeIdx","visibleLinks","$oldActive","activeHash","isNewActive","isNewHash","pathname","search","OffCanvas","contentClasses","base","reveal","$lastTrigger","$triggers","nested","$sticky","isInCanvas","contentId","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","insertAfter","revealOnRegExp","revealClass","revealOnClass","isRevealed","revealOn","_setMQChecker","transitionTime","contentScroll","inCanvasFor","inCanvasOn","_checkInCanvas","_removeContentClasses","_handleKeyboard","hasReveal","_","absoluteTopVal","stickyData","_addContentClasses","lastY","pageY","delta","_canScroll","allowUp","allowDown","forceTo","scrollTo","_stopScrolling","_recordScrollable","_preventDefaultAtEdges","_scrollboxTouchMoved","canvasFocus","_fixStickyElements","_unfixStickyElements","Orbit","_reset","containerClass","$slides","slideClass","$images","initActive","useMUI","_prepareForOrbit","bullets","_loadBullets","autoPlay","geoSync","accessible","$bullets","boxOfBullets","timerDelay","changeSlide","_setWrapperHeight","temp","counter","pauseOnHover","navButtons","$controls","nextClass","prevClass","$slide","_updateBullets","isLTR","chosenSlide","$curSlide","$firstSlide","$lastSlide","dirIn","dirOut","$newSlide","infiniteWrap","$oldBullet","$othersBullets","$newBullet","activeStateDescriptor","spans","spanCountInOthersBullets","toArray","every","count","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","MenuPlugins","dropdown","cssClass","drilldown","accordion","ResponsiveMenu","currentMq","currentPlugin","rulesTree","ruleSize","rulePlugin","isEmptyObject","_checkMediaQueries","matchedMq","destroy","ResponsiveToggle","targetID","$targetMenu","$toggler","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","Reveal","cached","mq","fullScreen","_makeOverlay","additionalOverlayClasses","outerWidth","outerHeight","margin","_updatePosition","_handleState","$activeAnchor","activeElement","multipleOpened","_disableScroll","afterAnimation","_addGlobalClasses","focusableElements","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","closeOnEsc","finishUp","hideDelay","_removeGlobalClasses","_enableScroll","resetOnClose","urlWithoutHash","title","Slider","inputs","handles","$handle","$input","$fill","vertical","disabled","disabledClass","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_setHandlePos","pctOfBar","percent","positionValueFunction","_logTransform","_powTransform","toFixed","baseLog","nonLinearBase","pow","$hndl","isDbl","h2Val","step","h1Val","vert","hOrW","lOrT","handleDim","elemDim","_pctOfBar","pxToMove","movement","decimal","_setValues","isLeftHndl","dim","handlePct","handlePos","initialStart","moveTime","changedDelay","initVal","initialEnd","direction","eventOffset","barDim","windowScroll","scrollLeft","elemOffset","eventFromBar","barXY","offsetPct","_value","_adjustValue","firstHndlPos","absPosition","secndHndlPos","div","previousVal","nextVal","_eventsForHandle","curHandle","handleChangeEvent","_handleEvent","clickSelect","draggable","_$handle","oldValue","newValue","decrease","increase","decreaseFast","increaseFast","invertVertical","frac","num","clickPos","log","Sticky","$container","wasWrapped","container","stickyClass","scrollCount","checkEvery","isStuck","containerHeight","elemHeight","_parsePoints","_setSizes","scroll","_calc","_removeSticky","topPoint","reverse","topAnchor","btm","btmAnchor","pts","breaks","place","canStick","_eventsHandler","_pauseListeners","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","bottom","stickyOn","newElemWidth","comp","pdngl","pdngr","dynamicHeight","newContainerHeight","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","em","fontSize","Tabs","$tabTitles","linkClass","linkActiveClass","matchHeight","_setHeight","anchorNoHash","selectTab","_collapse","_addKeyHandler","_addClickHandler","_setHeightMqHandler","_handleTabChange","wrapOnKeys","historyHandled","activeCollapse","$oldTab","$tabLink","$targetContent","_collapseTab","panelActiveClass","$targetAnchor","$activeTab","idStr","hashIdStr","panelClass","panel","Toggler","toggler","$trigger","controls","containsId","_updateARIA","undefined","Tooltip","isClick","tipText","template","_buildTemplate","allowHtml","triggerClass","elementClassName","SVGElement","baseVal","tooltipWidth","tooltipHeight","templateClasses","tooltipClass","$template","showOn","fadeIn","fadeInDuration","fadeOutDuration","isFocus","disableForTouch","touchCloseText","tabs","ResponsiveAccordionTabs","storezfData","currentRule","_getAllOptions","allOptions","dummyPlugin","tmpPlugin","keyKey","objObj","_changedZfMediaQueryHandler","_handleMarkup","toSet","fromString","$panels","tabsTitle","tabsPanel","$liHeads","$liHeadsA","display","visibility","$tabsContent","$placeholder","tempValue","CoreUtils"],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"foundation.cjs.js","sources":["../../js/foundation.core.utils.js","../../js/foundation.util.mediaQuery.js","../../js/foundation.core.js","../../js/foundation.util.box.js","../../js/foundation.util.imageLoader.js","../../js/foundation.util.keyboard.js","../../js/foundation.util.motion.js","../../js/foundation.util.nest.js","../../js/foundation.util.timer.js","../../js/foundation.util.touch.js","../../js/foundation.util.triggers.js","../../js/foundation.core.plugin.js","../../js/foundation.abide.js","../../js/foundation.accordion.js","../../js/foundation.accordionMenu.js","../../js/foundation.drilldown.js","../../js/foundation.positionable.js","../../js/foundation.dropdown.js","../../js/foundation.dropdownMenu.js","../../js/foundation.equalizer.js","../../js/foundation.interchange.js","../../js/foundation.smoothScroll.js","../../js/foundation.magellan.js","../../js/foundation.offcanvas.js","../../js/foundation.orbit.js","../../js/foundation.responsiveMenu.js","../../js/foundation.responsiveToggle.js","../../js/foundation.reveal.js","../../js/foundation.slider.js","../../js/foundation.sticky.js","../../js/foundation.tabs.js","../../js/foundation.toggler.js","../../js/foundation.tooltip.js","../../js/foundation.responsiveAccordionTabs.js","../../js/entries/foundation.js"],"sourcesContent":["import $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n /**\n * Returns a boolean for RTL support\n */\nfunction rtl() {\n return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length = 6, namespace){\n let str = '';\n const chars = '0123456789abcdefghijklmnopqrstuvwxyz';\n const charsLength = chars.length;\n for (let i = 0; i < length; i++) {\n str += chars[Math.floor(Math.random() * charsLength)];\n }\n return namespace ? `${str}-${namespace}` : str;\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n var transitions = {\n 'transition': 'transitionend',\n 'WebkitTransition': 'webkitTransitionEnd',\n 'MozTransition': 'transitionend',\n 'OTransition': 'otransitionend'\n };\n var elem = document.createElement('div'),\n end;\n\n for (let transition in transitions){\n if (typeof elem.style[transition] !== 'undefined'){\n end = transitions[transition];\n }\n }\n if (end) {\n return end;\n } else {\n setTimeout(function(){\n $elem.triggerHandler('transitionend', [$elem]);\n }, 1);\n return 'transitionend';\n }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n const didLoad = document.readyState === 'complete';\n const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n const cb = () => $elem.triggerHandler(eventType);\n\n if ($elem) {\n if (handler) $elem.one(eventType, handler);\n\n if (didLoad)\n setTimeout(cb);\n else\n $(window).one('load', cb);\n }\n\n return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n * (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n * outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n return function leaveEventHandler(eLeave, ...rest) {\n const callback = handler.bind(this, eLeave, ...rest);\n\n // The mouse left: call the given callback if the mouse entered elsewhere\n if (eLeave.relatedTarget !== null) {\n return callback();\n }\n\n // Otherwise, check if the mouse actually left the window.\n // In firefox if the user switched between windows, the window sill have the focus by the time\n // the event is triggered. We have to debounce the event to test this case.\n setTimeout(function leaveEventDebouncer() {\n if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n return callback();\n }\n\n // Otherwise, wait for the mouse to reeapear outside of the element,\n if (!ignoreReappear) {\n $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n // Fill where the mouse finally entered.\n eLeave.relatedTarget = eReenter.target;\n callback();\n }\n });\n }\n\n }, 0);\n };\n}\n\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","import $ from 'jquery';\n\n// Default set of media queries\n// const defaultQueries = {\n// 'default' : 'only screen',\n// landscape : 'only screen and (orientation: landscape)',\n// portrait : 'only screen and (orientation: portrait)',\n// retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n// 'only screen and (min--moz-device-pixel-ratio: 2),' +\n// 'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n// 'only screen and (min-device-pixel-ratio: 2),' +\n// 'only screen and (min-resolution: 192dpi),' +\n// 'only screen and (min-resolution: 2dppx)'\n// };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright © 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n \"use strict\";\n\n // For browsers that support matchMedium api such as IE 9 and webkit\n var styleMedia = (window.styleMedia || window.media);\n\n // For those that don't support matchMedium\n if (!styleMedia) {\n var style = document.createElement('style'),\n script = document.getElementsByTagName('script')[0],\n info = null;\n\n style.type = 'text/css';\n style.id = 'matchmediajs-test';\n\n if (!script) {\n document.head.appendChild(style);\n } else {\n script.parentNode.insertBefore(style, script);\n }\n\n // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n styleMedia = {\n matchMedium: function (media) {\n var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n if (style.styleSheet) {\n style.styleSheet.cssText = text;\n } else {\n style.textContent = text;\n }\n\n // Test if media query is true or false\n return info.width === '1px';\n }\n };\n }\n\n return function(media) {\n return {\n matches: styleMedia.matchMedium(media || 'all'),\n media: media || 'all'\n };\n };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n queries: [],\n\n current: '',\n\n /**\n * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n * @function\n * @private\n */\n _init() {\n\n // make sure the initialization is only done once when calling _init() several times\n if (this.isInitialized === true) {\n return this;\n } else {\n this.isInitialized = true;\n }\n\n var self = this;\n var $meta = $('meta.foundation-mq');\n if(!$meta.length){\n $('').appendTo(document.head);\n }\n\n var extractedStyles = $('.foundation-mq').css('font-family');\n var namedQueries;\n\n namedQueries = parseStyleToObject(extractedStyles);\n\n self.queries = []; // reset\n\n for (var key in namedQueries) {\n if(namedQueries.hasOwnProperty(key)) {\n self.queries.push({\n name: key,\n value: `only screen and (min-width: ${namedQueries[key]})`\n });\n }\n }\n\n this.current = this._getCurrentSize();\n\n this._watcher();\n },\n\n /**\n * Reinitializes the media query helper.\n * Useful if your CSS breakpoint configuration has just been loaded or has changed since the initialization.\n * @function\n * @private\n */\n _reInit() {\n this.isInitialized = false;\n this._init();\n },\n\n /**\n * Checks if the screen is at least as wide as a breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint to check.\n * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n */\n atLeast(size) {\n var query = this.get(size);\n\n if (query) {\n return window.matchMedia(query).matches;\n }\n\n return false;\n },\n\n /**\n * Checks if the screen is within the given breakpoint.\n * If smaller than the breakpoint of larger than its upper limit it returns false.\n * @function\n * @param {String} size - Name of the breakpoint to check.\n * @returns {Boolean} `true` if the breakpoint matches, `false` otherwise.\n */\n only(size) {\n return size === this._getCurrentSize();\n },\n\n /**\n * Checks if the screen is within a breakpoint or smaller.\n * @function\n * @param {String} size - Name of the breakpoint to check.\n * @returns {Boolean} `true` if the breakpoint matches, `false` if it's larger.\n */\n upTo(size) {\n const nextSize = this.next(size);\n\n // If the next breakpoint does not match, the screen is smaller than\n // the upper limit of this breakpoint.\n if (nextSize) {\n return !this.atLeast(nextSize);\n }\n\n // If there is no next breakpoint, the \"size\" breakpoint does not have\n // an upper limit and the screen will always be within it or smaller.\n return true;\n },\n\n /**\n * Checks if the screen matches to a breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n */\n is(size) {\n const parts = size.trim().split(' ').filter(p => !!p.length);\n const [bpSize, bpModifier = ''] = parts;\n\n // Only the breakpont\n if (bpModifier === 'only') {\n return this.only(bpSize);\n }\n // At least the breakpoint (included)\n if (!bpModifier || bpModifier === 'up') {\n return this.atLeast(bpSize);\n }\n // Up to the breakpoint (included)\n if (bpModifier === 'down') {\n return this.upTo(bpSize);\n }\n\n throw new Error(`\n Invalid breakpoint passed to MediaQuery.is().\n Expected a breakpoint name formatted like \" \", got \"${size}\".\n `);\n },\n\n /**\n * Gets the media query of a breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint to get.\n * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n */\n get(size) {\n for (var i in this.queries) {\n if(this.queries.hasOwnProperty(i)) {\n var query = this.queries[i];\n if (size === query.name) return query.value;\n }\n }\n\n return null;\n },\n\n /**\n * Get the breakpoint following the given breakpoint.\n * @function\n * @param {String} size - Name of the breakpoint.\n * @returns {String|null} - The name of the following breakpoint, or `null` if the passed breakpoint was the last one.\n */\n next(size) {\n const queryIndex = this.queries.findIndex((q) => this._getQueryName(q) === size);\n if (queryIndex === -1) {\n throw new Error(`\n Unknown breakpoint \"${size}\" passed to MediaQuery.next().\n Ensure it is present in your Sass \"$breakpoints\" setting.\n `);\n }\n\n const nextQuery = this.queries[queryIndex + 1];\n return nextQuery ? nextQuery.name : null;\n },\n\n /**\n * Returns the name of the breakpoint related to the given value.\n * @function\n * @private\n * @param {String|Object} value - Breakpoint name or query object.\n * @returns {String} Name of the breakpoint.\n */\n _getQueryName(value) {\n if (typeof value === 'string')\n return value;\n if (typeof value === 'object')\n return value.name;\n throw new TypeError(`\n Invalid value passed to MediaQuery._getQueryName().\n Expected a breakpoint name (String) or a breakpoint query (Object), got \"${value}\" (${typeof value})\n `);\n },\n\n /**\n * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n * @function\n * @private\n * @returns {String} Name of the current breakpoint.\n */\n _getCurrentSize() {\n var matched;\n\n for (var i = 0; i < this.queries.length; i++) {\n var query = this.queries[i];\n\n if (window.matchMedia(query.value).matches) {\n matched = query;\n }\n }\n\n return matched && this._getQueryName(matched);\n },\n\n /**\n * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n * @function\n * @private\n */\n _watcher() {\n $(window).on('resize.zf.trigger', () => {\n var newSize = this._getCurrentSize(), currentSize = this.current;\n\n if (newSize !== currentSize) {\n // Change the current media query\n this.current = newSize;\n\n // Broadcast the media query change on the window\n $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n }\n });\n }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n var styleObject = {};\n\n if (typeof str !== 'string') {\n return styleObject;\n }\n\n str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n if (!str) {\n return styleObject;\n }\n\n styleObject = str.split('&').reduce(function(ret, param) {\n var parts = param.replace(/\\+/g, ' ').split('=');\n var key = parts[0];\n var val = parts[1];\n key = decodeURIComponent(key);\n\n // missing `=` should be `null`:\n // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n if (!ret.hasOwnProperty(key)) {\n ret[key] = val;\n } else if (Array.isArray(ret[key])) {\n ret[key].push(val);\n } else {\n ret[key] = [ret[key], val];\n }\n return ret;\n }, {});\n\n return styleObject;\n}\n\nexport {MediaQuery};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.8.0';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n version: FOUNDATION_VERSION,\n\n /**\n * Stores initialized plugins.\n */\n _plugins: {},\n\n /**\n * Stores generated unique ids for plugin instances\n */\n _uuids: [],\n\n /**\n * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n * @param {Object} plugin - The constructor of the plugin.\n */\n plugin: function(plugin, name) {\n // Object key to use when adding to global Foundation object\n // Examples: Foundation.Reveal, Foundation.OffCanvas\n var className = (name || functionName(plugin));\n // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n // Examples: data-reveal, data-off-canvas\n var attrName = hyphenate(className);\n\n // Add to the Foundation object and the plugins list (for reflowing)\n this._plugins[attrName] = this[className] = plugin;\n },\n /**\n * @function\n * Populates the _uuids array with pointers to each individual plugin instance.\n * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n * Also fires the initialization event for each plugin, consolidating repetitive code.\n * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n * @param {String} name - the name of the plugin, passed as a camelCased string.\n * @fires Plugin#init\n */\n registerPlugin: function(plugin, name){\n var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n plugin.uuid = GetYoDigits(6, pluginName);\n\n if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n /**\n * Fires when the plugin has initialized.\n * @event Plugin#init\n */\n plugin.$element.trigger(`init.zf.${pluginName}`);\n\n this._uuids.push(plugin.uuid);\n\n return;\n },\n /**\n * @function\n * Removes the plugins uuid from the _uuids array.\n * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n * Also fires the destroyed event for the plugin, consolidating repetitive code.\n * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n * @fires Plugin#destroyed\n */\n unregisterPlugin: function(plugin){\n var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n /**\n * Fires when the plugin has been destroyed.\n * @event Plugin#destroyed\n */\n .trigger(`destroyed.zf.${pluginName}`);\n for(var prop in plugin){\n if(typeof plugin[prop] === 'function'){\n plugin[prop] = null; //clean up script to prep for garbage collection.\n }\n }\n return;\n },\n\n /**\n * @function\n * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n * @default If no argument is passed, reflow all currently active plugins.\n */\n reInit: function(plugins){\n var isJQ = plugins instanceof $;\n try{\n if(isJQ){\n plugins.each(function(){\n $(this).data('zfPlugin')._init();\n });\n }else{\n var type = typeof plugins,\n _this = this,\n fns = {\n 'object': function(plgs){\n plgs.forEach(function(p){\n p = hyphenate(p);\n $('[data-'+ p +']').foundation('_init');\n });\n },\n 'string': function(){\n plugins = hyphenate(plugins);\n $('[data-'+ plugins +']').foundation('_init');\n },\n 'undefined': function(){\n this.object(Object.keys(_this._plugins));\n }\n };\n fns[type](plugins);\n }\n }catch(err){\n console.error(err);\n }finally{\n return plugins;\n }\n },\n\n /**\n * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n */\n reflow: function(elem, plugins) {\n\n // If plugins is undefined, just grab everything\n if (typeof plugins === 'undefined') {\n plugins = Object.keys(this._plugins);\n }\n // If plugins is a string, convert it to an array with one item\n else if (typeof plugins === 'string') {\n plugins = [plugins];\n }\n\n var _this = this;\n\n // Iterate through each plugin\n $.each(plugins, function(i, name) {\n // Get the current plugin\n var plugin = _this._plugins[name];\n\n // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']').filter(function () {\n return typeof $(this).data(\"zfPlugin\") === 'undefined';\n });\n\n // For each plugin found, initialize it\n $elem.each(function() {\n var $el = $(this),\n opts = { reflow: true };\n\n if($el.attr('data-options')){\n $el.attr('data-options').split(';').forEach(function(option){\n var opt = option.split(':').map(function(el){ return el.trim(); });\n if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n });\n }\n try{\n $el.data('zfPlugin', new plugin($(this), opts));\n }catch(er){\n console.error(er);\n }finally{\n return;\n }\n });\n });\n },\n getFnName: functionName,\n\n addToJquery: function() {\n // TODO: consider not making this a jQuery function\n // TODO: need way to reflow vs. re-initialize\n /**\n * The Foundation jQuery method.\n * @param {String|Array} method - An action to perform on the current jQuery object.\n */\n var foundation = function(method) {\n var type = typeof method,\n $noJS = $('.no-js');\n\n if($noJS.length){\n $noJS.removeClass('no-js');\n }\n\n if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n MediaQuery._init();\n Foundation.reflow(this);\n }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n if(this.length === 1){//if there's only one, call it directly.\n plugClass[method].apply(plugClass, args);\n }else{\n this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n plugClass[method].apply($(el).data('zfPlugin'), args);\n });\n }\n }else{//error for no class or no method\n throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n }\n }else{//error for invalid argument type\n throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n }\n return this;\n };\n $.fn.foundation = foundation;\n return $;\n }\n};\n\nFoundation.util = {\n /**\n * Function for applying a debounce effect to a function call.\n * @function\n * @param {Function} func - Function to be called at end of timeout.\n * @param {Number} delay - Time in ms to delay the call of `func`.\n * @returns function\n */\n throttle: function (func, delay) {\n var timer = null;\n\n return function () {\n var context = this, args = arguments;\n\n if (timer === null) {\n timer = setTimeout(function () {\n func.apply(context, args);\n timer = null;\n }, delay);\n }\n };\n }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n if (!Date.now || !window.Date.now)\n window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n var vendors = ['webkit', 'moz'];\n for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n var vp = vendors[i];\n window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n || window[vp+'CancelRequestAnimationFrame']);\n }\n if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n var lastTime = 0;\n window.requestAnimationFrame = function(callback) {\n var now = Date.now();\n var nextTime = Math.max(lastTime + 16, now);\n return setTimeout(function() { callback(lastTime = nextTime); },\n nextTime - now);\n };\n window.cancelAnimationFrame = clearTimeout;\n }\n /**\n * Polyfill for performance.now, required by rAF\n */\n if(!window.performance || !window.performance.now){\n window.performance = {\n start: Date.now(),\n now: function(){ return Date.now() - this.start; }\n };\n }\n})();\nif (!Function.prototype.bind) {\n /* eslint-disable no-extend-native */\n Function.prototype.bind = function(oThis) {\n if (typeof this !== 'function') {\n // closest thing possible to the ECMAScript 5\n // internal IsCallable function\n throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n }\n\n var aArgs = Array.prototype.slice.call(arguments, 1),\n fToBind = this,\n fNOP = function() {},\n fBound = function() {\n return fToBind.apply(this instanceof fNOP\n ? this\n : oThis,\n aArgs.concat(Array.prototype.slice.call(arguments)));\n };\n\n if (this.prototype) {\n // native functions don't have a prototype\n fNOP.prototype = this.prototype;\n }\n fBound.prototype = new fNOP();\n\n return fBound;\n };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n if (typeof Function.prototype.name === 'undefined') {\n var funcNameRegex = /function\\s([^(]{1,})\\(/;\n var results = (funcNameRegex).exec((fn).toString());\n return (results && results.length > 1) ? results[1].trim() : \"\";\n }\n else if (typeof fn.prototype === 'undefined') {\n return fn.constructor.name;\n }\n else {\n return fn.prototype.constructor.name;\n }\n}\nfunction parseValue(str){\n if ('true' === str) return true;\n else if ('false' === str) return false;\n else if (!isNaN(str * 1)) return parseFloat(str);\n return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","var Box = {\n ImNotTouchingYou: ImNotTouchingYou,\n OverlapArea: OverlapArea,\n GetDimensions: GetDimensions,\n GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n}\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n var eleDims = GetDimensions(element),\n topOver, bottomOver, leftOver, rightOver;\n if (parent) {\n var parDims = GetDimensions(parent);\n\n bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n topOver = eleDims.offset.top - parDims.offset.top;\n leftOver = eleDims.offset.left - parDims.offset.left;\n rightOver = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n }\n else {\n bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n topOver = eleDims.offset.top - eleDims.windowDims.offset.top;\n leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;\n rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n }\n\n bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n topOver = Math.min(topOver, 0);\n leftOver = Math.min(leftOver, 0);\n rightOver = Math.min(rightOver, 0);\n\n if (lrOnly) {\n return leftOver + rightOver;\n }\n if (tbOnly) {\n return topOver + bottomOver;\n }\n\n // use sum of squares b/c we care about overlap area.\n return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n elem = elem.length ? elem[0] : elem;\n\n if (elem === window || elem === document) {\n throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n }\n\n var rect = elem.getBoundingClientRect(),\n parRect = elem.parentNode.getBoundingClientRect(),\n winRect = document.body.getBoundingClientRect(),\n winY = window.pageYOffset,\n winX = window.pageXOffset;\n\n return {\n width: rect.width,\n height: rect.height,\n offset: {\n top: rect.top + winY,\n left: rect.left + winX\n },\n parentDims: {\n width: parRect.width,\n height: parRect.height,\n offset: {\n top: parRect.top + winY,\n left: parRect.left + winX\n }\n },\n windowDims: {\n width: winRect.width,\n height: winRect.height,\n offset: {\n top: winY,\n left: winX\n }\n }\n }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n var $eleDims = GetDimensions(element),\n $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n var topVal, leftVal;\n\n if ($anchorDims !== null) {\n // set position related attribute\n switch (position) {\n case 'top':\n topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n break;\n case 'bottom':\n topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n break;\n case 'left':\n leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n break;\n case 'right':\n leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n break;\n }\n\n // set alignment related attribute\n switch (position) {\n case 'top':\n case 'bottom':\n switch (alignment) {\n case 'left':\n leftVal = $anchorDims.offset.left + hOffset;\n break;\n case 'right':\n leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n break;\n case 'center':\n leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n break;\n }\n break;\n case 'right':\n case 'left':\n switch (alignment) {\n case 'bottom':\n topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n break;\n case 'top':\n topVal = $anchorDims.offset.top + vOffset\n break;\n case 'center':\n topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n break;\n }\n break;\n }\n }\n\n return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n","import $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n var unloaded = images.length;\n\n if (unloaded === 0) {\n callback();\n }\n\n images.each(function(){\n // Check if image is loaded\n if (this.complete && typeof this.naturalWidth !== 'undefined') {\n singleImageLoaded();\n }\n else {\n // If the above check failed, simulate loading on detached element.\n var image = new Image();\n // Still count image as loaded if it finalizes with an error.\n var events = \"load.zf.images error.zf.images\";\n $(image).one(events, function me(){\n // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n $(this).off(events, me);\n singleImageLoaded();\n });\n image.src = $(this).attr('src');\n }\n });\n\n function singleImageLoaded() {\n unloaded--;\n if (unloaded === 0) {\n callback();\n }\n }\n}\n\nexport { onImagesLoaded };\n","/*******************************************\n * *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n * *\n ******************************************/\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n 9: 'TAB',\n 13: 'ENTER',\n 27: 'ESCAPE',\n 32: 'SPACE',\n 35: 'END',\n 36: 'HOME',\n 37: 'ARROW_LEFT',\n 38: 'ARROW_UP',\n 39: 'ARROW_RIGHT',\n 40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n if(!$element) {return false; }\n return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n return true;\n })\n .sort( function( a, b ) {\n if ($(a).attr('tabindex') === $(b).attr('tabindex')) {\n return 0;\n }\n let aTabIndex = parseInt($(a).attr('tabindex'), 10),\n bTabIndex = parseInt($(b).attr('tabindex'), 10);\n // Undefined is treated the same as 0\n if (typeof $(a).attr('tabindex') === 'undefined' && bTabIndex > 0) {\n return 1;\n }\n if (typeof $(b).attr('tabindex') === 'undefined' && aTabIndex > 0) {\n return -1;\n }\n if (aTabIndex === 0 && bTabIndex > 0) {\n return 1;\n }\n if (bTabIndex === 0 && aTabIndex > 0) {\n return -1;\n }\n if (aTabIndex < bTabIndex) {\n return -1;\n }\n if (aTabIndex > bTabIndex) {\n return 1;\n }\n });\n}\n\nfunction parseKey(event) {\n var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n key = key.replace(/\\W+/, '');\n\n if (event.shiftKey) key = `SHIFT_${key}`;\n if (event.ctrlKey) key = `CTRL_${key}`;\n if (event.altKey) key = `ALT_${key}`;\n\n // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n key = key.replace(/_$/, '');\n\n return key;\n}\n\nvar Keyboard = {\n keys: getKeyCodes(keyCodes),\n\n /**\n * Parses the (keyboard) event and returns a String that represents its key\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n * @param {Event} event - the event generated by the event handler\n * @return String key - String that represents the key pressed\n */\n parseKey: parseKey,\n\n /**\n * Handles the given (keyboard) event\n * @param {Event} event - the event generated by the event handler\n * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n * @param {Objects} functions - collection of functions that are to be executed\n */\n handleKey(event, component, functions) {\n var commandList = commands[component],\n keyCode = this.parseKey(event),\n cmds,\n command,\n fn;\n\n if (!commandList) return console.warn('Component not defined!');\n\n // Ignore the event if it was already handled\n if (event.zfIsKeyHandled === true) return;\n\n // This component does not differentiate between ltr and rtl\n if (typeof commandList.ltr === 'undefined') {\n cmds = commandList; // use plain list\n } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n }\n command = cmds[keyCode];\n\n fn = functions[command];\n // Execute the handler if found\n if (fn && typeof fn === 'function') {\n var returnValue = fn.apply();\n\n // Mark the event as \"handled\" to prevent future handlings\n event.zfIsKeyHandled = true;\n\n // Execute function when event was handled\n if (functions.handled || typeof functions.handled === 'function') {\n functions.handled(returnValue);\n }\n } else {\n // Execute function when event was not handled\n if (functions.unhandled || typeof functions.unhandled === 'function') {\n functions.unhandled();\n }\n }\n },\n\n /**\n * Finds all focusable elements within the given `$element`\n * @param {jQuery} $element - jQuery object to search within\n * @return {jQuery} $focusable - all focusable elements within `$element`\n */\n\n findFocusable: findFocusable,\n\n /**\n * Returns the component name name\n * @param {Object} component - Foundation component, e.g. Slider or Reveal\n * @return String componentName\n */\n\n register(componentName, cmds) {\n commands[componentName] = cmds;\n },\n\n\n // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n //\n /**\n * Traps the focus in the given element.\n * @param {jQuery} $element jQuery object to trap the foucs into.\n */\n trapFocus($element) {\n var $focusable = findFocusable($element),\n $firstFocusable = $focusable.eq(0),\n $lastFocusable = $focusable.eq(-1);\n\n $element.on('keydown.zf.trapfocus', function(event) {\n if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n event.preventDefault();\n $firstFocusable.focus();\n }\n else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n event.preventDefault();\n $lastFocusable.focus();\n }\n });\n },\n /**\n * Releases the trapped focus from the given element.\n * @param {jQuery} $element jQuery object to release the focus for.\n */\n releaseFocus($element) {\n $element.off('keydown.zf.trapfocus');\n }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n var k = {};\n for (var kc in kcs) {\n if (kcs.hasOwnProperty(kc)) k[kcs[kc]] = kcs[kc];\n }\n return k;\n}\n\nexport {Keyboard};\n","import $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n animateIn: function(element, animation, cb) {\n animate(true, element, animation, cb);\n },\n\n animateOut: function(element, animation, cb) {\n animate(false, element, animation, cb);\n }\n}\n\nfunction Move(duration, elem, fn){\n var anim, prog, start = null;\n\n if (duration === 0) {\n fn.apply(elem);\n elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n return;\n }\n\n function move(ts){\n if(!start) start = ts;\n prog = ts - start;\n fn.apply(elem);\n\n if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n else{\n window.cancelAnimationFrame(anim);\n elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n }\n }\n anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n element = $(element).eq(0);\n\n if (!element.length) return;\n\n var initClass = isIn ? initClasses[0] : initClasses[1];\n var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n // Set up the animation\n reset();\n\n element\n .addClass(animation)\n .css('transition', 'none');\n\n requestAnimationFrame(() => {\n element.addClass(initClass);\n if (isIn) element.show();\n });\n\n // Start the animation\n requestAnimationFrame(() => {\n // will trigger the browser to synchronously calculate the style and layout\n // also called reflow or layout thrashing\n // see https://gist.github.com/paulirish/5d52fb081b3570c81e3a\n element[0].offsetWidth;\n element\n .css('transition', '')\n .addClass(activeClass);\n });\n\n // Clean up the animation when it finishes\n element.one(transitionend(element), finish);\n\n // Hides the element (for out animations), resets the element, and runs a callback\n function finish() {\n if (!isIn) element.hide();\n reset();\n if (cb) cb.apply(element);\n }\n\n // Resets transitions and removes motion-specific classes\n function reset() {\n element[0].style.transitionDuration = 0;\n element.removeClass(`${initClass} ${activeClass} ${animation}`);\n }\n}\n\nexport { Move, Motion };\n\n","import $ from 'jquery';\n\nconst Nest = {\n Feather(menu, type = 'zf') {\n menu.attr('role', 'menubar');\n menu.find('a').attr({'role': 'menuitem'});\n\n var items = menu.find('li').attr({'role': 'none'}),\n subMenuClass = `is-${type}-submenu`,\n subItemClass = `${subMenuClass}-item`,\n hasSubClass = `is-${type}-submenu-parent`,\n applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n items.each(function() {\n var $item = $(this),\n $sub = $item.children('ul');\n\n if ($sub.length) {\n $item.addClass(hasSubClass);\n if(applyAria) {\n const firstItem = $item.children('a:first');\n firstItem.attr({\n 'aria-haspopup': true,\n 'aria-label': firstItem.attr('aria-label') || firstItem.text()\n });\n // Note: Drilldowns behave differently in how they hide, and so need\n // additional attributes. We should look if this possibly over-generalized\n // utility (Nest) is appropriate when we rework menus in 6.4\n if(type === 'drilldown') {\n $item.attr({'aria-expanded': false});\n }\n }\n $sub\n .addClass(`submenu ${subMenuClass}`)\n .attr({\n 'data-submenu': '',\n 'role': 'menubar'\n });\n if(type === 'drilldown') {\n $sub.attr({'aria-hidden': true});\n }\n }\n\n if ($item.parent('[data-submenu]').length) {\n $item.addClass(`is-submenu-item ${subItemClass}`);\n }\n });\n\n return;\n },\n\n Burn(menu, type) {\n var //items = menu.find('li'),\n subMenuClass = `is-${type}-submenu`,\n subItemClass = `${subMenuClass}-item`,\n hasSubClass = `is-${type}-submenu-parent`;\n\n menu\n .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n .removeAttr('data-submenu').css('display', '');\n\n }\n}\n\nexport {Nest};\n","function Timer(elem, options, cb) {\n var _this = this,\n duration = options.duration,//options is an object for easily adding features later.\n nameSpace = Object.keys(elem.data())[0] || 'timer',\n remain = -1,\n start,\n timer;\n\n this.isPaused = false;\n\n this.restart = function() {\n remain = -1;\n clearTimeout(timer);\n this.start();\n }\n\n this.start = function() {\n this.isPaused = false;\n // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n clearTimeout(timer);\n remain = remain <= 0 ? duration : remain;\n elem.data('paused', false);\n start = Date.now();\n timer = setTimeout(function(){\n if(options.infinite){\n _this.restart();//rerun the timer.\n }\n if (cb && typeof cb === 'function') { cb(); }\n }, remain);\n elem.trigger(`timerstart.zf.${nameSpace}`);\n }\n\n this.pause = function() {\n this.isPaused = true;\n //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n clearTimeout(timer);\n elem.data('paused', true);\n var end = Date.now();\n remain = remain - (end - start);\n elem.trigger(`timerpaused.zf.${nameSpace}`);\n }\n}\n\nexport {Timer};\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n startTime,\n elapsedTime,\n startEvent,\n isMoving = false,\n didMoved = false;\n\nfunction onTouchEnd(e) {\n this.removeEventListener('touchmove', onTouchMove);\n this.removeEventListener('touchend', onTouchEnd);\n\n // If the touch did not move, consider it as a \"tap\"\n if (!didMoved) {\n var tapEvent = $.Event('tap', startEvent || e);\n $(this).trigger(tapEvent);\n }\n\n startEvent = null;\n isMoving = false;\n didMoved = false;\n}\n\nfunction onTouchMove(e) {\n if (true === $.spotSwipe.preventDefault) { e.preventDefault(); }\n\n if(isMoving) {\n var x = e.touches[0].pageX;\n // var y = e.touches[0].pageY;\n var dx = startPosX - x;\n // var dy = startPosY - y;\n var dir;\n didMoved = true;\n elapsedTime = new Date().getTime() - startTime;\n if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n dir = dx > 0 ? 'left' : 'right';\n }\n // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n // dir = dy > 0 ? 'down' : 'up';\n // }\n if(dir) {\n e.preventDefault();\n onTouchEnd.apply(this, arguments);\n $(this)\n .trigger($.Event('swipe', Object.assign({}, e)), dir)\n .trigger($.Event(`swipe${dir}`, Object.assign({}, e)));\n }\n }\n\n}\n\nfunction onTouchStart(e) {\n\n if (e.touches.length === 1) {\n startPosX = e.touches[0].pageX;\n startEvent = e;\n isMoving = true;\n didMoved = false;\n startTime = new Date().getTime();\n this.addEventListener('touchmove', onTouchMove, { passive : true === $.spotSwipe.preventDefault });\n this.addEventListener('touchend', onTouchEnd, false);\n }\n}\n\nfunction init() {\n this.addEventListener && this.addEventListener('touchstart', onTouchStart, { passive : true });\n}\n\n// function teardown() {\n// this.removeEventListener('touchstart', onTouchStart);\n// }\n\nclass SpotSwipe {\n constructor() {\n this.version = '1.0.0';\n this.enabled = 'ontouchstart' in document.documentElement;\n this.preventDefault = false;\n this.moveThreshold = 75;\n this.timeThreshold = 200;\n this._init();\n }\n\n _init() {\n $.event.special.swipe = { setup: init };\n $.event.special.tap = { setup: init };\n\n $.each(['left', 'up', 'down', 'right'], function () {\n $.event.special[`swipe${this}`] = { setup: function(){\n $(this).on('swipe', $.noop);\n } };\n });\n }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and *\n * setupTouchHandler should be idempotent, *\n * because they directly replace functions & *\n * values, and do not add event handlers directly. *\n ****************************************************/\n\nTouch.setupSpotSwipe = function() {\n $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function() {\n $.fn.addTouch = function(){\n this.each(function(i, el){\n $(el).bind('touchstart touchmove touchend touchcancel', function(event) {\n //we pass the original event object because the jQuery event\n //object is normalized to w3c specs and does not provide the TouchList\n handleTouch(event);\n });\n });\n\n var handleTouch = function(event) {\n var touches = event.changedTouches,\n first = touches[0],\n eventTypes = {\n touchstart: 'mousedown',\n touchmove: 'mousemove',\n touchend: 'mouseup'\n },\n type = eventTypes[event.type],\n simulatedEvent\n ;\n\n if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n simulatedEvent = new window.MouseEvent(type, {\n 'bubbles': true,\n 'cancelable': true,\n 'screenX': first.screenX,\n 'screenY': first.screenY,\n 'clientX': first.clientX,\n 'clientY': first.clientY\n });\n } else {\n simulatedEvent = document.createEvent('MouseEvent');\n simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n }\n first.target.dispatchEvent(simulatedEvent);\n };\n };\n};\n\nTouch.init = function () {\n if(typeof($.spotSwipe) === 'undefined') {\n Touch.setupSpotSwipe($);\n Touch.setupTouchHandler($);\n }\n};\n\nexport {Touch};\n","import $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n for (var i=0; i < prefixes.length; i++) {\n if (`${prefixes[i]}MutationObserver` in window) {\n return window[`${prefixes[i]}MutationObserver`];\n }\n }\n return false;\n})();\n\nconst triggers = (el, type) => {\n el.data(type).split(' ').forEach(id => {\n $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n });\n};\n\nvar Triggers = {\n Listeners: {\n Basic: {},\n Global: {}\n },\n Initializers: {}\n}\n\nTriggers.Listeners.Basic = {\n openListener: function() {\n triggers($(this), 'open');\n },\n closeListener: function() {\n let id = $(this).data('close');\n if (id) {\n triggers($(this), 'close');\n }\n else {\n $(this).trigger('close.zf.trigger');\n }\n },\n toggleListener: function() {\n let id = $(this).data('toggle');\n if (id) {\n triggers($(this), 'toggle');\n } else {\n $(this).trigger('toggle.zf.trigger');\n }\n },\n closeableListener: function(e) {\n let animation = $(this).data('closable');\n\n // Only close the first closable element. See https://git.io/zf-7833\n e.stopPropagation();\n\n if(animation !== ''){\n Motion.animateOut($(this), animation, function() {\n $(this).trigger('closed.zf');\n });\n }else{\n $(this).fadeOut().trigger('closed.zf');\n }\n },\n toggleFocusListener: function() {\n let id = $(this).data('toggle-focus');\n $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global = {\n resizeListener: function($nodes) {\n if(!MutationObserver){//fallback for IE 9\n $nodes.each(function(){\n $(this).triggerHandler('resizeme.zf.trigger');\n });\n }\n //trigger all listening elements and signal a resize event\n $nodes.attr('data-events', \"resize\");\n },\n scrollListener: function($nodes) {\n if(!MutationObserver){//fallback for IE 9\n $nodes.each(function(){\n $(this).triggerHandler('scrollme.zf.trigger');\n });\n }\n //trigger all listening elements and signal a scroll event\n $nodes.attr('data-events', \"scroll\");\n },\n closeMeListener: function(e, pluginId){\n let plugin = e.namespace.split('.')[0];\n let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n plugins.each(function(){\n let _this = $(this);\n _this.triggerHandler('close.zf.trigger', [_this]);\n });\n }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n var yetiBoxes = $('[data-yeti-box]'),\n plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n if(pluginName){\n if(typeof pluginName === 'string'){\n plugNames.push(pluginName);\n }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n plugNames = plugNames.concat(pluginName);\n }else{\n console.error('Plugin names must be strings');\n }\n }\n if(yetiBoxes.length){\n let listeners = plugNames.map((name) => {\n return `closeme.zf.${name}`;\n }).join(' ');\n\n $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n let timer, args = Array.prototype.slice.call(arguments, 3);\n $(window).on(trigger, function() {\n if (timer) { clearTimeout(timer); }\n timer = setTimeout(function(){\n listener.apply(null, args);\n }, debounce || 10); //default time to emit scroll event\n });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n let $nodes = $('[data-resize]');\n if($nodes.length){\n debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n let $nodes = $('[data-scroll]');\n if($nodes.length){\n debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n if(!MutationObserver){ return false; }\n let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n //element callback\n var listeningElementsMutation = function (mutationRecordsList) {\n var $target = $(mutationRecordsList[0].target);\n\n //trigger the event handler for the element depending on type\n switch (mutationRecordsList[0].type) {\n case \"attributes\":\n if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n }\n if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n $target.triggerHandler('resizeme.zf.trigger', [$target]);\n }\n if (mutationRecordsList[0].attributeName === \"style\") {\n $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n }\n break;\n\n case \"childList\":\n $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n break;\n\n default:\n return false;\n //nothing\n }\n };\n\n if ($nodes.length) {\n //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n for (var i = 0; i <= $nodes.length - 1; i++) {\n var elementObserver = new MutationObserver(listeningElementsMutation);\n elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n }\n }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n let $document = $(document);\n\n Triggers.Initializers.addOpenListener($document);\n Triggers.Initializers.addCloseListener($document);\n Triggers.Initializers.addToggleListener($document);\n Triggers.Initializers.addCloseableListener($document);\n Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n let $document = $(document);\n Triggers.Initializers.addMutationEventsListener($document);\n Triggers.Initializers.addResizeListener(250);\n Triggers.Initializers.addScrollListener();\n Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function (__, Foundation) {\n onLoad($(window), function () {\n if ($.triggersInitialized !== true) {\n Triggers.Initializers.addSimpleListeners();\n Triggers.Initializers.addGlobalListeners();\n $.triggersInitialized = true;\n }\n });\n\n if(Foundation) {\n Foundation.Triggers = Triggers;\n // Legacy included to be backwards compatible for now.\n Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n }\n}\n\nexport {Triggers};\n","import { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n constructor(element, options) {\n this._setup(element, options);\n var pluginName = getPluginName(this);\n this.uuid = GetYoDigits(6, pluginName);\n\n if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n /**\n * Fires when the plugin has initialized.\n * @event Plugin#init\n */\n this.$element.trigger(`init.zf.${pluginName}`);\n }\n\n destroy() {\n this._destroy();\n var pluginName = getPluginName(this);\n this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n /**\n * Fires when the plugin has been destroyed.\n * @event Plugin#destroyed\n */\n .trigger(`destroyed.zf.${pluginName}`);\n for(var prop in this){\n if (this.hasOwnProperty(prop)) {\n this[prop] = null; //clean up script to prep for garbage collection.\n }\n }\n }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n return hyphenate(obj.className);\n}\n\nexport {Plugin};\n","import $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n /**\n * Creates a new instance of Abide.\n * @class\n * @name Abide\n * @fires Abide#init\n * @param {Object} element - jQuery object to add the trigger to.\n * @param {Object} options - Overrides to the default plugin settings.\n */\n _setup(element, options = {}) {\n this.$element = element;\n this.options = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n this.isEnabled = true;\n this.formnovalidate = null;\n\n this.className = 'Abide'; // ie9 back compat\n this._init();\n }\n\n /**\n * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n * @private\n */\n _init() {\n this.$inputs = $.merge( // Consider as input to validate:\n this.$element.find('input').not('[type=\"submit\"]'), // * all input fields expect submit\n this.$element.find('textarea, select') // * all textareas and select fields\n );\n this.$submits = this.$element.find('[type=\"submit\"]');\n const $globalErrors = this.$element.find('[data-abide-error]');\n\n // Add a11y attributes to all fields\n if (this.options.a11yAttributes) {\n this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n }\n\n this._events();\n }\n\n /**\n * Initializes events for Abide.\n * @private\n */\n _events() {\n this.$element.off('.abide')\n .on('reset.zf.abide', () => {\n this.resetForm();\n })\n .on('submit.zf.abide', () => {\n return this.validateForm();\n });\n\n this.$submits\n .off('click.zf.abide keydown.zf.abide')\n .on('click.zf.abide keydown.zf.abide', (e) => {\n if (!e.key || (e.key === ' ' || e.key === 'Enter')) {\n e.preventDefault();\n this.formnovalidate = e.target.getAttribute('formnovalidate') !== null;\n this.$element.submit();\n }\n });\n\n if (this.options.validateOn === 'fieldChange') {\n this.$inputs\n .off('change.zf.abide')\n .on('change.zf.abide', (e) => {\n this.validateInput($(e.target));\n });\n }\n\n if (this.options.liveValidate) {\n this.$inputs\n .off('input.zf.abide')\n .on('input.zf.abide', (e) => {\n this.validateInput($(e.target));\n });\n }\n\n if (this.options.validateOnBlur) {\n this.$inputs\n .off('blur.zf.abide')\n .on('blur.zf.abide', (e) => {\n this.validateInput($(e.target));\n });\n }\n }\n\n /**\n * Calls necessary functions to update Abide upon DOM change\n * @private\n */\n _reflow() {\n this._init();\n }\n\n /**\n * Checks whether the submitted form should be validated or not, consodering formnovalidate and isEnabled\n * @returns {Boolean}\n * @private\n */\n _validationIsDisabled() {\n if (this.isEnabled === false) { // whole validation disabled\n return true;\n } else if (typeof this.formnovalidate === 'boolean') { // triggered by $submit\n return this.formnovalidate;\n }\n // triggered by Enter in non-submit input\n return this.$submits.length ? this.$submits[0].getAttribute('formnovalidate') !== null : false;\n }\n\n /**\n * Enables the whole validation\n */\n enableValidation() {\n this.isEnabled = true;\n }\n\n /**\n * Disables the whole validation\n */\n disableValidation() {\n this.isEnabled = false;\n }\n\n /**\n * Checks whether or not a form element has the required attribute and if it's checked or not\n * @param {Object} element - jQuery object to check for required attribute\n * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n */\n requiredCheck($el) {\n if (!$el.attr('required')) return true;\n\n var isGood = true;\n\n switch ($el[0].type) {\n case 'checkbox':\n isGood = $el[0].checked;\n break;\n\n case 'select':\n case 'select-one':\n case 'select-multiple':\n var opt = $el.find('option:selected');\n if (!opt.length || !opt.val()) isGood = false;\n break;\n\n default:\n if (!$el.val() || !$el.val().length) isGood = false;\n }\n\n return isGood;\n }\n\n /**\n * Get:\n * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n * 1. The element's direct sibling('s).\n * 2. The element's parent's children.\n * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n *\n * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n *\n * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n * @param {String[]} [failedValidators] - List of failed validators.\n * @returns {Object} jQuery object with the selector.\n */\n findFormError($el, failedValidators) {\n var id = $el.length ? $el[0].id : '';\n var $error = $el.siblings(this.options.formErrorSelector);\n\n if (!$error.length) {\n $error = $el.parent().find(this.options.formErrorSelector);\n }\n\n if (id) {\n $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n }\n\n if (!!failedValidators) {\n $error = $error.not('[data-form-error-on]')\n\n failedValidators.forEach((v) => {\n $error = $error.add($el.siblings(`[data-form-error-on=\"${v}\"]`));\n $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"][data-form-error-on=\"${v}\"]`));\n });\n }\n\n return $error;\n }\n\n /**\n * Get the first element in this order:\n * 2. The
      • Back